Quartz Scheduler插件–隱藏的寶藏

盡管在官方文檔中進行了簡要描述,但我相信Quartz插件了解得還不夠多,看看它們有多有用。

本質上,Quartz中的插件是方便的類,用于包裝基礎偵聽器的注冊。 您可以自由編寫自己的插件,但我們將專注于Quartz隨附的現有插件。

LoggingTriggerHistoryPlugin

首先介紹一些背景。 Quartz中的兩個主要抽象是作業和觸發器。 Job是我們要計劃的一段代碼。 觸發器指示調度程序何時應運行此代碼。 CRON(例如,每個星期五在9 AM到5 PM之間運行直到11月)和簡單的(每2小時運行100次)觸發器是最常用的。 您可以將任意數量的觸發器關聯到一個作業。

信不信由你,Quartz默認不提供任何日志記錄或監視任何已執行的作業和觸發器。 有一個API,但是沒有實現內置的日志記錄。 它不會向您顯示由于觸發觸發器而現在可以執行此特定作業。 因此,您應該做的第一件事是將以下幾行添加到quartz.properties中:

org.quartz.plugin.triggerHistory.class=org.quartz.plugins.history.LoggingTriggerHistoryPluginorg.quartz.plugin.triggerHistory.triggerFiredMessage=Trigger [{1}.{0}] fired job [{6}.{5}] scheduled at: {2, date, dd-MM-yyyy HH:mm:ss.SSS}, next scheduled at: {3, date, dd-MM-yyyy HH:mm:ss.SSS}org.quartz.plugin.triggerHistory.triggerCompleteMessage=Trigger [{1}.{0}] completed firing job [{6}.{5}] with resulting trigger instruction code: {9}. Next scheduled at: {3, date, dd-MM-yyyy HH:mm:ss.SSS}org.quartz.plugin.triggerHistory.triggerMisfiredMessage=Trigger [{1}.{0}] misfired job [{6}.{5}]. Should have fired at: {3, date, dd-MM-yyyy HH:mm:ss.SSS}

第一行(也是唯一需要的行)將加載插件類LoggingTriggerHistoryPlugin。 其余各行將配置插件,自定義日志消息。 我發現內置默認值不是很周全,例如,它們顯示當前時間,這已經是日志框架消息的一部分。 您可以自由構造任何日志消息,有關詳細信息,請參閱API。 添加這些額外的幾行使調試和監視更加容易:

LoggingTriggerHistoryPlugin | Trigger [Demo.Every-few-seconds] fired job [Demo.Print-message] scheduled at:  04-04-2012 23:23:47.036, next scheduled at:  04-04-2012 23:23:51.036
//...job output
LoggingTriggerHistoryPlugin | Trigger [Demo.Every-few-seconds] completed firing job [Demo.Print-message] with resulting trigger instruction code: DO NOTHING. Next scheduled at:  04-04-2012 23:23:51.036

現在您知道為什么命名觸發器(Demo.Every-few-seconds)和作業(Demo.Print-message)如此重要。

LoggingJobHistoryPlugin

還有另一個與日志記錄相關的便捷插件:

org.quartz.plugin.jobHistory.class=org.quartz.plugins.history.LoggingJobHistoryPlugin
org.quartz.plugin.jobHistory.jobToBeFiredMessage=Job [{1}.{0}] to be fired by trigger [{4}.{3}], re-fire: {7}
org.quartz.plugin.jobHistory.jobSuccessMessage=Job [{1}.{0}] execution complete and reports: {8}
org.quartz.plugin.jobHistory.jobFailedMessage=Job [{1}.{0}] execution failed with exception: {8}
org.quartz.plugin.jobHistory.jobWasVetoedMessage=Job [{1}.{0}] was vetoed. It was to be fired by trigger [{4}.{3}] at: {2, date, dd-MM-yyyy HH:mm:ss.SSS}

規則是相同的–插件+額外配置。 有關詳細信息和可能的占位符,請參見LoggingJobHistoryPlugin的JavaDoc 。 快速查看日志可以發現非常具有描述性的輸出:

Trigger [Demo.Every-few-seconds] fired job [Demo.Print-message] scheduled at:  04-04-2012 23:34:53.739, next scheduled at:  04-04-2012 23:34:57.739
Job [Demo.Print-message] to be fired by trigger [Demo.Every-few-seconds], re-fire: 0
//...job output
Job [Demo.Print-message] execution complete and reports: null
Trigger [Demo.Every-few-seconds] completed firing job [Demo.Print-message] with resulting trigger instruction code: DO NOTHING. Next scheduled at:  04-04-2012 23:34:57.739

我不知道為什么默認情況下不啟用這些插件。 畢竟,如果您不需要這樣的詳細輸出,則可以在日志記錄框架中將其關閉。 沒關系,我認為在對Quartz執行進行故障排除時將它們安裝到位是個好主意。

XMLSchedulingDataProcessorPlugin

這是一個非常全面的插件。 它讀取包含作業的XML文件(默認名稱為quartz_data.xml)并觸發定義,并將其添加到調度程序中。 當您有一次需要添加一次的全局作業時,此功能特別有用。 插件可以更新現有的作業/觸發器,也可以忽略XML文件(如果它們已經存在)–在使用JDBCJobStore時非常有用。

org.quartz.plugin.xmlScheduling.class=org.quartz.plugins.xml.XMLSchedulingDataProcessorPlugin

在上述文章中,我們一直在手動將作業添加到調度程序中:

val trigger = newTrigger().withIdentity("Every-few-seconds", "Demo").withSchedule(simpleSchedule().withIntervalInSeconds(4).repeatForever()).build()val job = newJob(classOf[PrintMessageJob]).withIdentity("Print-message", "Demo").usingJobData("msg", "Hello, world!").build()scheduler.scheduleJob(job, trigger)

使用XML配置可以實現相同的效果,只需將以下quartz_data.xml放在CLASSPATH中:

<?xml version="1.0" encoding="UTF-8"?>
<job-scheduling-data xmlns="http://www.quartz-scheduler.org/xml/JobSchedulingData"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation=" http://www.quartz-scheduler.org/xml/JobSchedulingData http://www.quartz-scheduler.org/xml/job_scheduling_data_2_0.xsd "><processing-directives><overwrite-existing-data>false</overwrite-existing-data><ignore-duplicates>true</ignore-duplicates></processing-directives><schedule><trigger><simple><name>Every-few-seconds</name><group>Demo</group><job-name>Print-message</job-name><job-group>Demo</job-group><repeat-count>-1</repeat-count><repeat-interval>4000</repeat-interval></simple></trigger><job><name>Print-message</name><group>Demo</group><job-class>com.blogspot.nurkiewicz.quartz.demo.PrintMessageJob</job-class><job-data-map><entry><key>msg</key><value>Hello, World!</value></entry></job-data-map></job></schedule></job-scheduling-data>

使用XML配置可以實現相同的效果,只需將以下quartz_data.xml放在CLASSPATH中:

org.quartz.plugin.xmlScheduling.fileNames=/etc/quartz/system-jobs.xml,/home/johnny/my-jobs.xml
org.quartz.plugin.xmlScheduling.scanInterval=60

關機鉤子插件

最后但并非最不重要的是ShutdownHookPlugin。 小型但可能有用的插件,可以在JVM中注冊關閉鉤子,以便輕輕地停止調度程序。 但是,我建議關閉cleanShutdown –如果系統已經試圖突然停止應用程序(通常是Spring通過SchedulerFactoryBean通過SchedulerFactoryBean調用調度程序關閉)或用戶按下Ctrl + C –等待當前正在運行的作業似乎是個壞主意。 畢竟,也許由于某些作業運行時間過長/過長而導致我們正在終止應用程序?

org.quartz.plugin.shutdownHook.class=org.quartz.plugins.management.ShutdownHookPlugin
org.quartz.plugin.shutdownHook.cleanShutdown=false

如您所見,Qurtz附帶了一些非常有趣的插件。 由于某些原因,它們在官方文檔中沒有詳細描述,但是它們工作得很好,并且是調度程序的重要補充。

帶有已應用插件的源代碼可在GitHub上獲得。

參考: Quartz Scheduler插件– Java和社區博客上來自JCG合作伙伴 Tomasz Nurkiewicz的隱藏寶藏 。


翻譯自: https://www.javacodegeeks.com/2012/04/quartz-scheduler-plugins-hidden.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372843.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372843.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372843.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mysql查詢表名匹配只有字母的_MySQL按某些匹配字母查詢表

MySQL查詢是MySQL的核心功能&#xff0c;有時候我們需要查找帶有某些匹配字母的表。下文對該MySQL查詢方式作了詳細的介紹&#xff0c;供您參考。在MySQL中我們可以使用LIKE或者NOT LIKE操作符進行比較。在MySQL中模式默認是不區分大小寫的。查詢示例&#xff0c;student表----…

hdu 1181(Floyed)

變形課 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submission(s): 20748 Accepted Submission(s): 7494 Problem Description呃......變形課上Harry碰到了一點小麻煩,因為他并不像Hermione那樣能夠記住所有的咒語而隨意的…

讀書筆記-你不知道的JS上-混入與原型

繼承 mixin混合繼承 function mixin(obj1, obj2) {for (var key in obj2) {//重復不復制if (!(key in obj1)) {obj1[key] obj2[key];}}return obj1;} 這種復制是淺復制&#xff0c;對象或者數組函數等都是同一個引用&#xff0c;改變obj1的會同時影響obj2。 寄生繼承 ... 隱式…

JUnit和Hamcrest:在assertEquals上進行改進

在我的博客文章中&#xff0c;Java越來越接受靜態導入嗎&#xff1f; &#xff0c;我討論了在Java中越來越多地使用靜態導入來使代碼在某些情況下更流暢。 Java 單元測試特別受靜態導入的影響&#xff0c;在此博客文章中&#xff0c;我提供了一個簡單的示例&#xff0c;說明如何…

mysql delete temporary denied_這些錯誤是什么意思?djang中的mysql

我試著運行一個程序&#xff0c;我被給予了一個例子&#xff0c;它就像一個購物網站&#xff0c;使用MySQL數據庫而不是Django提供的原始數據庫&#xff01;我只是想看看有沒有人理解這些錯誤的含義&#xff1f;任何信息都將不勝感激&#xff01;我本可以提供網頁的代碼&#x…

C語言 · 芯片測試

基礎練習 芯片測試 時間限制&#xff1a;1.0s 內存限制&#xff1a;512.0MB問題描述有n&#xff08;2≤n≤20&#xff09;塊芯片&#xff0c;有好有壞&#xff0c;已知好芯片比壞芯片多。每個芯片都能用來測試其他芯片。用好芯片測試其他芯片時&#xff0c;能正確給出被測試…

Animation用法

測試代碼及說明&#xff1a; <!DOCTYPE html> <html lang"en-US"> <head><meta charset"UTF-8"><title>Simple CSS3 Animation</title><style type"text/css">#demo {position: absolute;left: 30%;t…

mysql dese_MySQL 5.6-類似于DENSE_RANK的功能,無需訂購

小編典典對于 MySQL版本<8.0(OP的版本是5.6)&#xff1a;問題陳述看起來需要DENSE_RANK功能groupVarian; 但是事實并非如此。正如 GordonLinoff解釋的那樣 &#xff1a;您似乎希望按它們在數據中出現的順序來枚舉它們。假設您的表名是t(請為您的代碼相應地更改表名和字段名)…

Spring和JSF集成:動態導航

通常&#xff0c;您的JSF應用程序將需要超越基本的靜態導航并開始做出動態導航決策。 例如&#xff0c;您可能想根據用戶的年齡重定向他們。 大多數JSF教程建議通過將命令的action屬性綁定到支持bean來實現動態導航&#xff1a; <h:commandButton action"#{bean.action…

通過富文本改變UITextFieldPlaceholder顏色

1、通過屬性 a、 //文字屬性(一般) NSMutableDictionary *attrs [NSMutableDictionary dictionary]; attrs[NSForegroundColorAttributeName] [UIColor blueColor]; NSAttributedString *placeholderStr [[NSAttributedString alloc] initWithString:"手機號" a…

阻塞/非阻塞/同步/異步方法和多線程的關系?沒有任何關系,倆不挨著

1.阻塞非阻塞異步同步是針對方法說的&#xff0c;是評判一個方法運行狀態的。和多線程完全兩個級別。 2.阻塞非阻塞異步同步是針對方法說的&#xff0c;是評判一個方法運行狀態的。和多線程完全兩個級別。 3.阻塞非阻塞異步同步是針對方法說的&#xff0c;是評判一個方法運行狀…

mysql備份 where_MySQL備份與還原

1.mysqldumpmysqlbinlog介紹mysqldump備份結合binlog日志恢復。MySQL備份一般采取全庫備份加日志備份的方式&#xff0c;例如每天執行一次全備份&#xff0c;每小時執行一次二進制日志備份&#xff0c;這樣在MySQL故障后可以使用全備份和日志備份將數據恢復到最后一個二進制日志…

JMeter:負載測試關系數據庫

Apache JMeter是完全使用Java編寫的性能測試工具。 可以在請求/響應模型上運行的任何應用程序都可以使用JMeter進行負載測試。 關系數據庫也不例外&#xff1a;接收sql查詢&#xff0c;執行它們并返回執行結果。 我將向您展示使用JMeter的圖形用戶界面設置測試方案有多么容易。…

new: Set up a window

Nehe的教程確實太老了&#xff0c;不過我認為它也能夠讓我了解OpenGL3.2以前的管線渲染模式&#xff0c;即使它在現在已經不常見了。因為想要了解&#xff0c;所以我還是會看完Nehe的教程。 現在這是一個新的教程 - JoeyDeVries的教程&#xff0c;可以說是網上最好的OpenGL教程…

Python全棧開發:socket

Socket socket通常也稱作"套接字"&#xff0c;用于描述IP地址和端口&#xff0c;是一個通信鏈的句柄&#xff0c;應用程序通常通過"套接字"向網絡發出請求或者應答網絡請求。 socket起源于Unix&#xff0c;而Unix/Linux基本哲學之一就是“一切皆文件”&…

oracle sga pga mysql_修改Oracle數據庫SGA和PGA大小

SGA的大小&#xff1a;一般物理內存20%用作操作系統保留&#xff0c;其他80%用于數據庫。SGA普通數據庫可以分配40%-60%之間&#xff0c;PGA可以分配20%-40%之間。1、以dba身份登錄并查看SGA信息&#xff1a;SQL>show parameter sga&#xff1b;查看PGA信息&#xff1a;SQL&…

NetBeans 7.1:創建自定義提示

我已經在帖子中介紹了一些我最喜歡的NetBeans提示 &#xff0c;這些信息是用于使Java代碼現代化的七個NetBeans提示和七個不可或缺的NetBeans Java提示 。 這兩個帖子中涉及的十四個提示僅占NetBeans支持的“即開即用”提示總數的一小部分。 但是&#xff0c;由于NetBeans 7.1使…

今年暑假不AC

Problem Description “今年暑假不AC&#xff1f;”“是的。”“那你干什么呢&#xff1f;”“看世界杯呀&#xff0c;笨蛋&#xff01;”“#$%^&*%...”確實如此&#xff0c;世界杯來了&#xff0c;球迷的節日也來了&#xff0c;估計很多ACMer也會拋開電腦&#xff0c;奔向…

qregexp括號匹配_轉:Qt的正則表達式和QRegExp

考慮一下我們經常遇到的問題&#xff0c;比如gemfield想從青島之光讀書(www.civilnet.cn/book)中找一個關鍵的電話號碼&#xff0c;通常第一步就是將書中所有的電話號碼查找出來放在手邊。那么怎么擬定查詢條件呢&#xff1f;電話的格式有如下幾種&#xff1a;01088888888010 8…

具有Tron效果的JavaFX 2 Form

這是一個具有TRON效果的簡單JavaFX登錄表單。 在此示例中&#xff0c;我使用CSS設置TextField和Button的樣式。 這是CSS和Effect代碼的片段&#xff1a; .text-field{-fx-background-color: transparent;-fx-border-color: #00CCFF;-fx-text-fill: white; }.password-field{-fx…