複製鏈接
請複製以下鏈接發送給好友

quartz

(開源項目)

鎖定
Quartz是OpenSymphony開源組織在Job scheduling領域又一個開源項目,它可以與J2EE與J2SE應用程序相結合也可以單獨使用。Quartz可以用來創建簡單或為運行十個,百個,甚至是好幾萬個Jobs這樣複雜的程序。Jobs可以做成標準的Java組件EJBs。Quartz的最新版本為Quartz 2.3.2。
中文名
擴特茲公式
外文名
quartz
類    別
開源項目
最新版本
Quartz 2.3.0
解    釋
由java編寫的開源作業調度框架

quartz調度簡單

Quartz是一個完全由java編寫的開源作業調度框架。不要讓作業調度這個術語嚇着你。儘管Quartz框架整合了許多額外功能, 但就其簡易形式看,你會發現它易用得簡直讓人受不了!簡單地創建一個實現org.quartz.Job接口的java類。Job接口包含唯一的方法:
public void execute(JobExecutionContext context)
throws JobExecutionException;
在你的Job接口實現類裏面,添加一些邏輯到execute()方法。一旦你配置好Job實現類並設定好調度時間表,Quartz將密切注意剩餘時間。當調度程序確定該是通知你的作業的時候,Quartz框架將調用你Job實現類(作業類)上的execute()方法並允許做它該做的事情。無需報告任何東西給調度器或調用任何特定的東西。僅僅執行任務和結束任務即可。如果配置你的作業在隨後再次被調用,Quartz框架將在恰當的時間再次調用它。

quartz內部架構

在規模方面,Quartz跟大多數開源框架類似。大約有300個java類和接口,並被組織到12個包中。這可以和Apache Struts把大約325個類和接口以及組織到11個包中相比。儘管規模幾乎不會用來作為衡量框架質量的一個特性,但這裏的關鍵是quartz內含很多功能,這些功能和特性集是否成為、或者應該成為評判一個開源或非開源框架質量的因素。

quartz調度器

Quartz框架的核心是調度器。調度器負責管理Quartz應用運行時環境。調度器不是靠自己做所有的工作,而是依賴框架內一些非常重要的部件。Quartz不僅僅是線程和線程管理。為確保可伸縮性,Quartz採用了基於多線程的架構。啓動時,框架初始化一套worker線程,這套線程被調度器用來執行預定的作業。這就是Quartz怎樣能併發運行多個作業的原理。Quartz依賴一套松耦合的線程池管理部件來管理線程環境。本篇文章中,我們會多次提到線程池管理,但Quartz裏面的每個對象是可配置的或者是可定製的。所以,例如,如果你想要插進自己線程池管理設施,我猜你一定能!

quartz框架特徵

Quartz框架有一個豐富的特徵集。事實上,Quartz有太多特性以致不能在一種情況中全部領會,下面列出了一些有意思的特徵,但沒時間在此詳細討論。
監聽器和插件
每個人都喜歡監聽和插件。今天,幾乎下載任何開源框架,你必定會發現支持這兩個概念。監聽是你創建的java類,當關鍵事件發生時會收到框架的回調。例如,當一個作業被調度、沒有調度或觸發器終止和不再觸發時,這些都可以通過設置來通知你的監聽器。Quartz框架包含了調度器監聽、作業和觸發器監聽。你可以配置作業和觸發器監聽為全局監聽或者是特定於作業和觸發器的監聽。
一旦你的一個具體監聽被調用,你就能使用這個技術來做一些你想要在監聽類裏面做的事情。例如,你如果想要在每次作業完成時發送一個電子郵件,你可以將這個邏輯寫進作業裏面,也可以寫進JobListener裏面。寫進JobListener的方式強制使用松耦合有利於設計上做到更好。
Quartz插件是一個新的功能特性,無須修改Quartz源碼便可被創建和添加進Quartz框架。他為想要擴展Quartz框架又沒有時間提交改變給Quartz開發團隊和等待新版本的開發人員而設計。如果你熟悉Struts插件的話,那麼完全可以理解Quartz插件的使用。
與其Quartz提供一個不能滿足你需要的有限擴展點,還不如通過使用插件來擁有可修整的擴展點。
集羣Quartz應用
Quartz應用能被集羣,是水平集羣還是垂直集羣取決於你自己的需要。集羣提供以下好處:
Quartz可以藉助關係數據庫和JDBC作業存儲支持集羣。
Terracotta擴展quartz提供集羣功能而不需要數據庫支持
相關工具
Quartz經常會用到cron表達式,可以使用國外網站cronmaker輔助生成cron表達式。