原文链接: https://blog.csdn.net/m386084855/article/details/79041621
现象:
上传excel,出现报错:
1[Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io
2
3.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid] with root causejava.io
4
5.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:
1server:
2 port: 8112
3 maxHttpHeaderSize: 20480 #header头 默认8K改成20K
4 tomcat:
5 accesslog:
6 enabled: true
7 directory: /app/logs/tomcat/gtw/
8 pattern: '%h "%{yyyy-MM-dd HH:mm:ss.SSS}t" "%r" %s %b %D'
9 basedir: /var/tmp # 设置个固定文件夹
2.2启动时增加参数-Djava.io.tmpdir=自定义目录
3.修改tmpwatch 删除文件的逻辑,系统级别的命令,不建议操作
4.在网上看到有:编码的方式catch异常,生成删除的文件夹;(方法未验证)