解決SpringBoot中的Scheduled單線程執(zhí)行問題
問題描述
在一次SpringBoot中使用Scheduled定時(shí)任務(wù)時(shí),發(fā)現(xiàn)某一個(gè)任務(wù)出現(xiàn)執(zhí)行占用大量資源,會(huì)導(dǎo)致其他任務(wù)也執(zhí)行失敗。
類似于以下模擬場(chǎng)景,test1定時(shí)任務(wù)模擬有五秒鐘執(zhí)行時(shí)間,這時(shí)會(huì)同步影響到test2任務(wù)的執(zhí)行,導(dǎo)致test2任務(wù)也變成五秒執(zhí)行一次。
@Scheduled(fixedRate = 1000) public void test1() throws InterruptedException { log.info(Thread.currentThread().getName() + " | task01 "); Thread.sleep(5000); } @Scheduled(fixedRate = 2000) public void test2() { log.info(Thread.currentThread().getName() + " | task02 "); }
原因分析:
經(jīng)過相關(guān)資料查閱,發(fā)現(xiàn)Scheduled定時(shí)任務(wù)默認(rèn)的線程數(shù)只有一個(gè),進(jìn)行定時(shí)任務(wù)調(diào)度時(shí)會(huì)同步的去調(diào)度,一個(gè)執(zhí)行完成后再執(zhí)行另一個(gè),這是導(dǎo)致該問題的直接原因。
解決方案:
@Bean public TaskScheduler taskScheduler() { ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler(); // 設(shè)置線程數(shù)量 taskScheduler.setPoolSize(50); return taskScheduler; }
添加一個(gè)配置,設(shè)置TaskScheduler線程數(shù)為多個(gè),這樣再執(zhí)行時(shí)就會(huì)異步執(zhí)行了,各個(gè)定時(shí)任務(wù)間互不影響。
補(bǔ)充:
使用以下Java的util包中帶的TimerTask也可以進(jìn)行定時(shí)任務(wù)的執(zhí)行。
以下參數(shù)中TimerTask是執(zhí)行的任務(wù),0表示第一次延遲0秒執(zhí)行,3000表示每3000毫秒執(zhí)行一次。
// true表示定時(shí)任務(wù)創(chuàng)建為守護(hù)線程 Timer timer = new Timer(true); //timer.scheduleAtFixedRate(); timer.schedule(new TimerTask() { @Override public void run() { logger.info(Thread.currentThread().getName() + "************"+ftpGaFilePrefix); } }, 0, 3000);
到此這篇關(guān)于SpringBoot中的Scheduled單線程執(zhí)行的文章就介紹到這了,更多相關(guān)SpringBoot Scheduled單線程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot定時(shí)任務(wù)動(dòng)態(tài)擴(kuò)展ScheduledTaskRegistrar詳解
- SpringBoot中定時(shí)任務(wù)@Scheduled注解的使用解讀
- SpringBoot中使用@scheduled定時(shí)執(zhí)行任務(wù)的坑
- 聊聊SpringBoot的@Scheduled的并發(fā)問題
- SpringBoot項(xiàng)目中使用@Scheduled讀取動(dòng)態(tài)參數(shù)
- springboot定時(shí)任務(wù)@Scheduled執(zhí)行多次的問題
- SpringBoot?Schedule調(diào)度任務(wù)的動(dòng)態(tài)管理
相關(guān)文章
SpringBoot集成swagger-ui以及swagger分組顯示操作
這篇文章主要介紹了SpringBoot集成swagger-ui以及swagger分組顯示操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09MyBatis-Plus邏輯刪除和字段自動(dòng)填充的實(shí)現(xiàn)
本文主要介紹了MyBatis-Plus邏輯刪除和字段自動(dòng)填充的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08使用GenericObjectPool避免泄漏設(shè)置方法
這篇文章主要為大家介紹了使用GenericObjectPool避免泄漏的設(shè)置方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09一文學(xué)會(huì)處理SpringBoot統(tǒng)一返回格式
這篇文章主要介紹了一文學(xué)會(huì)處理SpringBoot統(tǒng)一返回格式,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08深入理解Java class文件格式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
對(duì)于理解JVM和深入理解Java語言, 學(xué)習(xí)并了解class文件的格式都是必須要掌握的功課2017-06-06SpringBoot監(jiān)控Tomcat活動(dòng)線程數(shù)來判斷是否完成請(qǐng)求處理方式
這篇文章主要介紹了SpringBoot監(jiān)控Tomcat活動(dòng)線程數(shù)來判斷是否完成請(qǐng)求處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02mybatisPlus自動(dòng)填充更新時(shí)間的示例代碼
本文主要介紹了mybatisPlus自動(dòng)填充更新時(shí)間,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09