1. 程式人生 > >Quartz.Net實現作業定時排程詳解

Quartz.Net實現作業定時排程詳解

1、Quartz.NET介紹

Quartz.NET是一個強大、開源、輕量的作業排程框架,你能夠用它來為執行一個作業而建立簡單的或複雜的作業排程。它有很多特徵,如:資料庫支援,叢集,外掛,支援cron-like表示式等等。非常適合在平時的工作中,定時輪詢資料庫同步,定時郵件通知,定時處理資料等。

Quartz.NET允許開發人員根據時間間隔(或天)來排程作業。它實現了作業和觸發器的多對多關係,還能把多個作業與不同的觸發器關聯。整合了 Quartz.NET的應用程式可以重用來自不同事件的作業,還可以為一個事件組合多個作業。

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

原始碼:https://github.com/quartznet/quartznet

示例:https://www.quartz-scheduler.net/documentation/quartz-3.x/quick-start.html

Quartz.NET是一個強大、開源、輕量的作業排程框架,是 OpenSymphony 的 Quartz API 的.NET移植,用C#改寫,可用於winform和Web應用中。它靈活而不復雜,你能夠用它來為執行一個作業而建立簡單的或複雜的作業排程。Quartz.NET 3.0 已經開始支援 .NET Core/.NET Standard 2.0。

Job 為作業的介面,JobDetail 用來描述 Job 的實現類及其它相關的靜態資訊;Trigger 作為作業的定時管理工具,一個 Trigger 只能對應一個作業例項,而一個作業例項可對應多個 Trigger ;Scheduler 做為定時任務容器,它包含了所有觸發器和作業,每個 Scheduler 都存有 JobDetail 和 Trigger

的註冊,一個 Scheduler 中可以註冊多個 JobDetail 和多個 Trigger 。

2、依賴框架

引入框架的方法非常簡單你可以直接用nuget管理包也可以在專案中新增引用。為了滿足不同客戶的需求,本文以最簡單的方式來講解在Visual Studio中如何正確使用Quartz.NET。

2.1、使用Nuget新增使用

2.1.0、建立一個專案

建立一個新專案,可以是ASP.NET MVC、WebForms、Winforms、.NET Core等多種.Net專案,這裡使用的是VS2017,建立了一個控制檯應用專案。

要使用Quartz.NET我們需要安裝Quartz.NET包,最簡單的方式就是從Quartz.NET管網下載dll檔案引用即可。本文我們使用Nuget進行dll檔案的引用與管理。要使用Nuget必須確保已經安裝過,最簡單的方式是通過VS“工具”選單檢視是否有程式包管理控制檯,如果有說明已經安裝過,如下圖所示。

如果沒有找到那我們就要進行安裝。

2.1.2、安裝Nuget

新版本的Visual Studio預設情況是安裝了Nuget的,如Visual Studio 2015+,如果沒有安裝,開啟VS選單“工具”->"擴充套件與更新"。

在擴充套件與更新中搜索“nuget”,可以新安裝或解除安裝後升級。

2.1.3、使用nuget安裝Quartz.NET

點選“工具”->"NuGet包管理器"->“程式包管理器控制檯”

輸入安裝包的命令:

Install-Package Quartz

安裝結果如下:

時包管理器中就下載了需要的程式集與相關檔案,同時程式中也添加了引用。

3、Quartz.NET應用

假定要實現每隔5秒鐘向控制檯記錄當前時間。

因為這是一個控制檯應用,我想一啟動時就開始該項工作,這裡我們需要將程式碼寫在static void Main(string[] args)方法中。

3.1、定義要執行的任務

定義一個類,實現Quartz.IJob介面,實現方法Execute,TimeJob.cs檔案的程式碼如下:

using System;
using System.Threading.Tasks;

namespace QuartzTest
{
    using Quartz;

    public class TimeJob : IJob
    {
        /// <summary>
        /// 作業排程定時執行的方法
        /// </summary>
        /// <param name="context"></param>
        /// <returns></returns>
        public async Task Execute(IJobExecutionContext context)
        {
            await Console.Out.WriteLineAsync("Hello QuartzNet..." + DateTime.Now + Environment.NewLine);           
        }
    }
}

3.2、建立一個排程器

排程器負責管理與控制任務的執行,在Main方法中新增如下程式碼:

//排程器
IScheduler scheduler;
//排程器工廠
ISchedulerFactory factory;

//建立一個排程器
factory = new StdSchedulerFactory();
scheduler = factory.GetScheduler();
scheduler.Start();

3.3、建立一個任務物件

這個任務物件就是我們將要執行的工作,job1是名稱,group1是組名。
//2、建立一個任務
IJobDetail job = JobBuilder.Create().WithIdentity("job1", "group1").Build();

3.4、建立一個觸發器

觸發器定義了什麼時間任務開始或每隔多久執行一次。

//3、建立一個觸發器
//DateTimeOffset runTime = DateBuilder.EvenMinuteDate(DateTimeOffset.UtcNow);
ITrigger trigger = TriggerBuilder.Create()
    .WithIdentity("trigger1", "group1")
    .WithCronSchedule("0/5 * * * * ?")     //5秒執行一次
    .Build();

3.5、將任務與觸發器新增到排程器中並執行

//4、將任務與觸發器新增到排程器中
scheduler.ScheduleJob(job, trigger);
//5、開始執行
scheduler.Start();

3.6、執行結果

3.7 Main方法完整程式碼

using Quartz;
using Quartz.Impl;
using System;

namespace QuartzTest
{
    class Program
    {
        static void Main(string[] args)
        {
            //1、排程器
            ISchedulerFactory sf = new StdSchedulerFactory();
            IScheduler sched = sf.GetScheduler();
            //2、建立一個任務
            IJobDetail job = JobBuilder.Create<TimeJob>()
              .WithIdentity("job1", "group1")
              .Build();

            //3、建立一個觸發器
            //DateTimeOffset runTime = DateBuilder.EvenMinuteDate(DateTimeOffset.UtcNow);
            ITrigger trigger = TriggerBuilder.Create()
                .WithIdentity("trigger1", "group1")
                .WithCronSchedule("0/5 * * * * ?")     //5秒執行一次                                                      
                .Build();

            sched.ScheduleJob(job, trigger);
            //啟動任務
            sched.Start();
        }
    }
}

4、Quartz的cron表示式

 Cron表示式是一個字串,字串以5或6個空格隔開,分為6或7個域,每一個域代表一個含義,Cron有如下兩種語法格式:

  (1) Seconds Minutes Hours DayofMonth Month DayofWeek Year

  (2)Seconds Minutes Hours DayofMonth Month DayofWeek

結構

  corn從左到右(用空格隔開):秒 分 小時 月份中的日期 月份 星期中的日期 年份(可為空)

  例  "0 0 12 ? * WED" 在每星期三下午12:00 執行(年份通常 省略)

Cron各欄位的含義

萬用字元說明

星號(*):可用在所有欄位中,表示對應時間域的每一個時刻,例如, 在分鐘欄位時,表示“每分鐘”;

問號(?):該字元只在日期和星期欄位中使用,它通常指定為“無意義的值”,相當於點位符;

減號(-):表達一個範圍,如在小時欄位中使用“10-12”,則表示從10到12點,即10,11,12;

逗號(,):表達一個列表值,如在星期欄位中使用“MON,WED,FRI”,則表示星期一,星期三和星期五;

斜槓(/):x/y表達一個等步長序列,x為起始值,y為增量步長值。如在分鐘欄位中使用0/15,則表示為0,15,30和45秒,而5/15在分鐘欄位中表示5,20,35,50,你也可以使用*/y,它等同於0/y;

L:該字元只在日期和星期欄位中使用,代表“Last”的意思,但它在兩個欄位中意思不同。L在日期欄位中,表示這個月份的最後一天,如一月的31號,非閏年二月的28號;如果L用在星期中,則表示星期六,等同於7。但是,如果L出現在星期欄位裡,而且在前面有一個數值X,則表示“這個月的最後X天”,例如,6L表示該月的最後星期五;

W:該字元只能出現在日期欄位裡,是對前導日期的修飾,表示離該日期最近的工作日。例如15W表示離該月15號最近的工作日,如果該月15號是星期六,則匹配14號星期五;如果15日是星期日,則匹配16號星期一;如果15號是星期二,那結果就是15號星期二。但必須注意關聯的匹配日期不能夠跨月,如你指定1W,如果1號是星期六,結果匹配的是3號星期一,而非上個月最後的那天。W字串只能指定單一日期,而不能指定日期範圍;

LW組合:在日期欄位可以組合使用LW,它的意思是當月的最後一個工作日;

井號(#):該字元只能在星期欄位中使用,表示當月某個工作日。如6#3表示當月的第三個星期五(6表示星期五,#3表示當前的第三個),而4#5表示當月的第五個星期三,假設當月沒有第五個星期三,忽略不觸發;

C:該字元只在日期和星期欄位中使用,代表“Calendar”的意思。它的意思是計劃所關聯的日期,如果日期沒有被關聯,則相當於日曆中所有日期。例如5C在日期欄位中就相當於日曆5日以後的第一天。1C在星期欄位中相當於星期日後的第一天。

Cron表示式對特殊字元的大小寫不敏感,對代表星期的縮寫英文大小寫也不敏感。

一些例子:

表示式 說明

0 0 12 * * ? 每天12點執行

0 15 10 ? * * 每天10:15執行

0 15 10 * * ? 每天10:15執行

0 15 10 * * ? * 每天10:15執行

0 15 10 * * ? 2008 在2008年的每天10:15執行

0 * 14 * * ? 每天14點到15點之間每分鐘執行一次,開始於14:00,結束於14:59。

0 0/5 14 * * ? 每天14點到15點每5分鐘執行一次,開始於14:00,結束於14:55。

0 0/5 14,18 * * ? 每天14點到15點每5分鐘執行一次,此外每天18點到19點每5鍾也執行一次。

0 0-5 14 * * ? 每天14:00點到14:05,每分鐘執行一次。

0 10,44 14 ? 3 WED 3月每週三的14:10分到14:44,每分鐘執行一次。

0 15 10 ? * MON-FRI 每週一,二,三,四,五的10:15分執行。

0 15 10 15 * ? 每月15日10:15分執行。

0 15 10 L * ? 每月最後一天10:15分執行。

0 15 10 ? * 6L 每月最後一個星期五10:15分執行。

0 15 10 ? * 6L 2007-2009 在2007,2008,2009年每個月的最後一個星期五的10:15分執行。

0 15 10 ? * 6#3 每月第三個星期五的10:15分執行。

注意:

(1)有些子表示式能包含一些範圍或列表

  例如:子表示式(天(星期))可以為 “MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”

“*”字元代表所有可能的值

  因此,“”在子表示式(月)裡表示每個月的含義,“”在子表示式(天(星期))表示星期的每一天

  “/”字元用來指定數值的增量 
  例如:在子表示式(分鐘)裡的“0/15”表示從第0分鐘開始,每15分鐘 
在子表示式(分鐘)裡的“3/20”表示從第3分鐘開始,每20分鐘(它和“3,23,43”)的含義一樣

  “?”字元僅被用於天(月)和天(星期)兩個子表示式,表示不指定值 
  當2個子表示式其中之一被指定了值以後,為了避免衝突,需要將另一個子表示式的值設為“?”

  “L” 字元僅被用於天(月)和天(星期)兩個子表示式,它是單詞“last”的縮寫 
  但是它在兩個子表示式裡的含義是不同的。 
  在天(月)子表示式中,“L”表示一個月的最後一天 
  在天(星期)自表示式中,“L”表示一個星期的最後一天,也就是SAT

  如果在“L”前有具體的內容,它就具有其他的含義了

  例如:“6L”表示這個月的倒數第6天,“FRIL”表示這個月的最一個星期五 
  注意:在使用“L”引數時,不要指定列表或範圍,因為這會導致問題

表示式生成器
有很多的cron表示式線上生成器,這裡給大家推薦幾款
http://www.pdtools.net/tools/becron.jsp

或者

http://cron.qqe2.com/

5、其他文章參考

  • 微信公眾號開發系列-玩轉微信開發-目錄彙總

  • RDIFramework.NET — 基於.NET的快速資訊化系統開發框架 — 系列目錄

  • RDIFramework.NET ━ .NET快速資訊化系統開發框架 ━ 工作流程元件介紹

  • RDIFramework.NET框架SOA解決方案(集Windows服務、WinForm形式與IIS形式釋出)-分散式應用

  • RDIFramework.NET程式碼生成器全新V3.5版本釋出-重大升級


一路走來數個年頭,感謝RDIFramework.NET框架的支持者與使用者,大家可以通過下面的地址瞭解詳情。

RDIFramework.NET官方網站:http://www.rdiframework.net/

RDIFramework.NET官方部落格:http://blog.rdiframework.net/

同時需要說明的,以後的所有技術文章以官方網站為準,歡迎大家收藏!

RDIFramework.NET框架由專業團隊長期打造、一直在更新、一直在升級,請放心使用!

歡迎關注RDIFramework.net框架官方公眾微信(微訊號:guosisoft),及時瞭解最新動態。

掃描二維碼立即關注

相關推薦

Quartz.Net實現作業定時排程

1、Quartz.NET介紹 Quartz.NET是一個強大、開源、輕量的作業排程框架,你能夠用它來為執行一個作業而建立簡單的或複雜的作業排程。它有很多特徵,如:資料庫支援,叢集,外掛,支援cron-like表示式等等。非常適合在平時的工作中,定時輪詢資料庫同步,定時郵件通知,定時處理資料等。 Quart

TopShelf+Quartz.net實現window定時排程服務

1、新建控制檯應用,通過nuget安裝Quartz和topshelf、log4net Install-Package Quartz Install-Package Common.Logging Install-Package log4net Install

RDIFramework.NET框架基於Quartz.Net實現任務排程及效果展示

在上一篇Quartz.Net實現作業定時排程詳解,我們通過例項程式碼詳細講解與演示了基於Quartz.NET開發的詳細方法。本篇我們主要講述基於RDIFramework.NET框架整合Quartz.NET,以實現任務排程,並對任務持久化操作的全過程。本文主要通過以下幾個方面講解: 1、任務排程概述 2

ASP.NET Core託管執行Quartz.NET作業排程

Quartz.NET這麼NB的作業排程系統,不會還行?   今天介紹一下Quartz.NET的託管執行,官網傳送門。 一、前言 Quartz.NET,按官網上的說法,是一款功能齊全的任務排程系統,從小型應用到大型企業級系統都能適用。在眾多專案中,Quartz.NET以可靠、叢集的方式,被用作在定時器上執

【轉】Quartz.net開源作業調度框架使用

詳解 des 關於 utc ogg knowledge imp common dem 轉自:http://www.cnblogs.com/knowledgesea/p/4930469.html 前言 quartz.net作業調度框架是偉大組織OpenSymphony開發的q

springboot整合quartz定時實現定時任務

最近需要 做一個按照時間,定時初始化一些資訊的功能,研究了一下quartz,也簡單瞭解一下TimerTask,廢話不多說。 quartz和TimerTask的區別: timer是jdk自帶的(可想而知,肯定是不怎麼好用)。 Quartz可以通過cron表示式精確到特定時間執行,而T

基於zookeeper和quartz實現分散式定時排程

目的 利用zookeeper的特性,來控制quartz實現分散式排程,保證quartz的單點執行,同時解除quartz自身分散式部署對資料庫的依賴,保證同一時刻只有一個quartz應用在執行任務。 實現方式 利用zk的分散式獨佔鎖,控制quartz應用執行節點,讓拿

quartz定時表示式

(一)格式講解 Cron表示式的格式:秒 分 時 日 月 周 年。其欄位取值如下圖所示: “?”字元:表示不確定的值 “,”字元 :指定數個值 “-”字元:指定一個值的範圍 “/”字元:指定一個值的增加幅度。n/m表示從n開始,每次增加m “L”

Quartz.NET開源作業排程框架:CronTrigger

1 //排除的日期 2 HolidayCalendar cal = new HolidayCalendar(); 3 DateTime dt排除 = new DateTime(2015, 12, 1); 4 cal.Ad

Java定時任務排程

前言 在實際專案開發中,除了Web應用、SOA服務外,還有一類不可缺少的,那就是定時任務排程。定時任務的場景可以說非常廣泛,比如某些視訊網站,購買會員後,每天會給會員送成長值,每月會給會員送一些電影券;比如在保證最終一致性的場景中,往往利用定時任務排程進行一些比對工作;比如

任務排程~Quartz.net實現簡單的任務除錯

任務排程類似於sqlserver中的作業,即按週期性執行某個程式,程式碼段,或者某種服務,在JAVA環境中出現了Quartz,它可以簡單的實現任務的除錯,而像lucene一樣,它會有對於的.net版本,Quartz.net,今天我們來做一個簡單的實驗,其時很簡單的實驗: 環境:.net4.0+mvc3 功能

quartz定時任務

------------------------開始  application-quartz.xml----------

C#基於Quartz.NET實現任務排程並部署Windows服務

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

crontab定時任務

文件 install 重新 init 設定 ntpdate 關閉 同步 星期 1、安裝crontab:yum install crontabs 說明:/sbin/service crond start //啟動服務/sbin/service crond stop //關閉

lucene、lucene.NET詳細使用與優化[轉]

構造 bitset 更多 隱患 .net wrapper 屬性設置 似的 擔心 1 lucene簡介1.1 什麽是luceneLucene是一個全文搜索框架,而不是應用產品。因此它並不像www.baidu.com 或者google Desktop那麽拿來就能用,它只是提供了

Topshelf結合Quartz.NET實現服務端定時調度任務

param eve basedir 定時 鏈接庫 uninstall for 技術 編寫 這周接受到一個新的需求:一天內分時間段定時輪詢一個第三方WebAPI,並保存第三方WebAPI結果。 需求分析:分時段、定時開啟、定時結束、輪詢。主要工作集中在前三個上,輪詢其實就是

14.linux-platform機制實現驅動層分離()

擴展性 blank 事件處理 相關 技術分享 消息 驅動 array iou 版權聲明:本文為博主原創文章,未經博主允許不得轉載。 本節目標: 學習platform機制,如何實現驅動層分離 1.先來看看我們之前分析輸入子系統的分層概念

zabbix實現原理及架構

收集 信息 核心 狀態 start 原理 整體架構 比較 zabbix 想要用好zabbix進行監控,那麽我們首要需要了解下zabbix這個軟件的實現原理及它的架構。建議多閱讀官方文檔。 一、總體上zabbix的整體架構如下圖所示: 重要組件說明: 1)zabbix se

Linux如何實現開機啟動程序(轉)

window 自己的 進行 執行時間 dns服務 全部 星期 ext 例如 Linux開機啟動程序詳解我們假設大家已經熟悉其它操作系統的引導過程,了解硬件的自檢引導步驟,就只從Linux操作系統的引導加載程序(對個人電腦而言通常是LILO)開始,介紹Linux開機引導的步驟

Linux 定時任務

什麽 file 同名 實現 link 打印 環境 grep 導入 fileclear.sh tamcdir=${HOME}/ora/user_projects/domains/tamc cd ${tamcdir} echo rm -f `ls heapdump*.phd