概述
分享最近应用碰到的一个奇怪bug,一开始以为是代码上的问题,找了一段时间发现居然是因为系统的一个自动清理规则导致,下面一起来看看吧~
一、应用报错:
logwire.core.exceptions.GeneralUnhandledException:服务端未处理异常 ... Causedby:org.springframework.web.multipart.MultipartException:Failedtoparsemultipartservletrequest;nestedexceptionis java.io.IOException:Thetemporaryuploadlocation[/tmp/tomcat.5454715517323162300.8031/work/Tomcat/localhost/ROOT]isnotvalid .... Causedby:java.io.IOException:Thetemporaryuploadlocation[/tmp/tomcat.5454715517323162300.8031/work/Tomcat/localhost/ROOT]isnotvalid
报错截图:
二、思路
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:CreateVolatileFilesandDirectories systemd-tmpfiles-setup-dev.service:Createstaticdevicenodesin/dev systemd-tmpfiles-clean.service:CleanupofTemporaryDirectories
相关的配置文件也有3个地方:
/etc/tmpfiles.d/*.conf /run/tmpfiles.d/*.conf /usr/lib/tmpfiles.d/*.conf
/tmp目录的清理规则主要取决于/usr/lib/tmpfiles.d/tmp.conf文件的设定,默认配置有:
#Thisfileispartofsystemd. # #systemdisfreesoftware;youcanredistributeitand/ormodifyit #underthetermsoftheGNULesserGeneralPublicLicenseaspublishedby #theFreeSoftwareFoundation;eitherversion2.1oftheLicense,or #(atyouroption)anylaterversion. #Seetmpfiles.d(5)fordetails #Cleartmpdirectoriesseparately,tomakethemeasiertooverride v/tmp1777rootroot10d#清理/tmp下10天前的目录和文件 v/var/tmp1777rootroot30d#清理/var/tmp下30天前的目录和文件 #ExcludenamespacemountpointscreatedwithPrivateTmp=yes x/tmp/systemd-private-%b-* X/tmp/systemd-private-%b-*/tmp x/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方面的内容,感兴趣的朋友可以关注下~
转载请注明:IT运维空间 » 运维技术 » 详解Centos 7和Centos 6系统的/tmp目录自动清理规则及区别
发表评论