91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring Boot與Kotlin定時任務的示例(Scheduling Tasks)

發布時間:2020-08-30 17:03:32 來源:腳本之家 閱讀:343 作者:zx 欄目:編程語言

在編寫Spring Boot應用中會遇到這樣的場景,比如:需要定時地發送一些短信、郵件之類的操作,也可能會定時地檢查和監控一些標志、參數等。

創建定時任務

在Spring Boot中編寫定時任務是非常簡單的事,下面通過實例介紹如何在Spring Boot中創建定時任務,實現每過5秒輸出一下當前時間。

在Spring Boot的主類中加入@EnableScheduling注解,啟用定時任務的配置

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)
}

創建定時任務實現類

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(“現在時間 , ${dateFormat.format(Date())}”)
}
}

運行程序,控制臺中可以看到類似如下輸出,定時任務開始正常運作了。

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 : 現在時間 , 23:09:02
2018-01-21 23:09:03.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現在時間 , 23:09:03
2018-01-21 23:09:04.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現在時間 , 23:09:04
2018-01-21 23:09:05.042 INFO 23832 — [pool-2-thread-1] n.q.k.chaper11_8_1.task.ScheduledTasks : 現在時間 , 23:09:05

@Scheduled詳解

在上面的入門例子中,使用了@Scheduled(fixedRate = 1000) 注解來定義每過1秒執行的任務,對于@Scheduled的使用可以總結如下幾種方式:

  1. @Scheduled(fixedRate = 1000) :上一次開始執行時間點之后1秒再執行
  2. @Scheduled(fixedDelay = 1000) :上一次執行完畢時間點之后1秒再執行
  3. @Scheduled(initialDelay=1000, fixedRate=5000) :第一次延遲1秒后執行,之后按fixedRate的規則每5秒執行一次
  4. @Scheduled(cron=”/1 “) :通過cron表達式定義規則

@Scheduled 注解是單線程的,如果需要多線程,請增加@Async

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东丰县| 札达县| 乌恰县| 克东县| 黄浦区| 小金县| 宝鸡市| 石渠县| 怀宁县| 高阳县| 贵德县| 沁阳市| 河间市| 新化县| 桦川县| 犍为县| 阿拉善盟| 东兰县| 兴安盟| 双峰县| 冕宁县| 西城区| 新巴尔虎右旗| 临高县| 青铜峡市| 翼城县| 常熟市| 密山市| 壶关县| 定兴县| 贵阳市| 政和县| 都昌县| 旬阳县| 鹿邑县| 文安县| 贡嘎县| 界首市| 普定县| 安平县| 扶沟县|