Spring Schedule是Spring提供的定時任務框架,相較於Quartz,Schedule更加簡單易用,在中小型應用中,對於大部分需求,Schedule均可以勝任。java
在SpringBoot使用Spring Schedule很是簡單,由於SpringBoot自身的starter中已經集成了Schedule,而不須要咱們作更多的處理。spring
使用@EnableScheduling註解開啓定時功能,該註解可使用在啓動類上,也能夠註解於定時任務的類上。而後使用@Scheduled註解配合其參數完成定時任務。服務器
例如咱們須要每一秒執行一次的任務, 寫成@Scheduled(fixedRate = 1000)便可。框架
@EnableScheduling @Component public class Task { private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss"); @Scheduled(fixedRate = 1000) public void taskOne(){ System.out.println("如今時間:" + dateFormat.format(new Date())); } }
啓動程序,該定時就能夠間隔一秒持續執行了。3d
使用Spring Schedule就是這麼簡單,若是有更多其餘的需求,配合@Scheduled的其餘參數,基本也能夠實現。code
支持傳入cron表達式:[秒] [分] [小時] [日] [月] [周] [年],[年]不是必須的域,能夠省略[年],則一共6個域。orm
位置 | 說明 | 必填 | 容許填寫的值 | 容許的通配符 |
---|---|---|---|---|
1 | 秒 | 是 | 0-59 | - * / |
2 | 分 | 是 | 0-59 | - * / |
3 | 時 | 是 | 0-23 | - * / |
4 | 日 | 是 | 1-31 | - * ? / L W |
5 | 月 | 是 | 1-12 or JAN-DEC | - * / |
6 | 周 | 是 | 1-7 or SUN-SAT | - * ? / L # |
7 | 年 | 否 | 1970-2099 | - * / |
表示時區,接收一個java.util.TimeZone#ID。cron表達式會基於該時區解析。默認是一個空字符串,即取服務器所在地的時區。blog
上一次執行完畢時間點以後多長時間再執行。字符串
與fixedDelay相似,傳入字符串,也可支持傳入${}佔位符讀取配置文件。string
@Scheduled(fixedDelayString = "${task.two.fixedDelay}") void taskTwo() { System.out.println("如今時間:" + dateFormat.format(new Date())); }
上一次開始執行時間點以後多長時間再執行。
fixedRate與fixedDelay的區別就是:fixedDelay是在上一個任務結束後纔開始進行間隔計時,也就是說兩次任務之間的時間差等於間隔+任務執行耗時,而fixedRate是在上一個任務一開始就已經開始進行間隔計時了,能夠視爲固定等於設置的間隔時間。
與fixedRate同樣,傳入字符串,支持佔位符讀取配置文件。
第一次任務延遲時間。
同initialDelay,支持佔位符讀取配置信息。