Quartz.NET总结(四)Quartz 远程调度


  前面篇已经介绍了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;
            }
        }

     这里,只说了暂停的,只不过其余的都差很少。code

  3. 其余

    另外,Quartz.NET提供了crystal-quartz  来实现远程管理。CrystalQuartz.Example.RemoteScheduler.Server 示例。感兴趣的朋友, 能够本身手动配置看看。

相关文章
相关标签/搜索