@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 ...