定時任務是互聯(lián)網(wǎng)行業(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 定時器的時間設置