摘要:分類中共包含有種觸發(fā)器。建立一個觸發(fā)器,每隔一分鐘,每天上午點至下午點之間建立一個觸發(fā)器,將在每天上午執(zhí)行第一種實現(xiàn)方式第二種實現(xiàn)方式建立一個觸發(fā)器,將在星期三上午在系統(tǒng)默認值之外執(zhí)行第一種方式第二種方式
Trigger分類
Quartz中共包含有4種觸發(fā)器。
常用的是: SimpleTrigger 和 CronTrigger。
不常用的是:CalendarIntervalTrigger 和 DailyTimeIntervalTrigger。雖然后面兩種用到的不是特別多,但是在特定的場景下,也是有不可替代的作用(具體看下官方文檔)。
CalendarIntervalTrigger: 根據(jù)一個給定的日歷時間進行重復(fù),可以設(shè)置啟動時間。它可以完成 SimpleTrigger(比如每個月,因為月不是一個確定的秒數(shù))和CronTrigger(比如5個月,因為5個月并不是12個月的公約數(shù))不能完成的一些任務(wù)。注意,使用month作為周期單位時,如果起始日期是在某月的最后一天,比如1月31日,那么下一個激活日在2月28日,以后所有的激活日都在當(dāng)月的28日。如果你要嚴格限制在每月的最后一天激活,那你需要使用cronTrigger。不受夏令時引起的時鐘偏移影響。
DailyTimeIntervalTrigger:在給定的時間窗口或指定的星期以秒、分鐘、小時為周期進行重復(fù)。比如,每天早上8:00到11:00之間,每隔72分鐘激活;或者每周的周一到周五9:20到16:47之間,每隔23分鐘激活。
SimpleTrigger 常用的方法記錄SimpleTrigger的屬性包括:開始時間、結(jié)束時間、重復(fù)次數(shù)以及重復(fù)的間隔。
重復(fù)次數(shù),可以是0、正整數(shù),以及常量SimpleTrigger.REPEAT_INDEFINITELY。重復(fù)的間隔,必須是0,或者long型的正數(shù),表示毫秒。注意,如果重復(fù)間隔為0,trigger將會以重復(fù)次數(shù)并發(fā)執(zhí)行(或者以scheduler可以處理的近似并發(fā)數(shù))。
指定時間開始觸發(fā),不重復(fù)
SimpleTrigger trigger = (SimpleTrigger) newTrigger() .withIdentity("trigger1", "group1") .startAt(myStartTime) // some Date .forJob("job1", "group1") // identify job with name, group strings .build();
指定時間觸發(fā),每隔10秒執(zhí)行一次,重復(fù)10次
trigger = newTrigger() .withIdentity("trigger3", "group1") .startAt(myTimeToStartFiring) // if a start time is not given (if this line were omitted), "now" is implied .withSchedule(simpleSchedule() .withIntervalInSeconds(10) .withRepeatCount(10)) // note that 10 repeats will give a total of 11 firings .forJob(myJob) // identify job with handle to its JobDetail itself .build();
立即觸發(fā),每個5分鐘執(zhí)行一次,直到22:00:
trigger = newTrigger() .withIdentity("trigger7", "group1") .withSchedule(simpleSchedule() .withIntervalInMinutes(5) .repeatForever()) .endAt(dateOf(22, 0, 0)) .build();
建立一個觸發(fā)器,將在下一個小時的整點觸發(fā),然后每2小時重復(fù)一次:
trigger = newTrigger() .withIdentity("trigger8") // because group is not specified, "trigger8" will be in the default group .startAt(evenHourDate(null)) // get the next even-hour (minutes and seconds zero ("00:00")) .withSchedule(simpleSchedule() .withIntervalInHours(2) .repeatForever()) // note that in this example, "forJob(..)" is not called which is valid // if the trigger is passed to the scheduler along with the job .build(); scheduler.scheduleJob(trigger, job);
建立一個觸發(fā)器,將在下一個小時的整點觸發(fā),然后每2小時重復(fù)一次
trigger = newTrigger() .withIdentity("trigger8") // because group is not specified, "trigger8" will be in the default group .startAt(evenHourDate(null)) // get the next even-hour (minutes and seconds zero ("00:00")) .withSchedule(simpleSchedule() .withIntervalInHours(2) .repeatForever()) // note that in this example, "forJob(..)" is not called which is valid // if the trigger is passed to the scheduler along with the job .build(); scheduler.scheduleJob(trigger, job);CronTrigger 常用的方法記錄
CronTrigger 通常比 Simple Trigger 更有用,如果需要基于日歷的概念而不是按照 SimpleTrigger 的精確指定間隔進行重新啟動的作業(yè)啟動計劃。
使用 CronTrigger ,可以指定號時間表,例如“每周五中午”或“每個工作日和上午9:30”,甚至“每周一至周五上午9:00至10點之間每5分鐘”和1月份的星期五“。
即使如此,和 SimpleTrigger 一樣,CronTrigger 有一個 startTime ,它指定何時生效,以及一個(可選的)endTime,用于指定何時停止計劃。
建立一個觸發(fā)器,每隔一分鐘,每天上午8點至下午5點之間
trigger = newTrigger() .withIdentity("trigger3", "group1") .withSchedule(cronSchedule("0 0/2 8-17 * * ?")) .forJob("myJob", "group1") .build();
建立一個觸發(fā)器,將在每天上午10:42執(zhí)行
// 第一種實現(xiàn)方式 trigger = newTrigger() .withIdentity("trigger3", "group1") .withSchedule(dailyAtHourAndMinute(10, 42)) .forJob(myJobKey) .build(); // 第二種實現(xiàn)方式 trigger = newTrigger() .withIdentity("trigger3", "group1") .withSchedule(cronSchedule("0 42 10 * * ?")) .forJob(myJobKey) .build();
建立一個觸發(fā)器,將在星期三上午10:42在TimeZone(系統(tǒng)默認值)之外執(zhí)行
// 第一種方式 trigger = newTrigger() .withIdentity("trigger3", "group1") .withSchedule(weeklyOnDayAndHourAndMinute(DateBuilder.WEDNESDAY, 10, 42)) .forJob(myJobKey) .inTimeZone(TimeZone.getTimeZone("America/Los_Angeles")) .build(); // 第二種方式 trigger = newTrigger() .withIdentity("trigger3", "group1") .withSchedule(cronSchedule("0 42 10 ? * WED")) .inTimeZone(TimeZone.getTimeZone("America/Los_Angeles")) .forJob(myJobKey) .build();
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/71209.html
摘要:觸發(fā)器也可以給予名稱和放置在組中,以方便地將它們調(diào)度內(nèi)組織。作業(yè)可以被添加到所述調(diào)度器一次,而是具有多個觸發(fā)器注冊。調(diào)度類鏈接工作和觸發(fā)器到一起,并執(zhí)行它。 簡介 Quartz是一個開源的作業(yè)調(diào)度框架,可以讓計劃的程序任務(wù)一個預(yù)定義的日期和時間運行。Quartz可以用來創(chuàng)建簡單或復(fù)雜的日程安排執(zhí)行幾十,幾百,甚至是十萬的作業(yè)數(shù)。官方鏈接,戳這里 Quartz是什么? 作業(yè)調(diào)度庫 Qua...
摘要:多作業(yè)例子在這個例子中,我們將介紹如何通過多個作業(yè)。在調(diào)度框架中,每個作業(yè)將被連接到一個唯一的觸發(fā),并且由調(diào)度器運行它。備注說明在中,一個觸發(fā)器觸發(fā)多個作業(yè)是不可以的。第一步創(chuàng)建個作業(yè),,和。 多作業(yè)例子 在這個例子中,我們將介紹如何通過Quartz API 多個作業(yè)。在Quartz調(diào)度框架中,每個作業(yè)將被連接到一個唯一的觸發(fā),并且由調(diào)度器運行它。 備注說明:在 Quartz 中,一個...
摘要:請注意,觸發(fā)器將不會在上午點開始,僅在,,和請注意,一些調(diào)度要求太復(fù)雜,無法用單一觸發(fā)表示例如每上午至之間每分鐘,下午至晚上點之間每分鐘一次。在這種情況下的解決方案是簡單地創(chuàng)建兩個觸發(fā)器,并注冊它們來運行相同的作業(yè)。 表達式說明 Cron-Expressions 用于配置 CronTrigger的實例。Cron Expressions 是由七個子表達式組成的字符串,用于描述日程表的各個...
摘要:時間年月日星期一說明本文部分內(nèi)容均來自慕課網(wǎng)。屬性任務(wù)名稱任務(wù)所屬組任務(wù)實現(xiàn)類傳參的作用淺談上是什么當(dāng)調(diào)用一個,就會將傳遞給的方法能通過對象訪問到運行時候的環(huán)境以及本身的明細數(shù)據(jù)。 時間:2017年06月26日星期一說明:本文部分內(nèi)容均來自慕課網(wǎng)。@慕課網(wǎng):http://www.imooc.com教學(xué)示例源碼:https://github.com/zccodere/s...個人學(xué)習(xí)源碼...
摘要:也有,觸發(fā)點和相關(guān),和我們的需求關(guān)系不大,暫忽略。實現(xiàn)為每個算法任務(wù)創(chuàng)建一個,任務(wù)失敗不能啟動后續(xù)任務(wù),所以在運行失敗的情況下,需要把啟動的刪除掉。需要自己在中實現(xiàn)多個依賴是否完成的檢查。后續(xù)主線程的任務(wù)就是檢查工作流是否已經(jīng)完成。 Quartz簡介 作為一個優(yōu)秀的開源調(diào)度框架,Quartz 具有以下特點:強大的調(diào)度功能,支持立即調(diào)度、定時調(diào)度、周期調(diào)度、并發(fā)調(diào)度; 靈活的應(yīng)用方式,支...
閱讀 1140·2021-11-24 10:21
閱讀 2576·2021-11-19 11:35
閱讀 1678·2019-08-30 15:55
閱讀 1307·2019-08-30 15:54
閱讀 1205·2019-08-30 15:53
閱讀 3519·2019-08-29 17:21
閱讀 3319·2019-08-29 16:12
閱讀 3428·2019-08-29 15:23