定時排程系列之Quartz.Net詳解

Yaopengfei發表於2018-06-23

一. 背景

  我們在日常開發中,可能你會遇到這樣的需求:”每個月的3號給使用者發資訊,提醒使用者XXX “、”每天的0點需要統計前一天的考勤記錄”、”每個月的1號計算上個月的庫存情況”、”定時初始化資料供其它業務使用”、”每隔2分鐘輪詢查資料庫看某業務是否被稽核通過,並提示使用者” 等等。

  以上需求在開發中都非常常見,但它們僅僅屬於低端一點的需求,稍高階一點的需求比如:” 客服派車給排程,如果排程3天內沒有執行任何操作,需要提示排程要抓緊派車了 “,到這一步為止看起來和上面的需求並沒有什麼兩樣,但如果我要求,系統管理員可以動態配置提示時間呢?即管理員可以配置排程幾天沒有執行任何操作,系統需要給出提示。這麼一改的話,對於一些新手而已,難度就陡然上升了。

  下面我們接著升級需求,系統中有A、B、C、D。。。。等等多個業務,系統管理員可以動態配置每個業務的執行時間情況(如:每隔2s執行一次、每月3號執行一次等等),並且可以動態的控制每個業務的開啟、關閉、暫停、全部關閉、全部暫停等。需求升級到這個程度,估計新手就抓蝦了,有一定經驗的人但是沒有接觸過類似框架,面對這樣的需求,也需要一點時間去研究。

解惑:

  需求1:也就是我們常說的定時任務,簡單一點的可以藉助Timer類來實現,對時間要求複雜的需要藉助第三方的框架來實現,如:Quartz.Net.

  需求2:需要我們動態配置定時任務的執行時間。

  需求3:需要我們自己搭建一個定時排程框架,然後來動態配置任務的開啟、關閉和觸發器的情況。

   需求三就是我們最終的目標,即我們要搭建一套通用的定時排程框架,可以手動增加定時任務,配置其觸發器,手動控制任務的開啟、關閉(B/S 架構);或者C/S架構,最終部署成windows服務的形式。

  綜上所述:Quartz.Net將是我們的最佳選擇。

 

二. Quartz.Net簡介

 1. Quartz.Net是一個強大、開源、輕量的作業排程框架,是 OpenSymphony 的 Quartz API 的.NET移植,用C#改寫,可用於winform和asp.net應用中。它靈活而不復雜。你能夠用它來為執行一個作業而建立簡單的或複雜的作業排程。

它有幾大優勢:

  a.持久化資料庫:SQLServer、MySQL、MongoDB、Redis

  b.叢集支援:雙機熱備

  c.支援Web B/S架構和WinForm C/S架構

  d.trigger可以靈活的控制時間各類苛刻的時間要求

2. Quartz.Net框架的使用

①.引入方式:

  a. 通過NuGet引入搜尋Quartz引入相應的程式集。

  (2.x版本需要引入三個程式集:Common.Logging、Common.Logging.Core、Quartz和一個xsd檔案(用於xml配置進行程式碼提示)

  b. 去官網下載原始碼,通過引入原始碼的形式進行使用(http://www.quartz-scheduler.net/)。

  PS:目前最新版本為3.0.5(2018-06-23),這裡採用的是2.6.1 即2x的最後一個版本,3x起支援.netcore,且基本用法發生一些變化,最好使用vs2017

②.基本使用:

  a.建立作業排程池(Scheduler)

  b.建立一個具體的作業即job (具體的job需要單獨在一個檔案中執行)

  c.建立並配置一個觸發器即trigger 

  d.將job和trigger加入到作業排程池中

  e.開始排程 start

3. 官方地址

  官網:http://www.quartz-scheduler.net/

  示例:http://www.quartz-scheduler.net/documentation/quartz-2.x/quick-start.html

 

三. 系列章節

   下面我們將一起通過以下幾個章節,系統的學習一下Quartz.Net的基本用法、擴充套件一些高階配置,並且最終從框架的角度來處理定時排程這一類通用的問題,歡迎廣大博友前來交流、指正、學習。

       第一節: Timer的定時任務的複習、Quartz.Net的入門使用、Aop思想的體現  :

         第二節: 比較DateTime和DateTimeOffset兩種時間型別並介紹Quartz.Net中用到的幾類時間形式(定點、四捨五入、倍數、遞增)      

         第三節: Quartz.Net五大構件之Scheduler(建立、封裝、基本方法)和Job(建立、關聯等) :

         第四節: Quartz.Net五大構件之Trigger通用用法(常用方法、優先順序、與job關聯等) :

         第五節: Quartz.Net五大構件之Trigger的四大觸發類 :

         第六節: 六類Calander處理六種不同的時間場景 :

         第七節:Trigger(SimpleTrigger、CronTrigger)啞火(MisFire)策略 :

         第八節: Quartz.Net五大構件之SimpleThreadPool及其四種配置方案 :

         第九節: 利用RemoteSheduler實現Scheduler跨伺服器的遠端控制 :

         第十節: 利用SQLServer實現Quartz的持久化和雙機熱備的叢集模式 :

         第十一節: 封裝通用的定時排程框架,實現新增、刪除、開啟、暫停計劃任務(未完):

         第十二節: 總結Quartz.Net幾種部署模式(IIS、Exe、服務部署【藉助TopSelf、服務類】) :

        

 

!

  • 作       者 : Yaopengfei(姚鵬飛)
  • 部落格地址 : http://www.cnblogs.com/yaopengfei/
  • 聲     明1 : 本人才疏學淺,用郭德綱的話說“我是一個小學生”,如有錯誤,歡迎討論,請勿謾罵^_^。
  • 聲     明2 : 原創部落格請在轉載時保留原文連結或在文章開頭加上本人部落格地址,如需程式碼請留下你的郵箱

 

相關文章