場景:
上傳文件功能報錯,然后排查日志。
報錯日志:
The temporary upload location [/tmp/tomcat.7957874575370093230.8088/work/Tomcat/localhost/ROOT] is not valid
原因:
在linux系統中,springboot應用服務再啟動(java -jar 命令啟動服務)的時候,會在操作系統的/tmp目錄下生成一個tomcat*的文件目錄,上傳的文件先要轉換成臨時文件保存在這個文件夾下面。由於臨時/tmp目錄下的文件,在長時間(10天)沒有使用的情況下,就會被系統機制自動刪除掉。所以如果系統長時間沒有使用到臨時文件夾,就可能導致上面這個問題。
解決辦法:
1.創建臨時文件夾:
mkdir -p /tmp/tomcat.7957874575370093230.8088/work/Tomcat/localhost/ROOT
后面可能還會出現這種情況
2.application.properties重新配置一個文件目錄,然后重啟項目
# 存放Tomcat的日志、Dump等文件的臨時文件夾,默認為系統的tmp文件夾
server.tomcat.basedir=/data/apps/temp
3.配置類配置臨時文件存儲目錄
@Bean
MultipartConfigElement multipartConfigElement() {
MultipartConfigFactory factory = new MultipartConfigFactory();
factory.setLocation(tmepPath);
return factory.createMultipartConfig();
}
