1.背景
1.1 问题
最近出现一个问题,一个基于Jetty的Web容器,因为会监听webapps下文件,当一个代码框架在webapps目录下产生临时文件,会导致应用重启
1.2 疑问
我的印象中,Tomcat就有开启和关闭扫描应用目录的配置。东方通、金蝶等国产web容器也有都有热部署的开关,而且自动部署的文件夹和应用文件夹是分开的,那这个基于Jetty的Web容器应该也有响应的配置
Tomcat如下,在conf/server.xml的host层配置
2.思路
tomcat、东方通、金蝶有自动部署的配置开关,其中东方通和金蝶也区分了自动部署目录和运行目录。
下载一个jetty,打开所有xml文件,对所有文件搜索webapps的字眼,
发现在etc/jetty-deploy.xml有scanInterval的配置,在,看起来是设置扫描间隔的,那么我猜如果没有扫描间隔,就可以关闭自动扫描重启。
然后我在项目引入了那个基于Jetty的Web容器 内嵌容器的依赖,在源码中搜索scanInterval,发现一个叫扫描类的scanner类的一个属性scanInterval,从注释看,它的作用是控制容器启动后扫描webapps文件夹的时间间隔,如果设置0代表启动后不扫描。
3.验证
下载那个基于Jetty的Web容器的包,看目录果然也有etc/jetty-deploy.xml的配置,通过启动时直接放webapps或通过控制台上传包两种方式验证,结果是当此配置为默认值1时,变化会触发应用重启;如果把配置改为0,则不重启。
结论就是将TAS的etc/jetty-deploy.xml的scanInterval设为0秒时可以避免运行中自动重启(但是和东方通、金蝶不一样,此时TAS控制台上传也不会启动应用)。
这个结论是针对外置tas的,内嵌的tas容器没使用这个配置,一是我没有在他官网和其starter的spring-configuration-metadata.json中没找到对应的配置项,二是我觉得内置容器也没webapps,应该不影响。
参考
Jetty : The Definitive Reference
https://www.eclipse.org/jetty/documentation/jetty-9/index.html#hot-deployment
Apache Tomcat 9 Configuration Reference
https://tomcat.apache.org/tomcat-9.0-doc/config/context.html
The Apache Software Foundation
Apache Tomcat 9
https://tomcat.apache.org/tomcat-9.0-doc/deployer-howto.html