介紹
在實際使用quartz.net中,持久化能保證例項重啟後job不丟失、 叢集能均衡伺服器壓力和解決單點問題。
quartz.net在這兩方面配置都比較簡單。
持久化
quartz.net的持久化,是把job、trigger一些資訊儲存到資料庫裡面,以解決記憶體儲存重啟丟失。
下載sql指令碼
https://github.com/quartznet/quartznet/blob/master/database/tables/tables_sqlServer.sql
建立個資料庫,並執行指令碼
QRTZ_BLOB_TRIGGERS 以Blob 型別儲存的觸發器。
QRTZ_CALENDARS 存放日曆資訊, quartz.net可以指定一個日曆時間範圍。
QRTZ_CRON_TRIGGERS cron表示式觸發器。
QRTZ_JOB_DETAILS job詳細資訊。
QRTZ_LOCKS 叢集實現同步機制的行鎖表
QRTZ_SCHEDULER_STATE 例項資訊,叢集下多使用。
quartz.net 配置
//===持久化==== //儲存型別 properties["quartz.jobStore.type"] = "Quartz.Impl.AdoJobStore.JobStoreTX, Quartz"; //表明字首 properties["quartz.jobStore.tablePrefix"] = "QRTZ_"; //驅動型別 properties["quartz.jobStore.driverDelegateType"] = "Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz"; //資料來源名稱 properties["quartz.jobStore.dataSource"] = "myDS"; //連線字串 properties["quartz.dataSource.myDS.connectionString"] = @"Data Source=(local);Initial Catalog=JobScheduler;User ID=sa;Password=123465"; //sqlserver版本 properties["quartz.dataSource.myDS.provider"] = "SqlServer-20";
啟動客戶端
var properties = JobsManager.GetProperties(); var schedulerFactory = new StdSchedulerFactory(properties); scheduler = schedulerFactory.GetScheduler(); scheduler.Start(); //var job = JobBuilder.Create<MonitorJob>() // .WithIdentity("test", "value") // .Build(); //var trigger = (ICronTrigger) TriggerBuilder.Create() // .WithIdentity("test", "value") // .WithCronSchedule("0 0/5 * * * ?") // .Build(); //scheduler.ScheduleJob(job, trigger);
補充
1: 持久化後,job只有新增一次了(資料庫已經有了),所以不能再執行端寫新增job的行為。這時候需要一個管理工具,動態新增操作。
2: quartz.net 支援sql server、sqlite、mysql、oracle、mongodb(非官方版)。
叢集
部署圖:
如圖quartz.net 的叢集模式是依賴資料庫表的,所以要持久化配置。 叢集節點之間是不通訊的,這樣分散式的架構,很方便進行水平擴充套件。
1: 除了執行緒池數量,instanceId可以不同外,各個節點的配置必須是一樣的。
2:叢集中節點的系統時間一致。
3:多執行緒、叢集中。quartz.net 利用資料庫鎖來保證job不會重複執行。
原始碼在DBSemaphore.cs、UpdateLockRowSemaphore.cs、StdRowLockSemaphore.cs
4:叢集化後,某節點失效後,剩餘的節點能保證job繼續執行下去。
例項配置後啟動。
//cluster properties["quartz.jobStore.clustered"] = "true"; properties["quartz.scheduler.instanceId"] = "AUTO";
簡單管理介面: