部署过程的坑:quartz定时器时执行旧版本代码问题

   场景:近半月,反复定时器不按规定执行代码 ,其中有:

          1、代码中混杂旧版本代码,实际在最新版本中已经删除;

          2、执行时间混乱,历史中任何一次设置时间,在最新日期仍旧还在执行;

  分析:

      初步分析,要么是定时器出问题,要么代码有问题;

      结合部署时,是将整个包upload服务器,并将上一版本更名作为备份,以便万一需要时回滚,都放在webapps下,且未清理过work下的缓存。


   解决思路:

   1、反复确认,代码经单元测试是没问题的;

   2、定时器:单独设置定时器也没问题,能正确执行;

   3、缓存:清除work下的缓存后,还是报同样错误,看来不是缓存问题;

   4、部署:因为生产包与备份包在同一文件夹下,是不是运行时执行了历史版本呢?遂将所有备份包删除,只保留生产版本,重启tomcat后,连续4天正常,说明问题根源就在部署方式上,webapps下不能有非生产版本,否则会影响。

你可能感兴趣的:(部署过程的坑:quartz定时器时执行旧版本代码问题)