现象:
springboot项目突然报错:
Servlet.service() for servlet [dispatcherServlet] in context with path [/cloud-disk] threw exception [Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Failed to parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.4568985732109845389.8080/work/Tomcat/localhost/cloud-disk] is not valid] with root cause java.io.IOException: The temporary upload location [/tmp/tomcat.4568985732109845389.8080/work/Tomcat/localhost/cloud-disk] is not valid
原因:
在Linux 系统中,SpringBoot 应用服务在启动(java -jar 命令启动服务)的时候,会在操作系统的/tmp目录下生成一个tomcat*的文件目录,上传的文件先要转换成临时文件保存在这个文件夹下面。
由于临时/tmp目录下的文件,在长时间(10天)没有使用的情况下,就会被系统机制自动删除掉。所以如果系统长时间无人问津的话,就可能导致上面这个问题。
解决办法:
一、临时的,直接重新启动项目就行,会重新建立临时文件夹;
二、配置/tmp目录下的tomcat*不删除;