SpringBoot 定時(shí)任務(wù)遇到的坑
前言
springboot已經(jīng)支持了定時(shí)任務(wù)Schedule模塊,一般情況已經(jīng)完全能夠滿足我們的實(shí)際需求。今天就記錄一下我使用 schedule 時(shí)候踩的坑吧。
想要使用定時(shí),我們首先要開啟支持,其實(shí)就是在啟動(dòng)類上面加個(gè)注解就 Ok。
@SpringBootApplication @EnableScheduling public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
這篇博客的主題是記錄踩的坑,具體定時(shí)任務(wù)怎么使用我就不寫了,有需要的參考我的博客 Spring定時(shí)任務(wù) 。
今天踩的這個(gè)坑和 cron 表達(dá)式有關(guān),我們就先來看看 cron 表達(dá)式的解釋吧:
Cron表達(dá)式是一個(gè)字符串,字符串以5或6個(gè)空格隔開,分為6或7個(gè)域,每一個(gè)域代表一個(gè)含義
解釋
* 第一位,表示秒,取值0-59
* 第二位,表示分,取值0-59
* 第三位,表示小時(shí),取值0-23
* 第四位,日期天/日,取值1-31
* 第五位,日期月份,取值1-12
* 第六位,星期,取值1-7,星期一,星期二...,注:不是第1周,第二周的意思
另外:1表示星期天,2表示星期一。
* 第7為,年份,可以留空,取值1970-2099
(*)星號(hào):可以理解為每的意思,每秒,每分,每天,每月,每年...
(?)問號(hào):?jiǎn)柼?hào)只能出現(xiàn)在日期和星期這兩個(gè)位置,表示這個(gè)位置的值不確定,每天3點(diǎn)執(zhí)行,所以第六位星期的位置,我們是不需要關(guān)注的,就是不確定的值。同時(shí):日期和星期是兩個(gè)相互排斥的元素,通過問號(hào)來表明不指定值。比如,1月10日,比如是星期1,如果在星期的位置是另指定星期二,就前后沖突矛盾了。
(-)減號(hào):表達(dá)一個(gè)范圍,如在小時(shí)字段中使用“10-12”,則表示從10到12點(diǎn),即10,11,12
(,)逗號(hào):表達(dá)一個(gè)列表值,如在星期字段中使用“1,2,4”,則表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是開始值,y是步長(zhǎng),比如在第一位(秒) 0/15就是,從0秒開始,每15秒,最后就是0,15,30,45,60 另:*/y,等同于0/y
注: 這個(gè)是官方解釋
0 0 3 * * ? 每天3點(diǎn)執(zhí)行
0 5 3 * * ? 每天3點(diǎn)5分執(zhí)行
0 5 3 ? * * 每天3點(diǎn)5分執(zhí)行,與上面作用相同
0 5/10 3 * * ? 每天3點(diǎn)的 5分,15分,25分,35分,45分,55分這幾個(gè)時(shí)間點(diǎn)執(zhí)行
0 10 3 ? * 1 每周星期天,3點(diǎn)10分 執(zhí)行,注:1表示星期天
0 10 3 ? * 1#3 每個(gè)月的第三個(gè)星期,星期天 執(zhí)行,#號(hào)只能出現(xiàn)在星期的位置
在此我要說明,springBoot 中的 schedule 支持的 cron 表達(dá)式和這個(gè)不太相符,官方說的星期表示,1是周天,依次類推,但是我在測(cè)試過程中,1實(shí)際上代表的就是周一,口說無憑
那我就來貼代碼和測(cè)試結(jié)果吧.
@Component @EnableScheduling public class Task { private static final Logger LOGGER = MyLogger.getLogger(Task.class); @Scheduled(cron = "0 46 20 ? * 1") public void task() { LOGGER.info("聽說今天是周日"); }
測(cè)試結(jié)果:
2017-05-08 20:46:00.006 INFO 18838 --- [pool-1-thread-1] com.yiyexy.task.Task : 聽說今天是周日
按照上面的解釋來講,第六域是星期,并且值是1那么代表是周日運(yùn)行,但是我的運(yùn)行結(jié)果表明是周一運(yùn)行,我在此表示很無奈。
最后我覺得用單詞來表示周幾,這樣就不會(huì)出這種問題了,于是
@Component @EnableScheduling public class Task { private static final Logger LOGGER = MyLogger.getLogger(Task.class); @Scheduled(cron = "0 49 20 ? * MON") public void task() { LOGGER.info("聽說今天是周日"); } }
測(cè)試結(jié)果:
2017-05-08 20:49:00.005 INFO 18864 --- [pool-1-thread-1] com.yiyexy.task.Task : 聽說今天是周日
好了,這個(gè)坑就記錄到這吧,最后奉上一句,時(shí)間是檢驗(yàn)真理的唯一標(biāo)準(zhǔn)。
好了,下面看下Spring Boot 定時(shí)任務(wù)的使用
本文介紹在 Spring Boot 中如何使用定時(shí)任務(wù),使用非常簡(jiǎn)單,就不做過多說明了。
下面是代碼類:
package org.springboot.sample.config; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.scheduling.annotation.Scheduled; /** * 定時(shí)任務(wù)配置類 * * @author 單紅宇(365384722) * @myblog http://blog.csdn.net/catoop/ * @create 2016年3月21日 */ @Configuration @EnableScheduling // 啟用定時(shí)任務(wù) public class SchedulingConfig { private final Logger logger = LoggerFactory.getLogger(getClass()); @Scheduled(cron = "0/20 * * * * ?") // 每20秒執(zhí)行一次 public void scheduler() { logger.info(">>>>>>>>>>>>> scheduled ... "); } }
總結(jié)
以上所述是小編給大家介紹的SpringBoot 定時(shí)任務(wù)遇到的坑,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
java 中 String format 和Math類實(shí)例詳解
這篇文章主要介紹了java 中 String format 和Math類實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06Java基于享元模式實(shí)現(xiàn)五子棋游戲功能實(shí)例詳解
這篇文章主要介紹了Java基于享元模式實(shí)現(xiàn)五子棋游戲功能,較為詳細(xì)的分析了享元模式的概念、功能并結(jié)合實(shí)例形式詳細(xì)分析了Java使用享元模式實(shí)現(xiàn)五子棋游戲的具體操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-05-05Java項(xiàng)目中獲取路徑的絕對(duì)路徑問題和相對(duì)路徑問題
這篇文章主要介紹了如何Java項(xiàng)目中獲取文件地址,在 Java 項(xiàng)目中我們經(jīng)常會(huì)讀取配置文件,但是文件的路徑在獲取時(shí)我們是怎么得到的?下面我們就一起進(jìn)入文章學(xué)習(xí)該內(nèi)容吧,需要的朋友可以參考下2022-02-02Intellij IDEA 與maven 版本不符 Unable to import maven project See
這篇文章主要介紹了Intellij IDEA 與maven 版本不符 Unable to import maven project See logs for details: No implementation for org.apache.maven.model.path.PathTranslator was bound,本文通過圖文給大家分享解決方案,需要的朋友可以參考下2020-08-08springboot2.x整合redis知識(shí)點(diǎn)講解
在本篇文章中小編給大家分享的是一篇關(guān)于springboot2.x整合redis知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2020-01-01bool當(dāng)成函數(shù)參數(shù)錯(cuò)誤理解
經(jīng)常會(huì)在函數(shù)的參數(shù)里使用bool參數(shù),這會(huì)大大地降低代碼的可讀性2012-11-11java反射之Method的invoke方法實(shí)現(xiàn)教程詳解
這篇文章主要給大家介紹了關(guān)于java反射之Method的invoke方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Java 中的 BufferedReader 介紹_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
BufferedReader 是緩沖字符輸入流。它繼承于Reader。接下來通過本文給大家介紹BufferedReader的相關(guān)知識(shí),需要的朋友參考下吧2017-05-05一個(gè)簡(jiǎn)陋的java圖書管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了一個(gè)簡(jiǎn)陋的java圖書管理系統(tǒng),簡(jiǎn)單的實(shí)現(xiàn)功能測(cè)試,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07