几种定时任务的实现
參考這個博客,學習了
http://blog.csdn.net/rockstar541/article/details/21093261
?
查看官網提供的文檔,關于quartz的一個小demo;
?這里創建倆類。
1 import org.quartz.Job; 2 import org.quartz.JobExecutionContext; 3 import org.quartz.JobExecutionException; 4 5 import java.text.SimpleDateFormat; 6 import java.util.Date; 7 8 /** 9 * Created by yh on 2015/10/28. 10 */ 11 public class MyJob implements Job { 12 @Override 13 public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { 14 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS"); 15 System.out.println(sdf.format(new Date())); 16 } 17 }?第二個:
import org.quartz.JobDetail; import org.quartz.CronTrigger; import org.quartz.Scheduler; import org.quartz.SchedulerFactory; import org.quartz.impl.StdSchedulerFactory;import java.text.SimpleDateFormat; import java.util.Date;import static org.quartz.CronScheduleBuilder.cronSchedule; import static org.quartz.JobBuilder.newJob; import static org.quartz.TriggerBuilder.newTrigger;/*** Created by yh on 2015/10/28.*/ public class Test {public void test() throws Exception {// 首先,必需要取得一個Scheduler的引用SchedulerFactory sf = new StdSchedulerFactory();Scheduler sched = sf.getScheduler();//jobs可以在scheduled的sched.start()方法前被調用//job 將每隔20秒執行一次String str = "0/10 * * * * ?";//將每隔10秒執行一次JobDetail job = newJob(MyJob.class).withIdentity("job", "group").build();CronTrigger trigger = newTrigger().withIdentity("trigger", "group").withSchedule(cronSchedule(str)).build();Date ft = sched.scheduleJob(job, trigger);SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS");System.out.println(job.getKey() + " job.getKey() 已被安排執行于: " + sdf.format(ft) + ",[sdf.format(ft)]并且以如下重復規則重復執行: [ trigger.getCronExpression()]" + trigger.getCronExpression());// 開始執行,start()方法被調用后,計時器就開始工作,計時調度中允許放入N個Job sched.start();try {//主線程等待一分鐘Thread.sleep(60L * 1000L);} catch (Exception e) {}//關閉定時調度,定時器不再工作sched.shutdown(true);}public static void main(String[] args) throws Exception {Test t = new Test();t.test();} }?當然需要相關的依賴。
<dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.2.2</version> </dependency> <dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz-jobs</artifactId><version>2.2.2</version> </dependency> <dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>${slf4j.version}</version> </dependency> <dependency><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId><version>${slf4j.version}</version> </dependency> <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>${log4j.version}</version> </dependency>?
?
這兩天查了一下quartz定時器,收集了一些cron表達式說明,放在這里,以后參考繼續學習。
cron表達式詳解
Cron表達式是一個字符串,字符串以5或6個空格隔開,分為6或7個域,每一個域代表一個含義,Cron有如下兩種語法格式:
Seconds Minutes Hours DayofMonth Month DayofWeek Year或
Seconds Minutes Hours DayofMonth Month DayofWeek
每一個域可出現的字符如下:
Seconds:可出現", - * /"四個字符,有效范圍為0-59的整數
Minutes:可出現", - * /"四個字符,有效范圍為0-59的整數
Hours:可出現", - * /"四個字符,有效范圍為0-23的整數
DayofMonth:可出現", - * / ? L W C"八個字符,有效范圍為0-31的整數
Month:可出現", - * /"四個字符,有效范圍為1-12的整數或JAN-DEc
DayofWeek:可出現", - * / ? L C #"四個字符,有效范圍為1-7的整數或SUN-SAT兩個范圍。1表示星期天,2表示星期一, 依次類推
Year:可出現", - * /"四個字符,有效范圍為1970-2099年
每一個域都使用數字,但還可以出現如下特殊字符,它們的含義是:
(1)*:表示匹配該域的任意值,假如在Minutes域使用*, 即表示每分鐘都會觸發事件。
(2)?:只能用在DayofMonth和DayofWeek兩個域。它也匹配域的任意值,但實際不會。因為DayofMonth和DayofWeek會相互影響。例如想在每月的20日觸發調度,不管20日到底是星期幾,則只能使用如下寫法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期幾都會觸發,實際上并不是這樣。
(3)-:表示范圍,例如在Minutes域使用5-20,表示從5分到20分鐘每分鐘觸發一次
(4)/:表示起始時間開始觸發,然后每隔固定時間觸發一次,例如在Minutes域使用5/20,則意味著5分鐘觸發一次,而25,45等分別觸發一次.
(5),:表示列出枚舉值值。例如:在Minutes域使用5,20,則意味著在5和20分每分鐘觸發一次。
(6)L:表示最后,只能出現在DayofWeek和DayofMonth域,如果在DayofWeek域使用5L,意味著在最后的一個星期四觸發。
(7)W:表示有效工作日(周一到周五),只能出現在DayofMonth域,系統將在離指定日期的最近的有效工作日觸發事件。例如:在 DayofMonth使用5W,如果5日是星期六,則將在最近的工作日:星期五,即4日觸發。如果5日是星期天,則在6日(周一)觸發;如果5日在星期一到星期五中的一天,則就在5日觸發。另外一點,W的最近尋找不會跨過月份
(8)LW:這兩個字符可以連用,表示在某個月最后一個工作日,即最后一個星期五。
(9)#:用于確定每個月第幾個星期幾,只能出現在DayofMonth域。例如在4#2,表示某月的第二個星期三。
舉幾個例子:
0 0 2 1 * ? * 表示在每月的1日的凌晨2點調度任務
0 15 10 ? * MON-FRI 表示周一到周五每天上午10:15執行作業
0 15 10 ? 6L 2002-2006 表示2002-2006年的每個月的最后一個星期五上午10:15執行作
一個cron表達式有至少6個(也可能7個)有空格分隔的時間元素。
按順序依次為
秒(0~59)
分鐘(0~59)
小時(0~23)
天(月)(0~31,但是你需要考慮你月的天數)
月(0~11)
天(星期)(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)
年份(1970-2099)
其中每個元素可以是一個值(如6),一個連續區間(9-12),一個間隔時間(8-18/4)(/表示每隔4小時),一個列表(1,3,5),通配符。由于"月份中的日期"和"星期中的日期"這兩個元素互斥的,必須要對其中一個設置?
0 0 10,14,16 * * ? 每天上午10點,下午2點,4點
0 0/30 9-17 * * ? 朝九晚五工作時間內每半小時
0 0 12 ? * WED 表示每個星期三中午12點
"0 0 12 * * ?" 每天中午12點觸發
"0 15 10 ? * *" 每天上午10:15觸發
"0 15 10 * * ?" 每天上午10:15觸發
"0 15 10 * * ? *" 每天上午10:15觸發
"0 15 10 * * ? 2005" 2005年的每天上午10:15觸發
"0 * 14 * * ?" 在每天下午2點到下午2:59期間的每1分鐘觸發
"0 0/5 14 * * ?" 在每天下午2點到下午2:55期間的每5分鐘觸發
"0 0/5 14,18 * * ?" 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發
"0 0-5 14 * * ?" 在每天下午2點到下午2:05期間的每1分鐘觸發
"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44觸發
"0 15 10 ? * MON-FRI" 周一至周五的上午10:15觸發
"0 15 10 15 * ?" 每月15日上午10:15觸發
"0 15 10 L * ?" 每月最后一日的上午10:15觸發
"0 15 10 ? * 6L" 每月的最后一個星期五上午10:15觸發
"0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一個星期五上午10:15觸發
"0 15 10 ? * 6#3" 每月的第三個星期五上午10:15觸發
有些子表達式能包含一些范圍或列表
例如:子表達式(天(星期))可以為 “MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”
“*”字符代表所有可能的值
因此,“*”在子表達式(月)里表示每個月的含義,“*”在子表達式(天(星期))表示星期的每一天
“/”字符用來指定數值的增量
例如:在子表達式(分鐘)里的“0/15”表示從第0分鐘開始,每15分鐘
在子表達式(分鐘)里的“3/20”表示從第3分鐘開始,每20分鐘(它和“3,23,43”)的含義一樣
“?”字符僅被用于天(月)和天(星期)兩個子表達式,表示不指定值
當2個子表達式其中之一被指定了值以后,為了避免沖突,需要將另一個子表達式的值設為“?”
“L” 字符僅被用于天(月)和天(星期)兩個子表達式,它是單詞“last”的縮寫
但是它在兩個子表達式里的含義是不同的。
在天(月)子表達式中,“L”表示一個月的最后一天
在天(星期)自表達式中,“L”表示一個星期的最后一天,也就是SAT
如果在“L”前有具體的內容,它就具有其他的含義了
例如:“6L”表示這個月的倒數第6天,“FRIL”表示這個月的最一個星期五
注意:在使用“L”參數時,不要指定列表或范圍,因為這會導致問題
字段 允許值 允許的特殊字符
秒 0-59 , - * /
分 0-59 , - * /
小時 0-23 , - * /
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - * /
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可選) 留空, 1970-2099 , - * /
**********************************************************************************************************************************************************************************************************************************************************************************************************************************************
1. cron表達式格式:
{秒數} {分鐘} {小時} {日期} {月份} {星期} {年份(可為空)}
2. cron表達式各占位符解釋:
{秒數} ==> 允許值范圍: 0~59 ,不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每隔1秒鐘觸發;
"," 代表在指定的秒數觸發,比如"0,15,45"代表0秒、15秒和45秒時觸發任務
"-" 代表在指定的范圍內觸發,比如"25-45"代表從25秒開始觸發到45秒結束觸發,每隔1秒觸發1次
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/20"或者"*/20"代表從0秒鐘開始,每隔20秒鐘觸發1次,即0秒觸發1次,20秒觸發1次,40秒觸發1次;"5/20"代表5秒觸發1次,25秒觸發1次,45秒觸發1次;"10-45/20"代表在[10,45]內步進20秒命中的時間點觸發,即10秒觸發1次,30秒觸發1次
{分鐘} ==> 允許值范圍: 0~59 ,不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每隔1分鐘觸發;
"," 代表在指定的分鐘觸發,比如"10,20,40"代表10分鐘、20分鐘和40分鐘時觸發任務
"-" 代表在指定的范圍內觸發,比如"5-30"代表從5分鐘開始觸發到30分鐘結束觸 發,每隔1分鐘觸發
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/25"或者"*/25"代表從0分鐘開始,每隔25分鐘觸發1次,即0分鐘觸發1次,第25分鐘觸發1次,第50分鐘觸發1次;"5/25"代表5分鐘觸發1次,30分鐘觸發1次,55分鐘觸發1次;"10-45/20"代表在[10,45]內步進20分鐘命中的時間點觸發,即10分鐘觸發1次,30分鐘觸發1次
{小時} ==> 允許值范圍: 0~23 ,不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每隔1小時觸發;
"," 代表在指定的時間點觸發,比如"10,20,23"代表10點鐘、20點鐘和23點觸發任務
"-" 代表在指定的時間段內觸發,比如"20-23"代表從20點開始觸發到23點結束觸發,每隔1小時觸發
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/1"或者"*/1"代表從0點開始觸發,每隔1小時觸發1次;"1/2"代表從1點開始觸發,以后每隔2小時觸發一次;"19-20/2"表達式將只在19點觸發
{日期} ==> 允許值范圍: 1~31 ,不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每天觸發;
"?" 與{星期}互斥,即意味著若明確指定{星期}觸發,則表示{日期}無意義,以免引起 沖突和混亂
"," 代表在指定的日期觸發,比如"1,10,20"代表1號、10號和20號這3天觸發
"-" 代表在指定的日期范圍內觸發,比如"10-15"代表從10號開始觸發到15號結束觸發,每隔1天觸發
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/5"或者"*/5"代表從1號開始觸發,每隔5天觸發1次;"10/5"代表從10號開始觸發,以后每隔5天觸發一次;"1-10/2"表達式意味著在[1,10]范圍內,每隔2天觸發,即1號,3號,5號,7號,9號觸發
"L" 如果{日期}占位符如果是"L",即意味著當月的最后一天觸發
"W "意味著在本月內離當天最近的工作日觸發,所謂最近工作日,即當天到工作日的前后最短距離,如果當天即為工作日,則距離為0;所謂本月內的說法,就是不能跨月取到最近工作日,即使前/后月份的最后一天/第一天確實滿足最近工作日;因此,"LW"則意味著本月的最后一個工作日觸發,"W"強烈依賴{月份}
"C" 根據日歷觸發,由于使用較少,暫時不做解釋
{月份} ==> 允許值范圍: 1~12 (JAN-DEC),不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每個月都觸發;
"," 代表在指定的月份觸發,比如"1,6,12"代表1月份、6月份和12月份觸發任務
"-" 代表在指定的月份范圍內觸發,比如"1-6"代表從1月份開始觸發到6月份結束觸發,每隔1個月觸發
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/2"或者"*/2"代表從1月份開始觸發,每隔2個月觸發1次;"6/6"代表從6月份開始觸發,以后每隔6個月觸發一次;"1-6/12"表達式意味著每年1月份觸發
{星期} ==> 允許值范圍: 1~7 (SUN-SAT),1代表星期天(一星期的第一天),以此類推,7代表星期六(一星期的最后一天),不允許為空值,若值不合法,調度器將拋出SchedulerException異常
"*" 代表每星期都觸發;
"?" 與{日期}互斥,即意味著若明確指定{日期}觸發,則表示{星期}無意義,以免引起沖突和混亂
"," 代表在指定的星期約定觸發,比如"1,3,5"代表星期天、星期二和星期四觸發
"-" 代表在指定的星期范圍內觸發,比如"2-4"代表從星期一開始觸發到星期三結束觸發,每隔1天觸發
"/" 代表觸發步進(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/3"或者"*/3"代表從星期天開始觸發,每隔3天觸發1次;"1-5/2"表達式意味著在[1,5]范圍內,每隔2天觸發,即星期天、星期二、星期四觸發
"L" 如果{星期}占位符如果是"L",即意味著星期的的最后一天觸發,即星期六觸發,L= 7或者 L = SAT,因此,"5L"意味著一個月的最后一個星期四觸發
"#" 用來指定具體的周數,"#"前面代表星期,"#"后面代表本月第幾周,比如"2#2"表示本月第二周的星期一,"5#3"表示本月第三周的星期四,因此,"5L"這種形式只不過是"#"的特殊形式而已
"C" 根據日歷觸發,由于使用較少,暫時不做解釋
{年份} ==> 允許值范圍: 1970~2099 ,允許為空,若值不合法,調度器將拋出SchedulerException異常
"*"代表每年都觸發;
","代表在指定的年份才觸發,比如"2011,2012,2013"代表2011年、2012年和2013年觸發任務
"-"代表在指定的年份范圍內觸發,比如"2011-2020"代表從2011年開始觸發到2020年結束觸發,每隔1年觸發
"/"代表觸發步進(step),"/"前面的值代表初始值("*"等同"1970"),后面的值代表偏移量,比如"2011/2"或者"*/2"代表從2011年開始觸發,每隔2年觸發1次
注意:除了{日期}和{星期}可以使用"?"來實現互斥,表達無意義的信息之外,其他占位符都要具有具體的時間含義,且依賴關系為:年->月->日期(星期)->小時->分鐘->秒數
3. cron表達式的強大魅力在于靈活的橫向和縱向組合以及簡單的語法,用cron表達式幾乎可以寫出任何你想要觸發的時間點
經典案例:
"30 * * * * ?" 每半分鐘觸發任務
"30 10 * * * ?" 每小時的10分30秒觸發任務
"30 10 1 * * ?" 每天1點10分30秒觸發任務
"30 10 1 20 * ?" 每月20號1點10分30秒觸發任務
"30 10 1 20 10 ? *" 每年10月20號1點10分30秒觸發任務
"30 10 1 20 10 ? 2011" 2011年10月20號1點10分30秒觸發任務
"30 10 1 ? 10 * 2011" 2011年10月每天1點10分30秒觸發任務
"30 10 1 ? 10 SUN 2011" 2011年10月每周日1點10分30秒觸發任務
"15,30,45 * * * * ?" 每15秒,30秒,45秒時觸發任務
"15-45 * * * * ?" 15到45秒內,每秒都觸發任務
"15/5 * * * * ?" 每分鐘的每15秒開始觸發,每隔5秒觸發一次
"15-30/5 * * * * ?" 每分鐘的15秒到30秒之間開始觸發,每隔5秒觸發一次
"0 0/3 * * * ?" 每小時的第0分0秒開始,每三分鐘觸發一次
"0 15 10 ? * MON-FRI" 星期一到星期五的10點15分0秒觸發任務
"0 15 10 L * ?" 每個月最后一天的10點15分0秒觸發任務
"0 15 10 LW * ?" 每個月最后一個工作日的10點15分0秒觸發任務
"0 15 10 ? * 5L" 每個月最后一個星期四的10點15分0秒觸發任務
"0 15 10 ? * 5#3" 每個月第三周的星期四的10點15分0秒觸發任務
?corn表達式是可以在線生成的 。
轉載于:https://www.cnblogs.com/yangh965/p/4921814.html
總結
- 上一篇: Xamarin只言片语4——Xamari
- 下一篇: VSftp常规服务配置