-
起因
公司研发人员 部署服务在阿里云 ecs 服务器; 上传文件过1周左右文件自动丢失;
-
排查思路:
(1).查询tomcat 启动日志出现如下信息:
java.io.IOException: The temporary upload location [/tmp/tomcat.1593253653386650830.8220/work/Tomcat/localhost/ROOT] is not valid
(2).这个目录在Linux系统中默认建在/tmp目录下, 10天就会被清除, 引发上述异常.
(3).man systemd-tmpfiles
(3).由此可确定服务为凶手;就是说/tmp 目录下除了下面排除的文件,都给删了。擦~
-
系统环境:
Centos-7.2
内核版本:
2.6.32-696.3.2.el6.x86_64
容器:
Tomcat 8.5.15.tar.gz
2.tomcat 服务层解决办法;
3.程序框架解决办法:
框架配置文件新增: application.properties ####sprint-boot 框架配置文件#######
4.系统解决方案;
解决方案在 /usr/lib/tmpfiles.d/ 新建文件把指定目录添加上并规定不让被清除
root@~:# vi /usr/lib/tmpfiles.d/tomcat.conf
d /tmp/tomcat* 0755 root root -
d /tmp/upload 0755 root root - ##tomcat 程序上传目录文件
OK,重启 systemctl restart systemd-tmpfiles-clean 服务;
----------------------------------------------------------------------------------------
线上的系统中不能上传文件了,出现如下错误:
org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request;nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.1337767218595042057.80/work/Tomcat/localhost/ROOT] is not valid org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.parseRequest(StandardMultipartHttpServletRequest.java:112) org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.
1
原因:
在linux系统中,springboot应用服务再启动(java -jar 命令启动服务)的时候,会在操作系统的/tmp目录下生成一个tomcat*的文件目录,上传的文件先要转换成临时文件保存在这个文件夹下面。由于临时/tmp目录下的文件,在长时间(10天)没有使用的情况下,就会被系统机制自动删除掉。所以如果系统长时间无人问津的话,就可能导致上面这个问题。
解决办法:
在 yml配置文件 中添加:
server.tomcat.basedir: /data/apps/temp
1
手动的将临时文件夹设置为自定义的文件夹,就不会被Linux删除了。
ps:在windows系统中可以生效,系统会自动生成/data/apps/temp这一路径,但是在Linux系统中不会生成/data/apps/temp路径。tell me why?…