Quartz.NET總結(四)Quartz 遠程調度


轉載自:http://www.cnblogs.com/zhangweizhong/p/5552558.html

 前面篇已經介紹了Quartz.NET的配置,使用和Cron表達式表達式的寫法。基本上后台的定時任務的定時執行已經完成,並能正確的按照執行計划,執行相關的job 。

  然后,如果任務需要更新,停止某個任務呢 ? 總不能上服務器去改相關job 的配置吧。 所以,Quartz.NET 也給我們提供了遠程調度的方法。這次就簡單介紹下Quartz.NET 遠程調度的配置和方法。

  

  1. 配置Quartz.NET 遠程方式執行

    計划任務的服務器上配置遠程調用Quartz的出口, quartz.config 增加如下配置即可

      #export this server to remoting context
      quartz.scheduler.exporter.type = Quartz.Simpl.RemotingSchedulerExporter, Quartz
      quartz.scheduler.exporter.port = 555
      quartz.scheduler.exporter.bindName = QuartzScheduler
      quartz.scheduler.exporter.channelType = tcp
      quartz.scheduler.exporter.channelName = httpQuartz

    幾點說明:
      1. 客戶端的"quartz.scheduler.proxy.address" 配置的地址由服務器上配置的channelType,port和 bindName 等組成。注意保持一致。

      2. 服務器初始化啟動時,從數據庫啟動相關Job 的過程這里不細說。下次介紹我自己做的任務調度平台的時候,再細說。

      3. Job 服務器上,其實就算一個服務宿主,在后台控制調度全部的job 執行計划。

  2. 管理客戶端

    a) 創建一個后台管理的客戶端,可以是web網站。也可以是別的。
      初始化遠程服務器上的全部Scheduler

復制代碼
        private static IScheduler scheduler = null;
        public static void InitRemoteScheduler()
        {
            try
            {
                NameValueCollection properties = new NameValueCollection();
                properties["quartz.scheduler.instanceName"] = "schedMaintenanceService";
                properties["quartz.scheduler.proxy"] = "true";
                properties["quartz.scheduler.proxy.address"] = string.Format("{0}://{1}:{2}/QuartzScheduler", scheme, server, port);
                ISchedulerFactory sf = new StdSchedulerFactory(properties);

                scheduler = sf.GetScheduler();
            }
            catch (Exception ex)
            {
                LogHelper.WriteLog("初始化遠程任務管理器失敗" + ex.StackTrace);
            }
        }        
復制代碼

    b) 增加,暫停,刪除任務等操作

復制代碼
        /// <summary>
        /// 暫停任務
        /// </summary>
        /// <param name="JobKey"></param>
        public static void PauseJob(string JobKey)
        {
            try
            {
                JobKey jk = new JobKey(JobKey);
                if (scheduler.CheckExists(jk))
                {
                    //任務已經存在則暫停任務
                    scheduler.PauseJob(jk);
                    LogHelper.WriteLog(string.Format("任務“{0}”已經暫停", JobKey));
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
復制代碼

     這里,只說了暫停的,只不過其他的都差不多。

  3. 其他

    另外,Quartz.NET提供了crystal-quartz  來實現遠程管理。CrystalQuartz.Example.RemoteScheduler.Server 示例。感興趣的朋友, 可以自己手動配置看看。


免責聲明!

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



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