问题分析:
自己写的小项目在线上出现了定时执行的入库操作被执行两次的问题,一开始以为自己程序实现相关功能的处理逻辑存在问题,查看定时日志的时候发现定时的记录每次都记录了同一(几乎)时间的两条。以前的定时都是用作数据同步数据更新,数据量较小的情况下一直没注意到这一点,这一次的插入操作多了一倍的数据才发现。
定时执行两次后首先检查了配置,但是我的定时是通过注解配置的,所以几乎不可能出错,然后上网查询后发现,Tomcat容器的配置会导致其加载两次应用,使得定时也被加载了两次。
原server.xml:
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">
<Context path="" docBase="项目名" debug="0" reloadable="true" />
host配置appBase="webapps"会使tomcat容器加载一次应用,context配置docBase="项目名"又会使其加载一次。
现server.xml:
<Host name="localhost" appBase="" unpackWARs="true" autoDeploy="true">
<Context path="" docBase="/usr/local/apache-tomcat-8.0.36/webapps/项目名" debug="0" reloadable="true" />
docBase填写该项目的绝对路径。