您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“SpringBoot定時任務會遇到什么問題”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“SpringBoot定時任務會遇到什么問題”這篇文章吧。
前言
springboot已經支持了定時任務Schedule模塊,一般情況已經完全能夠滿足我們的實際需求。今天就記錄一下我使用 schedule 時候踩的坑吧。
想要使用定時,我們首先要開啟支持,其實就是在啟動類上面加個注解就 Ok。
@SpringBootApplication @EnableScheduling public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
這篇博客的主題是記錄踩的坑,具體定時任務怎么使用我就不寫了,有需要的參考我的博客 Spring定時任務 。
今天踩的這個坑和 cron 表達式有關,我們就先來看看 cron 表達式的解釋吧:
Cron表達式是一個字符串,字符串以5或6個空格隔開,分為6或7個域,每一個域代表一個含義
解釋
* 第一位,表示秒,取值0-59
* 第二位,表示分,取值0-59
* 第三位,表示小時,取值0-23
* 第四位,日期天/日,取值1-31
* 第五位,日期月份,取值1-12
* 第六位,星期,取值1-7,星期一,星期二...,注:不是第1周,第二周的意思
另外:1表示星期天,2表示星期一。
* 第7為,年份,可以留空,取值1970-2099
(*)星號:可以理解為每的意思,每秒,每分,每天,每月,每年...
(?)問號:問號只能出現在日期和星期這兩個位置,表示這個位置的值不確定,每天3點執行,所以第六位星期的位置,我們是不需要關注的,就是不確定的值。同時:日期和星期是兩個相互排斥的元素,通過問號來表明不指定值。比如,1月10日,比如是星期1,如果在星期的位置是另指定星期二,就前后沖突矛盾了。
(-)減號:表達一個范圍,如在小時字段中使用“10-12”,則表示從10到12點,即10,11,12
(,)逗號:表達一個列表值,如在星期字段中使用“1,2,4”,則表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是開始值,y是步長,比如在第一位(秒) 0/15就是,從0秒開始,每15秒,最后就是0,15,30,45,60 另:*/y,等同于0/y
注: 這個是官方解釋
0 0 3 * * ? 每天3點執行
0 5 3 * * ? 每天3點5分執行
0 5 3 ? * * 每天3點5分執行,與上面作用相同
0 5/10 3 * * ? 每天3點的 5分,15分,25分,35分,45分,55分這幾個時間點執行
0 10 3 ? * 1 每周星期天,3點10分 執行,注:1表示星期天
0 10 3 ? * 1#3 每個月的第三個星期,星期天 執行,#號只能出現在星期的位置
在此我要說明,springBoot 中的 schedule 支持的 cron 表達式和這個不太相符,官方說的星期表示,1是周天,依次類推,但是我在測試過程中,1實際上代表的就是周一,口說無憑
那我就來貼代碼和測試結果吧.
@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("聽說今天是周日"); }
測試結果:
2017-05-08 20:46:00.006 INFO 18838 --- [pool-1-thread-1] com.yiyexy.task.Task : 聽說今天是周日
按照上面的解釋來講,第六域是星期,并且值是1那么代表是周日運行,但是我的運行結果表明是周一運行,我在此表示很無奈。
最后我覺得用單詞來表示周幾,這樣就不會出這種問題了,于是
@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("聽說今天是周日"); } }
測試結果:
2017-05-08 20:49:00.005 INFO 18864 --- [pool-1-thread-1] com.yiyexy.task.Task : 聽說今天是周日
好了,這個坑就記錄到這吧,最后奉上一句,時間是檢驗真理的唯一標準。
好了,下面看下Spring Boot 定時任務的使用
本文介紹在 Spring Boot 中如何使用定時任務,使用非常簡單,就不做過多說明了。
下面是代碼類:
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; /** * 定時任務配置類 * * @author 單紅宇(365384722) * @myblog http://blog.csdn.net/catoop/ * @create 2016年3月21日 */ @Configuration @EnableScheduling // 啟用定時任務 public class SchedulingConfig { private final Logger logger = LoggerFactory.getLogger(getClass()); @Scheduled(cron = "0/20 * * * * ?") // 每20秒執行一次 public void scheduler() { logger.info(">>>>>>>>>>>>> scheduled ... "); } }
以上是“SpringBoot定時任務會遇到什么問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。