Quartz Scheduler失火指令说明

有时,Quartz无法在您需要的时间运行您的工作。 这有三个原因:
  • 所有工作线程都忙于运行其他作业(可能具有更高的优先级)
  • 调度程序本身已关闭
  • 该作业是在过去的开始时间安排的(可能是编码错误)

您可以通过简单地在quartz.properties自定义org.quartz.threadPool.threadCount (默认值为10)来增加工作线程的数量。 但是当整个应用程序/服务器/调度程序停机时,您实际上无法执行任何操作。 当Quartz无法触发给定的触发器时,这种情况称为不点火 。 您知道Quartz在发生时在做什么吗? 事实证明,Quartz可以采用多种策略(称为失火指令 ),并且如果您没有考虑的话,还有一些默认设置。 但是,为了使您的应用程序健壮和可预测(尤其是在高负载或维护情况下),您应该真正确保触发器和作业的配置合理。

根据选择的触发器,有不同的配置选项(可用的失火说明 )。 Quartz的行为也取决于触发器设置(所谓的智能策略 )。 尽管失火说明已在文档中进行了描述,但我发现很难理解它们的真正含义。 因此,我创建了这篇小总结文章。

在深入探讨细节之前,应该先介绍另一个配置选项。 它是org.quartz.jobStore.misfireThreshold (以毫秒为单位),默认为60000(一分钟)。 它定义了触发器应该多长时间才被认为触发失败 。 在默认设置下,如果触发器是在30秒前触发的,那么Quartz会很高兴地运行它。 这种延迟不被认为是错误触发。 但是,如果在计划的时间之后61秒发现触发器,则特殊的失火处理程序线程会按照失火指令来处理它。 出于测试目的,我们将此参数设置为1000(1秒),以便我们可以快速测试错火。

简单触发,无需重复

在我们的第一个示例中,我们将看到计划仅运行一次的简单触发器如何处理错火:

val trigger = newTrigger().startAt(DateUtils.addSeconds(new Date(), -10)).build()

相同的触发器,但显式设置了失火指令处理程序:

val trigger = newTrigger().startAt(DateUtils.addSeconds(new Date(), -10)).withSchedule(simpleSchedule().withMisfireHandlingInstructionFireNow()  //MISFIRE_INSTRUCTION_FIRE_NOW).build()

为了进行测试,我只是将触发器安排在10秒钟前运行(因此,它在创建之时要晚10秒钟!)在现实世界中,您通常不会安排这样的触发器。 而是假设触发器已正确设置,但是在安排好调度程序时,调度程序已关闭或没有任何可用的辅助线程。 然而,石英将如何处理这种特殊情况? 在上面的第一个代码段中,未设置失火处理指令(在这种情况下,使用了智能策略 )。 第二个代码段明确定义了发生错火时我们期望什么样的行为。 见表:

简单触发重复固定次数

这种情况要复杂得多。 想象一下,我们已经安排了一些工作来重复固定的次数:

val trigger = newTrigger().startAt(dateOf(9, 0, 0)).withSchedule(simpleSchedule().withRepeatCount(7).withIntervalInHours(1).WithMisfireHandlingInstructionFireNow()  //or other).build()

在此示例中,假设触发器每小时触发8次(首次执行+ 7次重复),从今天上午9点开始( startAt(dateOf(9, 0, 0)) 。因此,最后一次执行应在下午4点进行。假设由于某种原因,调度程序无法在上午9点和10点运行作业,并且在10:15 AM发现了这一事实,即2次点火失败,调度程序在这种情况下将如何表现?

简单触发无限重复

在这种情况下,触发器以给定的间隔重复无数次:

val trigger = newTrigger().startAt(dateOf(9, 0, 0)).withSchedule(simpleSchedule().withRepeatCount(SimpleTrigger.REPEAT_INDEFINITELY).withIntervalInHours(1).WithMisfireHandlingInstructionFireNow()  //or other).build()

再次应该从今天的上午9点开始每小时触发一次( startAt(dateOf(9, 0, 0))startAt(dateOf(9, 0, 0)) 。然而,调度程序无法在上午9点和10点运行作业,并且它在10:15发现了这一事实AM,即2次点火失败,与简单触发器固定运行次数相比,这是更普遍的情况。

CRON触发器

CRON触发器是Quartz用户中最受欢迎的触发器。 但是,还有两个其他可用的触发器: DailyTimeIntervalTrigger (例如, 每25分钟触发一次 )和CalendarIntervalTrigger (例如, 每5个月触发一次 )。 它们支持在CRON和简单触发器中均不可能的触发策略。 但是,他们了解与CRON触发器相同的失火处理说明。

val trigger = newTrigger().withSchedule(cronSchedule("0 0 9-17 ? * MON-FRI").withMisfireHandlingInstructionFireAndProceed()  //or other).build()

在此示例中,触发器应在周一至周五的上午9点至下午5点之间每小时触发一次。 但是再次错过了前两次调用(因此触发器未触发),这种情况在上午10:15被发现。 请注意,可用的失火指令与简单触发器相比有所不同:


QTZ-283 QTZ-283:MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY不JDBCJobStore工作 -显然存在一个bug,当JDBCJobStore时,留意这个问题。

如您所见,各种触发器的行为基于实际设置而有所不同。 而且,即使提供了所谓的智能策略 ,该决定通常还是基于业务需求。 从本质上讲,有三种主要策略: 忽略立即运行,继续丢弃并等待下一个 。 它们都有不同的用例:

当您要确保触发了所有计划执行时,请使用忽略策略,即使这意味着将触发多个未触发的触发器。 考虑一下一个工作,该工作根据最后一个小时的订单每小时生成一次报告。 如果服务器停机了8个小时,您仍然希望尽快生成报告。 在这种情况下, 忽略策略将简单地以计划程序的速度运行在该8个小时内计划的所有触发器。 他们将迟到几个小时,但最终将被执行。

当有定期执行的作业以及失火情况下,应立即使用*策略,但应尽快运行,但只能运行一次。 想一想每分钟都会清理/tmp目录的作业。 如果调度程序忙了20分钟并且最终可以运行此作业,则您不想运行20次! 一个就足够了,但要确保它能尽快运行。 然后回到正常的一分钟间隔。

最后,当您要确保作业在特定的时间点运行时, next *策略很好。 例如,您需要每小时获取一个季度的股票价格。 它们会Swift变化,因此,如果您的工作失败了,并且已经整整20分钟了,那就不要打扰了。 您错过了5分钟的正确时间,现在您不在乎。 最好有一个差距而不是一个不正确的值。 在这种情况下,Quartz将跳过所有未执行的执行,而仅等待下一个执行。

参考: Quartz调度程序失火指令,由我们的JCG合作伙伴 Tomasz Nurkiewicz在Java和社区博客中解释。


翻译自: https://www.javacodegeeks.com/2012/04/quartz-scheduler-misfire-instructions.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373082.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android 代码获取屏幕图像,安卓获取屏幕以及获得像素点 ~ 大树洞

由于一些不可告人的需求,所以开始寻找各种可以实现安卓实时获得屏幕上某个像素点的功能首先,将需求进行拆解,分别为1、获得屏幕2、获得屏幕上一个像素点获得屏幕获得屏幕分为比较多种的方式,在以前大致分为adb screencap 获取当前…

海量端口扫描工具masscan

海量端口扫描工具masscanmasscan号称是互联网上最快的端口扫描工具,可以6分钟扫描整个互联网,每秒可以发送一百万个数据包。为了提高处理速度,masscan定制了TCP/IP栈,从而不影响本地其他TCP/IP的数据传输。masscan提供较为丰富的选…

改进租房练习

代码基本没有改动&#xff0c;函数有变化&#xff0c;老师只用了一个函数&#xff0c;自己做写了4个function&#xff0c;减少了代码量 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitio…

Google App Engine JAX-RS REST服务

在本文中&#xff0c;您将学习如何使用JAX-RS参考实现&#xff08;Jersey&#xff09;创建REST服务并将其部署在Google AppEngine上。 先决条件 对于本教程&#xff0c;您将需要&#xff1a; Google AppEngine帐户 Eclipse Galileo&#xff08;3.5.x&#xff09; 适用于Java的…

libnids校验和引起回放包不能正常捕捉

如题 取消校验和校验即可&#xff1a; struct nids_chksum_ctl temp;temp.netaddr 0;temp.mask 0;temp.action 1;nids_register_chksum_ctl(&temp,1); 在init之前。转载于:https://www.cnblogs.com/yaoyuanfeixing/p/6308067.html

鸿蒙系统的全面开源,华为:打造全球的操作系统,鸿蒙今日全面开源!

原标题&#xff1a;华为&#xff1a;打造全球的操作系统&#xff0c;鸿蒙今日全面开源&#xff01;今日下午&#xff0c;2019华为全球开发者大会在华为松山湖基地正式开幕。华为正式对外推出了自研操作系统——鸿蒙系统(Harmony OS)。华为消费者业务CEO余承东指出&#xff0c;鸿…

android 获取路径目录方法以及判断目录是否存在,创建目录

Environment 常用方法&#xff1a; * 方法&#xff1a;getDataDirectory()解释&#xff1a;返回 File &#xff0c;获取 Android 数据目录。* 方法&#xff1a;getDownloadCacheDirectory()解释&#xff1a;返回 File &#xff0c;获取 Android 下载/缓存内容目录。* 方法&…

Maven不会吮吸。 。 。 但是Maven文件会

我不会参加整个Maven辩论&#xff0c;但是可以说我是所有最佳实践的有力支持者&#xff0c;对我而言&#xff0c;Maven是最佳实践的体现。 我的意思是说&#xff0c;Maven是围绕特定的最佳实践构建方法构建的。 注意&#xff0c;我说了一种特定的最佳实践构建方法。 在现实世界…

html5 游戏制作教程,html5一步步实现超级玛丽游戏制作(新手教程源码)

【实例简介】【实例截图】【核心代码】My first Gamebody {border:none 0px;margin:0px;padding:10px;font-size : 16px;background-color : #f3f3f3;}canvas {border : 1px solid blue;}// 页面初始化函数function init(){//加载图片,并存入全局变量 ImgCache,// 加载完成后,调…

同步与异步的概念

进程同步用来实现程序并发执行时候的可再现性。 一&#xff0e;进程同步及异步的概念 1&#xff0e;进程同步&#xff1a;就是在发出一个功能调用时&#xff0c;在没有得到结果之前&#xff0c;该调用就不返回。也就是必须一件一件事做,等前一件做完了才能做下一件事.就像早上起…

编写Play 2的模块,第1部分:使工作正常

几周前&#xff0c;我迁移了Play&#xff01; 框架 1.x版本的Deadbolt应用于Play 2平台&#xff0c;并且对缺少有关创建模块的信息感到惊讶。 Play 1.x文档中详细介绍了该主题&#xff0c;这使得创建模块非常简单。 显然&#xff0c;需要做些事情-这是关于为Play 2创建模块和插…

Dotnet Core

Global Exceptionhttp://www.talkingdotnet.com/global-exception-handling-in-aspnet-core-webapi/转载于:https://www.cnblogs.com/zwheui/p/6339692.html

交友系统设计:哪种地理空间邻近算法更快?

小熊学Java&#xff1a;https://javaxiaobear.cn 交友与婚恋是人们最基本的需求之一。随着互联网时代的不断发展&#xff0c;移动社交软件已经成为了人们生活中必不可少的一部分。然而&#xff0c;熟人社交并不能完全满足年轻人的社交与情感需求&#xff0c;于是陌生人交友平台…

linux ntp 'ntp_request.c'远程拒绝服务漏洞,NTP 'ntp_request.c'远程拒绝服务漏洞

NTP ntp_request.c远程拒绝服务漏洞发布日期&#xff1a;2013-12-30更新日期&#xff1a;2014-01-09受影响系统&#xff1a;NTP NTP 描述&#xff1a;--------------------------------------------------------------------------------BUGTRAQ ID: 64692CVE(CAN) ID: CVE-20…

指针的内容 ; 指针的地址 指针所指向的内容 指针的类型 指针所指向的类型...

这几个个东东很具有迷惑性。 int a10; //假设a的地址是 0x0000004C int *p; //假设p的地址是 0x0035FA94 p&a; 指针的内容&#xff1a;指针里面存放的是地址。 指针p里面存放的是a的地址(&a)。即指针p里面存放的内容是0x0000004C。 指针的地址&#xff…

Apache Camel教程– EIP,路由,组件,测试和其他概念的简介

公司之间的数据交换增加了很多。 必须集成的应用程序数量也增加了。 这些接口使用不同的技术&#xff0c;协议和数据格式。 但是&#xff0c;这些应用程序的集成应以标准化的方式建模&#xff0c;有效实现并由自动测试支持。 企业集成模式&#xff08;EIP&#xff09;[1]中存在…

iOS开发UI篇—UITableview控件简单介绍

一、基本介绍 在众多移动应⽤用中,能看到各式各样的表格数据 。 在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView&#xff0c;UITableView继承自UIScrollView,因此支持垂直滚动,⽽且性能极佳 。 UITableview有分组和不分组两种样式&#xff0c;可以在storyboard或…

PL/SQL 08 异常 exception

--PL/SQL错误 编译时 运行时--运行时的出错处理 EXCEPTION --异常处理块DECLARE …BEGIN …EXCEPTION WHEN OTHERS THEN handler_error(…);END; --用户自定义的异常DECLARE e_TooManyStudents EXCEPTION; …BEGIN … RAISE e_TooManyStudents; …EXCEPTION WHEN e_TooMany…

html鼠标事件没反应,鼠标有时候点击没反应怎么解决

关于鼠标有时候点击没反应的问题&#xff0c;一些网友显得一头雾水&#xff0c;那这该怎么解决呢?下面就由小编来给你们说说鼠标有时候点击没反应的原因及解决方法吧&#xff0c;希望可以帮到你们哦!鼠标有时候点击没反应的解决方法一&#xff1a;一&#xff0c;系统繁忙&…

动态ADF火车:以编程方式添加火车停靠站

我将展示如何以编程方式“即时”将火车停靠站添加到ADF火车中。 在我的用例中&#xff0c;我有一些票务预订应用程序。 它具有训练模型的有限任务流。 在火车的第一站&#xff0c;用户输入乘客的数量&#xff0c;在随后的站点&#xff0c;他们输入一些乘客的信息。 带有乘客信息…