过完年回来,测试同事发现我们服务器所有的上传文件都不能使用了,全部报500错误:
java.io.IOException: The temporary upload location [/tmp/tomcat.xxxxx.20100/work/Tomcat/localhost/ROOT] is not valid
一开始以为接口里哪儿有更改照成了问题,就翻看代码提交历史记录,半天也没有发现到底哪里有问题,最后还是通过上网搜索找到答案。
原因:
1.spring boot的应用服务在启动的时候,会生成在操作系统的/tmp目录下生成一个Tomcat.*的文件目录,用于"java.io.tmpdir"文件流操作
2.程序对文件的操作时:会生成临时文件,暂存在临时文件中;
linux 系统的tmpwatch 命令会删除10天未使用的临时文件;
长时间不操作,导致/tmp下面的tomcat临时文件目录被删除,且删除的文件不可恢复,上传文件时获取不到文件目录,报错
解决方案:
1.重启服务,会重新生成/tmp/tomcat...目录,但是生产环境不建议如此操作(临时方案)
2.1增加服务配置,自定义baseDir
2.2启动时增加参数-Djava.io.tmpdir=自定义目录
3.修改tmpwatch 删除文件的逻辑,系统级别的命令,不建议操作
4.编码的方式catch异常,生成删除的文件夹
5.docker环境下,在Dockerfile中新增指令 VOLUME /tmp 生成匿名卷不会被自动删除
网友评论