Quartz任務(wù)調(diào)度詳細(xì)教程_第1頁(yè)
Quartz任務(wù)調(diào)度詳細(xì)教程_第2頁(yè)
Quartz任務(wù)調(diào)度詳細(xì)教程_第3頁(yè)
Quartz任務(wù)調(diào)度詳細(xì)教程_第4頁(yè)
Quartz任務(wù)調(diào)度詳細(xì)教程_第5頁(yè)
已閱讀5頁(yè),還剩16頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、Quartz任務(wù)調(diào)度快速入門1概述各種企業(yè)應(yīng)用幾乎都會(huì)碰到任務(wù)調(diào)度的需求,就拿論壇來(lái)說(shuō):每隔半個(gè)小時(shí)生成精華文章的文件,每天凌晨統(tǒng)計(jì)論壇用戶的積分排名,每隔分鐘執(zhí)行鎖定用戶解鎖任務(wù)。對(duì)于一個(gè)典型的系統(tǒng)來(lái)說(shuō),在每月號(hào)凌晨統(tǒng)計(jì)上個(gè)月各部門的業(yè)務(wù)數(shù)據(jù)生成月報(bào)表,每半個(gè)小時(shí)查詢用戶是否已經(jīng)有快到期的待處理業(yè)務(wù),這樣的例子俯拾皆是,不勝枚舉。任務(wù)調(diào)度本身涉及到多線程并發(fā)、運(yùn)行時(shí)間規(guī)則制定和解析、場(chǎng)景保持與恢復(fù)、線程池維護(hù)等諸多方面的工作。如果直接使用自定義線程這種刀耕火種的原始辦法,開發(fā)任務(wù)調(diào)度程序是一項(xiàng)頗具挑戰(zhàn)性的工作。Ja訴源的好處就是:領(lǐng)域問(wèn)題都能找到現(xiàn)成的解決方案。e所提供的a自年發(fā)布版本以來(lái)已

2、經(jīng)被眾多項(xiàng)目作為任務(wù)調(diào)度的解決方案,a在提供巨大靈活性的同時(shí)并未犧牲其簡(jiǎn)單性,它所提供的強(qiáng)大功能使你可以應(yīng)付絕大多數(shù)的調(diào)度需求。a在開源任務(wù)調(diào)度框架中的翹首,它提供了強(qiáng)大任務(wù)調(diào)度機(jī)制,難能可貴的是它同時(shí)保持了使用的簡(jiǎn)單性。a允許開發(fā)人員靈活地定義觸發(fā)器的調(diào)度時(shí)間表,并可以對(duì)觸發(fā)器和任務(wù)進(jìn)行關(guān)聯(lián)映射。此外,a提供了調(diào)度運(yùn)行環(huán)境的持久化機(jī)制,可以保存并恢復(fù)調(diào)度現(xiàn)場(chǎng),即使系統(tǒng)因故障關(guān)閉,任務(wù)調(diào)度現(xiàn)場(chǎng)數(shù)據(jù)并不會(huì)丟失。此外,a還提供了組件式的偵聽器、各種插件、線程池等功能。了解a體系結(jié)構(gòu)a對(duì)任務(wù)調(diào)度的領(lǐng)域問(wèn)題進(jìn)行了高度的抽象,提出了調(diào)度器、任務(wù)和觸發(fā)器這個(gè)核心的概念,并在o通過(guò)接口和類對(duì)重要的這些核心概

3、念進(jìn)行描述:Job:是一個(gè)接口,只有一個(gè)方法oieeteJobetiootetote,t開發(fā)者實(shí)現(xiàn)該接口定義運(yùn)行任務(wù),Jobetioc類提供了調(diào)度上下文的各種信息。Job運(yùn)行時(shí)的信息保存在JobDataa實(shí)例中;JobDetail:a在每次執(zhí)行Job時(shí),都重新創(chuàng)建一個(gè)Job實(shí)例,所以它不直接接受一個(gè)Job的實(shí)例,相反它接收一個(gè)Job實(shí)現(xiàn)類,以便運(yùn)行時(shí)通過(guò)eta的反射機(jī)制實(shí)例化Job。因此需要通過(guò)一個(gè)類來(lái)描述Job的實(shí)現(xiàn)類及其它相關(guān)的靜態(tài)信息,如Job名字、描述、關(guān)聯(lián)監(jiān)聽器等信息,JobDetail承擔(dān)了這一角色。ring通過(guò)該類的構(gòu)造函數(shù)可以更具體地了解它的功用:OeailaalangSnae

4、aalangSringgrouaalang,該構(gòu)造函數(shù)要Cla求指定o的實(shí)現(xiàn)類,以及任務(wù)在Scheduler中的組名和o名稱;Trigger:是一個(gè)類,描述觸發(fā)o執(zhí)行的時(shí)間觸發(fā)規(guī)則。主要有SileTrigger和CronTrigger這兩個(gè)子類。當(dāng)僅需觸發(fā)一次或者以固定時(shí)間間隔周期執(zhí)行,SileTrigge是最適合的選擇;而CronTrigger則可以通過(guò)Cron表達(dá)式定義出各種復(fù)雜時(shí)間規(guī)則的調(diào)度方案:如每早晨執(zhí)行,周一、周三、周五下午執(zhí)行等;Calendar:orguarCale和daraauilCale不同b它是一些日歷特定時(shí)間點(diǎn)的集合(可以簡(jiǎn)單地將orguarCale看低aauilCal

5、e的集合aauilCale代表一個(gè)日歷時(shí)間點(diǎn),無(wú)特殊說(shuō)明后面的Calendar即指orguarCalendar個(gè)Trigger可以和多個(gè)Calendar關(guān)聯(lián),以便排除或包含某些時(shí)間點(diǎn)。假設(shè),我們安排每周星期一早上10:執(zhí)0行0任務(wù),但是如果碰到法定的節(jié)日,任務(wù)則不執(zhí)行,這時(shí)就需要在Trigger觸發(fā)機(jī)制的基礎(chǔ)上使用Calendar進(jìn)行定點(diǎn)排除。針對(duì)不同時(shí)間段類型,uar在orguaril(包下提a供了若干個(gè)Calendar的實(shí)現(xiàn)類,如nnualCalendaronhlCalendareelCalendMU針對(duì)每年、每月和每周進(jìn)行定義;Scheduler:代表一個(gè)uar的獨(dú)立運(yùn)行容器,Trigg

6、er和oe可以注冊(cè)到Scheduler中,兩者在Scheduler中擁有各自的組及名稱,組及名稱是Scheduler查找定位容器中某一對(duì)象的依據(jù),Trigger的組及名稱必須唯一,oe的組和名稱也必須唯一(但可以和Trigger的組和名稱相同,因?yàn)樗鼈兪遣煌愋偷模cheduler定義了多個(gè)接口方法,允許外部通過(guò)組及名稱訪問(wèn)和控制容器中Trigger和oe。ilScheduler可以將Trigger綁定到某一oe中,l這樣當(dāng)Trigger觸發(fā)時(shí),對(duì)應(yīng)的o就被執(zhí)行。一個(gè)o可以對(duì)應(yīng)多個(gè)Trigger,但一個(gè)Trigger只能對(duì)應(yīng)一個(gè)o??梢酝ㄟ^(guò)Scheduleracor創(chuàng)建一個(gè)Schedule

7、r實(shí)例。Scheduler擁有一個(gè)SchedulerCone,它類似于SerleCone保存著Scheduler上下文信息,o和Trigger都可以訪問(wèn)SchedulerCone內(nèi)的信息。SchedulerCone內(nèi)部通過(guò)一個(gè)a,以鍵值對(duì)的方式維護(hù)這些上下文數(shù)據(jù),SchedulerCone為保存和獲取數(shù)據(jù)提供了多個(gè)u和)e的方法??梢酝ㄟ^(guò)SchedulergeCone獲取對(duì)應(yīng)的SchedulerCone實(shí)例;Quartz任務(wù)調(diào)度快速入門2ThreadPool:Scheduler使用一個(gè)線程池作為任務(wù)運(yùn)行的基礎(chǔ)設(shè)施,任務(wù)通過(guò)共享線程池中的線程提高運(yùn)行效率。o有一個(gè)Saeul子接口,代表有狀態(tài)的任

8、務(wù),該接口是一個(gè)沒(méi)有方法的標(biāo)簽接口,其目的是讓uar知道任務(wù)的類型,以便采用不同的執(zhí)行方案。無(wú)狀態(tài)任務(wù)在執(zhí)行時(shí)擁有自己的拷貝,對(duì)的更改不會(huì)影響下次的執(zhí)行。而有狀態(tài)任務(wù)共享共享同一個(gè)實(shí)例,每次任務(wù)執(zhí)行對(duì)所做的更改會(huì)保存下來(lái),后面的執(zhí)行可以看到這個(gè)更改,也即每次執(zhí)行任務(wù)后都會(huì)對(duì)后面的執(zhí)行發(fā)生影響。正因?yàn)檫@個(gè)原因,無(wú)狀態(tài)的可以并發(fā)執(zhí)行,而有狀態(tài)的不能并發(fā)執(zhí)行,這意味著如果前次的還沒(méi)有執(zhí)行完畢,下一次的任務(wù)將阻塞等待,直到前次任務(wù)執(zhí)行完畢。有狀態(tài)任務(wù)比無(wú)狀態(tài)任務(wù)需要考慮更多的因素,程序往往擁有更高的復(fù)雜度,因此除非必要,應(yīng)該盡量使用無(wú)狀態(tài)的。如果使用了數(shù)據(jù)庫(kù)持久化任務(wù)調(diào)度信息,無(wú)狀態(tài)的僅會(huì)在注冊(cè)任務(wù)時(shí)

9、保持一次,而有狀態(tài)任務(wù)對(duì)應(yīng)的在每次執(zhí)行任務(wù)后都會(huì)進(jìn)行保存。自身也可以擁有一個(gè),其關(guān)聯(lián)的可以通過(guò)獲取中的。不管是有狀態(tài)還是無(wú)狀態(tài)的任務(wù),在任務(wù)執(zhí)行期間對(duì)的所做的更改都不會(huì)進(jìn)行持久,也即不會(huì)對(duì)下次的執(zhí)行產(chǎn)生影響。擁有完善的事件和監(jiān)聽體系,大部分組件都擁有事件,如任務(wù)執(zhí)行前事件、任務(wù)執(zhí)行后事件、觸發(fā)器觸發(fā)前事件、觸發(fā)后事件、調(diào)度器開始事件、關(guān)閉事件等等,可以注冊(cè)相應(yīng)的監(jiān)聽器處理感興趣的事件。圖描述了的內(nèi)部組件結(jié)構(gòu),提供全局可見(jiàn)的上下文信息,每一個(gè)任務(wù)都對(duì)應(yīng)一個(gè),虛線表達(dá)的表示對(duì)應(yīng)有狀態(tài)的任務(wù):Eilendar廠JoblfetailTlircadPoolSclKdukrContcxt-Schedule

10、rTriggerJob陽(yáng):;iM.ip)(JutiDtiTJiMrtpj(JobDtitaMxp圖結(jié)構(gòu)圖一個(gè)可以擁有多個(gè)組和多個(gè)組,注冊(cè)和時(shí),如果不顯式指定所屬的組,將放入到默認(rèn)組中,默認(rèn)組的組名為。組名和名稱組成了對(duì)象的全名,同一類型對(duì)象的全名不能相同。Sedule本身就是一個(gè)容器,它維護(hù)著uart的各種組件并實(shí)施調(diào)度的規(guī)則。Sedule還擁有一個(gè)線程池,線程池為任務(wù)提供執(zhí)行線程這比執(zhí)行任務(wù)時(shí)簡(jiǎn)單地創(chuàng)建一個(gè)新線程要擁有更高的效率,同時(shí)通過(guò)共享節(jié)約資源的占用。通過(guò)線程池組件的支持,對(duì)于繁忙度高、壓力大的任務(wù)調(diào)度,uart將可以提供良好的伸縮性。提示:uart完整下載包eamples目錄下?lián)碛卸?/p>

11、個(gè)實(shí)例,它們是快速掌握uart應(yīng)用很好的實(shí)例。使用SimpleTriggerSimpleTrigger擁有多個(gè)重載的構(gòu)造函數(shù),用以在不同場(chǎng)合下構(gòu)造出對(duì)應(yīng)的實(shí)例:SimpleTrigger(Stringname,Stringgroup):通過(guò)該構(gòu)造函數(shù)扌旨定Trigger所屬組和名稱;SimpleTrigger(Stringname,Stringgroup,DatestartTime):除扌旨定Trigger所屬組和名稱外,還可以指定觸發(fā)的開發(fā)時(shí)間;SimpleTrigger(Stringname,Stringgroup,DatestartTime,DateendTime,intrepeatou

12、nt,longrepeatnteral)除指定以上信息外,還可以指定結(jié)束時(shí)間、重復(fù)執(zhí)行次數(shù)、時(shí)間間隔等參數(shù);SimpleTrigger(Stringname,Stringgroup,StringjobName,StringjobGroup,DatestartTime,DateendTime,intrepeatCount,longrepeatnteral)這是最復(fù)雜的一個(gè)構(gòu)造函數(shù),在指定觸發(fā)參數(shù)的同時(shí),還通過(guò)oroSpo,讓該Trigger和Sedule中的某個(gè)任務(wù)關(guān)聯(lián)起來(lái)。通過(guò)實(shí)現(xiàn)orguart接口,可以使a類化身為可調(diào)度的任務(wù)。代碼清單提供了uart任務(wù)的一個(gè)示例:代碼清單1Simpleo簡(jiǎn)

13、單的o實(shí)現(xiàn)類packagecom.baobaotao.basic.quartimportjava.util.Dateimportorg.quartz.Job;importorg.quartz.JobExecutionContext;importorg.quartz.JobExecutionExceptionpublilassSimpleoimplements實(shí)例接口方法這個(gè)類用一條非常簡(jiǎn)單的輸出語(yǔ)句實(shí)現(xiàn)了接口的方法,這個(gè)方法可以包含想要執(zhí)行的任何代碼。下面,我們通過(guò)對(duì)進(jìn)行調(diào)度:代碼清單:使用進(jìn)行調(diào)度創(chuàng)建一個(gè)實(shí)例,指定通過(guò)次定義調(diào)度規(guī)則:馬上啟動(dòng),每秒運(yùn)行一次,共運(yùn)行通過(guò)獲取一個(gè)調(diào)度器實(shí)例注冊(cè)并

14、進(jìn)行調(diào)度調(diào)度啟動(dòng)首先在處通過(guò)組及名稱,這里,組名為封裝,同時(shí)指定o而名稱為。在中所屬在處創(chuàng)建一個(gè)實(shí)例,指定該在中所屬組及名稱。接著設(shè)置調(diào)度的時(shí)間規(guī)則。最后,需要?jiǎng)?chuàng)建實(shí)例,并將中。這里,我們通過(guò)并通過(guò)和實(shí)例注冊(cè)到獲取一個(gè)實(shí)例,完成兩件事:將和注冊(cè)到中;將指派給,將兩者關(guān)聯(lián)起來(lái)。啟動(dòng)后,將定期觸發(fā)并執(zhí)行方法,然后每的秒重復(fù)一次,直到任通過(guò)獲取一個(gè)調(diào)度器實(shí)例務(wù)被執(zhí)行次后停止。還可以通過(guò)的和指定運(yùn)行的時(shí)間范圍,當(dāng)運(yùn)行次數(shù)和時(shí)間范圍沖突時(shí),超過(guò)時(shí)間范圍的任務(wù)運(yùn)行不被執(zhí)行。如可以通過(guò)指定秒鐘以后開始。除了通過(guò)建立和的關(guān)聯(lián),還有另外種關(guān)聯(lián)和的方式:指定關(guān)聯(lián)的組名:指定關(guān)聯(lián)的名稱注冊(cè)注冊(cè)指定了關(guān)聯(lián)的在這種方式

15、中,的通過(guò)指定所屬組及方法注冊(cè)名稱,然后使用i有兩個(gè)值得注意的地方:通過(guò)這種方式注冊(cè)的實(shí)例必須已經(jīng)指定冊(cè)的方法將拋出異常;組和名稱,否則調(diào)用注引用的對(duì)象必須已經(jīng)存在于的先后順序不能互換。中。也即,代碼中、和在構(gòu)造實(shí)例時(shí),可以考慮使用工具類,該工具類不但提供了眾多獲取特定時(shí)間的方法,還擁有眾多獲取常見(jiàn)的方法,如方法將創(chuàng)建一個(gè)每秒執(zhí)行一次的,而將創(chuàng)建一個(gè)每星期某一特定時(shí)間點(diǎn)執(zhí)行一次的法而方法將返回某一時(shí)間點(diǎn)一分鐘以后的時(shí)間。使用能夠提供比規(guī)則基于表達(dá)式,更有具體實(shí)際意義的調(diào)度方案,調(diào)度支持日歷相關(guān)的重復(fù)時(shí)間間隔(比如每月第一個(gè)周一執(zhí)行),而不是簡(jiǎn)單的周期時(shí)間間隔。因此,相對(duì)于而言,在使用上也要復(fù)雜

16、一些。表達(dá)式a使用類似于L下的表達(dá)式定義時(shí)間規(guī)則,表達(dá)式由或個(gè)由空格分隔的時(shí)間字段組成,如表1所示:表1表達(dá)式時(shí)間字段位置時(shí)間域名允許值允許的特殊字符1秒02分鐘”0小時(shí)02日期丁11,LW月份n112星期彳1,L年可選空值1020表達(dá)式的時(shí)間字段除允許設(shè)置數(shù)值外,還可使用一些特殊的字符,提供列表、范圍、通配符等功能,細(xì)說(shuō)如下:星號(hào)(*:)可用在所有字段中,表示對(duì)應(yīng)時(shí)間域的每一個(gè)時(shí)刻,例如,*在分鐘字段時(shí),表示“每分鐘”;問(wèn)號(hào)(?):該字符只在日期和星期字段中使用,它通常指定為“無(wú)意義的值”,相當(dāng)于點(diǎn)位符;減號(hào)(-:)表達(dá)一個(gè)范圍,如在小時(shí)字段中使用“10-12”,則表示從10到12點(diǎn),即10

17、,11,12;逗號(hào),)表達(dá)一個(gè)列表值,如在星期字段中使用“MON,WED,FRI”,則表示星期一,星期三和星期五;斜杠:表達(dá)一個(gè)等步長(zhǎng)序列,為起始值,為增量步長(zhǎng)值。如在分鐘字段中使用0/1,5則表示為0,15,3和045秒,而5/1在5分鐘字段中表示,20,夕你也可以使用/它等同于0;L:該字符只在日期和星期字段中使用,代表“Last”的意思,但它在兩個(gè)字段中意思不同。L在日期字段中,表示這個(gè)月份的最后一天,如一月的號(hào),非閏年二月的2號(hào);如果L用在星期中,則表示星期六,等同于。但是,如果L出現(xiàn)在星期字段里,而且在前面有一個(gè)數(shù)值,則表示“這個(gè)月的最后天”,例如,I表示該月的最后星期五;W:該字符

18、只能出現(xiàn)在日期字段里,是對(duì)前導(dǎo)日期的修飾,表示離該日期最近的工作日。例如表示離該月號(hào)最近的工作日,如果該月號(hào)是星期六,則匹配14號(hào)星期五;如果15日是星期日,則匹配16號(hào)星期一;如果15號(hào)是星期二,那結(jié)果就是號(hào)星期二。但必須注意關(guān)聯(lián)的匹配日期不能夠跨月,如你指定W如果號(hào)是星期六,結(jié)果匹配的是號(hào)星期一,而非上個(gè)月最后的那天。W字符串只能指定單一日期,而不能指定日期范圍;LW組合:在日期字段可以組合使用LW,它的意思是當(dāng)月的最后一個(gè)工作日;井號(hào)(#:)該字符只能在星期字段中使用,表示當(dāng)月某個(gè)工作日。如6#表3示當(dāng)月的第三個(gè)星期五(6表示星期五,#3表示當(dāng)前的第三個(gè)),而4#表5示當(dāng)月的第五個(gè)星期三

19、,假設(shè)當(dāng)月沒(méi)有第五個(gè)星期三,忽略不觸發(fā);C:該字符只在日期和星期字段中使用,代表“Calendar”的意思。它的意思是計(jì)劃所關(guān)聯(lián)的日期,如果日期沒(méi)有被關(guān)聯(lián),則相當(dāng)于日歷中所有日期。例如(在日期字段中就相當(dāng)于日歷日以后的第一天。(在星期字段中相當(dāng)于星期日后的第一天。Crr表達(dá)式對(duì)特殊字符的大小寫不敏感,對(duì)代表星期的縮寫英文大小寫也不敏感。表下面給出一些完整的Crr表示式的實(shí)例:表Cr表示式示例表示式說(shuō)明每天點(diǎn)運(yùn)行每天運(yùn)行每天運(yùn)行每天運(yùn)行在年的每天0運(yùn)行每天點(diǎn)到點(diǎn)之間每分鐘運(yùn)行一次,開始于:結(jié)束于:每天點(diǎn)到點(diǎn)每分鐘運(yùn)行次,開始于:結(jié)束于:每天點(diǎn)到點(diǎn)每分鐘運(yùn)行一次,此外每天點(diǎn)到點(diǎn)每鐘也運(yùn)行一次。每天

20、點(diǎn)到:每分鐘運(yùn)行一次。1W月每周三的分到:每分鐘運(yùn)行一次。每周一,二,三,四,五的分運(yùn)行。每月日分運(yùn)行。每月最后天分運(yùn)行。每月最后一個(gè)星期五分運(yùn)行。十在年每個(gè)月的最后一個(gè)星期五的分運(yùn)行。每月第三個(gè)星期五的分運(yùn)行。實(shí)例下面,我們使用對(duì)進(jìn)行調(diào)度,通過(guò)表達(dá)式制定調(diào)度規(guī)則,讓它每秒鐘運(yùn)行一次:代碼清單:使用進(jìn)行調(diào)度1創(chuàng)建,指定組及名稱:定義表達(dá)式:設(shè)置表達(dá)式一次。默認(rèn)情況下的/運(yùn)行,每秒鐘將觸發(fā)運(yùn)行表達(dá)式對(duì)應(yīng)當(dāng)前的時(shí)區(qū),可以通過(guò)方法顯式指定時(shí)區(qū)。你還也可以通和指定開始和結(jié)束的時(shí)間。的方式讓主線程在代碼清單的處需要通過(guò)睡眠,以便調(diào)度器可以繼續(xù)工作執(zhí)行任務(wù)調(diào)度。否則在調(diào)度器啟動(dòng)后,因?yàn)橹骶€程馬上退出,也將

21、同時(shí)引起調(diào)度器關(guān)閉,調(diào)度器中的任務(wù)都將相應(yīng)銷毀,這將導(dǎo)致看不到實(shí)際的運(yùn)行效果。在單元測(cè)試的時(shí)候,讓主線程睡眠經(jīng)常使用的辦法。對(duì)于某些長(zhǎng)周期任務(wù)調(diào)度的測(cè)試,你可以簡(jiǎn)單地調(diào)整操作系統(tǒng)時(shí)間進(jìn)行模擬。使用在實(shí)際任務(wù)調(diào)度中,我們不可能一成不變地按照某個(gè)周期性的調(diào)度規(guī)則運(yùn)行任務(wù),必須考慮到實(shí)現(xiàn)生活中日歷上特定日期,就象習(xí)慣了大男人作風(fēng)的人在2月14號(hào)也會(huì)有不同表現(xiàn)一樣。下面,我們安排一個(gè)任務(wù),每小時(shí)運(yùn)行一次,并將五一節(jié)和國(guó)際節(jié)排除在外,其代碼如代碼清單4所示:代碼清單:使用法定節(jié)日是以每年為周期的,所以使用五一勞動(dòng)節(jié):排除的日期,如果設(shè)置為則為包含國(guó)慶節(jié):排除該日期向注冊(cè)日歷點(diǎn)八、讓4月號(hào)上午應(yīng)用指定的日

22、歷規(guī)則/實(shí)際應(yīng)用中主線程不能停止,否則得不到執(zhí)行,此處從略由于節(jié)日是每年重復(fù)的,所以使用的現(xiàn)類,通過(guò)、的代碼,指定五一和國(guó)慶兩個(gè)節(jié)日并通過(guò)兩個(gè)日期。為指定的日期。時(shí)表示排除指定的日期,如果為實(shí)方法添加這時(shí)表示包含在定制好后,還需要通過(guò)進(jìn)行注冊(cè),如果為將得到更新,如所示。中已引用的在處,我們讓一個(gè)指定使用中代表節(jié)日的,這樣就會(huì)避開五一和國(guó)慶這兩個(gè)特殊日子了。任務(wù)調(diào)度信息存儲(chǔ)在默認(rèn)情況下將任務(wù)調(diào)度的運(yùn)行信息保存在內(nèi)存中,這種方法提供了最佳的性能,因?yàn)閮?nèi)存中數(shù)據(jù)訪問(wèn)最快。不足之處是缺乏數(shù)據(jù)的持久性,當(dāng)程序路途停止或系統(tǒng)崩潰時(shí),所有運(yùn)行的信息都會(huì)丟失。比如我們希望安排一個(gè)執(zhí)行10次0的任務(wù),如果執(zhí)行到

23、50次時(shí)系統(tǒng)崩潰了,系統(tǒng)重啟時(shí)任務(wù)的執(zhí)行計(jì)數(shù)器將從0開始。在大多數(shù)實(shí)際的應(yīng)用中,我們往往并不需要保存任務(wù)調(diào)度的現(xiàn)場(chǎng)數(shù)據(jù),因?yàn)楹苌傩枰?guī)劃一個(gè)指定執(zhí)行次數(shù)的任務(wù)。對(duì)于僅執(zhí)行一次的任務(wù)來(lái)說(shuō),其執(zhí)行條件信息本身應(yīng)該是已經(jīng)持久化的業(yè)務(wù)數(shù)據(jù)(如鎖定到期解鎖任務(wù),解鎖的時(shí)間應(yīng)該是業(yè)務(wù)數(shù)據(jù)),當(dāng)執(zhí)行完成后,條件信息也會(huì)相應(yīng)改變。當(dāng)然調(diào)度現(xiàn)場(chǎng)信息不僅僅是記錄運(yùn)行次數(shù),還包括調(diào)度規(guī)則、中的數(shù)據(jù)等等。如果確實(shí)需要持久化任務(wù)調(diào)度信息,允許你通過(guò)調(diào)整其屬性文件,將這些信息保存到數(shù)據(jù)庫(kù)中。使用數(shù)據(jù)庫(kù)保存任務(wù)調(diào)度信息后,即使系統(tǒng)崩潰后重新啟動(dòng),任務(wù)的調(diào)度信息將得到恢復(fù)。如前面所說(shuō)的例子,執(zhí)行50次崩潰后重新運(yùn)行,計(jì)數(shù)器將

24、從51開始計(jì)數(shù)。使用了數(shù)據(jù)庫(kù)保存信息的任務(wù)稱為持久化任務(wù)。通過(guò)配置文件調(diào)整任務(wù)調(diào)度信息的保存策略其實(shí)文件的包下就包含了一個(gè)屬性配置文件并提供了默認(rèn)設(shè)置。如果需要調(diào)整默認(rèn)配置,可以在類路徑下建立一個(gè)新的r它將自動(dòng)被加載并覆蓋默認(rèn)的設(shè)置。先來(lái)了解一下的默認(rèn)屬性配置文件:代碼清單:默認(rèn)配置集群的配置,這里不使用集群配置調(diào)度器的線程池配置任務(wù)調(diào)度現(xiàn)場(chǎng)數(shù)據(jù)保存機(jī)制的屬性配置文件主要包括三方面的信息:集群信息;調(diào)度器線程池;任務(wù)調(diào)度現(xiàn)場(chǎng)數(shù)據(jù)的保存。如果任務(wù)數(shù)目很大時(shí),可以通過(guò)增大線程池的大小得到更好的性能。默認(rèn)情況下采用保存任務(wù)的現(xiàn)場(chǎng)數(shù)據(jù),顧名思義,信息保存在內(nèi)存中,我們可以通過(guò)以下設(shè)置將任務(wù)調(diào)度現(xiàn)場(chǎng)數(shù)據(jù)

25、保存到數(shù)據(jù)庫(kù)中:代碼清單:使用數(shù)據(jù)庫(kù)保存任務(wù)調(diào)度現(xiàn)場(chǎng)數(shù)據(jù)數(shù)據(jù)表前綴數(shù)據(jù)源名稱定義數(shù)據(jù)源的具體屬性要將任務(wù)調(diào)度數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中,就必須使用代替原來(lái)的并提供相應(yīng)的數(shù)據(jù)庫(kù)配置信息。首先處指定了數(shù)據(jù)庫(kù)表的前綴,在處定義了一個(gè)數(shù)據(jù)源,在處具體定義這個(gè)數(shù)據(jù)源的連接信息。你必須事先在相應(yīng)的數(shù)據(jù)庫(kù)中創(chuàng)建的數(shù)據(jù)表(共張),在的完整發(fā)布包的目錄下?lián)碛袑?duì)應(yīng)不同數(shù)據(jù)庫(kù)的腳本。查詢數(shù)據(jù)庫(kù)中的運(yùn)行信息任務(wù)的現(xiàn)場(chǎng)保存對(duì)于上層的程序來(lái)說(shuō)是完全透明的,我們?cè)谀夸浵戮帉懸粋€(gè)如代碼清單所示的文件后,重新運(yùn)行代碼清單2或代碼清單3的程序,在數(shù)據(jù)庫(kù)表中將可以看到對(duì)應(yīng)的持久化信息。當(dāng)調(diào)度程序運(yùn)行過(guò)程中途停止后,任務(wù)調(diào)度的現(xiàn)場(chǎng)數(shù)據(jù)將記錄在數(shù)據(jù)表中,在系統(tǒng)重啟時(shí)就可以在此基礎(chǔ)上繼續(xù)進(jìn)行任務(wù)的調(diào)度。代碼清單:從數(shù)據(jù)庫(kù)中恢復(fù)任務(wù)的調(diào)度獲取調(diào)度器中所有的觸發(fā)器組重新恢復(fù)在組中,名為觸發(fā)器的運(yùn)行根據(jù)名稱判斷恢復(fù)運(yùn)行當(dāng)代碼清單中的執(zhí)行到一段時(shí)間后非正常退出,我們就可以通過(guò)這個(gè)根據(jù)記錄在數(shù)據(jù)庫(kù)中的現(xiàn)場(chǎng)數(shù)據(jù)恢復(fù)任務(wù)的調(diào)度。中的所有以及的運(yùn)行信息都會(huì)保存在數(shù)據(jù)庫(kù)中,這里我們僅恢復(fù)組中名稱為的觸發(fā)器,這可以通過(guò)如所示的代碼進(jìn)行過(guò)濾,觸發(fā)器的采用的全名格式。通過(guò)即可重新調(diào)度關(guān)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論