问题分析:
自己写的小项目在线上出现了定时执行的入库操作被执行两次的问题,一开始以为自己程序实现相关功能的处理逻辑存在问题,查看定时日志的时候发现定时的记录每次都记录了同一(几乎)时间的两条。以前的定时都是用作数据同步数据更新,数据量较小的情况下一直没注意到这一点,这一次的插入操作多了一倍的数据才发现。
定时执行两次后首先检查了配置,但是我的定时是通过注解配置的,所以几乎不可能出错,然后上网查询后发现,Tomcat容器的配置会导致其加载两次应用,使得定时也被加载了两次。
原server.xml:
<Host name="www.abc.cn" appBase="webapps" unpackWARs="true" autoDeploy="true" > <Context Path="typg" docBase="/typg/" debug="0" reloadable="true" />
现server.xml:
<Host name="www.abc.cn" appBase="webapps" unpackWARs="true" autoDeploy="false" > <Context Path="typg" docBase="/typg/" debug="0" reloadable="true" />
<Host/>里面的改成 autoDeploy="false" deployOnStartup="false" 这样就可以避免tomcat服务器中自启动导致quartz定时任务被触发两次。(当然还可以按需求修改,毕竟每个项目的需求都不尽相同。)
1. autodeploy属性值设置为false,如果此项设为true,表示Tomcat服务处于运行状态时,能够监测appBase下的文件,如果有新有web应用加入进来,会自运发布这个WEB应用,设成false就不会。
2.增加deployOnStartup="false",表示Tomcat服务器启动时, 不会自动发布appBase目录下所有的Web应用。
这样的话,在tomcat启动时,不会自动发布appBase下的应用,启动后也不会自动发步appBase下的应用。
web应用程序默认都是放在webapps这个目录下的,如果不把“webapps“去掉,这里会调用一次quartz的任务调度,在接下来的“<Context path”中又会调用一次quartz的任务调度 这个原因导致。
而且本人刚开始执行3次,tomcat的webapp下面XXX.WAR包解压之后,war包没有删除,相当webapp目录下有 XXX 和XXX.war 所以XXX和XXX.war各执行一次,当删除XXX.war时,就只执行了2次,分别是 tomcat的server.xml中appBase和 < = 就只执行一次了。