分布式調(diào)度器之Spring Task 的使用詳解
Spring Task是 Spring 框架的一個組件,它為任務(wù)調(diào)度提供了支持,使開發(fā)者能 創(chuàng)建后臺任務(wù) 或 定期執(zhí)行任務(wù)
1、啟動類(App.java)上加@EnableScheduling注解: 開啟基于注解的任務(wù)調(diào)度器
默認(rèn)情況下,系統(tǒng)會自動啟動一個線程,調(diào)度執(zhí)行項目中定義的所有定時任務(wù)
這個注解 是SpringBoot內(nèi)置的 不需要依賴任何的starter包
2、同步定時任務(wù)
需要在定時執(zhí)行的方法上 添加@Scheduled
注解
定時執(zhí)行的方法不能有參數(shù),并且一般沒有返回值
定時任務(wù)所在的類要作為 Spring Bean,在類上添加@Component
注解即可,即:定時方法所在的類,要放到IOC容器里面
注意:使用@Scheduled
注解形式的定時任務(wù),默認(rèn)是單線程來執(zhí)行項目中所有的定時任務(wù)。
即使如果同一時刻有兩個定時任務(wù)需要執(zhí)行,那么只能其中一個定時任務(wù)完成之后再執(zhí)行下一個定時任務(wù)。
如果項目只有一個定時任務(wù)還好。若定時任務(wù)增多時,如果一個任務(wù)被阻塞,則會導(dǎo)致其他任務(wù)無法正常執(zhí)行。
若要改變這種行為,使得定時任務(wù)能夠并發(fā)執(zhí)行,可以配置任務(wù)調(diào)度線程池,來解決以上問題。首先配置一個線程池
package com.***.springtask; import lombok.extern.slf4j.Slf4j; import org.springframework.scheduling.annotation.Async; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component @Slf4j @EnableAsync //開啟異步支持 @EnableScheduling //開啟定時任務(wù)支持 public class ScheduledTask { int i = 1; //@Scheduled(fixedRate = 5000, initialDelay = 15*1000) public void task1(){ // i++; // if(i > 5){ // ThreadUtil.safeSleep(8*1000); // } log.debug("task1執(zhí)行了{(lán)}次,{}",i,Thread.currentThread().getId()); } @Scheduled(cron = "0/5 * * * * ?") @Async("asyncScheduledPool") public void task2(){ // ThreadUtil.safeSleep(8*1000); log.debug("task2執(zhí)行了,{}",Thread.currentThread().getId()); } }
3、多線程(異步)定時任務(wù)
3.1 配置線程池
package com.***.config; import org.springframework.context.annotation.Bean; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import org.springframework.stereotype.Component; import java.util.concurrent.Executor; import java.util.concurrent.ThreadPoolExecutor; @Component public class ExecutorConfig { //定義核心線程數(shù) public static final int CORE_POOL_SIZE = 10; // 最大線程數(shù) public static final int MAX_POOL_SIZE = 20; // 任務(wù)隊列容量大小 public static final int QUEUE_MAX_COUNT = 100; @Bean("asyncScheduledPool") public Executor asyncScheduledPool(){ //自定義線程池 ThreadPoolTaskExecutor threadPoolExecutor = new ThreadPoolTaskExecutor(); //設(shè)置核心線程數(shù) threadPoolExecutor.setCorePoolSize(CORE_POOL_SIZE); //設(shè)置最大線程數(shù) : 長工 + 臨時工 threadPoolExecutor.setMaxPoolSize(MAX_POOL_SIZE); //設(shè)置任務(wù)隊列容量大小 threadPoolExecutor.setQueueCapacity(QUEUE_MAX_COUNT); //設(shè)置線程的名稱前綴 threadPoolExecutor.setThreadNamePrefix("myTask-"); //設(shè)置拒絕策略 threadPoolExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy()); return threadPoolExecutor; } }
3.2 開啟異步支持
要在 Spring Boot 應(yīng)用中啟用異步方法調(diào)用,需在啟動類上添加 @EnableAsync
注解
3.3 定義異步方法
在服務(wù)類中定義一個方法,并使用 @Async
注解標(biāo)記它以實現(xiàn)異步執(zhí)行
4、Api說明
4.1 fixedDelay
@Scheduled(fixedDelay = 4000)
4.2 fixedRate
@Scheduled(fixedRate = 10000)
4.3 initialDelay
@Scheduled(initialDelay=1000, fixedRate=5000) //第一次延遲1秒后執(zhí)行,之后按fixedRate的規(guī)則每5秒執(zhí)行一次
4.4 cron(掌握)
cron表達(dá)式 ① 格式
Seconds Minutes Hours Day Month Week
② 特殊符號
*:任意值
-:范圍,eg:3-5指3點到5點執(zhí)行
,:枚舉,eg:3,5指3點和5點執(zhí)行
/:增量,eg:3/5從第3秒開始每隔5秒執(zhí)行一次
?:忽略,且只能在 日期域 或 星期域 只用
③ 練習(xí) 標(biāo)準(zhǔn)格式: * * * * * ?
周一至周五的上午10:15觸發(fā)
0 15 10 ? * 2-6
表示在每月的1日的凌晨2點調(diào)整任務(wù)
0 0 2 1 * ?
朝九晚五工作時間內(nèi)每半小時
0 0/30 9-16 * * ?
每天上午10點,下午2點,4點
0 0 10,14,16 * * ?
表示每個星期三中午12點
0 0 12 ? * 4
在每天下午2點到下午2:59期間的每1分鐘觸發(fā)
0 /1 14-15 * * ?
在每天下午2點到下午2:05期間的每1分鐘觸發(fā)
0 0-5/1 14 * * ?
在每天下午2點到下午2:55期間的每5分鐘觸發(fā)
0 0-55/5 14 * * ?
在每天下午2點到2:55期間和下午6點到6:55期間的每5分鐘觸發(fā)
0 0-55/5 14,18 * * ?
到此這篇關(guān)于分布式調(diào)度器之Spring Task 的使用詳解的文章就介紹到這了,更多相關(guān)Spring Task 使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中的Unsafe在安全領(lǐng)域的使用總結(jié)和復(fù)現(xiàn)(實例詳解)
unsafe里面有很多好用的方法,比如allocateInstance可以直接創(chuàng)建實例對象,defineAnonymousClass可以創(chuàng)建一個VM匿名類(VM?Anonymous?Class),以及直接從內(nèi)存級別修改對象的值。這篇文章主要介紹了Java中的Unsafe在安全領(lǐng)域的一些應(yīng)用總結(jié)和復(fù)現(xiàn),需要的朋友可以參考下2022-03-03Spring中的@ConditionalOnProperty作用和用法詳解
這篇文章主要介紹了Spring中的@ConditionalOnProperty作用和用法詳解,在spring boot中有時候需要控制配置類是否生效,可以使用@ConditionalOnProperty注解來控制@Configuration是否生效,需要的朋友可以參考下2023-11-11Java中比較運(yùn)算符compareTo()、equals()與==的區(qū)別及應(yīng)用總結(jié)
這篇文章主要給大家介紹了關(guān)于Java中比較運(yùn)算符compareTo()、equals()與==的區(qū)別及應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09java多線程編程之使用runnable接口創(chuàng)建線程
實現(xiàn)Runnable接口的類必須使用Thread類的實例才能創(chuàng)建線程,通過Runnable接口創(chuàng)建線程分為以下兩步2014-01-01淺談SpringBoot中的Bean初始化方法?@PostConstruct
這篇文章主要介紹了SpringBoot中的Bean初始化方法?@PostConstruct,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11Spring中allowedOriginPatterns和allowedOrigins方法有何不同詳解
這篇文章主要給大家介紹了關(guān)于Spring中allowedOriginPatterns和allowedOrigins方法有何不同,allowedOriginPatterns和allowedOrigins都是用來設(shè)置允許跨域請求的來源,需要的朋友可以參考下2023-10-10