项目运行了一段时间没有发现任何异常,过了一段时间发现项目上传功能无法正常上传。
日志异常信息 :java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid的异常。
错误原因:/tmp/tomcat.117985270780171125.80/work/Tomcat/localhost/bcp 文件夹不存在导致
错误分析:springboo在创建项目时候会创建一个tmp的临时文件用来存放临时文件信息等内容
tmp文件夹 有个特性 ,如果在10天内没有进行操作,该文件夹下的文件和和文件夹都会自动被清除,导致一些文件丢失。
在进行文件上传的时候会先将文件临时存放在/tmp/tomcat.117985270780171125.80/work/Tomcat/localhost/pay 下(备注:这个对应的是我自己的项目路径,项目不同路径肯定不相同)
解决方法:
方法一:直接从新启动项目即可解决(这个只能治标不治本)
方法二:在springboot的配置文件里加个配置 :server.tomcat.basedir=/app/temp ,这个路径需要你在Linux根目录下下建个/app/temp文件
方法三:指定上传文件临时的路径(从根本解决),如下
//在启动类里面添加MultipartConfigElement 配置类
@Bean
public MultipartConfigElement multipartConfigElement() {
MultipartConfigFactory factory = new MultipartConfigFactory();
factory.setLocation("/pttms/tmp");//指定临时文件路径,这个路径可以随便写
return factory.createMultipartConfig();
}
指定好临时路径后还需要在Linux环境上创建对应的文件夹,在重启项目