SpringBoot上传临时文件被删除引起报错的解决

编辑: admin 分类: java 发布时间: 2021-12-04 来源:互联网
目录
  • 上传临时文件被删除引起报错的解决
    • 1.前言
    • 2.问题分析
    • 3.解决方案
  • 文件上传提示临时文件夹不存在
    • 1.异常信息
    • 2.原因
    • 3.解决方法

上传临时文件被删除引起报错的解决

1.前言

在项目中使用到了SpringBoot的上传实现了一个excel导入功能,上线后稳得一批,但突然有一天发现,导入失败报错:

location [/tmp/tomcat.xxx.8551/work/Tomcat/localhost/ROOT] is not valid

详见如图

image.png

2.问题分析

在SpringBoot项目启动后,系统会在‘/tmp'目录下自动的创建以下几个文件;

  • hsperfdata_root
  • tomcat.************.8080,(结尾为端口)
  • tomcat-docbase.*********.8080 ;

程序对上传文件操作时,会生成临时文件,暂存在临时文件目录中,经查阅资料发现CentOS有自动清理规则,系统会对/tmp下10天未使用的文件进行清理,清理后再次使用文件上传就会出现以上问题 ;

3.解决方案

3.1重启项目

启动时会自动新建临时目录的。但是以后依旧会有被系统自动清除的可能(未彻底解决)。

3.2自定义临时文件路径

新增如下配置

server.tomcat.basedir=/home/dev/temp

注意事项:

  • 需要重启项目生效 ;
  • 若启动项目的用户有权限在该目录下创建文件夹,则会自动创建 ;

3.2新增配置

配置类方式指定临时文件路径

@Configuration
public class MultipartConfig {
    /**
     * 文件上传临时路径
     */
    @Bean
    MultipartConfigElement multipartConfigElement() {
        MultipartConfigFactory factory = new MultipartConfigFactory();
        String location = System.getProperty("user.dir") + "/dev/temp";
        File tmpFile = new File(location);
        if (!tmpFile.exists()) {
            tmpFile.mkdirs();
        }
        factory.setLocation(location);
        return factory.createMultipartConfig();
    }
}

文件上传提示临时文件夹不存在

1.异常信息

java.io.IOException: The temporary upload location [C:\Users\Administrator\AppData\Local\Temp\tomcat.1668302398522753093.8383\work\Tomcat\loca lhost\ROOT] is not valid

2.原因

文件上传临时上传文件夹失效了,可能是系统清除了临时目录。

3.解决方法

1.重启服务,不建议在生产环境使用。

2.增加服务配置,自定义baseDir。

server.tomcat.basedir=/tmp/tomcat

3.注入bean,手动配置临时目录,建议有项目组统一配置,便于管理和错误定位。

@Bean
  MultipartConfigElement multipartConfigElement() {
    MultipartConfigFactory factory = new MultipartConfigFactory();
    factory.setLocation("/tmp/tomcat");
    return factory.createMultipartConfig();
  }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持自由互联。

【本文转自:游戏服务器 转载请保留连接】