背景:
Linux服务器上,使用外置 Tomcat部署 war 项目,且项目中有图片上传的功能
场景:
项目部署到线上很久没有人使用,某天尝试上传图片时,提示 The temporary upload location xxx is not valid
原因:
前提:
- Linux 机制中,当 temp 文件夹下的文件或目录很久不使用时就会被删掉
- 当 Tomcat 运行起来时,会在 Linux 服务器的 temp 文件夹下创建自己的临时目录
- 当上传文件时,Tomcat 会先在临时目录中创建一个临时文件,文件传输完毕后,才会将文件复制到正确的文件夹中,并删除这个临时文件
情况分析:
由于项目很久没使用了,但 Tomcat 没有被关闭。Linux 将 temp 文件夹下属于 tomcat 的临时文件夹删除了。
此时调用上传文件接口进行上传,由于临时文件夹被删除了,Tomcat 无法在这个不存在的文件夹下创建临时文件,就会报 The temporary upload location xxx is not valid
解决方式:
知道了原因,解决起来就简单了。Linux 机制会将 temp 文件夹下的文件删除,那么我不指定在 temp 文件夹下面不就行了。
查找发现可以在项目配置文件中指定 Tomcat 临时文件夹的位置:
server.tomcat.basedir=[xxxx.. 你的文件夹名称]
例如: server.tomcat.basedir=/opt/springdemo/tmp
由于这样做,临时文件夹以及内部的文件不会被删除了,最好在每次项目启动后,都主动删除下 tmp 目录,再创建这个目录。
贡献启动脚本:
#!bin/sh
CRTDIR=/opt/spring-boot-imapi
....
# 判断是否有tmp文件夹,没有则创建
if [ -d "${CRTDIR}/tmp" ]; then
rm -rf ${CRTDIR}/tmp
fi
.....