org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.2737591724424319502.8062/work/Tomcat/localhost/ROOT] is not valid
有一段時間沒有使用測試環境的測試服務器。
然后昨天想使用一下測試環境,進行過文件的上傳。以前也沒有問題,但是今天突然不能使用,打開日志文件發現是報錯了,報錯為上面的報錯。是缺少文件。
但是一般也沒有人對服務器上的文件進行清理。??????
后來根據多方查找,找到了原因,原來是Linux下會自動清除tmp目錄下10天沒有使用過的文件,SpringBoot啟動的時候會在/tmp目錄下生成一個Tomcat.*的文件目錄,用於"java.io.tmpdir"文件流操作,因為放假期間無人操作,導致Linux系統自動刪除了臨時文件,所以導致上傳報錯
解決方案
一、臨時方案(快速解決方案,但是不推薦)
重啟服務,重啟后被刪除的tomcat目錄會重新生成
二、添加啟動配置項(如果你的應用是用腳本啟動的,可以考慮)
啟動時增加參數-Djava.io.tmpdir=自定義目錄
三、添加文件配置類(添加配置類,可以考慮)
@Bean MultipartConfigElement multipartConfigElement() { MultipartConfigFactory factory = new MultipartConfigFactory(); factory.setLocation("/var/tmp"); return factory.createMultipartConfig(); }
四、修改tmpwatch 刪除文件的邏輯(修改了系統,不推薦)
tmpwatch 刪除文件的邏輯
五、修改application.yml配置文件(推薦)
設置文件臨時存儲路徑
spring.http.multipart.location = /var/tmp