现象:
上传excel,出现报错:
[Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid] with root causejava.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid
原因:
1.spring boot的应用服务在启动的时候,会生成在操作系统的/tmp目录下生成一个Tomcat.*的文件目录,用于"java.io.tmpdir"文件流操作
TomcatEmbeddedServletContainerFactory
2.程序对文件的操作时:会生成临时文件,暂存在临时文件中;
lunix 系统的tmpwatch 命令会删除10天未使用的临时文件;
长时间不操作,导致/tmp下面的tomcat临时文件目录被删除,且删除的文件不可恢复,上传文件时获取不到文件目录,报错
解决方案:
1.重启服务,临时方案:会重新生成tomcat目录,但是生产环境不建议如此操作;
2.1增加服务配置,自定义baseDir:
2.2启动时增加参数-Djava.io.tmpdir=自定义目录
3.修改tmpwatch 删除文件的逻辑,系统级别的命令,不建议操作
4.在网上看到有:编码的方式catch异常,生成删除的文件夹;(方法未验证)
参考: