一、常用接口:
1、Job接口:該接口只有一個方法
void execute(JobExecutionContext context)
開發者實現該接口定義需要執行的任務。JobExecutionContext類提供調度上下文的各種信息
2、JobDetail:用于描敘Job實現類及其他的一些靜態信息
3、Trigger:描敘觸發Job執行的時間觸發規則
4、Calendar:定義了一個關聯Trigger可能(或者不可能)觸發的時間空間。它沒有定義觸發的真實時間,而是用在在普通的Schedule需要限制Trigger觸發的時候。大部分Calendar包含默認所有的時間,并且用戶去排除部分時間。
5、Scheduler:運行容器,使用SchedulerFactory創建Scheduler實例
二、代碼示例:
1、使用Quartz,需要實現Job接口;
public class TestJob implements Job { public void execute(JobExecutionContext context) throws JobExecutionException { System.out.println("Hello World! - " + new Date()); //do more... }}2、調度【比較簡單,直接看代碼就可以了】
public class quartzTest { public static void main(String args[]) throws SchedulerException, ParseException { JobDetail jobDetail= JobBuilder.newJob(TestJob.class) .withIdentity("testJob_1","group_1") .build(); Trigger trigger= TriggerBuilder .newTrigger() .withIdentity("trigger_1","group_1") .startNow() .withSchedule(SimpleScheduleBuilder.simpleSchedule() .withIntervalInSeconds(10) //時間間隔 .withRepeatCount(5) //重復次數(將執行6次) ) .build(); SchedulerFactory sf = new StdSchedulerFactory(); Scheduler sched = sf.getScheduler(); sched.scheduleJob(jobDetail,trigger); sched.start(); }}這里使用的是2.2.1版本,參考官方文檔的示例。看到一些參考書使用的版本比較老,所以會有一些出入,很多方法都被棄用了,所以還是直接看文檔比較實在,Quartz的官方網站地址是:http://www.quartz-scheduler.org/
三、Quartz2.2.1配置文件示例
# Default Properties file for use by StdSchedulerFactory# to create a Quartz Scheduler Instance, if a different# properties file is not explicitly specified.# #集群配置org.quartz.scheduler.instanceName: DefaultQuartzSchedulerorg.quartz.scheduler.rmi.export: falseorg.quartz.scheduler.rmi.proxy: falseorg.quartz.scheduler.wrapJobExecutionInUserTransaction: false org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPoolorg.quartz.threadPool.threadCount: 10org.quartz.threadPool.threadPriority: 5org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread: true org.quartz.jobStore.misfireThreshold: 60000 #============================================================================# Configure JobStore#============================================================================ #默認配置,數據保存到內存#org.quartz.jobStore.class: org.quartz.simpl.RAMJobStore#持久化配置org.quartz.jobStore.class:org.quartz.impl.jdbcjobstore.JobStoreTXorg.quartz.jobStore.driverDelegateClass:org.quartz.impl.jdbcjobstore.StdJDBCDelegateorg.quartz.jobStore.useProperties:true#數據庫表前綴org.quartz.jobStore.tablePrefix:qrtz_org.quartz.jobStore.dataSource:qzDS #============================================================================# Configure Datasources#============================================================================#JDBC驅動org.quartz.dataSource.qzDS.driver:com.mysql.jdbc.Driverorg.quartz.dataSource.qzDS.URL:jdbc:mysql://localhost:3306/quartzdborg.quartz.dataSource.qzDS.user:rootorg.quartz.dataSource.qzDS.password:123456org.quartz.dataSource.qzDS.maxConnection:10
四、數據庫相關
持久化須事先在相應數據庫創建Quartz的數據表,在Quartz發布包里面的docs/dbTables有對應不同數據庫的SQL腳本
例如,這里使用的是MYSQL:

數據表字段解釋:
新聞熱點
疑難解答