一、核心概念
Quartz的原理不是很復(fù)雜,只要搞明白幾個(gè)概念,然后知道如何去啟動(dòng)和關(guān)閉一個(gè)調(diào)度程序即可。
1、Job
表示一個(gè)工作,要執(zhí)行的具體內(nèi)容。此接口中只有一個(gè)方法
void execute(JobExecutionContext context)
2、JobDetail
JobDetail表示一個(gè)具體的可執(zhí)行的調(diào)度程序,Job是這個(gè)可執(zhí)行程調(diào)度程序所要執(zhí)行的內(nèi)容,另外JobDetail還包含了這個(gè)任務(wù)調(diào)度的方案和策略。
3、Trigger代表一個(gè)調(diào)度參數(shù)的配置,什么時(shí)候去調(diào)。
4、Scheduler代表一個(gè)調(diào)度容器,一個(gè)調(diào)度容器中可以注冊(cè)多個(gè)JobDetail和Trigger。當(dāng)Trigger與JobDetail組合,就可以被Scheduler容器調(diào)度了。
二、一個(gè)最簡(jiǎn)單入門(mén)實(shí)例
import java.util.Date;
/**
* quartz定時(shí)器測(cè)試
*
* @author leizhimin 2009-7-23 8:49:01
*/
public class MyJob implements Job {
public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
System.out.println(new Date() + ": doing something...");
}
}
class Test {
public static void main(String[] args) {
//1、創(chuàng)建JobDetial對(duì)象
JobDetail jobDetail = new JobDetail();
//設(shè)置工作項(xiàng)
jobDetail.setJobClass(MyJob.class);
jobDetail.setName("MyJob_1");
jobDetail.setGroup("JobGroup_1");
//2、創(chuàng)建Trigger對(duì)象
SimpleTrigger strigger = new SimpleTrigger();
strigger.setName("Trigger_1");
strigger.setGroup("Trigger_Group_1");
strigger.setStartTime(new Date());
//設(shè)置重復(fù)停止時(shí)間,并銷(xiāo)毀該Trigger對(duì)象
java.util.Calendar c = java.util.Calendar.getInstance();
c.setTimeInMillis(System.currentTimeMillis() + 1000 * 1L);
strigger.setEndTime(c.getTime());
strigger.setFireInstanceId("Trigger_1_id_001");
//設(shè)置重復(fù)間隔時(shí)間
strigger.setRepeatInterval(1000 * 1L);
//設(shè)置重復(fù)執(zhí)行次數(shù)
strigger.setRepeatCount(3);
//3、創(chuàng)建Scheduler對(duì)象,并配置JobDetail和Trigger對(duì)象
SchedulerFactory sf = new StdSchedulerFactory();
Scheduler scheduler = null;
try {
scheduler = sf.getScheduler();
scheduler.scheduleJob(jobDetail, strigger);
//4、并執(zhí)行啟動(dòng)、關(guān)閉等操作
scheduler.start();
} catch (SchedulerException e) {
e.printStackTrace();
}
// try {
// //關(guān)閉調(diào)度器
// scheduler.shutdown(true);
// } catch (SchedulerException e) {
// e.printStackTrace();
// }
}
}
執(zhí)行結(jié)果:
當(dāng)把結(jié)束時(shí)間改為:
執(zhí)行結(jié)果:
當(dāng)添加一條關(guān)閉調(diào)度器的語(yǔ)句:
//4、并執(zhí)行啟動(dòng)、關(guān)閉等操作
scheduler.start();
scheduler.shutdown(true);
程序執(zhí)行結(jié)果:
Thu Jul 23 10:11:50 CST 2009: doing something...
Process finished with exit code 0
僅僅執(zhí)行了一次,這一次能執(zhí)行完,原因是設(shè)定了scheduler.shutdown(true);true表示等待本次任務(wù)執(zhí)行完成后停止。
從這里也可以看出,scheduler是個(gè)容器,scheduler控制jobDetail的執(zhí)行,控制的策略是通過(guò)trigger。
當(dāng)scheduler容器啟動(dòng)后,jobDetail才能根據(jù)關(guān)聯(lián)的trigger策略去執(zhí)行。當(dāng)scheduler容器關(guān)閉后,所有的jobDetail都停止執(zhí)行。
三、透過(guò)實(shí)例看原理
通過(guò)研讀Quartz的源代碼,和本實(shí)例,終于悟出了Quartz的工作原理。
1、scheduler是一個(gè)計(jì)劃調(diào)度器容器(總部),容器里面可以盛放眾多的JobDetail和trigger,當(dāng)容器啟動(dòng)后,里面的每個(gè)JobDetail都會(huì)根據(jù)trigger按部就班自動(dòng)去執(zhí)行。
2、JobDetail是一個(gè)可執(zhí)行的工作,它本身可能是有狀態(tài)的。
3、Trigger代表一個(gè)調(diào)度參數(shù)的配置,什么時(shí)候去調(diào)。
4、當(dāng)JobDetail和Trigger在scheduler容器上注冊(cè)后,形成了裝配好的作業(yè)(JobDetail和Trigger所組成的一對(duì)兒),就可以伴隨容器啟動(dòng)而調(diào)度執(zhí)行了。
5、scheduler是個(gè)容器,容器中有一個(gè)線程池,用來(lái)并行調(diào)度執(zhí)行每個(gè)作業(yè),這樣可以提高容器效率。
6、將上述的結(jié)構(gòu)用一個(gè)圖來(lái)表示,如下:
四、總結(jié)
1、搞清楚了上Quartz容器執(zhí)行作業(yè)的的原理和過(guò)程,以及作業(yè)形成的方式,作業(yè)注冊(cè)到容器的方法。就認(rèn)識(shí)明白了Quartz的核心原理。
2、Quartz雖然很龐大,但是一切都圍繞這個(gè)核心轉(zhuǎn),為了配置強(qiáng)大時(shí)間調(diào)度策略,可以研究專(zhuān)門(mén)的CronTrigger。要想靈活配置作業(yè)和容器屬性,可以通過(guò)Quartz的properties文件或者XML來(lái)實(shí)現(xiàn)。
3、要想調(diào)度更多的持久化、結(jié)構(gòu)化作業(yè),可以通過(guò)數(shù)據(jù)庫(kù)讀取作業(yè),然后放到容器中執(zhí)行。
4、所有的一切都圍繞這個(gè)核心原理轉(zhuǎn),搞明白這個(gè)了,再去研究更高級(jí)用法就容易多了。
5、Quartz與Spring的整合也非常簡(jiǎn)單,Spring提供一組Bean來(lái)支持:MethodInvokingJobDetailFactoryBean、SimpleTriggerBean、SchedulerFactoryBean,看看里面需要注入什么屬性即可明白了。Spring會(huì)在Spring容器啟動(dòng)時(shí)候,啟動(dòng)Quartz容器。
6、Quartz容器的關(guān)閉方式也很簡(jiǎn)單,如果是Spring整合,則有兩種方法,一種是關(guān)閉Spring容器,一種是獲取到SchedulerFactoryBean實(shí)例,然后調(diào)用一個(gè)shutdown就搞定了。如果是Quartz獨(dú)立使用,則直接調(diào)用scheduler.shutdown(true);
7、Quartz的JobDetail、Trigger都可以在運(yùn)行時(shí)重新設(shè)置,并且在下次調(diào)用時(shí)候起作用。這就為動(dòng)態(tài)作業(yè)的實(shí)現(xiàn)提供了依據(jù)。你可以將調(diào)度時(shí)間策略存放到數(shù)據(jù)庫(kù),然后通過(guò)數(shù)據(jù)庫(kù)數(shù)據(jù)來(lái)設(shè)定Trigger,這樣就能產(chǎn)生動(dòng)態(tài)的調(diào)度。
新聞熱點(diǎn)
疑難解答
圖片精選