Quartz 在misfire模式[错失、补偿执行] 策略_misfire_instruction_ignore_misfire_policy-程序员宅基地

技术标签: Quartz  

概述

调度(scheduleJob)或恢复调度(resumeTrigger,resumeJob)后不同的misfire对应的处理规则

misfire产生的条件是:到了该触发执行时上一个执行还未完成,且线程池中没有空闲线程可以使用(或有空闲线程可以使用但job设置为@DisallowConcurrentExecution)且过期时间已经超过misfireThreshold就认为是misfire了,错失触发了

job默认是并发执行, 如果job设置@DisallowConcurrentExecution ,则为串行执行.
 

misfired job原因

  1. 系统因为某些原因被重启。在系统关闭到重新启动之间的一段时间里,可能有些任务会被 misfire;
  2. Trigger 被暂停(suspend)的一段时间里,有些任务可能会被 misfire;
  3. 线程池中所有线程都被占用,导致任务无法被触发执行,造成 misfire;
  4. 有状态任务在下次触发时间到达时,上次执行还没有结束;为了处理 misfired job,Quartz 中为 trigger 定义了处理策略,主要有下面两种:MISFIRE_INSTRUCTION_FIRE_ONCE_NOW:针对 misfired job 马上执行一次;MISFIRE_INSTRUCTION_DO_NOTHING:忽略 misfired job,等待下次触发;默认是MISFIRE_INSTRUCTION_SMART_POLICY,该策略在CronTrigger中=MISFIRE_INSTRUCTION_FIRE_ONCE_NOW线程默认1分钟执行一次;在一个事务中,默认一次最多recovery 20个;

 

 

 

参数设置

quartz.properties

org.quartz.jobStore.misfireThreshold = 60000 [默认]

CronSchedule 策略

org.quartz.Trigger trigger = TriggerBuilder.newTrigger()
                .withIdentity("trigger1", "group1")
                .startNow()
                .withSchedule(
                        CronScheduleBuilder.cronSchedule("0/3 * * * * ?")

                        //  withMisfireHandlingInstructionIgnoreMisfires() MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY 忽略所有的超时状态,按照触发器的策略执行。
                        // withMisfireHandlingInstructionFireAndProceed()   MISFIRE_INSTRUCTION_FIRE_ONCE_NOW   立刻执行一次,然后就按照正常的计划执行。
                        // withMisfireHandlingInstructionDoNothing()   MISFIRE_INSTRUCTION_DO_NOTHING           目前不执行,然后就按照正常的计划执行。
                )
                .build();

 

withMisfireHandlingInstructionFireAndProceed   [MISFIRE_INSTRUCTION_FIRE_ONCE_NOW](默认)
——以当前时间为触发频率立刻触发一次执行
——然后按照Cron频率依次执行



withMisfireHandlingInstructionDoNothing   [MISFIRE_INSTRUCTION_DO_NOTHING ]
——不触发立即执行
——等待下次Cron触发频率到达时刻开始按照Cron频率依次执行


withMisfireHandlingInstructionIgnoreMisfires    [MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY] 
——以错过的第一个频率时间立刻开始执行
——重做错过的所有频率周期后
——当下一次触发频率发生时间大于当前时间后,再按照正常的Cron频率依次执行
即: 忽略所有的超时状态,按照触发器的策略执行。

 

前提:在每个星期周一下午5点到7点,每隔一个小时执行一次,理论上共执行3次。

1. 情景一:

//所有misfire的任务会马上执行
public static final int MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY = -1;
若是5点misfire,6:15系统恢复之后,5,6点的misfire会马上执行。

2. 情景二:


//不做任何事情
public static final int MISFIRE_INSTRUCTION_DO_NOTHING = 2;
若是5点misfire,6:15系统恢复之后,只会执行7点的misfire。如果下次执行时间超过了end time,实际上就没有执行机会了。

3. 情景三:(cronTrigger的默认策略)


// CornTrigger默认策略,合并部分misfire,正常执行下一个周期的任务。
public static final int MISFIRE_INSTRUCTION_FIRE_ONCE_NOW = 1;
若是5点misfire,6:15系统恢复之后,立刻执行一次(只会一次)misfire。

 

SimpleSchedule 策略

SimpleScheduleBuilder sp = SimpleScheduleBuilder.simpleSchedule();
 
sp.withMisfireHandlingInstructionFireNow();
sp.withMisfireHandlingInstructionIgnoreMisfires();
sp.withMisfireHandlingInstructionNextWithExistingCount();
sp.withMisfireHandlingInstructionNextWithRemainingCount();
sp.withMisfireHandlingInstructionNowWithExistingCount();  (默认)
sp.withMisfireHandlingInstructionNowWithRemainingCount();

 

withMisfireHandlingInstructionNowWithExistingCount(默认)
——以当前时间为触发频率立即触发执行
——执行至FinalTIme的剩余周期次数
——以调度或恢复调度的时刻为基准的周期频率,FinalTime根据剩余次数和当前时间计算得到
——调整后的FinalTime会略大于根据starttime计算的到的FinalTime值


withMisfireHandlingInstructionFireNow
——以当前时间为触发频率立即触发执行
——执行至FinalTIme的剩余周期次数
——以调度或恢复调度的时刻为基准的周期频率,FinalTime根据剩余次数和当前时间计算得到
——调整后的FinalTime会略大于根据starttime计算的到的FinalTime值



withMisfireHandlingInstructionIgnoreMisfires
——以错过的第一个频率时间立刻开始执行
——重做错过的所有频率周期
——当下一次触发频率发生时间大于当前时间以后,按照Interval的依次执行剩下的频率
——共执行RepeatCount+1次


withMisfireHandlingInstructionNextWithExistingCount
——不触发立即执行
——等待下次触发频率周期时刻,执行至FinalTime的剩余周期次数
——以startTime为基准计算周期频率,并得到FinalTime
——即使中间出现pause,resume以后保持FinalTime时间不变


withMisfireHandlingInstructionNextWithRemainingCount
——不触发立即执行
——等待下次触发频率周期时刻,执行至FinalTime的剩余周期次数
——以startTime为基准计算周期频率,并得到FinalTime
——即使中间出现pause,resume以后保持FinalTime时间不变




withMisfireHandlingInstructionNowWithRemainingCount
——以当前时间为触发频率立即触发执行
——执行至FinalTIme的剩余周期次数
——以调度或恢复调度的时刻为基准的周期频率,FinalTime根据剩余次数和当前时间计算得到
——调整后的FinalTime会略大于根据starttime计算的到的FinalTime值


MISFIRE_INSTRUCTION_RESCHEDULE_NOW_WITH_REMAINING_REPEAT_COUNT
——此指令导致trigger忘记原始设置的starttime和repeat-count
——触发器的repeat-count将被设置为剩余的次数
——这样会导致后面无法获得原始设定的starttime和repeat-count值


 

 

 

 

 

 

 

参考:

https://www.cnblogs.com/skyLogin/p/6927629.html

https://www.jianshu.com/p/572322b36383

 

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zhanglong_4444/article/details/104322354

智能推荐

俺也来祭祭熊猫-程序员宅基地

文章浏览阅读5.2k次。最近熊猫烧香肆虐,WC里CIM那群人集体中招,俺的机子裸奔竟然也没事,呵呵。刚好python的邮件列表上有人给“熊猫”玩文字游戏,觉得特有意思,拿出来和大家分享一下 。 床前明月光,熊猫在烧香。专杀杀不尽,两眼泪汪汪。 熊猫烧不尽,关机开又生。   宝剑锋从磨砺出,熊猫香自网上来。   无边香火烧烧下,不尽熊猫滚滚来。身心俱疲终不悔,为猫烧得人憔悴。 相见时难杀亦难,熊猫烧

影响力在职场的重要性_职权影响力-程序员宅基地

文章浏览阅读7.8k次。前端时间参加了公司的管理培训,讲非职权影响力。对于领导者来讲,如果不能提高自己的影响力,那么是没办法做到让下属信服和追随的。整理了一下培训的收获。 影响力的定义运用一些别人所乐于接受的方式,改变他人的思想和行动,具体有个性、思想,以及行动。这些方式包括:举例引证、造成恐惧、赞美肯定、权势财富等。 影响力的6大武器互惠 承诺一致 社会认同 喜好 权威 稀缺另外次要..._职权影响力

用Vue制作记事本_vue选中文字做笔记-程序员宅基地

文章浏览阅读765次,点赞2次,收藏7次。先放个效果图吧制作记事本一共分为五个部分。1、第一部分就是添加内容。目的是输入内容后按下enter能够在目录下出现对应的内容,此部分应用v-for,v-model以及v-text完成,html程序如下<div id="app"> <input id="text" type="text" v-model="addValue" @keyup.enter="add" placeholder="请输入内容"> <ul> <li v-f_vue选中文字做笔记

Web安全--反序列化漏洞详解(php篇)-程序员宅基地

文章浏览阅读1k次,点赞2次,收藏9次。反序列化

“实践型”高级软件工程师精英成就计划,向年薪10W冲刺!-程序员宅基地

文章浏览阅读2.4k次。 “实践型”高级软件工程师精英成就计划学习方向:ü 进军IT行业,学完就业竞争力很强,薪酬一般比较高,目前坚持下来的学生全部就业,整体就业水平高于华工计算机系的水平.ü 攻读计算机或软件学院等相关专业的研究生.ü 考高级程序员(企业中级职称)或系统分析师(高级职称)。ü 以IT增强专业能力和开拓专业视野。师资力量:u

Cannot invoke “java.sql.Connection.prepareStatement(String)“because “this.conn“ is null_cannot read field "sym" because "this.lvar[od]" is-程序员宅基地

文章浏览阅读2.3w次,点赞5次,收藏10次。就是jar包太老了,数据库是新版本的,用8以上的connector_cannot read field "sym" because "this.lvar[od]" is null

随便推点

分布式计算中的数据一致性:Paxos 与 Raft 对比-程序员宅基地

文章浏览阅读888次,点赞8次,收藏23次。1.背景介绍分布式系统是现代计算机系统的基础设施之一,它允许多个计算节点在网络中协同工作。随着分布式系统的发展和应用,数据一致性问题变得越来越重要。在分布式计算中,数据一致性是指在分布式系统中的多个节点能够同步获取和更新相同的数据,以确保数据的一致性。在分布式系统中,数据一致性问题主要由于节点之间的异步通信和故障导致的数据不一致。为了解决这个问题,人们提出了一种称为Paxos和Raft的一...

Angular中父组件通过ViewChild调用子组件的方法_angualr viewchild可以调用方法,但是调用不了其他的方法-程序员宅基地

文章浏览阅读940次。场景Angualr中通过原生js和ViewChild的方式获取dom:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/105860965通过ViewChild不仅可以获取dom还可以实现在父组件中调用子组件的方法。注:博客:https://blog.csdn.net/badao_liumang_qizhi 关..._angualr viewchild可以调用方法,但是调用不了其他的方法

利用tinyproxy云服务器配置成代理服务器-程序员宅基地

文章浏览阅读6k次,点赞2次,收藏37次。利用tinyproxy来将自己的云服务器设置成代理服务器_tinyproxy

2022年沈阳市施工员(设备安装)考试练习题及答案_施工方案是编制技术交底交底文件的依据,技术交底文件是在临近作业前编写的,与-程序员宅基地

文章浏览阅读156次。一、单选题1、关于综合效能的测定与调整,描述错误的是(D)。A.通风与空调工程带生产负荷的综合效能试验与调整,应在已具备生产试运行的条件下进行B.由建设单位负责,设计、施工单位配合C.通风、空调系统带生产负荷的综合效能试验测定与调整的项目,应由建设单位根据工程性质、工艺和设计的要求进行确定D.施工单位不用参加综合效能的测定与调整2、项目管理层是(D)。A.其管理以企业确定的项目成本为目标,体现现场生产成本控制中心的监理职能B.其管理从投标开始止于结算的全过程,着眼于..._施工方案是编制技术交底交底文件的依据,技术交底文件是在临近作业前编写的,与

m基于yolov2深度学习的车辆检测系统matlab仿真,带GUI操作界面_yolo基于matlab仿真-程序员宅基地

文章浏览阅读896次,点赞17次,收藏16次。对于每个网格单元,网络输出T个类别概率(C类物体+C类背景)、B个边界框的坐标(x, y, w, h)以及每个框的置信度(confidence score),表示框内存在物体且预测框准确的程度。Localization Loss: 对于每个网格单元,只有当它包含ground truth box的中心时,才对其负责预测的边界框计算定位误差,通常采用L1或L2损失。Confidence Loss: 包含物体的网格单元,其置信度损失是预测的置信度与真实IOU的交叉熵损失;_yolo基于matlab仿真

磁盘扇区、柱面详解_tf卡柱面是什么意思-程序员宅基地

文章浏览阅读3.6k次,点赞2次,收藏3次。在下图中,我们可以看到一圈圈被分成18(假设)等分的同心圆,这些同心圆就是磁道(见图).不过真打开硬盘你可看不到.它实际上是被磁头磁化的同心圆.如图可以说是被放大了的磁盘片.那么扇区就是每一个磁道中被分成若干等分的区域.相邻磁道是有间隔的,这是因为磁化单元太近会产生干扰.一个小软盘有80个磁道,硬盘嘛要远远大于此值,有成千上万的磁道.每个柱面包括512个字节。那么什么是柱面呢?看下_tf卡柱面是什么意思

推荐文章

热门文章

相关标签