在實際使用quartz.net中,持久化能保證明例重啓後job不丟失、 集羣能均衡服務器壓力和解決單點問題。mysql
quartz.net在這兩方面配置都比較簡單。git
quartz.net的持久化,是把job、trigger一些信息存儲到數據庫裏面,以解決內存存儲重啓丟失。github
https://github.com/quartznet/quartznet/blob/master/database/tables/tables_sqlServer.sqlsql
QRTZ_BLOB_TRIGGERS 以Blob 類型存儲的觸發器。mongodb
QRTZ_CALENDARS 存放日曆信息, quartz.net能夠指定一個日曆時間範圍。數據庫
QRTZ_CRON_TRIGGERS cron表達式觸發器。服務器
QRTZ_JOB_DETAILS job詳細信息。多線程
QRTZ_LOCKS 集羣實現同步機制的行鎖表架構
QRTZ_SCHEDULER_STATE 實例信息,集羣下多使用。oracle
//===持久化==== //存儲類型 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";
簡單管理界面: