概述:Quartz.NET是一個強大的任務排程庫,支援透過配置檔案靈活配置任務和觸發器。配置檔案中定義了排程器、執行緒池、作業和觸發器的相關資訊。預設情況下,Quartz.NET在應用程式根目錄查詢名為 quartz.config 的配置檔案。若配置檔案位於其他路徑或具有不同名稱,可以透過傳遞 NameValueCollection 來指定。以下是一個簡單的示例,演示瞭如何使用配置檔案配置兩個作業和觸發器。
Quartz.NET是一個強大的開源任務排程庫,可以透過配置檔案方便地進行任務配置。使用配置檔案的優點在於可以將任務的排程資訊與程式碼分離,使得任務配置更加靈活,並且可以在不修改程式碼的情況下進行排程策略的調整。以下是一個簡單的配置檔案示例,以及詳細的講解、步驟、方法和注意事項。
quartz_jobs.xml配置檔案示例(quartz_jobs.xml)
<?xml version="1.0" encoding="utf-8"?>
<job-scheduling-data xmlns="http://quartznet.sourceforge.net/JobSchedulingData"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
version="2.0">
<processing-directives>
<overwrite-existing-data>true</overwrite-existing-data>
</processing-directives>
<schedule>
<job>
<name>Job1</name>
<group>JobGroup</group>
<description>Job1 Description</description>
<job-type>Sample_Quartz2.Job1, Sample_Quartz2</job-type>
<durable>true</durable>
<recover>false</recover>
</job>
<trigger>
<cron>
<name>Job1Trigger</name>
<group>JobGroup</group>
<description>Job1每2秒執行一次</description>
<job-name>Job1</job-name>
<job-group>JobGroup</job-group>
<cron-expression>0/2 * * * * ?</cron-expression>
</cron>
</trigger>
<job>
<name>Job2</name>
<group>JobGroup</group>
<description>Job2 Description</description>
<job-type>Sample_Quartz2.Job2, Sample_Quartz2</job-type>
<durable>true</durable>
<recover>false</recover>
</job>
<trigger>
<cron>
<name>Job2Trigger</name>
<group>JobGroup</group>
<description>Job2每5秒執行一次</description>
<job-name>Job2</job-name>
<job-group>JobGroup</job-group>
<cron-expression>0/5 * * * * ?</cron-expression>
</cron>
</trigger>
</schedule>
</job-scheduling-data>
講解、步驟、方法、注意事項
- 配置檔案結構解釋:
- configSections: 定義配置檔案的部分。
- quartz: Quartz.NET的配置部分,定義排程器、執行緒池、和作業儲存等資訊。
- schedule: 定義作業和觸發器的配置資訊。
- 配置項解釋:
- quartz.scheduler.instanceName: 排程器的例項名稱。
- quartz.threadPool.type: 執行緒池型別。
- quartz.threadPool.threadCount: 執行緒池中執行緒的數量。
- quartz.jobStore.type: 作業儲存型別。
- 作業(Job)和觸發器(Trigger)配置:
- 每個作業和觸發器都有名稱、組、描述等屬性。
- jobType指定作業的型別(完整型別名)。
- cronExpression定義觸發器的排程規則。
- 注意事項:
- 確保作業的型別和程式集資訊正確。
- 避免觸發器的規則衝突。
- 注意作業的執行時間和頻率,以免影響系統效能。
Quartz.NET實現和使用例項
下面是一個簡單的作業實現(Job1.cs和Job2.cs),以及一個用於啟動排程器的例項(SchedulerExample.cs)。
Job1.cs
using Quartz;
using System;
namespace MyNamespace
{
public class Job1 : IJob
{
public void Execute(IJobExecutionContext context)
{
Console.WriteLine("Job 1 is running at: " + DateTime.Now);
}
}
}
Job2.cs
using Quartz;
using System;
namespace MyNamespace
{
public class Job2 : IJob
{
public void Execute(IJobExecutionContext context)
{
Console.WriteLine("Job 2 is running at: " + DateTime.Now);
}
}
}
SchedulerExample.cs
using Quartz;
using Quartz.Impl;
using System;
namespace QuartzExample
{
class SchedulerExample
{
static void Main(string[] args)
{
ISchedulerFactory schedulerFactory = new StdSchedulerFactory();
IScheduler scheduler = schedulerFactory.GetScheduler().Result;
//載入配置檔案
XMLSchedulingDataProcessor xMLSchedulingDataProcessor = new XMLSchedulingDataProcessor(new SimpleTypeLoadHelper());
xMLSchedulingDataProcessor.ProcessFileAndScheduleJobs(AppDomain.CurrentDomain.BaseDirectory + "/quartz_jobs.xml", scheduler);
// 啟動排程器
scheduler.Start();
Console.WriteLine("Scheduler started at: " + DateTime.Now);
// 關閉排程器
//scheduler.Shutdown();
Console.ReadKey();
}
}
}
執行效果:
這個例子演示瞭如何使用Quartz.NET建立兩個簡單的作業,並透過配置檔案指定排程規則。在實際應用中,你需要根據具體需求更改作業的邏輯和配置檔案中的排程規則。