至于为什么会有misfire这个概念,我想可以重这三个方面来进行说明:
1 所有的线程都在忙于更高优先级的任务
2 任务本身CRASH了
3 代码的BUG,导置错误的设置了JOB
基于这3种原因,其实也是现实世界中的常理。没有任何事情,都能保证100%运行OK。quartz提出了misfire的理论,让任务在错过之后,还能正常的运行。
以下分别对几种类型的JOB进行说明:
without repeating(不重复的JOB)
这里只列出有代表的属性进行说明,这个JOB执行的时间为过去10秒之前,所以肯定会触发misfire
withMisfireHandlingInstructionFireNow(失效之后再恢复并马上执行)
就是当某个任务在理论执行的时间点没有执行,当任务正常起来之后,马上就去执行刚才未执行的任务。
withMisfireHandlingInstructionNextWithRemainingCount(失效之后不处理)
错过之后,不用管。
其它详细说明
这个其实比较简单。来看第二种
repeating fixed number of times(多次执行)
这个任务是说从9点开始,每隔一个小时,会执行一次,直到下午4点.
withMisfireHandlingInstructionFireNow(失效之后,再启动马上执行,总次数还是7次)
如果任务在10点的时候没有触发,但是在10:15分的时候执行了misfire,以后每次正点执行的时间就会较初始值晚15分钟,直到16:15
withMisfireHandlingInstructionNowWithExistingCount(失效之后,再启动之后马上执行,但是起始次数清零,总次数=7+当前misfire执行次数-1)
如果任务在10点没有触发,10:15分执行了misfire,以后执行时间都会较初始值晚15分钟,但是执行次数还是原来的7次,就会到17:15了。
withMisfireHandlingInstructionNextWithRemainingCount(失效之后,不管donothing,总次数还是7次)
withMisfireHandlingInstructionNextWithExistingCount(失效之后,donothgin,总次数=misfire的次数+7)
详情如图:
repeating infinitely(不停的执行)
这个任务是说从9点开始,每隔一个小时就会执行。
withMisfireHandlingInstructionFireNow(每次失效之后,在下个失效节点再执行)
这个模式下,withMisfireHandlingInstructionNowWithRemainingCount
,withMisfireHandlingInstructionNowWithExistingCount都是 一个意思。
withMisfireHandlingInstructionNextWithRemainingCount(每次失效之后,在下个定义的时间点再执行)
这个同withMisfireHandlingInstructionNextWithExistingCount的配置
CRON triggers(表达式,最复杂的)
在每个星期的周一至周五的上午9点到下午17点,每隔一个小时执行一次。
withMisfireHandlingInstructionIgnoreMisfires(所有misfire的任务会马上执行)
打个比方,如果9点misfire了,在10:15系统恢复之后,9点,10点的misfire会马上执行
withMisfireHandlingInstructionDoNothing(所有的misfire不管,执行下一个周期的任务)
withMisfireHandlingInstructionFireAndProceed(会合并部分的misfire,正常执行下一个周期的任务)
假设9,10的任务都misfire了,系统在10:15分起来了。只会执行一次misfire,下次正点执行。
现在,你了解到,不同模式的相同配置,misfire的行为其实是不一样的。大的方向其实就三个
1 忽略
2 立即执行
3 继续
4 放弃
5 等待下一个周期
最终就是根据合适的策略,选择合适的misfire.
翻译的原文地址:quartz-scheduler-misfire
相关推荐
Spring整合任务调度框架Quartz,本文档详细介绍了Spring整合任务调度框架Quartz,希望可以帮助学习者
Quartz定时任务框架,本次小白使用它实现一个简单的定时任务。每隔3秒打印一次Hello。这个是例子的jar包,实现过程在博客首页可看到。
任务调度框架Quartz, 任务调度框架Quartz, 任务调度框架Quartz
Quartz框架是一个全功能、开源的任务调度服务,可以集成几乎任何的java应用程序—从小的单片机系统到大型的电子商务系统。Quartz可以执行上千上万的任务调度
任务调度Quartz框架 任务调度Quartz框架
Java任务调度框架Quartz1.8.6(版本:1.8.6)教程实例源代码
NULL 博文链接:https://baobeituping.iteye.com/blog/629237
基于Quartz的定时任务Demo,可监控任务执行,临时添加任务等,包含建表数据库脚本。
Java任务调度框架Quartz2.0.2(版本:2.0.2)教程实例源代码
任务调度开源框架Quartz动态添加、修改和删除定时任务
任务调度框架Quartz[收集].pdf
Spring 框架自带定时任务使用 stask.xml Quartz定时任务
集成了分布式任务调度框架 Quartz ,任务存储于数据库。 使用SpringMVC作为路由控制, 集成 Swagger2 提供实时 RESTful API文档。 数据持久层集成 Mybatis 框架。 使用自定义注解 @TargetDataSource 实现了多数据源...
APScheduler提供了基于日期、固定时间间隔以及crontab类型的任务,并且可以持久化任务,它是基于Quartz的一个Python定时任务框架,实现了Quartz的所有功能。
使用Quartz调度任务,根据需要人为的终止某个任务,适用于很多常见的场景
quartz动态任务管理源码,为了方便各位需要者。
quartz定时任务框架
spring quartz 时间任务调度框架 spring quartz 时间任务调度框架 spring quartz 时间任务调度框架