Cron詳解:
Cron表達式是一個字符串,字符串以5或6個空格隔開,分為6或7個域,每一個域代表一個含義,Cron有如下兩種語法格式:
1.Seconds Minutes Hours DayofMonth Month DayofWeek Year
2.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,表示某月的第二個星期三。
舉幾個例子:
每隔5秒執行一次:"*/5 * * * * ?"
每隔1分鍾執行一次:"0 */1 * * * ?"
每天23點執行一次:"0 0 23 * * ?"
每天凌晨1點執行一次:"0 0 1 * * ?"
每月1號凌晨1點執行一次:"0 0 1 1 * ?"
每月最后一天23點執行一次:"0 0 23 L * ?"
每周星期天凌晨1點實行一次:"0 0 1 ? * L"
在26分、29分、33分執行一次:"0 26,29,33 * * * ?"
每天的0點、13點、18點、21點都執行一次:"0 0 0,13,18,21 * * ?"
表示在每月的1日的凌晨2點調度任務:"0 0 2 1 * ? *"
表示周一到周五每天上午10:15執行作業:"0 15 10 ? * MON-FRI"
表示2002-2006年的每個月的最后一個星期五上午10:15執行:"0 15 10 ? 6L 2002-2006"
注意:由於"月份中的日期"和"星期中的日期"這兩個元素互斥的,必須要對其中一個設置?
參數詳解
1. cron
該參數接收一個cron表達式
,cron表達式
是一個字符串,字符串以5或6個空格隔開,分開共6或7個域,每一個域代表一個含義。
cron表達式語法
[秒] [分] [小時] [日] [月] [周] [年]
注:[年]不是必須的域,可以省略[年],則一共6個域
序號 | 說明 | 必填 | 允許填寫的值 | 允許的通配符 |
---|---|---|---|---|
1 | 秒 | 是 | 0-59 | , - * / |
2 | 分 | 是 | 0-59 | , - * / |
3 | 時 | 是 | 0-23 | , - * / |
4 | 日 | 是 | 1-31 | , - * ? / L W |
5 | 月 | 是 | 1-12 / JAN-DEC | , - * / |
6 | 周 | 是 | 1-7 or SUN-SAT | , - * ? / L # |
7 | 年 | 否 | 1970-2099 | , - * / |
通配符說明:
*
表示所有值。 例如:在分的字段上設置 *,表示每一分鍾都會觸發。?
表示不指定值。使用的場景為不需要關心當前設置這個字段的值。例如:要在每月的10號觸發一個操作,但不關心是周幾,所以需要周位置的那個字段設置為”?” 具體設置為 0 0 0 10 * ?-
表示區間。例如 在小時上設置 “10-12”,表示 10,11,12點都會觸發。,
表示指定多個值,例如在周字段上設置 “MON,WED,FRI” 表示周一,周三和周五觸發/
用於遞增觸發。如在秒上面設置”5/15” 表示從5秒開始,每增15秒觸發(5,20,35,50)。 在月字段上設置’1/3’所示每月1號開始,每隔三天觸發一次。L
表示最后的意思。在日字段設置上,表示當月的最后一天(依據當前月份,如果是二月還會依據是否是潤年[leap]), 在周字段上表示星期六,相當於”7”或”SAT”。如果在”L”前加上數字,則表示該數據的最后一個。例如在周字段上設置”6L”這樣的格式,則表示“本月最后一個星期五”W
表示離指定日期的最近那個工作日(周一至周五). 例如在日字段上置”15W”,表示離每月15號最近的那個工作日觸發。如果15號正好是周六,則找最近的周五(14號)觸發, 如果15號是周未,則找最近的下周一(16號)觸發.如果15號正好在工作日(周一至周五),則就在該天觸發。如果指定格式為 “1W”,它則表示每月1號往后最近的工作日觸發。如果1號正是周六,則將在3號下周一觸發。(注,”W”前只能設置具體的數字,不允許區間”-“)。#
序號(表示每月的第幾個周幾),例如在周字段上設置”6#3”表示在每月的第三個周六.注意如果指定”#5”,正好第五周沒有周六,則不會觸發該配置(用在母親節和父親節再合適不過了) ;小提示:’L’和 ‘W’可以一組合使用。如果在日字段上設置”LW”,則表示在本月的最后一個工作日觸發;周字段的設置,若使用英文字母是不區分大小寫的,即MON與mon相同。
示例
每隔5秒執行一次:*/5 * * * * ?
每隔1分鍾執行一次:0 */1 * * * ?
每天23點執行一次:0 0 23 * * ?
每天凌晨1點執行一次:0 0 1 * * ?
每月1號凌晨1點執行一次:0 0 1 1 * ?
每月最后一天23點執行一次:0 0 23 L * ?
每周星期天凌晨1點實行一次:0 0 1 ? * L
在26分、29分、33分執行一次:0 26,29,33 * * * ?
每天的0點、13點、18點、21點都執行一次:0 0 0,13,18,21 * * ?
cron表達式使用占位符
另外,cron
屬性接收的cron表達式
支持占位符。eg:
配置文件:
time:
cron: */5 * * * * *
interval: 5
每5秒執行一次:
@Scheduled(cron="${time.cron}") void testPlaceholder1() { System.out.println("Execute at " + System.currentTimeMillis()); } @Scheduled(cron="*/${time.interval} * * * * *") void testPlaceholder2() { System.out.println("Execute at " + System.currentTimeMillis()); }
2. zone
時區,接收一個java.util.TimeZone#ID
。cron表達式
會基於該時區解析。默認是一個空字符串,即取服務器所在地的時區。比如我們一般使用的時區Asia/Shanghai
。該字段我們一般留空。
3. fixedDelay
上一次執行完畢時間點之后多長時間再執行。如:
@Scheduled(fixedDelay = 5000) //上一次執行完畢時間點之后5秒再執行
4. fixedDelayString
與 3. fixedDelay
意思相同,只是使用字符串的形式。唯一不同的是支持占位符。如:
@Scheduled(fixedDelayString = "5000") //上一次執行完畢時間點之后5秒再執行
占位符的使用(配置文件中有配置:time.fixedDelay=5000):
@Scheduled(fixedDelayString = "${time.fixedDelay}") void testFixedDelayString() { System.out.println("Execute at " + System.currentTimeMillis()); }
運行結果:

5. fixedRate
上一次開始執行時間點之后多長時間再執行。如:
@Scheduled(fixedRate = 5000) //上一次開始執行時間點之后5秒再執行
6. fixedRateString
與 5. fixedRate
意思相同,只是使用字符串的形式。唯一不同的是支持占位符。
7. initialDelay
第一次延遲多長時間后再執行。如:
@Scheduled(initialDelay=1000, fixedRate=5000) //第一次延遲1秒后執行,之后按fixedRate的規則每5秒執行一次
8. initialDelayString
與 7. initialDelay
意思相同,只是使用字符串的形式。唯一不同的是支持占位符。
That's all ! Thanks for reading.
作者:sprinkle_liz
鏈接:https://www.jianshu.com/p/1defb0f22ed1
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯系作者獲得授權並注明出處。