深刻解讀Quartz的原理

深刻解讀Quartz的原理
-----------------------------------------------
有些東西很久沒有用到,過一段時間重新過來翻一翻,記一記,上網看了這一篇不錯,故而轉載一下。                                          
-----------------------------------------------
Quartz是一個大名鼎鼎的Java版開源定時調度器,功能強悍,使用方便。
1、核心概念
Quartz的原理不是很複雜,只要搞明白幾個概念,而後知道如何去啓動和關閉一個調度程序便可。
 
一、Job
表示一個工做,要執行的具體內容。此接口中只有一個方法
void execute(JobExecutionContext context)
 
二、JobDetail
JobDetail表示一個具體的可執行的調度程序,Job是這個可執行程調度程序所要執行的內容,另外JobDetail還包含了這個任務調度的方案和策略。
 
三、Trigger表明一個調度參數的配置,何時去調。
 
四、Scheduler表明一個調度容器,一個調度容器中能夠註冊多個JobDetail和Trigger。當Trigger與JobDetail組合,就能夠被Scheduler容器調度了。
 
 
2、一個最簡單入門實例
 
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) { 
                 //一、建立JobDetial對象 
                JobDetail jobDetail =  new JobDetail(); 
                 //設置工做項 
                jobDetail.setJobClass(MyJob. class); 
                jobDetail.setName( "MyJob_1"); 
                jobDetail.setGroup( "JobGroup_1"); 

                 //二、建立Trigger對象 
                SimpleTrigger strigger =  new SimpleTrigger(); 
                strigger.setName( "Trigger_1"); 
                strigger.setGroup( "Trigger_Group_1"); 
                strigger.setStartTime( new Date()); 
                 //設置重複中止時間,並銷燬該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"); 
                 //設置重複間隔時間 
                strigger.setRepeatInterval(1000 * 1L); 
                 //設置重複執行次數 
                strigger.setRepeatCount(3); 

                 //三、建立Scheduler對象,並配置JobDetail和Trigger對象 
                SchedulerFactory sf =  new StdSchedulerFactory(); 
                Scheduler scheduler =  null
                 try { 
                        scheduler = sf.getScheduler(); 
                        scheduler.scheduleJob(jobDetail, strigger); 
                         //四、並執行啓動、關閉等操做 
                        scheduler.start(); 

                }  catch (SchedulerException e) { 
                        e.printStackTrace(); 
                } 
//                try { 
//                        //關閉調度器 
//                        scheduler.shutdown(true); 
//                } catch (SchedulerException e) { 
//                        e.printStackTrace(); 
//                } 
        } 
}
 
執行結果:
 
當把結束時間改成:
                 //設置重複中止時間,並銷燬該Trigger對象 
                java.util.Calendar c = java.util.Calendar.getInstance(); 
                c.setTimeInMillis(System.currentTimeMillis() + 1000 * 1L); 
                strigger.setEndTime(c.getTime());
 
執行結果:
 
當添加一條關閉調度器的語句:
                         //四、並執行啓動、關閉等操做 
                        scheduler.start(); 
                        scheduler.shutdown( true); 
 
程序執行結果:
Thu Jul 23 10:11:50 CST 2009: doing something... 

Process finished with exit code 0
僅僅執行了一次,這一次能執行完,緣由是設定了scheduler.shutdown(true);true表示等待本次任務執行完成後中止。
 
從這裏也能夠看出,scheduler是個容器,scheduler控制jobDetail的執行,控制的策略是經過trigger。
 
當scheduler容器啓動後,jobDetail才能根據關聯的trigger策略去執行。當scheduler容器關閉後,全部的jobDetail都中止執行。
 
3、透過實例看原理
 
經過研讀Quartz的源代碼,和本實例,終於悟出了Quartz的工做原理。
 
一、scheduler是一個計劃調度器容器(總部),容器裏面能夠盛放衆多的JobDetail和trigger,當容器啓動後,裏面的每一個JobDetail都會根據trigger循序漸進自動去執行。
 
二、JobDetail是一個可執行的工做,它自己多是有狀態的。
 
三、Trigger表明一個調度參數的配置,何時去調。
 
四、當JobDetail和Trigger在scheduler容器上註冊後,造成了裝配好的做業(JobDetail和Trigger所組成的一對兒),就能夠伴隨容器啓動而調度執行了。
 
五、scheduler是個容器,容器中有一個線程池,用來並行調度執行每一個做業,這樣能夠提升容器效率。
 
六、將上述的結構用一個圖來表示,以下:
 
 
4、總結
 
一、搞清楚了上Quartz容器執行做業的的原理和過程,以及做業造成的方式,做業註冊到容器的方法。就認識明白了Quartz的核心原理。
 
二、Quartz雖然很龐大,可是一切都圍繞這個核心轉,爲了配置強大時間調度策略,能夠研究專門的CronTrigger。要想靈活配置做業和容器屬性,能夠經過Quartz的properties文件或者XML來實現。
 
三、要想調度更多的持久化、結構化做業,能夠經過數據庫讀取做業,而後放到容器中執行。
 
四、全部的一切都圍繞這個核心原理轉,搞明白這個了,再去研究更高級用法就容易多了。
 
五、Quartz與Spring的整合也很是簡單,Spring提供一組Bean來支持:MethodInvokingJobDetailFactoryBean、SimpleTriggerBean、SchedulerFactoryBean,看看裏面須要注入什麼屬性便可明白了。Spring會在Spring容器啓動時候,啓動Quartz容器。
 
六、Quartz容器的關閉方式也很簡單,若是是Spring整合,則有兩種方法,一種是關閉Spring容器,一種是獲取到SchedulerFactoryBean實例,而後調用一個shutdown就搞定了。若是是Quartz獨立使用,則直接調用scheduler.shutdown(true);
 
七、Quartz的JobDetail、Trigger均可以在運行時從新設置,而且在下次調用時候起做用。這就爲動態做業的實現提供了依據。你能夠將調度時間策略存放到數據庫,而後經過數據庫數據來設定Trigger,這樣就能產生動態的調度。

轉載地址:http://lavasoft.blog.51cto.com/62575/181907/
相關文章
相關標籤/搜索