Spring Boot與Kotlin定時(shí)任務(wù)的示例(Scheduling Tasks)
在編寫Spring Boot應(yīng)用中會(huì)遇到這樣的場(chǎng)景,比如:需要定時(shí)地發(fā)送一些短信、郵件之類的操作,也可能會(huì)定時(shí)地檢查和監(jiān)控一些標(biāo)志、參數(shù)等。
創(chuàng)建定時(shí)任務(wù)
在Spring Boot中編寫定時(shí)任務(wù)是非常簡(jiǎn)單的事,下面通過(guò)實(shí)例介紹如何在Spring Boot中創(chuàng)建定時(shí)任務(wù),實(shí)現(xiàn)每過(guò)5秒輸出一下當(dāng)前時(shí)間。
在Spring Boot的主類中加入@EnableScheduling注解,啟用定時(shí)任務(wù)的配置
import org.springframework.boot.SpringApplication import org.springframework.boot.autoconfigure.SpringBootApplication import org.springframework.scheduling.annotation.EnableScheduling /** * Created by http://quanke.name on 2018/1/12. */ @SpringBootApplication @EnableScheduling class Application fun main(args: Array<String>) { SpringApplication.run(Application::class.java, *args) }
創(chuàng)建定時(shí)任務(wù)實(shí)現(xiàn)類
import org.apache.commons.logging.LogFactory import org.springframework.scheduling.annotation.Scheduled import org.springframework.stereotype.Component import java.text.SimpleDateFormat import java.util.* /** * Created by http://quanke.name on 2018/1/12. */ @Component class ScheduledTasks { val log = LogFactory.getLog(ScheduledTasks::class.java)!! private val dateFormat = SimpleDateFormat(“HH:mm:ss”) @Scheduled(fixedRate = 1000) fun reportCurrentTime() { log.info(“現(xiàn)在時(shí)間 , ${dateFormat.format(Date())}”) } }
運(yùn)行程序,控制臺(tái)中可以看到類似如下輸出,定時(shí)任務(wù)開(kāi)始正常運(yùn)作了。
2018-01-21 23:09:01.112 INFO 23832 — [ main] n.q.kotlin.chaper11_8_1.ApplicationKt : Started ApplicationKt in 8.024 seconds (JVM running for 8.724)
2018-01-21 23:09:02.112 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現(xiàn)在時(shí)間 , 23:09:02
2018-01-21 23:09:03.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現(xiàn)在時(shí)間 , 23:09:03
2018-01-21 23:09:04.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現(xiàn)在時(shí)間 , 23:09:04
2018-01-21 23:09:05.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現(xiàn)在時(shí)間 , 23:09:05
@Scheduled詳解
在上面的入門例子中,使用了@Scheduled(fixedRate = 1000) 注解來(lái)定義每過(guò)1秒執(zhí)行的任務(wù),對(duì)于@Scheduled的使用可以總結(jié)如下幾種方式:
- @Scheduled(fixedRate = 1000) :上一次開(kāi)始執(zhí)行時(shí)間點(diǎn)之后1秒再執(zhí)行
- @Scheduled(fixedDelay = 1000) :上一次執(zhí)行完畢時(shí)間點(diǎn)之后1秒再執(zhí)行
- @Scheduled(initialDelay=1000, fixedRate=5000) :第一次延遲1秒后執(zhí)行,之后按fixedRate的規(guī)則每5秒執(zhí)行一次
- @Scheduled(cron=”/1 “) :通過(guò)cron表達(dá)式定義規(guī)則
@Scheduled 注解是單線程的,如果需要多線程,請(qǐng)?jiān)黾覢Async
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot整合SpringTask實(shí)現(xiàn)定時(shí)任務(wù)的流程
- mall整合SpringTask實(shí)現(xiàn)定時(shí)任務(wù)的方法示例
- SpringBoot2 task scheduler 定時(shí)任務(wù)調(diào)度器四種方式
- spring boot task實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建定時(shí)任務(wù)的方法
- java 中Spring task定時(shí)任務(wù)的深入理解
- Spring Task定時(shí)任務(wù)的配置和使用詳解
- Spring Task定時(shí)任務(wù)每天零點(diǎn)執(zhí)行一次的操作
相關(guān)文章
spring?mvc?AOP切面方法未執(zhí)行的一種情況的分析和處理過(guò)程
這篇文章主要介紹了spring?mvc?AOP切面方法未執(zhí)行的一種情況的分析和處理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05Java同步鎖Synchronized底層源碼和原理剖析(推薦)
這篇文章主要介紹了Java同步鎖Synchronized底層源碼和原理剖析,釋放后,進(jìn)入減減操作、直到為0然后喚醒隊(duì)列,讓他們?nèi)?zhēng)奪鎖,循環(huán)前面步驟,對(duì)Java同步鎖Synchronized相關(guān)知識(shí)感興趣的朋友一起看看吧2022-05-05詳解Java的Hibernat框架中的Map映射與SortedMap映射
這篇文章主要介紹了Java的Hibernat框架中的Map映射與SortedMap映射,Hibernat是Java的SSH三大web開(kāi)發(fā)框架之一,需要的朋友可以參考下2015-12-12教你怎么解決IDEA中“\t“空格顯示不正確的問(wèn)題
在之前進(jìn)行先來(lái)先服務(wù)(FCFS)調(diào)度算法的模擬過(guò)程中,使用IDEA進(jìn)行開(kāi)發(fā)時(shí)遇到了"\t"無(wú)法補(bǔ)全當(dāng)前字符串長(zhǎng)度到8的整數(shù)倍的問(wèn)題.百度一圈發(fā)現(xiàn)也有很多程序員遇到了這樣的問(wèn)題,但是沒(méi)有解決方法,于是有了這篇文章,需要的朋友可以參考下2021-05-05java實(shí)現(xiàn)電腦定時(shí)關(guān)機(jī)的方法
這篇文章主要介紹了java實(shí)現(xiàn)電腦定時(shí)關(guān)機(jī)的方法,首先通過(guò)java注冊(cè)windows服務(wù)程序,再以一個(gè)簡(jiǎn)單的java程序?qū)崿F(xiàn)定時(shí)關(guān)機(jī)的功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-11-11Java實(shí)現(xiàn)簡(jiǎn)易五子棋小游戲
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)易五子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05springBoot接入阿里云oss的實(shí)現(xiàn)步驟
這篇文章主要介紹了springBoot接入阿里云oss的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01