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.pswp.cn/news/373082.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/373082.shtml
英文地址,請注明出處:http://en.pswp.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;他們輸入一些乘客的信息。 帶有乘客信息…