摘要:多線程并發(fā)定時(shí)任務(wù)剛剛看了下實(shí)現(xiàn)定時(shí)任務(wù)的文章,感覺還不錯(cuò)。存在問題但是后來(lái)發(fā)現(xiàn)個(gè)問題,通過(guò)同時(shí)測(cè)試幾個(gè)任務(wù)發(fā)現(xiàn),所有的任務(wù)都是在同一個(gè)線程池中的同一個(gè)線程來(lái)完成的。
spring-boot | 多線程并發(fā)定時(shí)任務(wù)
剛剛看了下Spring Boot實(shí)現(xiàn)定時(shí)任務(wù)的文章,感覺還不錯(cuò)。Spring Boot 使用Spring自帶的Schedule來(lái)實(shí)現(xiàn)定時(shí)任務(wù)變得非常簡(jiǎn)單和方便。在這里個(gè)大家分享下。
開啟緩存注解@SpringBootApplication @EnableScheduling //開啟定時(shí)任務(wù) public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }編寫定時(shí)任務(wù)
@Component public class ScheduledTasks { private Logger logger = LoggerFactory.getLogger(ScheduledTasks.class); // cron接受cron表達(dá)式,根據(jù)cron表達(dá)式確定定時(shí)規(guī)則 @Scheduled(cron="0/5 * * * * ? ") //每5秒執(zhí)行一次 public void testCron() { DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); logger.info(sdf.format(new Date())+"*********每5秒執(zhí)行一次"); } }任務(wù)完成
啟動(dòng)項(xiàng)目,查看控制臺(tái)打印信息,發(fā)現(xiàn)定時(shí)任務(wù)已經(jīng)生效。spring boot 和Scheduled整合完畢。
存在問題但是后來(lái)發(fā)現(xiàn)個(gè)問題,通過(guò)同時(shí)測(cè)試幾個(gè)任務(wù)發(fā)現(xiàn),所有的任務(wù)都是在同一個(gè)線程池中的同一個(gè)線程來(lái)完成的。在實(shí)際開發(fā)過(guò)程中,我們當(dāng)然不希望所有的任務(wù)都運(yùn)行在一個(gè)線程中。
@Scheduled(cron="0/1 * * * * ? ") //每1秒執(zhí)行一次 public void testCron1() { DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); logger.info(sdf.format(new Date())+"*********每1秒執(zhí)行一次"); } @Scheduled(cron="0/2 * * * * ? ") //每2秒執(zhí)行一次 public void testCron2() { DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); logger.info(sdf.format(new Date())+"*********每2秒執(zhí)行一次"); } @Scheduled(cron="0/3 * * * * ? ") //每3秒執(zhí)行一次 public void testCron3() { DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); logger.info(sdf.format(new Date())+"*********每3秒執(zhí)行一次"); } @Scheduled(cron="0/4 * * * * ? ") //每4秒執(zhí)行一次 public void testCron4() { DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); logger.info(sdf.format(new Date())+"*********每4秒執(zhí)行一次"); }解決方案
那么,怎么設(shè)計(jì)成多線程實(shí)現(xiàn)并發(fā)呢?在網(wǎng)上看到過(guò)這樣的解決方案。通過(guò)ScheduleConfig配置文件實(shí)現(xiàn)SchedulingConfigurer接口,并重寫setSchedulerfang方法,我們嘗試著配置了一下。
@Configuration public class ScheduleConfig implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.setScheduler(Executors.newScheduledThreadPool(5)); } }整合成功
這樣就完成了多線程并發(fā)的配置?我們啟動(dòng)項(xiàng)目通過(guò)控制臺(tái)輸出信息驗(yàn)證一下結(jié)果,最后發(fā)現(xiàn)所有的任務(wù)都在同一個(gè)線程池但不同線程中完成,說(shuō)明這個(gè)方案完全可行,這樣,我們就完成了spring boot 多線程并發(fā)定時(shí)任務(wù)。
注@Scheduled所支持的參數(shù):
1.cron:cron表達(dá)式,指定任務(wù)在特定時(shí)間執(zhí)行;
2.fixedDelay:表示上一次任務(wù)執(zhí)行完成后多久再次執(zhí)行,參數(shù)類型為long,單位ms;
3.fixedDelayString:與fixedDelay含義一樣,只是參數(shù)類型變?yōu)镾tring;
4.fixedRate:表示按一定的頻率執(zhí)行任務(wù),參數(shù)類型為long,單位ms;
5.fixedRateString: 與fixedRate的含義一樣,只是將參數(shù)類型變?yōu)镾tring;
6.initialDelay:表示延遲多久再第一次執(zhí)行任務(wù),參數(shù)類型為long,單位ms;
7.initialDelayString:與initialDelay的含義一樣,只是將參數(shù)類型變?yōu)镾tring;
8.zone:時(shí)區(qū),默認(rèn)為當(dāng)前時(shí)區(qū),一般沒有用到。
Cron表達(dá)式范例:
每隔5秒執(zhí)行一次:/5 * ?
每隔1分鐘執(zhí)行一次:0 /1 ?
每天23點(diǎn)執(zhí)行一次:0 0 23 ?
每天凌晨1點(diǎn)執(zhí)行一次:0 0 1 ?
每月1號(hào)凌晨1點(diǎn)執(zhí)行一次:0 0 1 1 * ?
每月最后一天23點(diǎn)執(zhí)行一次:0 0 23 L * ?
每周星期天凌晨1點(diǎn)實(shí)行一次:0 0 1 ? * L
在26分、29分、33分執(zhí)行一次:0 26,29,33 * ?
每天的0點(diǎn)、13點(diǎn)、18點(diǎn)、21點(diǎn)都執(zhí)行一次:0 0 0,13,18,21 ?
其實(shí)不會(huì)Cron表達(dá)式也不用擔(dān)心,網(wǎng)上有好多在線Cron生成器,我們完全可以通過(guò)在線生成器生成符合要求的cron,也很方便。
原文地址
有問題,請(qǐng)留言!
個(gè)人博客地址 https://ailijie.top/archives/...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/75981.html
摘要:表示起始時(shí)間開始觸發(fā),然后每隔固定時(shí)間觸發(fā)一次如在域使用則意味著分鐘觸發(fā)一次,而,等分別觸發(fā)一次表示列出枚舉值值。 showImg(https://segmentfault.com/img/remote/1460000015852353); 文章鏈接:https://liuyueyi.github.io/hexblog/2018/08/01/180801-Spring之定時(shí)任務(wù)基本使用...
摘要:注意當(dāng)使用注解時(shí),為了避免并發(fā)時(shí),存儲(chǔ)數(shù)據(jù)造成混亂,強(qiáng)烈建議把注解也加上。示例假設(shè)定時(shí)任務(wù)的時(shí)間間隔為秒,但執(zhí)行時(shí)間是秒。當(dāng)設(shè)置以后程序會(huì)等任務(wù)執(zhí)行完畢后再去執(zhí)行,否則會(huì)在秒時(shí)再啟動(dòng)新的線程執(zhí)行。 版權(quán)聲明:本文由吳仙杰創(chuàng)作整理,轉(zhuǎn)載請(qǐng)注明出處:https://segmentfault.com/a/1190000009128328 1. 禁止同一個(gè) JobDetail 中的多個(gè)實(shí)例并發(fā)...
摘要:也是自帶的一個(gè)基于線程池設(shè)計(jì)的定時(shí)任務(wù)類。其每個(gè)調(diào)度任務(wù)都會(huì)分配到線程池中的一個(gè)線程執(zhí)行,所以其任務(wù)是并發(fā)執(zhí)行的,互不影響。 原創(chuàng)不易,如需轉(zhuǎn)載,請(qǐng)注明出處https://www.cnblogs.com/baixianlong/p/10659045.html,否則將追究法律責(zé)任?。。?一、在JAVA開發(fā)領(lǐng)域,目前可以通過(guò)以下幾種方式進(jìn)行定時(shí)任務(wù) 1、單機(jī)部署模式 Timer:jdk中...
摘要:若以多線程的方式操作這些,則可能出現(xiàn)操作的沖突。另外,因?yàn)槭菃尉€程的,在某一時(shí)刻內(nèi)只能執(zhí)行特定的一個(gè)任務(wù),并且會(huì)阻塞其它任務(wù)執(zhí)行。瀏覽器事件觸發(fā)線程事件觸發(fā)線程,當(dāng)一個(gè)事件被觸發(fā)時(shí)該線程會(huì)把事件添加到任務(wù)隊(duì)列的隊(duì)尾,等待引擎的處理。 首先,說(shuō)下為什么 JavaScript 是單線程? 總所周知,JavaScript是以單線程的方式運(yùn)行的。說(shuō)到線程就自然聯(lián)想到進(jìn)程。那它們有什么聯(lián)系呢? ...
摘要:標(biāo)簽單線程首發(fā)地址碼農(nóng)網(wǎng)細(xì)說(shuō)單線程的一些事最近被同學(xué)問道單線程的一些事,我竟回答不上。若以多線程的方式操作這些,則可能出現(xiàn)操作的沖突。另外,因?yàn)槭菃尉€程的,在某一時(shí)刻內(nèi)只能執(zhí)行特定的一個(gè)任務(wù),并且會(huì)阻塞其它任務(wù)執(zhí)行。 標(biāo)簽: JavaScript 單線程 首發(fā)地址:碼農(nóng)網(wǎng)《細(xì)說(shuō)JavaScript單線程的一些事》 最近被同學(xué)問道 JavaScript 單線程的一些事,我竟回答不上。好...
閱讀 1922·2023-04-25 19:51
閱讀 1237·2021-11-15 11:43
閱讀 4619·2021-11-02 14:40
閱讀 2074·2021-10-11 10:59
閱讀 1409·2021-09-22 15:05
閱讀 1093·2021-09-09 09:32
閱讀 713·2019-08-30 15:56
閱讀 607·2019-08-30 15:52