tomcat9上传文件失败错误

    项目上线正常运行一段时间后,有一天突然所有的附件上传都出现了错误,查找项目本身的日志系统也一致没有跟踪到错误。经过几番折腾,在tomcat9-stdout.log日志中发现如下异常:

ERROR org.springframework.boot.web.servlet.support.ErrorPageFilter 190 forwardToErrorPage - Forwarding to error page from request [/upload/dbupload] due to exception [Failed to parse multipart servlet request; nested exception is java.io.IOException: org.apache.tomcat.util.http.fileupload.FileUploadBase$IOFileUploadException: Processing of multipart/form-data request failed. E:\Tomcat9\work\Catalina\localhost\ROOT\upload_6aee88fc_f7bb_4c8d_b663_51fad2d80eee_00000000.tmp (文件或目录损坏且无法读取。)] org.springframework.web.multipart.MultipartException: Failed to parse multipart servlet request; nested exception is java.io.IOException: org.apache.tomcat.util.http.fileupload.FileUploadBase$IOFileUploadException: Processing of multipart/form-data request failed. E:\Tomcat9\work\Catalina\localhost\ROOT\upload_6aee88fc_f7bb_4c8d_b663_51fad2d80eee_00000000.tmp (文件或目录损坏且无法读取。)

因此,可能是无法访问tomcat工作目录work所致。

 

因此将此work目录重命名为_work,并重启服务器后,重建工作目录work,恢复正常。

 

转载于:https://www.cnblogs.com/isaboy/p/tomcat9_uload_error.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\],在Linux系统中,当使用java -jar命令启动Spring Boot应用服务时,会在操作系统的/tmp目录下生成一个名为tomcat*的文件目录,用于保存上传的文件的临时文件。然而,由于系统机制的原因,/tmp目录下的文件会在10天后被自动删除,因此可能会出现找不到该路径的异常。 根据引用\[2\],企业通过Jenkins远程部署Tomcat时,在Windows操作系统下,如果Tomcat开启了自动部署,并且在删除旧文件时发生资源被锁定的情况,可以尝试在Tomcat的context.xml文件中设置antiResourceLocking属性为true。然而,这样设置之后可能会导致另一个问题,即应用的doc base被移动到临时目录下,导致访问资源时出现404的问题。 根据引用\[3\],从错误信息"/tmp/tomcat.133774185444442042.80/work/Tomcat/localhost/ROOT is not valid"可以得知,该目录下的某个目录已经不存在了。这可能是因为长时间没有使用上传文件功能,导致Spring Boot启动时创建的临时目录被Linux系统回收删除。 解决文件上传Tomcat临时文件无法删除的问题,可以尝试以下解决方案: 1. 检查/tmp目录是否存在,并确保有足够的权限进行读写操作。 2. 检查Tomcat的配置文件(如context.xml)中是否设置了正确的临时目录路径。 3. 如果使用了Jenkins进行远程部署,可以尝试在Jenkins的配置中设置正确的临时目录路径。 4. 如果长时间没有使用上传文件功能,可以手动删除临时目录,并重新启动应用程序以重新创建临时目录。 请注意,具体的解决方案可能因系统环境和具体情况而有所不同,建议根据实际情况进行调整和尝试。 #### 引用[.reference_title] - *1* [SpringBoot项目上传文件时报tomcat临时目录不合法或者不存在错误](https://blog.csdn.net/zlfjavahome/article/details/127884122)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [windows下tomcat热部署旧文件资源被锁定导致文件删除失败](https://blog.csdn.net/qq_24916085/article/details/122123279)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [上传文件解决tomcat的临时目录失效问题](https://blog.csdn.net/weixin_43675226/article/details/118940013)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值