springboot 上传文件报错:java.io.IOException: The temporary upload location [/tmp/tomcat.xxx] is not valid

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/jdk_wangtaida/article/details/90906597

前言: 

之前上线半个月后的项目,突然发现图片上传的接口有问题,无法上传,提示java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid的异常,经过百度,才知道这个是springboot项目文件上传的一个坑。

正文:

我们先复现下问题:

1.用postman调用图片上传的接口

2. 登录xshell去查看下日志

2019-06-05 11:04:35.904 [http-nio-8899-exec-10] ERROR o.a.c.c.C.[.[.[/main_service].[dispatcherServlet]  Servlet.service() for servlet [dispatcherServlet] in context with path [/main_service] threw exception [Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Failed to parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid] with root cause
java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid
	at org.apache.catalina.connector.Request.parseParts(Request.java:2821)
	at org.apache.catalina.connector.Request.getParts(Request.java:2754)
	at org.apache.catalina.connector.RequestFacade.getParts(RequestFacade.java:1098)
	at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.parseRequest(StandardMultipartHttpServletRequest.java:94)
	at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.<init>(StandardMultipartHttpServletRequest.java:87)
	at org.springframework.web.multipart.support.StandardServletMultipartResolver.resolveMultipart(StandardServletMultipartResolver.java:87)
	at org.springframework.web.servlet.DispatcherServlet.checkMultipart(DispatcherServlet.java:1175)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1010)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:942)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1005)
	at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:908)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:882)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)
	at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:200)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834)
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)
2019-06-05 11:04:36.526 [http-nio-8899-exec-2] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:04:36.532 [http-nio-8899-exec-2] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:04:36.536 [http-nio-8899-exec-1] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:04:55.870 [http-nio-8899-exec-8] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询入参:{"id":"1"}
2019-06-05 11:04:55.877 [http-nio-8899-exec-8] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询出参:{"data":{"createTime":1556249147000,"deleteFlag":false,"homeDescribe":"版本1.0","id":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRk2AISjCAAFDq-b0RWk898.jpg","intervalTime":2,"updateTime":1557284429000},"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:04:58.222 [http-nio-8899-exec-5] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:04:58.227 [http-nio-8899-exec-5] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:04:58.247 [http-nio-8899-exec-3] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:05:30.725 [http-nio-8899-exec-6] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询入参:{"id":"1"}
2019-06-05 11:05:30.730 [http-nio-8899-exec-6] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询出参:{"data":{"createTime":1556249147000,"deleteFlag":false,"homeDescribe":"版本1.0","id":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRk2AISjCAAFDq-b0RWk898.jpg","intervalTime":2,"updateTime":1557284429000},"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:05:33.082 [http-nio-8899-exec-9] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:05:33.086 [http-nio-8899-exec-9] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:05:33.135 [http-nio-8899-exec-7] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:06:00.715 [http-nio-8899-exec-4] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询入参:{"id":"1"}
2019-06-05 11:06:00.719 [http-nio-8899-exec-4] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询出参:{"data":{"createTime":1556249147000,"deleteFlag":false,"homeDescribe":"版本1.0","id":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRk2AISjCAAFDq-b0RWk898.jpg","intervalTime":2,"updateTime":1557284429000},"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:06:02.260 [http-nio-8899-exec-10] INFO  c.m.c.b.controller.startupImg.StartupImgController  欢迎页信息查询出参:{"data":[{"createTime":1556272212000,"deleteFlag":false,"id":7,"ifOpen":"true","imgMode":1,"imgNumber":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zIDtCADQgVAAJmUGL4EZs822.jpg","intervalTime":2,"updateTime":1556614864000},{"createTime":1556272212000,"deleteFlag":false,"id":8,"ifOpen":"true","imgMode":1,"imgNumber":2,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zIDtCAFoBGAAIv6wQeoI4998.jpg","intervalTime":2,"updateTime":1556614864000},{"createTime":1556272212000,"deleteFlag":false,"id":9,"ifOpen":"true","imgMode":1,"imgNumber":3,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zIDtCAUlS-AALPb5UnoCg293.jpg","intervalTime":2,"updateTime":1556614864000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:06:58.845 [http-nio-8899-exec-2] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:06:58.850 [http-nio-8899-exec-2] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:06:58.903 [http-nio-8899-exec-1] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:14:32.911 [http-nio-8899-exec-8] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询入参:{"id":"1"}
2019-06-05 11:14:32.917 [http-nio-8899-exec-8] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询出参:{"data":{"createTime":1556249147000,"deleteFlag":false,"homeDescribe":"版本1.0","id":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRk2AISjCAAFDq-b0RWk898.jpg","intervalTime":2,"updateTime":1557284429000},"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:14:35.152 [http-nio-8899-exec-5] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:14:35.156 [http-nio-8899-exec-5] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:14:35.357 [http-nio-8899-exec-3] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:17:34.650 [http-nio-8899-exec-6] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询入参:{"id":"1"}
2019-06-05 11:17:34.655 [http-nio-8899-exec-6] INFO  c.m.c.b.controller.homePage.HomePageController  启动页信息查询出参:{"data":{"createTime":1556249147000,"deleteFlag":false,"homeDescribe":"版本1.0","id":1,"imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRk2AISjCAAFDq-b0RWk898.jpg","intervalTime":2,"updateTime":1557284429000},"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:17:37.017 [http-nio-8899-exec-9] INFO  c.m.c.b.controller.version.VersionController  是否需要更新入参:{"versionNum":"1.0.1"}
2019-06-05 11:17:37.021 [http-nio-8899-exec-9] INFO  c.m.c.b.controller.version.VersionController  是否需要更新出参参:{"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:17:37.548 [http-nio-8899-exec-7] INFO  c.m.c.b.controller.management.ManagementController  查询集成应用信息列表出参:{"data":[{"accessAddress":"https://www.csdn.net/","appIntroduction":"111","appName":"资源","createTime":1556450538000,"deleteFlag":false,"id":28,"ifOpen":"false","imgUrl":"http://123.126.34.176:20152/group1/M00/00/01/wKilB1zSRiCANvxxAAGwq7IR7Bs985.jpg","updateTime":1557284384000}],"errorCode":"000","errorMessage":"成功","result":true}
2019-06-05 11:29:02.693 [http-nio-8899-exec-4] ERROR o.a.c.c.C.[.[.[/main_service].[dispatcherServlet]  Servlet.service() for servlet [dispatcherServlet] in context with path [/main_service] threw exception [Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Failed to parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid] with root cause
java.io.IOException: The temporary upload location [/tmp/tomcat.7538204303517105479.8899/work/Tomcat/localhost/main_service] is not valid
	at org.apache.catalina.connector.Request.parseParts(Request.java:2821)
	at org.apache.catalina.connector.Request.getParts(Request.java:2754)
	at org.apache.catalina.connector.RequestFacade.getParts(RequestFacade.java:1098)
	at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.parseRequest(StandardMultipartHttpServletRequest.java:94)
	at org.springframework.web.multipart.support.StandardMultipartHttpServletRequest.<init>(StandardMultipartHttpServletRequest.java:87)
	at org.springframework.web.multipart.support.StandardServletMultipartResolver.resolveMultipart(StandardServletMultipartResolver.java:87)
	at org.springframework.web.servlet.DispatcherServlet.checkMultipart(DispatcherServlet.java:1175)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1010)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:942)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1005)
	at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:908)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:882)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at com.alibaba.druid.support.http.WebStatFilter.doFilter(WebStatFilter.java:123)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)
	at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:200)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834)
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)

3.分析问题

spring boot的应用服务在启动的时候,会生成在操作系统的/tmp目录下生成一个tomcat.*的文件目录,用于"java.io.tmpdir"文件流操作。

程序对文件的操作时:会生成临时文件,暂存在临时文件中;lunix 系统的tmpwatch 命令会删除10天未使用的临时文件;长时间不操作,导致/tmp下面的tomcat临时文件目录被删除,且删除的文件不可恢复,上传文件时获取不到文件目录,所以就报了开头的错啦。

我进到/tmp的文件下,看有没有文件

4.解决方案1:重启下springboot项目,就可以解决,因为重启会重新生成这样的文件,我重启后,再看下/tmp下有没有文件

我们在访问下接口看下结果,发现就可以正常访问啦。

5.解决方案2:在springboot的配置文件里加个配置  

server.tomcat.basedir=/app/temp

这个路径需要你在Linux根目录下下建个/app/temp文件 

总结:

为什么会出现这个问题,具体原因我还没弄很清楚,稍后有新的进展,我会在更新上来。看来项目上线我们也不能轻易掉以轻心,预警机制要更加健全,及时发现问题和解决问题。

我是阿达,一名喜欢分享知识的程序员,时不时的也会荒腔走板的聊一聊电影、电视剧、音乐、漫画,这里已经有267位小伙伴在等你们啦,感兴趣的就赶紧来点击关注我把,哪里有不明白或有不同观点的地方欢迎留言。

猜你喜欢

转载自blog.csdn.net/jdk_wangtaida/article/details/90906597