一、獲取Quartz Web程序(Quartz GUI)。
早期的 Quartz 框架開發者意識到一個 GUI 對于某類用戶群體是必需的。幾年前,一個 Web 應用被創立,它可用于管理 Quartz 框架。雖說是歷經了幾年有相當投入的開發,但不得不說的,總是時斷時續的。近來出現有更多的要求對這個應用的更新與支持,因而又重新吸引了新的開發者自愿的工作并使之保持不斷更新。這個應用就是知名的 Quartz Web 程序。Quartz Web 程序是作為 OpenSymphony 上 Quartz 源程序庫的一部分。它曾經是放在 SourceForge 上的,但最近已遷移到新家了(譯者注:在 SourceForge 仍可下載到)。舊的站點是 http://sourceforge.net/projects/quartz;新的站點(包括 Quartz Web 程序) 可在 http://www.quartz-scheduler.org/community/repository.html 上找到。
當前,還沒有 Web 程序的二進制版,而且標準的 Quartz 下載中也不包括 Web 程序,所以你需要進入quartz的SVN(http://svn.terracotta.org/svn/quartz)源代碼樹下的webapp目錄即為Quartz Web 的源碼目錄,下載到 Quartz 源代碼樹并使用 quartz/webapp目錄下的 Ant 或Maven構建文件來構建這個 Web 程序。
最新版的quartz web采用了struts2+freemarker+spring2.5的架構,還用到了開源的sitemesh和dwr,并在web.xml中設置用org.quartz.ui.web.init.DefinitionInitializer啟動quartz,具體設置如下:
<servlet>
<servlet-name>DefinitionInitializer</servlet-name>
<servlet-class>
org.quartz.ui.web.init.DefinitionInitializer
</servlet-class>
<init-param>
<param-name>definition-file</param-name>
<param-value>(PATH_TO_DEFINITIONS_FILE)</param-value>
<!--
if (PATH_TO_DEFINITIONS_FILE) is left as such, definitions are loaded from
/WEB-INF/classes/JobDefinitions.xml
-->
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
二、修改設置。
運行quartz/webapp 目錄下的 Ant 或Maven構建文件來構建這個 Web 程序,會得到一各為quartz.war的包,但在打包前我們應該修改其默認設置。默認下Quartz Web是被設置內存(非持久化) 存儲,如果要改為數據庫存諸則須修改quartz的設置文件quartz.properties,為其配置jdbc(需用到dbcp連接池,所以另需加入commons-dbcp和commons-pool包)數據源或JNDI數據。
下面為jobStore各種設置:
1、內存存儲:
org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
2、JDBC數據源(本例為oracle數據庫,不同的數據庫只要修改org.quartz.jobStore.driverDelegateClass的值為對應的數據庫即可):
org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
#org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.DB2v7Delegate
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered = false
org.quartz.dataSource.myDS.driver = oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@polarbear:1521:dev
org.quartz.dataSource.myDS.user = quartz
org.quartz.dataSource.myDS.password = quartz
org.quartz.dataSource.myDS.maxConnections = 5
3、JNDI數據源(本例為oracle數據庫,不同的數據庫只要修改org.quartz.jobStore.driverDelegateClass的值為對應的數據庫即可):
org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
#org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.DB2v7Delegate
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered = false
org.quartz.dataSource.myDS.jndiURL = java:comp/env/jdbc/JNDITEMP
Quartz Web程序通過插件的形式設置日志記錄和自動加載job配置文件,具體如下:
1、日志記錄插件:
org.quartz.plugin.triggHistory.class = org.quartz.plugins.history.LoggingJobHistoryPlugin
2、用插件org.quartz.plugins.xml.JobInitializationPlugin加載job配置文件,org.quartz.plugin.jobInitializer.fileNames指定了位于classpath下的job配置文件的名稱,這里配置了兩個插件,分別指定了三個job配置文件jobs.xml、jobs2.xml,jobs3.xml:
org.quartz.plugin.jobInitializer.class = org.quartz.plugins.xml.JobInitializationPlugin
# init plugin will load jobs.xml as a classpath resource i.e. /jobs.xml if not found on file system
org.quartz.plugin.jobInitializer.fileNames=jobs.xml
org.quartz.plugin.jobInitializer.overWriteExistingJobs = false
org.quartz.plugin.jobInitializer.failOnFileNotFound = false
org.quartz.plugin.jobInitializer.scanInterval = 30
# org.quartz.plugin.jobInitializer.wrapInUserTransaction = true
org.quartz.plugin.jobInitializerMultiple.class = org.quartz.plugins.xml.JobInitializationPlugin
# init plugin will load jobs.xml as a classpath resource i.e. /jobs.xml and jobs2.xml if not found on file system
org.quartz.plugin.jobInitializerMultiple.fileNames=jobs2.xml,jobs3.xml
org.quartz.plugin.jobInitializerMultiple.overWriteExistingJobs = false
org.quartz.plugin.jobInitializerMultiple.failOnFileNotFound = false
# org.quartz.plugin.jobInitializerMultiple.wrapInUserTransaction = true
Quartz Web程序通過JobDefinitions.xml來默認加載常用的job的定義,默認定義了三種quartz內置的job,分別為:
org.quartz.jobs.NativeJob
org.quartz.jobs.NoOpJob
org.quartz.jobs.ee.mail
下面是Quartz內置的的各種job:
Job 類 | Job 用法 |
org.quartz.jobs.FileScanJob | 檢查某個指定文件是否變化,并在文 件被改變時通知到相應監聽器的 Job |
org.quartz.jobs.FileScanListener | 在文件被修改后通知 FileScanJob 的監聽器 |
org.quartz.jobs.NativeJob | 用來執行本地程序(如 windows 下 .exe 文件) 的 Job |
org.quartz.jobs.NoOpJob | 什么也不做,但用來測試監聽器不是很有用的。 一些用戶甚至僅僅用它來導致一個監聽器的運行 |
org.quartz.jobs.ee.mail.SendMailJob | 使用 JavaMail API 發送 e-mail 的 Job |
org.quartz.jobs.ee.jmx.JMXInvokerJob | 調用 JMX bean 上的方法的 Job |
org.quartz.jobs.ee.ejb.EJBInvokerJob | 用來調用 EJB 上方法的 Job |
三、運行。將打包好的war包部署到服務上,訪問http://localhost:8080/quartz,然后用默認用戶名:quartz 密碼:quartz 登陸便可激忿進入系統。用戶名和密碼可在applicationContext.xml中修改,具體如下:
<bean id="authenticator" class="org.quartz.ui.web.security.SimpleAuthenticator">
<property name="username">
<value>quartz</value>
</property>
<property name="password">
<value>quartz</value>
</property>
</bean>
Quartz Web 程序的截屏
1、Quartz Web 程序主界面的左上方展示了它所擁有的特征列表

2、Scheduler 控制界面,允許你啟動、停止和暫停 Scheduler

四、與現有Web程序結合(我已結合過,可行)。
我們也可將Quartz web加入到現有的web程序中,具體做法為:
1、將Quartz web的所有jar包和設置文件和頁面文件copy至現有Web工程中。
2、合并各設置文件(主要是:web.xml、struts.xml和applicationContext.xml等)
3、修改Quartz web各程序的訪問的命名空間。
4、Quartz web并不完善,有好多明顯的錯誤,好多頁面有錯誤需要修改后才能通過gui成功配置各調度
posted on 2012-02-28 15:25
Ke 閱讀(6376)
評論(0) 編輯 收藏 所屬分類:
quartz