您好,登錄后才能下訂單哦!
這篇文章主要介紹“SpringBoot通過@Scheduled怎么實現定時任務及單線程運行”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“SpringBoot通過@Scheduled怎么實現定時任務及單線程運行”文章能幫助大家解決問題。
Scheduled定時任務是Spring boot自身提供的功能,所以不需要引入Maven依賴包
在項目入口main方法上加注解
@EnableScheduling //開啟定時任務
fixedRate就是每隔多長時間執行一次。(開始------->X時間------>再開始)。如果間隔時間小于任務執行時間,上一次任務執行完成下一次任務就立即執行。如果間隔時間大于任務執行時間,就按照每隔X時間運行一次。
而fixedDelay是當任務執行完畢后一段時間再次執行。(開始—>結束(隔一分鐘)開始----->結束)。上一次執行任務未完成,下一次任務不會開始。
舉例說明
表達式 | 說明 |
---|---|
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 | 每個月的第三個星期,星期天 執行,#號只能出現在星期的位置 |
第一位,表示秒,取值0-59
第二位,表示分,取值0-59
第三位,表示小時,取值0-23
第四位,日期天/日,取值1-31
第五位,日期月份,取值1-12
第六位,星期,取值1-7,星期一,星期二…,注:不是第1周,第二周的意思,另外:1表示星期天,2表示星期一。
第七位,年份,可以留空,取值1970-2099
cron中,還有一些特殊的符號,含義如下:
()星號:可以理解為每的意思,每秒,每分,每天,每月,每年…
(?)問號:問號只能出現在日期和星期這兩個位置。
(-)減號:表達一個范圍,如在小時字段中使用“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
cron表達式在線:http://tools.jb51.net/code/Quartz_Cron_create
@Component public class ScheduledJobs { //表示方法執行完成后5秒再開始執行 @Scheduled(fixedDelay=5000) public void fixedDelayJob() throws InterruptedException{ System.out.println("fixedDelay 開始:" + new Date()); Thread.sleep(10 * 1000); System.out.println("fixedDelay 結束:" + new Date()); } //表示每隔3秒 @Scheduled(fixedRate=3000) public void fixedRateJob()throws InterruptedException{ System.out.println("===========fixedRate 開始:" + new Date()); Thread.sleep(5 * 1000); System.out.println("===========fixedRate 結束:" + new Date()); } //表示每隔10秒執行一次 @Scheduled(cron="0/10 * * * * ? ") public void cronJob(){ System.out.println("=========================== ...>>cron...." + new Date()); } }
運行結果如下:從運行結果上看,并未按照預期的時間規律運行。仔細看線程打印,竟然所有的定時任務使用的都是一個線程,所以彼此互相影響。
===========fixedRate 結束:Tue Jul 09 19:53:04 CST 2019pool-1-thread-1
fixedDelay 開始:Tue Jul 09 19:53:04 CST 2019pool-1-thread-1
fixedDelay 結束:Tue Jul 09 19:53:14 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:14 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:16 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:16 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:18 CST 2019pool-1-thread-1
=========================== ...>>cron....Tue Jul 09 19:53:18 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:18 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:20 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:20 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:22 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:22 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:24 CST 2019pool-1-thread-1
fixedDelay 開始:Tue Jul 09 19:53:24 CST 2019pool-1-thread-1
fixedDelay 結束:Tue Jul 09 19:53:34 CST 2019pool-1-thread-1
=========================== ...>>cron....Tue Jul 09 19:53:34 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:34 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:36 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:36 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:38 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:38 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:40 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:40 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:42 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:42 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:44 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:44 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:46 CST 2019pool-1-thread-1
===========fixedRate 開始:Tue Jul 09 19:53:46 CST 2019pool-1-thread-1
===========fixedRate 結束:Tue Jul 09 19:53:48 CST 2019pool-1-thread-1
fixedDelay 開始:Tue Jul 09 19:53:48 CST 2019pool-1-thread-1
fixedDelay 結束:Tue Jul 09 19:53:58 CST 2019pool-1-thread-1
=========================== ...>>cron....Tue Jul 09 19:53:58 CST 2019pool-1-thread-1
@Configuration @EnableScheduling public class ScheduleConfig implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.setScheduler(scheduledTaskExecutor()); } @Bean public Executor scheduledTaskExecutor() { return Executors.newScheduledThreadPool(3); //指定線程池大小 } }
再次運行上面的程序,運行時間規律就符合期望了。
關于“SpringBoot通過@Scheduled怎么實現定時任務及單線程運行”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。