溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SpringBoot定時(shí)任務(wù)會(huì)遇到什么問題

發(fā)布時(shí)間:2021-07-08 10:20:13 來源:億速云 閱讀:137 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“SpringBoot定時(shí)任務(wù)會(huì)遇到什么問題”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“SpringBoot定時(shí)任務(wù)會(huì)遇到什么問題”這篇文章吧。

前言

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
(*)星號:可以理解為每的意思,每秒,每分,每天,每月,每年...
(?)問號:問號只能出現(xiàn)在日期和星期這兩個(gè)位置,表示這個(gè)位置的值不確定,每天3點(diǎn)執(zhí)行,所以第六位星期的位置,我們是不需要關(guān)注的,就是不確定的值。同時(shí):日期和星期是兩個(gè)相互排斥的元素,通過問號來表明不指定值。比如,1月10日,比如是星期1,如果在星期的位置是另指定星期二,就前后沖突矛盾了。
(-)減號:表達(dá)一個(gè)范圍,如在小時(shí)字段中使用“10-12”,則表示從10到12點(diǎn),即10,11,12
(,)逗號:表達(dá)一個(gè)列表值,如在星期字段中使用“1,2,4”,則表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是開始值,y是步長,比如在第一位(秒) 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í)行,#號只能出現(xiàn)在星期的位置

在此我要說明,springBoot 中的 schedule 支持的 cron 表達(dá)式和這個(gè)不太相符,官方說的星期表示,1是周天,依次類推,但是我在測試過程中,1實(shí)際上代表的就是周一,口說無憑

那我就來貼代碼和測試結(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("聽說今天是周日");
 }

測試結(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("聽說今天是周日");
 }
}

測試結(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ù),使用非常簡單,就不做過多說明了。

下面是代碼類:

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 ... ");
  }
}

以上是“SpringBoot定時(shí)任務(wù)會(huì)遇到什么問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI