电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

如何在springboot中使用定時(shí)任務(wù)

瀏覽:69日期:2023-04-04 16:59:23

在日常的開發(fā)過程中經(jīng)常使用到定時(shí)任務(wù),在springMVC的開發(fā)中,經(jīng)常和quartz框架進(jìn)行集成使用,但在springboot中沒有這么做,而是使用了java的線程池來實(shí)現(xiàn)定時(shí)任務(wù)。

一、概述

在springboot中使用定時(shí)任務(wù)非常簡單,只需要簡單的幾步即可完成。

二、詳述

在springboot中要使用定時(shí)任務(wù),首先要保證環(huán)境是springboot的,這里使用的是springboot-2.1.2.release版本。在啟動類上加@EnableScheduling注解,如下,

package com.example.demo;import com.example.demo.properties.ApplicationPro;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.boot.context.properties.EnableConfigurationProperties;import org.springframework.scheduling.annotation.EnableScheduling;@SpringBootApplication@EnableConfigurationProperties({ApplicationPro.class})//引入開啟定時(shí)任務(wù)的注解@EnableSchedulingpublic class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); }}

@EnableScheduling注解的作用就是開啟對定時(shí)任務(wù)的支持,這個(gè)注解的作用是開啟定時(shí)任務(wù)的自動配置。

在使用了@EnableScheduling注解后便可以編寫具體的定時(shí)任務(wù)的job類,該job類無需繼承或?qū)崿F(xiàn)任何接口,只要是一個(gè)被spring管理的類即可。為了使spring可以管理統(tǒng)一使用@Component注解標(biāo)識。在定時(shí)任務(wù)的類中的方法上標(biāo)識@Scheduled注解便可以定時(shí)執(zhí)行該方法,@Scheduled注解上有幾種不同的屬性,看具體的該注解的定義,

如何在springboot中使用定時(shí)任務(wù)

如何在springboot中使用定時(shí)任務(wù)

fixedDelay

@Scheduled(fixedDelay=1000)/@Scheduled(fixedDelay='1000')的意思是該方法執(zhí)行完后每隔1000ms執(zhí)行一次。看具體的代碼

package com.example.demo.job;import lombok.extern.slf4j.Slf4j;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;@Slf4j@Componentpublic class SchedulFixedRelayTest { //@Scheduled(fixedDelay = 5000) public void jobTest(){ try { log.info('使用fixedDelay的定時(shí)任務(wù)'); Thread.sleep(10*1000); } catch (InterruptedException e) { e.printStackTrace(); } }}

看執(zhí)行結(jié)果,

2020-12-09 22:02:47.511 INFO 7368 --- [ main] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 940 ms2020-12-09 22:02:47.681 INFO 7368 --- [ main] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService ’applicationTaskExecutor’2020-12-09 22:02:47.782 INFO 7368 --- [ main] o.s.s.c.ThreadPoolTaskScheduler : Initializing ExecutorService ’taskScheduler’2020-12-09 22:02:47.802 INFO 7368 --- [ scheduling-1] c.e.demo.job.SchedulFixedRelayTest : 使用fixedDelay的定時(shí)任務(wù)2020-12-09 22:02:47.820 INFO 7368 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ’’2020-12-09 22:02:47.823 INFO 7368 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 1.627 seconds (JVM running for 2.51)2020-12-09 22:03:02.819 INFO 7368 --- [ scheduling-1] c.e.demo.job.SchedulFixedRelayTest : 使用fixedDelay的定時(shí)任務(wù)2020-12-09 22:03:17.834 INFO 7368 --- [ scheduling-1] c.e.demo.job.SchedulFixedRelayTest : 使用fixedDelay的定時(shí)任務(wù)

看上面打印的執(zhí)行時(shí)間,第一次在2020-12-09 22:02:47,由于程序會睡眠10秒,也就是說回在22:02:57執(zhí)行完,那么下次執(zhí)行應(yīng)該在22:03:02,看第二次打印的時(shí)間剛好和上面的一樣,那就證明了,該配置是在方法執(zhí)行完成后每隔XX秒執(zhí)行一次。

fixedRate

@Scheduled(fixedRate=1000)/@Scheduled(fixedRate='1000')的意思是該方法執(zhí)行完后每隔1000ms執(zhí)行一次,但是如果任務(wù)執(zhí)行的時(shí)間超過了配置的時(shí)間,則在任務(wù)執(zhí)行完會再次執(zhí)行。

任務(wù)時(shí)間小于配置的時(shí)間

package com.example.demo.job;import lombok.extern.slf4j.Slf4j;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;@Slf4j@Componentpublic class SchedulFixedRateTest { @Scheduled(fixedRate = 5000) public void jobTest(){ try { log.info('使用fixedRate的定時(shí)任務(wù)'); Thread.sleep(1*1000); } catch (InterruptedException e) { e.printStackTrace(); } }}

任務(wù)會睡眠1s也就是任務(wù)耗時(shí)1s,fixedRate配置的是每隔5s,由于任務(wù)時(shí)間小于配置的時(shí)間,所以會每隔5s執(zhí)行一次,看執(zhí)行結(jié)果,

2020-12-09 22:16:16.156 INFO 2800 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)2020-12-09 22:16:16.188 INFO 2800 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ’’2020-12-09 22:16:16.188 INFO 2800 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 1.625 seconds (JVM running for 2.462)2020-12-09 22:16:21.178 INFO 2800 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)2020-12-09 22:16:26.180 INFO 2800 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)

看打印的任務(wù)時(shí)間都是每隔5s執(zhí)行一次。

任務(wù)時(shí)間大于配置的時(shí)間

看任務(wù)的執(zhí)行時(shí)間打印配置的時(shí)間的情況,

package com.example.demo.job;import lombok.extern.slf4j.Slf4j;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;@Slf4j@Componentpublic class SchedulFixedRateTest { @Scheduled(fixedRate = 5000) public void jobTest(){ try { log.info('使用fixedRate的定時(shí)任務(wù)'); Thread.sleep(10*1000); } catch (InterruptedException e) { e.printStackTrace(); } }}

這里任務(wù)執(zhí)行10s,配置的時(shí)間為5s??磮?zhí)行結(jié)果,

2020-12-09 22:17:44.070 INFO 12952 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)2020-12-09 22:17:44.102 INFO 12952 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ’’2020-12-09 22:17:44.102 INFO 12952 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 1.626 seconds (JVM running for 2.462)2020-12-09 22:17:54.071 INFO 12952 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)2020-12-09 22:18:04.085 INFO 12952 --- [ scheduling-1] c.example.demo.job.SchedulFixedRateTest : 使用fixedRate的定時(shí)任務(wù)

從上面的結(jié)果可以看到任務(wù)是每隔10s執(zhí)行一次,由于任務(wù)耗時(shí)大于了配置的時(shí)長,所以任務(wù)執(zhí)行完以后便會進(jìn)入下次的執(zhí)行。

cron

cron表達(dá)式共7位,分別是秒、分、小時(shí)、日、月、周、年。cron表達(dá)式可以從網(wǎng)上找,如下,

https://cron.qqe2.com/

通過cron在線生成,分別設(shè)置值,如,0/5 * * * * ? 每隔5s執(zhí)行一次,

package com.example.demo.job;import lombok.extern.slf4j.Slf4j;import org.springframework.scheduling.annotation.Scheduled;import org.springframework.stereotype.Component;@Slf4j@Componentpublic class SchedulCronTest { @Scheduled(cron = '0/5 * * * * ?') public void jobTest(){ try { log.info('使用cron的定時(shí)任務(wù)'); Thread.sleep(10*1000); } catch (InterruptedException e) { e.printStackTrace(); } }}

每隔5s執(zhí)行一次,任務(wù)耗時(shí)10s,看下執(zhí)行結(jié)果,

2020-12-09 22:41:42.718 INFO 17828 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 1.609 seconds (JVM running for 2.453)2020-12-09 22:41:45.015 INFO 17828 --- [ scheduling-1] com.example.demo.job.SchedulCronTest : 使用cron的定時(shí)任務(wù)2020-12-09 22:42:00.004 INFO 17828 --- [ scheduling-1] com.example.demo.job.SchedulCronTest : 使用cron的定時(shí)任務(wù)2020-12-09 22:42:15.000 INFO 17828 --- [ scheduling-1] com.example.demo.job.SchedulCronTest : 使用cron的定時(shí)任務(wù)

可以看到是每隔15s執(zhí)行一次,也就是如果配置的時(shí)間間隔小于任務(wù)耗時(shí),那么在任務(wù)執(zhí)行完后的時(shí)間間隔后再執(zhí)行,在此種情況下和fixDelay的用法一致。

三、總結(jié)

本文分析了springboot中定時(shí)任務(wù)的使用,

首先,使用@EnableScheduling開啟定時(shí)任務(wù)的自動配置;

其次,任務(wù)類必須受spring管理(使用@Component、@Service等注解均可);

最后,任務(wù)方法使用@Scheduled注解標(biāo)識,該注解有3中不同的屬性配置,fixedDelay、fixedRate、cron;

以上就是如何在springboot中使用定時(shí)任務(wù)的詳細(xì)內(nèi)容,更多關(guān)于springboot中使用定時(shí)任務(wù)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 探伤仪,漆膜厚度测试仪,轮胎花纹深度尺厂家-淄博创宇电子 | 不锈钢水箱厂家,不锈钢保温水箱-山东桑特供水设备 | 杭州厂房降温,车间降温设备,车间通风降温,厂房降温方案,杭州嘉友实业爽风品牌 | 智能气瓶柜(大型气瓶储存柜)百科 | 咖啡加盟,咖啡店加盟连锁品牌-卡小逗| 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 佛山商标注册_商标注册代理|专利注册申请_商标注册公司_鸿邦知识产权 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | NMRV减速机|铝合金减速机|蜗轮蜗杆减速机|NMRV减速机厂家-东莞市台机减速机有限公司 | 臭氧老化试验箱,高低温试验箱,恒温恒湿试验箱,防水试验设备-苏州亚诺天下仪器有限公司 | 建筑工程资质合作-工程资质加盟分公司-建筑资质加盟 | 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 渗透仪-直剪仪-三轴仪|苏州昱创百科| SEO网站优化,关键词排名优化,苏州网站推广-江苏森歌网络 | 防爆电机_ybx3系列电机_河南省南洋防爆电机有限公司 | 医学模型生产厂家-显微手术模拟训练器-仿真手术模拟训练系统-北京医教科技 | 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 海日牌清洗剂-打造带电清洗剂、工业清洗剂等清洗剂国内一线品牌 海外整合营销-独立站营销-社交媒体运营_广州甲壳虫跨境网络服务 | 数控专用机床,专用机床,自动线,组合机床,动力头,自动化加工生产线,江苏海鑫机床有限公司 | 耐高温电缆厂家-远洋高温电缆 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 碳纤维复合材料制品生产定制工厂订制厂家-凯夫拉凯芙拉碳纤维手机壳套-碳纤维雪茄盒外壳套-深圳市润大世纪新材料科技有限公司 | 长春网站建设,五合一网站设计制作,免费优化推广-长春网站建设 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 悬浮拼装地板_幼儿园_篮球场_悬浮拼接地板-山东悬浮拼装地板厂家 | 挤奶设备过滤纸,牛奶过滤纸,挤奶机过滤袋-济南蓝贝尔工贸有限公司 | 京马网,京马建站,网站定制,营销型网站建设,东莞建站,东莞网站建设-首页-京马网 | 废旧物资回收公司_广州废旧设备回收_报废设备物资回收-益美工厂设备回收公司 | 联系我们-腾龙公司上分客服微信19116098882 | 电脑刺绣_绣花厂家_绣花章仔_织唛厂家-[源欣刺绣]潮牌刺绣打版定制绣花加工厂家 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 平面钻,法兰钻,三维钻-山东兴田阳光智能装备股份有限公司 | 正压密封性测试仪-静态发色仪-导丝头柔软性测试仪-济南恒品机电技术有限公司 | 高压油管,液压接头,液压附件-烟台市正诚液压附件 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | HDPE储罐_厂家-山东九州阿丽贝防腐设备 | 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 知名电动蝶阀,电动球阀,气动蝶阀,气动球阀生产厂家|价格透明-【固菲阀门官网】 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 垃圾处理设备_餐厨垃圾处理设备_厨余垃圾处理设备_果蔬垃圾处理设备-深圳市三盛环保科技有限公司 |