国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

實(shí)現(xiàn)quartz定時(shí)器及quartz定時(shí)器原理介紹

2019-11-26 15:51:25
字體:
供稿:網(wǎng)友

一、核心概念
 
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)度容器中可以注冊多個(gè)JobDetail和Trigger。當(dāng)Trigger與JobDetail組合,就可以被Scheduler容器調(diào)度了。

二、一個(gè)最簡單入門實(shí)例

復(fù)制代碼 代碼如下:

import org.quartz.*;
import org.quartz.impl.StdSchedulerFactory;

import java.util.Date;

/**
* quartz定時(shí)器測試
*
* @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對象
                JobDetail jobDetail = new JobDetail();
                //設(shè)置工作項(xiàng)
                jobDetail.setJobClass(MyJob.class);
                jobDetail.setName("MyJob_1");
                jobDetail.setGroup("JobGroup_1");

                //2、創(chuàng)建Trigger對象
                SimpleTrigger strigger = new SimpleTrigger();
                strigger.setName("Trigger_1");
                strigger.setGroup("Trigger_Group_1");
                strigger.setStartTime(new Date());
                //設(shè)置重復(fù)停止時(shí)間,并銷毀該Trigger對象
                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對象,并配置JobDetail和Trigger對象
                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í)間改為:

復(fù)制代碼 代碼如下:

//設(shè)置重復(fù)停止時(shí)間,并銷毀該Trigger對象
java.util.Calendar c = java.util.Calendar.getInstance();
c.setTimeInMillis(System.currentTimeMillis() + 1000 * 1L);
strigger.setEndTime(c.getTime());

執(zhí)行結(jié)果:

當(dāng)添加一條關(guān)閉調(diào)度器的語句:
//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í)行,控制的策略是通過trigger。

當(dāng)scheduler容器啟動(dòng)后,jobDetail才能根據(jù)關(guān)聯(lián)的trigger策略去執(zhí)行。當(dāng)scheduler容器關(guān)閉后,所有的jobDetail都停止執(zhí)行。

三、透過實(shí)例看原理

通過研讀Quartz的源代碼,和本實(shí)例,終于悟出了Quartz的工作原理。

1、scheduler是一個(gè)計(jì)劃調(diào)度器容器(總部),容器里面可以盛放眾多的JobDetail和trigger,當(dāng)容器啟動(dòng)后,里面的每個(gè)JobDetail都會根據(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容器上注冊后,形成了裝配好的作業(yè)(JobDetail和Trigger所組成的一對兒),就可以伴隨容器啟動(dòng)而調(diào)度執(zhí)行了。

5、scheduler是個(gè)容器,容器中有一個(gè)線程池,用來并行調(diào)度執(zhí)行每個(gè)作業(yè),這樣可以提高容器效率。

6、將上述的結(jié)構(gòu)用一個(gè)圖來表示,如下:
 


四、總結(jié)

1、搞清楚了上Quartz容器執(zhí)行作業(yè)的的原理和過程,以及作業(yè)形成的方式,作業(yè)注冊到容器的方法。就認(rèn)識明白了Quartz的核心原理。

2、Quartz雖然很龐大,但是一切都圍繞這個(gè)核心轉(zhuǎn),為了配置強(qiáng)大時(shí)間調(diào)度策略,可以研究專門的CronTrigger。要想靈活配置作業(yè)和容器屬性,可以通過Quartz的properties文件或者XML來實(shí)現(xiàn)。

3、要想調(diào)度更多的持久化、結(jié)構(gòu)化作業(yè),可以通過數(shù)據(jù)庫讀取作業(yè),然后放到容器中執(zhí)行。

4、所有的一切都圍繞這個(gè)核心原理轉(zhuǎn),搞明白這個(gè)了,再去研究更高級用法就容易多了。

5、Quartz與Spring的整合也非常簡單,Spring提供一組Bean來支持:MethodInvokingJobDetailFactoryBean、SimpleTriggerBean、SchedulerFactoryBean,看看里面需要注入什么屬性即可明白了。Spring會在Spring容器啟動(dòng)時(shí)候,啟動(dòng)Quartz容器。

6、Quartz容器的關(guā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ù)庫,然后通過數(shù)據(jù)庫數(shù)據(jù)來設(shè)定Trigger,這樣就能產(chǎn)生動(dòng)態(tài)的調(diào)度。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 星座| 迭部县| 永靖县| 肃宁县| 成安县| 自贡市| 富宁县| 大英县| 甘孜| 平乡县| 郓城县| 阿拉善左旗| 广宁县| 甘德县| 塔城市| 西吉县| 古蔺县| 阳山县| 宁波市| 金湖县| 沙雅县| 晋江市| 海淀区| 湛江市| 文成县| 竹山县| 罗平县| 岳西县| 农安县| 若尔盖县| 白河县| 高邮市| 陵川县| 宝应县| 富蕴县| 吴江市| 连平县| 自贡市| 黄平县| 会东县| 元江|