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

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

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

  而後,若是任務須要更新,中止某個任務呢 ? 總不能上服務器去改相關job 的配置吧。 因此,Quartz.NET 也給咱們提供了遠程調度的方法。此次就簡單介紹下Quartz.NET 遠程調度的配置和方法。github

  

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

    計劃任務的服務器上配置遠程調用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 的過程這裏不細說。下次介紹我本身作的任務調度平臺的時候,再細說。tcp

      3. Job 服務器上,其實就算一個服務宿主,在後臺控制調度所有的job 執行計劃。

  2. 管理客戶端網站

    a) 建立一個後臺管理的客戶端,能夠是web網站。也能夠是別的。
      初始化遠程服務器上的所有Schedulerthis

複製代碼
        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) 增長,暫停,刪除任務等操做spa

複製代碼
        /// <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 示例。感興趣的朋友, 能夠本身手動配置看看。

相關文章
相關標籤/搜索