網上能找到的QuartzWeb管理的資料都是使用的一個國外人寫的Quartz WebApp的東東。功能也非常全面。
可是作為自己的應用其有用不了那么多功能,一般我們僅僅要能夠定義一個job,指定一個Cron表達式完畢工作就可以,附帶的能夠再對任務進行暫停與重新啟動,基本就能夠滿足應用了。並且網上那個東西略微還是有點復雜的,不方便集成的自己的項目中。不管是風格還是樣式。
基於這種原因。也是為了學習一個Quartz(曾經還沒實用到過)。
就想着做一個簡單Quartz的Web管理工具。包含能夠加入一個任務(加入的任務僅僅能是實現了Quartz Job接口的任務),暫停、啟動、刪除任務。
基本這些都能滿足日常應用了。
列表界面:

加入任務界面

暫停、重新啟動沒有界面。
事實上要求不太復雜時以上功能完畢能滿足應用了。
假設要改動一個任務的時間刪除重建就能夠了。
實現這些功能僅僅有簡單的兩個JSP、兩個Servlet、兩個輔助類而已。集成的自己的項目中時非常easy改動。
這個功能是要求使用Quartz本地化存儲的JobStoreTX方式的。而不是RAMJobStore。
與自己的項目集成時,可能要改動的點包含下面幾個方面。1、 TaskListServlet中使用了項目中本身的數據源,須要依據實際情況改動。TaskOprateServlet中主要是為了完畢相關操作,不涉及數據庫。調用的都是Quartz的API。
須要有須要,全然能夠將這兩個JSP中的內容遷移到自己項目中的Action或Controller下。
2、 相關JSP中引入的JS文件路徑須要改動。也可能須要改動你訪問后台資源的路徑URL。
3、 由於要將Quartz的Job信息存儲到數據庫中,所以我們要使用Quartz的JobStoreTX。這些須要配置的東西都是在quartz.properties中,我的這個文件內容例如以下:
#===============================================================
#Configure Main Scheduler Properties
#===============================================================
org.quartz.scheduler.instanceName=QuartzScheduler
org.quartz.scheduler.instanceId=AUTO
#===============================================================
#Configure ThreadPool
#===============================================================
org.quartz.threadPool.threadCount =5
org.quartz.threadPool.threadPriority =5
org.quartz.threadPool.class=org.quartz.simpl.SimpleThreadPool
#===============================================================
#Configure JobStore
#===============================================================
org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass =org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
org.quartz.jobStore.tablePrefix = QRTZ_
#============================================================================
# Configure Datasources
#============================================================================
org.quartz.jobStore.dataSource = myDS
org.quartz.dataSource.myDS.driver =oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@localhost:1521:orcl
org.quartz.dataSource.myDS.user = loushang_test
org.quartz.dataSource.myDS.password = loushang_test
org.quartz.dataSource.myDS.maxConnections = 5
#===============================================================
#Configure Plugins only config JobInitializationPlugin but read quartz_jobs.xml file
#===============================================================
org.quartz.plugin.jobInitializer.class=org.quartz.plugins.xml.JobInitializationPlugin
org.quartz.plugin.jobInitializer.overWriteExistingJobs=true
org.quartz.plugin.jobInitializer.failOnFileNotFound=true
org.quartz.plugin.jobInitializer.validating=false
4、 JobTools類中QUARTZ_INSTANCE_NAME配置的是quartz.properties配置文件里的instanceName的值。
事實上配置不配置都能夠。但還是建議配置。
基本上就這么多了。總之是相當簡單。在這個應用中是要求將全部的job與trigger都使用同一個DEFAULT組。
后台的代碼基本上簡單的不能再簡單了。以加入任務為例。代碼例如以下:
String jobName = req.getParameter("jobName");
String jobGroup = req.getParameter("jobGroup");
String triggerName = req.getParameter("triggerName");
String triggerGroup = req.getParameter("triggerGroup");
String JobClassName = req.getParameter("JobClassName");
String jobDescription = req.getParameter("jobDescription");
String cronExpression = req.getParameter("cronExpression");
String startTime = req.getParameter("startTime");
String endTime = req.getParameter("endTime");
CronTrigger ct = new CronTrigger(triggerName.trim(),triggerGroup,cronExpression);
if(startTime!=null && !"".equals(startTime)){
Date date = JobTools.paraseToDate(startTime);
ct.setStartTime(date);
}
if(endTime!=null && !"".equals(endTime)){
Date date = JobTools.paraseToDate(endTime);
ct.setEndTime(date);
}
Class clz = Class.forName(JobClassName.trim());
JobDetail jd = new JobDetail(jobName.trim(),jobGroup,clz);
jd.setDescription(jobDescription.trim());
Scheduler scheduler = JobTools.getScheduler();
scheduler.scheduleJob(jd, ct);
能夠從下面位置下載案例代碼
http://download.csdn.net/detail/srar_hanshui/8867063
