宁波做微信网站,凡科建站快车登录,汉中网站seo,网站网站建设策划书概述分享最近应用碰到的一个奇怪bug#xff0c;一开始以为是代码上的问题#xff0c;找了一段时间发现居然是因为系统的一个自动清理规则导致#xff0c;下面一起来看看吧~一、应用报错#xff1a;logwire.core.exceptions.GeneralUnhandledException: 服务端未处理异常...…概述分享最近应用碰到的一个奇怪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 7CentOS7下系统使用systemd管理易变与临时文件与之相关的系统服务有3个systemd-tmpfiles-setup.service Create Volatile Files and Directoriessystemd-tmpfiles-setup-dev.serviceCreate 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 PrivateTmpyesx /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 6CentOS6以下系统(含)使用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方面的内容感兴趣的朋友可以关注下~