定時任務(wù)是互聯(lián)網(wǎng)行業(yè)里最常用的服務(wù)之一,本文給大家介紹定時任務(wù)在我司的發(fā)展歷程。
linux系統(tǒng)中一般使用crontab命令來實現(xiàn),在Java世界里,使用最廣泛的就是quartz了。我司使用quartz就已經(jīng)升級了三代,每一代在上一代系統(tǒng)之上有所優(yōu)化,寫這篇文章一方面介紹一下quartz的使用,另一方面可以根據(jù)此項目的變遷反應(yīng)出我司平臺架構(gòu)升級的一個縮影。
定時任務(wù)的使用場景很多,以我們平臺來講:計息,派息、對賬等等。
quartz 介紹
Quartz是個開源的作業(yè)調(diào)度框架,為在Java應(yīng)用程序中進行作業(yè)調(diào)度提供了簡單卻強大的機制。Quartz允許開發(fā)人員根據(jù)時間間隔(或天)來調(diào)度作業(yè)。它實現(xiàn)了作業(yè)和觸發(fā)器的多對多關(guān)系,還能把多個作業(yè)與不同的觸發(fā)器關(guān)聯(lián)。Quartz可以集成幾乎任何的java應(yīng)用程序—從小的單片機系統(tǒng)到大型的電子商務(wù)系統(tǒng)。Quartz可以執(zhí)行上千上萬的任務(wù)調(diào)度。
Quartz核心的概念:scheduler任務(wù)調(diào)度、Job任務(wù)、JobDetail任務(wù)細節(jié)、Trigger觸發(fā)器
Scheduler:調(diào)度器,調(diào)度器接受一組JobDetail+Trigger即可安排一個任務(wù),其中一個JobDetail可以關(guān)聯(lián)多個Trigger
Job:Job是任務(wù)執(zhí)行的流程,是一個類
JobDetail:JobDetail是Job是實例,是一個對象,包含了該實例的執(zhí)行計劃和所需要的數(shù)據(jù)
Trigger:Trigger是定時器,決定任務(wù)何時執(zhí)行
使用Quartz調(diào)度系統(tǒng)的思路就是,首先寫一個具體的任務(wù)(job),配置任務(wù)的觸發(fā)時間(Trigger),Scheduler很根據(jù)JobDetail+Trigger安排去執(zhí)行此任務(wù)。
Quartz 定時器的時間設(shè)置
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26