Net作業調度(四)—quartz.net持久化和集群


介紹

在實際使用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";

簡單管理界面:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM