乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      深入解讀Quartz的原理

       LibraryPKU 2013-02-24
      Quartz是一個大名鼎鼎的Java版開源定時調(diào)度器,功能強(qiáng)悍,使用方便。
       
      一、核心概念
       
      Quartz的原理不是很復(fù)雜,只要搞明白幾個概念,然后知道如何去啟動和關(guān)閉一個調(diào)度程序即可。
       
      1、Job
      表示一個工作,要執(zhí)行的具體內(nèi)容。此接口中只有一個方法
      void execute(JobExecutionContext context)
       
      2、JobDetail
      JobDetail表示一個具體的可執(zhí)行的調(diào)度程序,Job是這個可執(zhí)行程調(diào)度程序所要執(zhí)行的內(nèi)容,另外JobDetail還包含了這個任務(wù)調(diào)度的方案和策略。
       
      3、Trigger代表一個調(diào)度參數(shù)的配置,什么時候去調(diào)。
       
      4、Scheduler代表一個調(diào)度容器,一個調(diào)度容器中可以注冊多個JobDetail和Trigger。當(dāng)Trigger與JobDetail組合,就可以被Scheduler容器調(diào)度了。
       
       
      二、一個最簡單入門實例
       
      import org.quartz.*;
      import org.quartz.impl.StdSchedulerFactory;

      import java.util.Date;

      /**
      * quartz定時器測試
      *
      * @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è)置工作項
                      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ù)停止時間,并銷毀該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ù)間隔時間
                      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í)行啟動、關(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ù)停止時間,并銷毀該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í)行啟動、關(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是個容器,scheduler控制jobDetail的執(zhí)行,控制的策略是通過trigger。
       
      當(dāng)scheduler容器啟動后,jobDetail才能根據(jù)關(guān)聯(lián)的trigger策略去執(zhí)行。當(dāng)scheduler容器關(guān)閉后,所有的jobDetail都停止執(zhí)行。
       
      三、透過實例看原理
       
      通過研讀Quartz的源代碼,和本實例,終于悟出了Quartz的工作原理。
       
      1、scheduler是一個計劃調(diào)度器容器(總部),容器里面可以盛放眾多的JobDetail和trigger,當(dāng)容器啟動后,里面的每個JobDetail都會根據(jù)trigger按部就班自動去執(zhí)行。
       
      2、JobDetail是一個可執(zhí)行的工作,它本身可能是有狀態(tài)的。
       
      3、Trigger代表一個調(diào)度參數(shù)的配置,什么時候去調(diào)。
       
      4、當(dāng)JobDetail和Trigger在scheduler容器上注冊后,形成了裝配好的作業(yè)(JobDetail和Trigger所組成的一對兒),就可以伴隨容器啟動而調(diào)度執(zhí)行了。
       
      5、scheduler是個容器,容器中有一個線程池,用來并行調(diào)度執(zhí)行每個作業(yè),這樣可以提高容器效率。
       
      6、將上述的結(jié)構(gòu)用一個圖來表示,如下:
       
       
      四、總結(jié)
       
      1、搞清楚了上Quartz容器執(zhí)行作業(yè)的的原理和過程,以及作業(yè)形成的方式,作業(yè)注冊到容器的方法。就認(rèn)識明白了Quartz的核心原理。
       
      2、Quartz雖然很龐大,但是一切都圍繞這個核心轉(zhuǎn),為了配置強(qiáng)大時間調(diào)度策略,可以研究專門的CronTrigger。要想靈活配置作業(yè)和容器屬性,可以通過Quartz的properties文件或者XML來實現(xiàn)。
       
      3、要想調(diào)度更多的持久化、結(jié)構(gòu)化作業(yè),可以通過數(shù)據(jù)庫讀取作業(yè),然后放到容器中執(zhí)行。
       
      4、所有的一切都圍繞這個核心原理轉(zhuǎn),搞明白這個了,再去研究更高級用法就容易多了。
       
      5、Quartz與Spring的整合也非常簡單,Spring提供一組Bean來支 持:MethodInvokingJobDetailFactoryBean、SimpleTriggerBean、 SchedulerFactoryBean,看看里面需要注入什么屬性即可明白了。Spring會在Spring容器啟動時候,啟動Quartz容器。
       
      6、Quartz容器的關(guān)閉方式也很簡單,如果是Spring整合,則有兩種方法,一種是關(guān)閉Spring容器,一種是獲取到 SchedulerFactoryBean實例,然后調(diào)用一個shutdown就搞定了。如果是Quartz獨立使用,則直接調(diào)用 scheduler.shutdown(true);
       
      7、Quartz的JobDetail、Trigger都可以在運行時重新設(shè)置,并且在下次調(diào)用時候起作用。這就為動態(tài)作業(yè)的實現(xiàn)提供了依據(jù)。你可以將調(diào)度時間策略存放到數(shù)據(jù)庫,然后通過數(shù)據(jù)庫數(shù)據(jù)來設(shè)定Trigger,這樣就能產(chǎn)生動態(tài)的調(diào)度。

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多