SpringBoot使用多实例QUARTZ出现重复执行问题
来源:互联网 发布:数据科学实战 编辑:程序博客网 时间:2024/06/08 13:22
项目运行了1个多月,多实例的Quartz一直没有问题,今天突然出现一个JOB重复执行了2次。查看日志发现两个实例各执行了一次,但是是偶发现象,也就是一会执行一次,一会执行两次,没有规律。好奇怪,明明用了多实例Quartz。再次查看调度器服务的日志
2017-09-05T11:59:00+08:00[APP/0]OUT2017-09-05 11:59:00.004 INFO 14 --- [ryBean_Worker-3] o.q.p.history.LoggingJobHistoryPlugin : Job DEFAULT.PROBLEM_DISPATCH fired (by trigger DEFAULT.PROBLEM_DISPATCH) at: 11:59:00 09/05/20172017-09-05T11:58:00+08:00[APP/0]OUT2017-09-05 11:58:00.009 INFO 14 --- [ryBean_Worker-4] o.q.p.history.LoggingJobHistoryPlugin : Job DEFAULT.PROBLEM_DISPATCH execution complete at 11:58:00 09/05/2017 and reports: null
quartz是先找到trigger再次执行JOB,可是我的项目中有多个定时任务都是1分钟执行一次,在重复执行的这个JOB1日志那我发现有个错误,是它的后一个JOB2有错了,原来是同事的这个JOB2代码本身写错了,导致一直报错。
猜测是因为当JOB获得trigger的时间点正好在JOB2获得trigger时间点时,因为JOB2获得trigger报错了,所以导致另一个实例有获取JOB1一次,这样两个实例都获取到了JOB1的trigger,所以就执行了2次。
解决方法: 对于调度服务中的JOB只写一个消费服务的具体feign链接就好,再加上hystrix回退,这样消费者服务出任何错都不会影响其他服务的JOB。PS:同事就是把feign对应的服务名写错了……,唯一一个能出错的地方,就踩到雷了- _-
疑问:为什么我获取trigger时会相互影响?难道是他们在一个Group中的原因?知道的可以告诉我一声,我是先把trigger加了分组,以防万一,原来都是默认的DEFAULT。
阅读全文
0 0
- SpringBoot使用多实例QUARTZ出现重复执行问题
- Quartz重复执行问题
- Quartz任务重复执行的问题
- Quartz框架多个trigger任务执行出现漏执行的问题分析
- SSM集成Quartz定时任务 重复执行问题
- Spring的quartz定时器重复执行二次的问题
- spring集成quartz,出现2次重复调用的问题
- 使用springboot+maven出现的问题
- maven项目整合Spring与quartz出现的定时器任务二次重复执行问题(2017年12月2日16:57:32)
- Quartz入门实例3-使用CronTrigger指定触发器执行job
- 完美解决多应用服务器负载均衡环境下spring quartz同一定时任务重复执行问题
- 完美解决多应用服务器负载均衡环境下spring quartz同一定时任务重复执行问题
- quartz定时,重复的问题
- tomcat下Quartz重复执行两次
- spring quartz 重复执行2次
- springboot quartz 多任务整合
- quartz使用实例
- quartz使用实例
- Qcom spk protect 的流程
- DOM的基本操作
- ubuntu16.04 cuda8.0 cudnn6.0 faster-rcnn配置
- 索引,事务,视图
- Matplotlib基础教程
- SpringBoot使用多实例QUARTZ出现重复执行问题
- AVFoundation学习笔记(三): 媒体捕捉、读取及写入
- Zabbix安装配置
- JAVA笔记
- 有关ActiveMQ(二)
- 反转链表java实现
- 个人存档用2
- 模拟面试-线程向
- 合并单元格