quartz

quartz

OpenSymphony的開源項目
Quartz是OpenSymphony開源組織在Job scheduling領域又一個開源項目[2],它可以與J2EE與J2SE應用程序相結合也可以單獨使用。Quartz可以用來創建簡單或為運行十個,百個,甚至是好幾萬個Jobs這樣複雜的程序。Jobs可以做成标準的Java組件或 EJBs。Quartz的最新版本為Quartz 2.3.2。[1]
  • 中文名:開源項目
  • 英文名:quartz
  • 核心:調度器
  • 最新版本:Quartz 2.2.1
  • 解釋:由java編寫的開源作業調度框架

調度簡單

Quartz是一個完全由java編寫的開源作業調度框架。不要讓作業調度這個術語吓着你。盡管Quartz框架整合了許多額外功能, 但就其簡易形式看,你會發現它易用得簡直讓人受不了!簡單地創建一個實現org.quartz.Job接口的java類。Job接口包含唯一的方法:

public void execute(JobExecutionContext context)

throws JobExecutionException;

在你的Job接口實現類裡面,添加一些邏輯到execute()方法。一你配置好Job實現類并設定好調度時間表,Quartz将密切注意剩餘時間。當調度程序确定該是通知你的作業的時候,Quartz框架将調用你Job實現類(作業類)上的execute()方法并允許做它該做的事情。無需報告任何東西給調度器或調用任何特定的東西。僅僅執行任務和結束任務即可。如果配置你的作業在随後再次被調用,Quartz框架将在恰當的時間再次調用它。

内部架構

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

調度器

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

框架特征

Quartz框架有一個豐富的特征集。事實上,Quartz有太多特性以緻不能在一種情況中全部領會,下面列出了一些有意思的特征,但沒時間在此詳細讨論。

監聽器和插件

每個人都喜歡監聽和插件。今天,幾乎下載任何開源框架,你必定會發現支持這兩個概念。監聽是你創建的java類,當關鍵事件發生時會收到框架的回調。例如,當一個作業被調度、沒有調度或觸發器終止和不再打火時,這些都可以通過設置來來通知你的監聽器。Quartz框架包含了調度器監聽、作業和觸發器監聽。你可以配置作業和觸發器監聽為全局監聽或者是特定于作業和觸發器的監聽。

一旦你的一個具體監聽被調用,你就能使用這個技術來做一些你想要在監聽類裡面做的事情。例如,你如果想要在每次作業完成時發送一個電子郵件,你可以将這個邏輯寫進作業裡面,也可以JobListener裡面。寫進JobListener的方式強制使用松耦合有利于設計上做到更好。

Quartz插件是一個新的功能特性,無須修改Quartz源碼便可被創建和添加進Quartz框架。他為想要擴展Quartz框架又沒有時間提交改變給Quartz開發團隊和等待新版本的開發人員而設計。如果你熟悉Struts插件的話,那麼完全可以理解Quartz插件的使用。

與其Quartz提供一個不能滿足你需要的有限擴展點,還不如通過使用插件來擁有可修整的擴展點。

集群Quartz應用

Quartz應用能被集群,是水平集群還是垂直集群取決于你自己的需要。集群提供以下好處:伸縮性、高可用性、負載均衡

目前,Quartz隻能借助關系數據庫和JDBC作業存儲支持集群。将來的版本這個制約将消失并且用RAMJobStore集群将是可能的而且将不需要數據庫的支持。

相關詞條

相關搜索

其它詞條