`
caicai1230231
  • 浏览: 23834 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

任务框架quartz的misfire的理解

 
阅读更多
     quartz,java世界里面的任务管理容器。

至于为什么会有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 

分享到:
评论

相关推荐

    quartz支持集群的定时器任务

    Quartz是一款开源的作业调度框架,它允许开发者创建、调度和执行各种类型的任务。在分布式环境中,Quartz的集群功能可以实现高可用性和任务的负载均衡。以下是对"quartz支持集群的定时器任务"这一主题的详细阐述。 ...

    quartz完整资料

    Quartz是Java平台上的一款开源的、强大的作业调度框架,它被广泛应用于企业级应用系统中,用于执行定时任务。...这个压缩包中的资料将帮助开发者更深入地理解和使用Quartz,实现高效的企业级定时任务管理。

    问题点滴 QuartzDemo

    QuartzDemo是一个基于Java的开源任务调度框架——Quartz的示例项目,它主要用于演示如何在实际应用中配置和使用Quartz。Quartz是企业级应用程序中广泛使用的库,用于执行定时任务,如数据清理、报表生成或者发送通知...

    quartz由浅入深共21页.pdf.zip

    总的来说,Quartz是一个强大且灵活的作业调度框架,通过理解其核心概念和配置方式,可以有效地在Java应用中实现定时任务的需求。对于开发人员来说,掌握Quartz能够提升工作效率,实现更高效的服务运维。

    quartz集群完整应用实例

    Quartz是一个开源的作业调度框架,它允许程序在预定的时间执行特定的任务,广泛应用于Java企业级应用中。本文将深入探讨Quartz集群的完整应用实例,帮助开发者理解如何实现高可用性和任务调度的可靠性。 首先,...

    quartz job 配置手册

    Quartz是一个开源的作业调度框架,它允许开发者精确地安排任务执行时间,从而实现自动化的工作流程。下面将深入探讨Quartz Job配置的关键知识点。 1. **Quartz基本概念** - **Job**:在Quartz中,Job是执行具体...

    Quartz开发指南

    Quartz是一款开源的作业调度框架,它允许Java开发者在应用程序中安排任务的执行。Quartz提供了丰富的API,使得创建、管理和监控定时任务变得简单。在本文中,我们将深入探讨Quartz的核心概念、特性以及如何在实际...

    quarz定时任务,对应发布的博客

    通过上述内容,我们可以看到Quartz是一个强大且灵活的定时任务框架,它允许开发者轻松地创建和管理各种定时任务,从而提升应用的自动化程度和效率。在实际开发中,正确理解和运用Quartz的各项功能,能有效优化系统的...

    CronQuartz

    这个库是Quartz Scheduler的一个实现,Quartz是一个功能强大的、完全开源的作业调度框架,广泛应用于企业级应用程序中,用于自动化定时任务。本教程将深入探讨如何在CronQuartz中创建和执行单个任务,以及处理任务的...

    Quartz_Scheduler_Example_Programs_and_Sample_Code.pdf Version 2.2.1

    本文档将基于 `Quartz_Scheduler_Example_Programs_and_Sample_Code.pdf` 版本 2.2.1,深入探讨其中的关键概念、示例程序以及样例代码,旨在帮助读者更好地理解和应用 Quartz Scheduler。 #### 关于 Quartz 示例...

Global site tag (gtag.js) - Google Analytics