如何在springboot中使用定時(shí)任務(wù)
在日常的開(kāi)發(fā)過(guò)程中經(jīng)常使用到定時(shí)任務(wù),在springMVC的開(kāi)發(fā)中,經(jīng)常和quartz框架進(jìn)行集成使用,但在springboot中沒(méi)有這么做,而是使用了java的線程池來(lái)實(shí)現(xiàn)定時(shí)任務(wù)。
一、概述
在springboot中使用定時(shí)任務(wù)非常簡(jiǎn)單,只需要簡(jiǎn)單的幾步即可完成。
二、詳述
在springboot中要使用定時(shí)任務(wù),首先要保證環(huán)境是springboot的,這里使用的是springboot-2.1.2.release版本。在啟動(dòng)類上加@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}) //引入開(kāi)啟定時(shí)任務(wù)的注解 @EnableScheduling public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
@EnableScheduling注解的作用就是開(kāi)啟對(duì)定時(shí)任務(wù)的支持,這個(gè)注解的作用是開(kāi)啟定時(shí)任務(wù)的自動(dòng)配置。
在使用了@EnableScheduling注解后便可以編寫(xiě)具體的定時(shí)任務(wù)的job類,該job類無(wú)需繼承或?qū)崿F(xiàn)任何接口,只要是一個(gè)被spring管理的類即可。為了使spring可以管理統(tǒng)一使用@Component注解標(biāo)識(shí)。在定時(shí)任務(wù)的類中的方法上標(biāo)識(shí)@Scheduled注解便可以定時(shí)執(zhí)行該方法,@Scheduled注解上有幾種不同的屬性,看具體的該注解的定義,
fixedDelay
@Scheduled(fixedDelay=1000)/@Scheduled(fixedDelay="1000")的意思是該方法執(zhí)行完后每隔1000ms執(zhí)行一次??淳唧w的代碼
package com.example.demo.job; import lombok.extern.slf4j.Slf4j; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Slf4j @Component public 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 ms 2020-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,由于程序會(huì)睡眠10秒,也就是說(shuō)回在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í)間超過(guò)了配置的時(shí)間,則在任務(wù)執(zhí)行完會(huì)再次執(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 @Component public class SchedulFixedRateTest { @Scheduled(fixedRate = 5000) public void jobTest(){ try { log.info("使用fixedRate的定時(shí)任務(wù)"); Thread.sleep(1*1000); } catch (InterruptedException e) { e.printStackTrace(); } } }
任務(wù)會(huì)睡眠1s也就是任務(wù)耗時(shí)1s,fixedRate配置的是每隔5s,由于任務(wù)時(shí)間小于配置的時(shí)間,所以會(huì)每隔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 @Component public 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í)長(zhǎng),所以任務(wù)執(zhí)行完以后便會(huì)進(jìn)入下次的執(zhí)行。
cron
cron表達(dá)式共7位,分別是秒、分、小時(shí)、日、月、周、年。cron表達(dá)式可以從網(wǎng)上找,如下,
https://cron.qqe2.com/
通過(guò)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 @Component public 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開(kāi)啟定時(shí)任務(wù)的自動(dòng)配置;
其次,任務(wù)類必須受spring管理(使用@Component、@Service等注解均可);
最后,任務(wù)方法使用@Scheduled注解標(biāo)識(shí),該注解有3中不同的屬性配置,fixedDelay、fixedRate、cron;
以上就是如何在springboot中使用定時(shí)任務(wù)的詳細(xì)內(nèi)容,更多關(guān)于springboot中使用定時(shí)任務(wù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- springboot動(dòng)態(tài)定時(shí)任務(wù)的實(shí)現(xiàn)方法示例
- Springboot非分布式定時(shí)任務(wù)實(shí)現(xiàn)代碼
- springboot如何配置定時(shí)任務(wù)
- springboot+quartz以持久化的方式實(shí)現(xiàn)定時(shí)任務(wù)的代碼
- Java下SpringBoot創(chuàng)建定時(shí)任務(wù)詳解
- SpringBoot整合SpringTask實(shí)現(xiàn)定時(shí)任務(wù)的流程
- SpringBoot任務(wù)之定時(shí)任務(wù)相關(guān)知識(shí)總結(jié)
相關(guān)文章
使用maven命令安裝jar包到本地倉(cāng)庫(kù)的方法步驟
這篇文章主要介紹了使用maven命令安裝jar包到本地倉(cāng)庫(kù)的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06mybatis Example Criteria like 模糊查詢問(wèn)題
這篇文章主要介紹了mybatis Example Criteria like 模糊查詢問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02SpringBoot不讀取bootstrap.yml/properties文件問(wèn)題
這篇文章主要介紹了SpringBoot不讀取bootstrap.yml/properties文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12Java中IO流使用FileWriter寫(xiě)數(shù)據(jù)基本操作詳解
這篇文章主要介紹了Java中IO流FileWriter寫(xiě)數(shù)據(jù)操作,FileWriter類提供了多種寫(xiě)入字符的方法,包括寫(xiě)入單個(gè)字符、寫(xiě)入字符數(shù)組和寫(xiě)入字符串等,它還提供了一些其他的方法,如刷新緩沖區(qū)、關(guān)閉文件等,需要的朋友可以參考下2023-10-10Spring?Data?JPA框架的核心概念與Repository接口詳解
Spring?Data?JPA是Spring基于JPA規(guī)范的基礎(chǔ)上封裝的?套?JPA?應(yīng)?框架,可使開(kāi)發(fā)者?極簡(jiǎn)的代碼即可實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的訪問(wèn)和操作,本篇我們來(lái)了解Spring?Data?JPA框架的核心概念與Repository接口2022-04-04SpringBoot通過(guò)Filter實(shí)現(xiàn)整個(gè)項(xiàng)目接口的SQL注入攔截詳解
這篇文章主要介紹了SpringBoot通過(guò)Filter實(shí)現(xiàn)整個(gè)項(xiàng)目接口的SQL注入攔截詳解,SQL注入是比較常見(jiàn)的網(wǎng)絡(luò)攻擊方式之一,在客戶端在向服務(wù)器發(fā)送請(qǐng)求的時(shí)候,sql命令通過(guò)表單提交或者url字符串拼接傳遞到后臺(tái)持久層,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令,需要的朋友可以參考下2023-12-12高內(nèi)聚低耦合原則_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
耦合度就是某模塊(類)與其它模塊(類)之間的關(guān)聯(lián)、感知和依賴的程度,是衡量代碼獨(dú)立性的一個(gè)指標(biāo),也是軟件工程設(shè)計(jì)及編碼質(zhì)量評(píng)價(jià)的一個(gè)標(biāo)準(zhǔn)2017-08-08SpringBoot+Apache tika實(shí)現(xiàn)文檔內(nèi)容解析的示例詳解
Apache tika是Apache開(kāi)源的一個(gè)文檔解析工具,本文主要為大家介紹了如何在springboot中引入tika的方式解析文檔,感興趣的小伙伴可以了解一下2023-07-07Java中Thread和Runnable創(chuàng)建線程的方式對(duì)比
本文主要介紹了Java中Thread和Runnable創(chuàng)建線程的方式對(duì)比,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07