SpringBoot 定時任務

SpringBoot 定時任務

1.如何定時任務

1.1 開啓定時任務

@EnableScheduling  //開啓定時任務
@SpringBootApplication
public class  ManagerApplication {

    private static Logger logger = LoggerFactory.getLogger(ManagerApplication.class);


    public static void main(String[] args) {
        SpringApplication.run(ManagerApplication.class, args);
        logger.info("------------------------------------------------------------------");
        logger.info("application start success...");
        logger.info("--" +
                "----------------------------------------------------------------");
        try {
            System.in.read();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }


}


1.2 @Scheduled(預定的)選擇要定時執行的任務

@Component
public class ScheduledService {

    
   @Scheduled(fixedRate = 1000*60*60)
    public void scheduled1() {
    }
}

== 定時在前一個任務阻塞時 會等待他,這個時候可以通過@Async 用異步來解決 ==

2.@Scheduled 參數詳解

2.1 cron

2.1.1 cron表達式語法

[] [] [小時] [] [] [] []
序號 說明 是否必填 通配符
1 Y 0-59 , - * /
2 Y 0-59 , - * /
3 小時 Y 0-24 , - * /
4 Y 1-31 , - * /
5 Y 1-12/JAN-DEC(英文的1-12月) , - * / L W
6 星期 Y 1-7/SUN-SAT , - * / ? L #
7 N 1970-2099 , - * /

通配符說明
, :表示指定多個值, 例如:在分的字段上設置 1,2,3,則1,2,3 分鐘都會運行。
*:表示所有值。 例如:在分的字段上設置 *,表示每一分鐘都會觸發。
? :表示不指定值。只能在日和星期(周)中指定使用
-表示區間。例如:在分鐘上設置1-10表示 1到10分鐘都會 運行。
/ 用於遞增觸發。例如:在分上面設置”1/1” 表示從1分鐘開始,每增1分鐘觸發一次(1,2,3,4…)
L: 表示最後(last)的意思(只支持月和星期)。在日字段設置上,表示當月的最後一天, 在星期字段上表示星期六,相當於”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相同。
== 日和星期 只能存在一個 另一個用 ? ==

2.2 zone(地區)

cron表達式會基於該時區解析

2.3 fixedDelay

上一次執行後多少毫秒後執行注意是上一次執行完畢後

@Scheduled(fixedDelay = 2000)
開始,現在時間是 : 11:37:48scheduling-1
2019-12-12 11:37:48.884  INFO 18064 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8086 (http) with context path ''
2019-12-12 11:37:48.891  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : Started ManagerApplication in 7.266 seconds (JVM running for 10.023)
2019-12-12 11:37:48.894  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
2019-12-12 11:37:48.895  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : application start success...
2019-12-12 11:37:48.895  INFO 18064 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
結束,現在時間是 : 11:37:51scheduling-1
開始,現在時間是 : 11:37:53scheduling-1
結束,現在時間是 : 11:37:56scheduling-1
開始,現在時間是 : 11:37:58scheduling-1
結束,現在時間是 : 11:38:01scheduling-1

2.4 fixedRate

上一次執行開始多少毫秒後執行注意是上一次執行開始後

  @Scheduled(fixedRate=2000)
    @Async
    public void test()
    {   System.out.println("開始,現在時間是 : "+format.format(new Date())+""+Thread.currentThread().getName());
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("結束,現在時間是 : "+format.format(new Date())+""+Thread.currentThread().getName());
    }
開始,現在時間是 : 11:43:26ThreadPoolTaskExecutor-1
2019-12-12 11:43:26.379  INFO 17976 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8086 (http) with context path ''
2019-12-12 11:43:26.385  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : Started ManagerApplication in 7.273 seconds (JVM running for 9.84)
2019-12-12 11:43:26.389  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
2019-12-12 11:43:26.390  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : application start success...
2019-12-12 11:43:26.390  INFO 17976 --- [           main] com.wlgj.manager.ManagerApplication      : ------------------------------------------------------------------
開始,現在時間是 : 11:43:28ThreadPoolTaskExecutor-2
結束,現在時間是 : 11:43:29ThreadPoolTaskExecutor-1
開始,現在時間是 : 11:43:30ThreadPoolTaskExecutor-3
結束,現在時間是 : 11:43:31ThreadPoolTaskExecutor-2
開始,現在時間是 : 11:43:32ThreadPoolTaskExecutor-1
結束,現在時間是 : 11:43:33ThreadPoolTaskExecutor-3
開始,現在時間是 : 11:43:34ThreadPoolTaskExecutor-2
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章