SpringBoot定時任務

2021-10-23 16:11:52 字數 3308 閱讀 6641

@enablescheduling

執行方法和所在類的配置(

執行時間的設定(cron表示式)

只有加了這個註解,才能在工程中使用定時方法
//開啟對定時任務的支援

@enablescheduling

//@enableswagger2

public static void main(string args)

}

//把這個類放在springboot容器中管理

@component

public class test

private int count = 0;

@scheduled(cron = "*/6 * * * * ?")

private void process()

}

在上面的定時任務中,我們在方法上使用@scheduled註解來設定任務的執行時間,並且使用三種屬性配置方式:

**注意事項:**

每乙個域都使用數字,但還可以出現如下特殊字元,它們的含義是:

(1)*:表示匹配該域的任意值。假如在minutes域使用*, 即表示每分鐘都會觸發事件。

(2)?:只能用在dayofmonth和dayofweek兩個域。它也匹配域的任意值,但實際不會。因為dayofmonth和dayofweek會相互影響。例如想在每月的20日觸發排程,不管20日到底是星期幾,則只能使用如下寫法: 13 13 15 20 * ?, 其中最後一位只能用?,而不能使用*,如果使用*表示不管星期幾都會觸發,實際上並不是這樣。

(3)-:表示範圍。例如在minutes域使用5-20,表示從5分到20分鐘每分鐘觸發一次

(4)/:表示起始時間開始觸發,然後每隔固定時間觸發一次。例如在minutes域使用5/20,則意味著5分鐘觸發一次,而25,45等分別觸發一次.

(5),:表示列出列舉值。例如:在minutes域使用5,20,則意味著在5和20分每分鐘觸發一次。

(6)l:表示最後,只能出現在dayofweek和dayofmonth域。如果在dayofweek域使用5l,意味著在最後的乙個星期四觸發。

(7)w:表示有效工作日(周一到周五),只能出現在dayofmonth域,系統將在離指定日期的最近的有效工作日觸發事件。例如:在 dayofmonth使用5w,如果5日是星期六,則將在最近的工作日:星期五,即4日觸發。如果5日是星期天,則在6日(周一)觸發;如果5日在星期一到星期五中的一天,則就在5日觸發。另外一點,w的最近尋找不會跨過月份 。

(8)lw:這兩個字元可以連用,表示在某個月最後乙個工作日,即最後乙個星期五。

(9)#:用於確定每個月第幾個星期幾,只能出現在dayofmonth域。例如在4#2,表示某月的第二個星期三。

**常用表示式例子**

(1)**0 0 2 1 \* ? \*** 表示在每月的1日的凌晨2點調整任務

(2)**0 15 10 ? \* mon-fri** 表示周一到周五每天上午10:15執行作業

(3)**0 15 10 ? 6l 2002-2006** 表示2002-2023年的每個月的最後乙個星期五上午10:15執行作

(4)**0 0 10,14,16 \* \* ?** 每天上午10點,下午2點,4點

(5)**0 0/30 9-17 \* \* ?** 朝九晚五工作時間內每半小時

(6)**0 0 12 ? \* wed** 表示每個星期三中午12點

(7)**0 0 12 \* \* ?** 每天中午12點觸發

(8)**0 15 10 ? \* \*** 每天上午10:15觸發

(9)**0 15 10 \* \* ?** 每天上午10:15觸發

(10)**0 15 10 \* \* ? \*** 每天上午10:15觸發

(11)**0 15 10 \* \* ? 2005** 2023年的每天上午10:15觸發

(12)**0 \* 14 \* \* ?** 在每天下午2點到下午2:59期間的每1分鐘觸發

(13)**0 0/5 14 \* \* ?** 在每天下午2點到下午2:55期間的每5分鐘觸發

(14)**0 0/5 14,18 \* \* ?** 在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發

(15)**0 0-5 14 \* \* ?** 在每天下午2點到下午2:05期間的每1分鐘觸發

(16)**0 10,44 14 ? 3 wed** 每年三月的星期三的下午2:10和2:44觸發

(17)**0 15 10 ? \* mon-fri** 周一至周五的上午10:15觸發

(18)**0 15 10 15 \* ?** 每月15日上午10:15觸發

(19)**0 15 10 l \* ?** 每月最後一日的上午10:15觸發

(20)**0 15 10 ? \* 6l** 每月的最後乙個星期五上午10:15觸發

(21)**0 15 10 ? \* 6l 2002-2005** 2023年至2023年的每月的最後乙個星期五上午10:15觸發

(22)**0 15 10 ? \* 6#3** 每月的第三個星期五上午10:15觸發

**注:**

(1)有些子表示式能包含一些範圍或列表

例如:子表示式(天(星期))可以為 「mon-fri」,「mon,wed,fri」,「mon-wed,sat」

「*」字元代表所有可能的值。因此,「*」在子表示式(月)裡表示每個月的含義,「*」在子表示式(天(星期))表示星期的每一天

(2) 「/」字元用來指定數值的增量

例如:在子表示式(分鐘)裡的「0/15」表示從第0分鐘開始,每15分鐘

在子表示式(分鐘)裡的「3/20」表示從第3分鐘開始,每20分鐘(它和「3,23,43」)的含義一樣

(3)「?」字元僅被用於天(月)和天(星期)兩個子表示式,表示不指定值

當2個子表示式其中之一被指定了值以後,為了避免衝突,需要將另乙個子表示式的值設為「?」

(4)「l」 字元僅被用於天(月)和天(星期)兩個子表示式,它是單詞「last」的縮寫

但是它在兩個子表示式裡的含義是不同的。 在天(月)子表示式中,「l」表示乙個月的最後一天

在天(星期)自表示式中,「l」表示乙個星期的最後一天,也就是sat如果在「l」前有具體的內容,它就具有其他的含義了。例如:「6l」表示這個月的倒數第6天,「fril」表示這個月的最乙個星期五 注意:在使用「l」引數時,不要指定列表或範圍,因為這會導致問題

SpringBoot 定時任務

第一步 在啟動類中加入如下註解 enablescheduling public class public static void main string args 注意 enablescheduling必須加,否則無法開啟定時任務 第二步 建立定時任務 component public class ...

Spring boot定時任務

最近做專案,需要使用定時任務,半個小時去更新redis資料,於是便學習了一下經驗。希望可以幫到你們。定時任務可使用三種 created by fx on 2017 9 4.component allargsconstructor public class featuredatatask 實現乙個任務...

Spring boot 定時任務

1.在啟動類上加 enablescheduling註解 package com.example.demo import org.springframework.scheduling.annotation.enablescheduling enablescheduling public static ...