@Schedule?如何解決定時任務(wù)推遲執(zhí)行
前言
SpringBoot 實現(xiàn)定時任務(wù)很簡單,只需要使用**@Scheduled**注解即可,但是該注解是實現(xiàn)的定時任務(wù)默認是單線程的,也就意味著多個定時任務(wù)執(zhí)行時就可能導(dǎo)致線程堵塞,延緩定時任務(wù)的執(zhí)行。
下面就一步一步來解決這個問題。
一、@Scheduled
1、代碼
// 啟用定時任務(wù) @EnableScheduling @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@Component public class Task { Logger logger = LoggerFactory.getLogger(Task.class); // 每五秒執(zhí)行一次 @Scheduled(cron = "0/5 * * * * ?") public void taskTestA() throws InterruptedException { logger.info("A:"); TimeUnit.SECONDS.sleep(20); } // 每十秒執(zhí)行一次 @Scheduled(cron = "0/10 * * * * ?") public void taskTestB() { logger.info("B:"); } }
2、結(jié)果
由圖可知,首先這兩個定時任務(wù)都是單線程的,但是當定時A執(zhí)行了一次后,由于定時A中有個休眠20秒,然后執(zhí)行定時任務(wù)B,所以線程A第二次執(zhí)行在25秒后才執(zhí)行,這就是由于@Scheduled定時任務(wù)是單線程,造成的線程堵塞,導(dǎo)致定時任務(wù)推遲執(zhí)行。
二、@Scheduled + 配置線程池
1、代碼
和前面@Scheduled 相比,僅僅增加了配置線程池
// 若不設(shè)置默認為單線程,這里設(shè)置使用線程池,大小為4 spring: task: scheduling: pool: size: 4
2、結(jié)果
由圖可知,增加了線程池,這樣使得定時任務(wù)A和B在不同的線程進行執(zhí)行,但是定時任務(wù)A的第二次執(zhí)行,依舊是在25秒后執(zhí)行,由此可知這種方式其實解決的是不同定時任務(wù)之間的進程堵塞。
三、@Scheduled + @Async
1、代碼
和前面相比,僅僅增加了配置
// 啟用異步,動態(tài)創(chuàng)建線程 @EnableAsync @EnableScheduling @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@Component public class Task { Logger logger = LoggerFactory.getLogger(Task.class); // 異步,動態(tài)創(chuàng)建線程 @Async @Scheduled(cron = "0/5 * * * * ?") public void taskTestA() throws InterruptedException { logger.info("A:"); TimeUnit.SECONDS.sleep(20); } // 異步,動態(tài)創(chuàng)建線程 @Async @Scheduled(cron = "0/10 * * * * ?") public void taskTestB() { logger.info("B:"); } }
2、結(jié)果
由圖可知,啟用了異步,使用了spring 默認的線程池,動態(tài)創(chuàng)建線程,這樣使得定時任務(wù)A和B在不同的線程進行執(zhí)行,同時任務(wù)A的多次運行也是異步執(zhí)行,這樣就能確保所有定時任務(wù)不會延遲執(zhí)行!
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
idea2020安裝MybatisCodeHelper插件的圖文教程
這篇文章主要介紹了idea2020安裝MybatisCodeHelper插件的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09Mybatis中resultMap標簽和sql標簽的設(shè)置方式
這篇文章主要介紹了Mybatis中resultMap標簽和sql標簽的設(shè)置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01mybatis實現(xiàn)獲取入?yún)⑹荓ist和Map的取值
這篇文章主要介紹了mybatis實現(xiàn)獲取入?yún)⑹荓ist和Map的取值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06Spring Cloud分布式定時器之ShedLock的實現(xiàn)
這篇文章主要介紹了Spring Cloud分布式定時器之ShedLock的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2021-03-03java中ExecutorService創(chuàng)建方法總結(jié)
在本篇文章里小編給大家整理了一篇關(guān)于java中ExecutorService創(chuàng)建方法總結(jié),有興趣的朋友們可以參考下。2021-01-01基于Properties類操作.properties配置文件方法總結(jié)
這篇文章主要介紹了Properties類操作.properties配置文件方法總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09