部署过程的坑:quartz定时器时执行旧版本代码问题
2018-02-11 15:06
489 查看
场景:近半月,反复定时器不按规定执行代码 ,其中有:
1、代码中混杂旧版本代码,实际在最新版本中已经删除;
2、执行时间混乱,历史中任何一次设置时间,在最新日期仍旧还在执行;
分析:
初步分析,要么是定时器出问题,要么代码有问题;
结合部署时,是将整个包upload服务器,并将上一版本更名作为备份,以便万一需要时回滚,都放在webapps下,且未清理过work下的缓存。
解决思路:
1、反复确认,代码经单元测试是没问题的;
2、定时器:单独设置定时器也没问题,能正确执行;
3、缓存:清除work下的缓存后,还是报同样错误,看来不是缓存问题;
4、部署:因为生产包与备份包在同一文件夹下,是不是运行时执行了历史版本呢?遂将所有备份包删除,只保留生产版本,重启tomcat后,连续4天正常,说明问题根源就在部署方式上,webapps下不能有非生产版本,否则会影响。
1、代码中混杂旧版本代码,实际在最新版本中已经删除;
2、执行时间混乱,历史中任何一次设置时间,在最新日期仍旧还在执行;
分析:
初步分析,要么是定时器出问题,要么代码有问题;
结合部署时,是将整个包upload服务器,并将上一版本更名作为备份,以便万一需要时回滚,都放在webapps下,且未清理过work下的缓存。
解决思路:
1、反复确认,代码经单元测试是没问题的;
2、定时器:单独设置定时器也没问题,能正确执行;
3、缓存:清除work下的缓存后,还是报同样错误,看来不是缓存问题;
4、部署:因为生产包与备份包在同一文件夹下,是不是运行时执行了历史版本呢?遂将所有备份包删除,只保留生产版本,重启tomcat后,连续4天正常,说明问题根源就在部署方式上,webapps下不能有非生产版本,否则会影响。
相关文章推荐
- 关于Spring中用quartz定时器在定时到达时同时执行两次的问题
- spring定时器quartz版本问题
- Spring的quartz定时器同一时刻重复执行二次的问题解决
- 关于Spring中用quartz定时器在定时到达时同时执行两次的问题
- Spring的quartz定时器重复执行二次的问题解决
- Spring的quartz定时器重复执行二次的问题
- Spring的quartz定时器同一时刻重复执行二次的问题解决
- maven项目整合Spring与quartz出现的定时器任务二次重复执行问题(2017年12月2日16:57:32)
- Spring的Quartz定时器同一时刻重复执行二次的问题解决
- Spring的Quartz定时器同一时刻重复执行二次的问题解决
- rocketmq集群安装部署过程(4.0.0版本)、安装中的常见问题举例
- Spring的quartz定时器同一时刻重复执行二次的问题解决
- Spring的quartz定时器重复执行二次的问题解决
- Spring的quartz定时器同一时刻重复执行二次的问题解决
- Spring的Quartz定时器同一时刻重复执行二次的问题解决
- Spring的quartz定时器同一时刻重复执行二次的问题解决
- 在部署MVC4.0网站的过程中遇到的问题以及解决办法
- ClickOnce:部署,强制要求用户使用最新发布版本才可以执行软件的方法
- .NET Framwork 之 托管代码的执行过程
- c#写服务、exe 可执行程序、windows锁屏的过程中遇到的问题