日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

所有的service报红但不报错_从一个应用报错来看centos系统的/tmp目录自动清理规则...

發布時間:2024/9/27 windows 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 所有的service报红但不报错_从一个应用报错来看centos系统的/tmp目录自动清理规则... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

分享最近應用碰到的一個奇怪bug,一開始以為是代碼上的問題,找了一段時間發現居然是因為系統的一個自動清理規則導致,下面一起來看看吧~


一、應用報錯:

logwire.core.exceptions.GeneralUnhandledException: 服務端未處理異常...Caused by: org.springframework.web.multipart.MultipartException: Failed to parse multipart servlet request; nested exception isjava.io.IOException: The temporary upload location [/tmp/tomcat.5454715517323162300.8031/work/Tomcat/localhost/ROOT] is not valid....Caused by: java.io.IOException: The temporary upload location [/tmp/tomcat.5454715517323162300.8031/work/Tomcat/localhost/ROOT] is not valid

報錯截圖:


二、思路

CentOS 7 系統有一個默認定時器會每隔 1 天執行一次臨時目錄清理操作,把 /tmp 目錄下所有超過 10 天沒有任何變動的子目錄全部刪除。

若某個 Logwire 系統的用戶操作不太活躍,則 tomcat 運行臨時目錄(形如: /tmp/tomcat.xxx)會被刪除。這時候如果有用戶試圖上傳文件,則服務端會報錯:

The temporary upload location [/tmp/tomcat.5454715517323162300.8031/work/Tomcat/localhost/ROOT] is not valid


三、處理過程

在 /usr/lib/tmpfiles.d/tmp.conf 文件中增加配置項:

x /tmp/tomcat*

以上配置表示在清理臨時目錄時忽略所有以 /tmp/tomcat 開頭的目錄和文件


四、CentOS系統的/tmp目錄自動清理規則

1、CentOS 7

CentOS7下,系統使用systemd管理易變與臨時文件,與之相關的系統服務有3個:

systemd-tmpfiles-setup.service :Create Volatile Files and Directoriessystemd-tmpfiles-setup-dev.service:Create static device nodes in /devsystemd-tmpfiles-clean.service :Cleanup of Temporary Directories

相關的配置文件也有3個地方:

/etc/tmpfiles.d/*.conf/run/tmpfiles.d/*.conf/usr/lib/tmpfiles.d/*.conf

/tmp目錄的清理規則主要取決于/usr/lib/tmpfiles.d/tmp.conf文件的設定,默認配置有:

# This file is part of systemd.## systemd is free software; you can redistribute it and/or modify it# under the terms of the GNU Lesser General Public License as published by# the Free Software Foundation; either version 2.1 of the License, or# (at your option) any later version. # See tmpfiles.d(5) for details # Clear tmp directories separately, to make them easier to overridev /tmp 1777 root root 10d # 清理/tmp下10天前的目錄和文件v /var/tmp 1777 root root 30d # 清理/var/tmp下30天前的目錄和文件 # Exclude namespace mountpoints created with PrivateTmp=yesx /tmp/systemd-private-%b-*X /tmp/systemd-private-%b-*/tmpx /var/tmp/systemd-private-%b-*X /var/tmp/systemd-private-%b-*/tmp

也就是CentOS 7 系統有一個默認定時器會每隔 1 天執行一次臨時目錄清理操作,把 /tmp 目錄下所有超過 10 天沒有任何變動的子目錄全部刪除。

可以配置這個文件,比如你不想讓系統自動清理/tmp下以tomcat開頭的目錄,那么增加下面這條內容到配置文件中即可:

x /tmp/tomcat.*

2、CentOS 6

CentOS6以下系統(含)使用watchtmp + cron來實現定時清理臨時文件的效果,該目錄下的腳本每天執行一次。

如果要修改的話,可以修改此 tmpwatch 腳本(用 root 用戶修改或其他用戶 sudo 修改):

找到類似該語句:

/usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix -X '/tmp/hsperfdata_*' -X '/tmp/.hdb*lock' -X '/tmp/.sapstartsrv*.log' 10d /tmp

為該語句添加 -X '/tmp/tomcat*' 參數,以便在清除時忽略所有以 /tmp/tomcat 開頭的目錄和文件:

/usr/sbin/tmpwatch "$flags" -x /tmp/.X11-unix -x /tmp/.XIM-unix -x /tmp/.font-unix -x /tmp/.ICE-unix -x /tmp/.Test-unix -X '/tmp/hsperfdata_*' -X '/tmp/.hdb*lock' -X '/tmp/.sapstartsrv*.log' -X '/tmp/tomcat*' 10d /tmp

覺得有用的朋友多幫忙轉發哦!后面會分享更多devops和DBA方面的內容,感興趣的朋友可以關注下~

總結

以上是生活随笔為你收集整理的所有的service报红但不报错_从一个应用报错来看centos系统的/tmp目录自动清理规则...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。