博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Quartz.NET总结(四)Quartz 远程调度
阅读量:6708 次
发布时间:2019-06-25

本文共 2395 字,大约阅读时间需要 7 分钟。

转载自: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) 增加,暂停,删除任务等操作

///         /// 暂停任务        ///         ///         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  来实现远程管理。。感兴趣的朋友, 可以自己手动配置看看。

转载于:https://www.cnblogs.com/jbps/p/6054316.html

你可能感兴趣的文章
在Sql语句中使用正则表达式来查找你所要的字符
查看>>
18种最实用的网站推广方法大全
查看>>
浅谈C/C++中的typedef和#define
查看>>
浅谈C/C++中的指针和数组(一)
查看>>
这该死的数字化生活
查看>>
matlab练习程序(圆柱投影)
查看>>
需要谨记的产品设计原则
查看>>
checkbox实现单选多选
查看>>
billing是如何的拆分的?
查看>>
Lua 迭代器与closure
查看>>
mybatis_helloworld(2)_源码
查看>>
完整部署CentOS7.2+OpenStack+kvm 云平台环境(3)--为虚拟机指定固定ip
查看>>
BLE 广播数据解析
查看>>
Oracle用户密码过期和用户被锁解决方法【转】
查看>>
Android 解决Android的TextView和EditText换行问题
查看>>
CSS效果集锦(持续更新中)
查看>>
通过重建Hosting系统理解HTTP请求在ASP.NET Core管道中的处理流程[中]:管道如何处理请求...
查看>>
Eigen教程(9)
查看>>
单元测试
查看>>
操作hadoop的经验积累
查看>>