定時任務是互聯(lián)網行業(yè)里最常用的服務之一,本文給大家介紹定時任務在我司的發(fā)展歷程。

linux系統(tǒng)中一般使用crontab命令來實現(xiàn),在Java世界里,使用最廣泛的就是quartz了。我司使用quartz就已經升級了三代,每一代在上一代系統(tǒng)之上有所優(yōu)化,寫這篇文章一方面介紹一下quartz的使用,另一方面可以根據(jù)此項目的變遷反應出我司平臺架構升級的一個縮影。

定時任務的使用場景很多,以我們平臺來講:計息,派息、對賬等等。

quartz 介紹

Quartz是個開源的作業(yè)調度框架,為在Java應用程序中進行作業(yè)調度提供了簡單卻強大的機制。Quartz允許開發(fā)人員根據(jù)時間間隔(或天)來調度作業(yè)。它實現(xiàn)了作業(yè)和觸發(fā)器的多對多關系,還能把多個作業(yè)與不同的觸發(fā)器關聯(lián)。Quartz可以集成幾乎任何的java應用程序—從小的單片機系統(tǒng)到大型的電子商務系統(tǒng)。Quartz可以執(zhí)行上千上萬的任務調度。

Quartz核心的概念:scheduler任務調度、Job任務、JobDetail任務細節(jié)、Trigger觸發(fā)器

  • Scheduler:調度器,調度器接受一組JobDetail+Trigger即可安排一個任務,其中一個JobDetail可以關聯(lián)多個Trigger

  • Job:Job是任務執(zhí)行的流程,是一個類

  • JobDetail:JobDetail是Job是實例,是一個對象,包含了該實例的執(zhí)行計劃和所需要的數(shù)據(jù)

  • Trigger:Trigger是定時器,決定任務何時執(zhí)行

使用Quartz調度系統(tǒng)的思路就是,首先寫一個具體的任務(job),配置任務的觸發(fā)時間(Trigger),Scheduler很根據(jù)JobDetail+Trigger安排去執(zhí)行此任務。

Quartz 定時器的時間設置

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓學習是年輕人改變自己的最好方式