[干货]基于Quartz搭建动态作业调度器

作者: 朱志远_john | 来源:发表于2017-02-16 11:00 被阅读0次

   在日常的开发中,运行定时任务基本上已经是很普遍的需求了,可以通过windows服务+timer组件来实现,也可以使用第三方框架来集成,Quartz.NET就是一款从JAVA的Quartz移植过来的一个不错的作业调度组件,具体用法,不做介绍,可以自行百度。

本次主要介绍如何更灵活的使用Quartz.NET来实现以下几个特性
1. 通过web管理界面,进行作业的热更新和添加作业和删除
2. 通过web管理界面,进行作业的动态启动和停止
3. 通过web管理界面,查看作业运行状态的实时监控

既然是web管理界面,首先得建个网站,总共四个界面
1. 运行作业的监控列表
2. 正在运行的作业列表(附带停止功能)
3. 所有作业列表(附带删除和启动功能)
4. 添加作业界面


新建一个类库,只包含一个基类,BaseJob,只有一个虚方法 Run方法,在我们开发作业的时候 ,新建类库,然后引用这个类库,继承BaseJob,并实现Run方法即可。

再建一个类库,添加对上一个类库的引用(下面的添加作业功能第一种添加作业的方案,web站点需要引用这个类库),此类库主要做以下几个功能
1. 正在运行作业池(静态资源,里面包含了所有正在运行的作业),并包含以下几个主要功能
      1. 添加作业(这里有两种方式,第一种,作业直接运行再网站应用程序池下,第二个方案,网站再添加作业的时候通过MQ的方式添加,另外运行windows服务从MQ里获取,然后添加到程序池里,第二种方案,web站点不需要引用这个类库)      解压上传的作业类库,并通过动态加载程序集的方式,装载程序集,根据配置的时间表达式,动态组合第三步的JobDetail和Trigger,然后装载到Schedule,并启动[这个请参考Quartz.NET的用法,版本不一样可能稍微有差异]
      2. 停止作业,卸载程序集
2. 另开一个线程,监控作业的运行状态,写入数据库,web站点的监控列表,从数据库读取
3. 新建一个JobDetail类来实现Quartz.NET的IJob接口,Run方法里,调用我们动态加载并被转换为BaseJob类的Run方法

至此,动态管理程序集的基本步骤就完了,中间需要考虑异常处理,在动态添加作业的时候,需要有以下几个关键属性
   1. 作业的命名空间(包含命名空间和类名,用来动态加载程序集,实例化用)
   2. 入口dll的名称 (用来装载程序集)
   3. 上传压缩包,记录压缩包的存储位置,用来解压缩
   4. 版本号,用来装载不同的版本,回滚用
   5. 时间表达式,也就是运行策略,什么时候运行,或者多久运行一次

好了,够了,灵活的调度器至此诞生了。JAVA的原理一样。

相关文章

  • [干货]基于Quartz搭建动态作业调度器

    在日常的开发中,运行定时任务基本上已经是很普遍的需求了,可以通过windows服务+timer组件来实现,也可以...

  • Quartz 调度器

    一、简介 Quartz是一个开源作业调度框架,框架的核心是调度器,调度器负责管理Quartz应用运行时环境,调度器...

  • 关于任务定时调度

    Tags:定时作业调度 分布式定时任务调度 Quartz TBSchedule Elastic-job 基于给定...

  • 调度执行--quartz核心线程类

    QuartzSchedulerThread 调度器初始化后构造了核心调度线程,quartz整个作业获取执行均由此线...

  • Quartz.NET 作业调度(一):Test

    Quartz.NET 是一个开源的作业调度框架,是 Java 作业调度框架 Quartz 的.NET 版本,对于...

  • Quartz 概览

    Quartz Enterprise Job Scheduler 什么是Quartz作业调度库? Quartz是一个...

  • elasticjob架构

    基于zookeeper、quzrtz的分布式任务调度(作业)框架实现的主要功能: 重写quartz基于数据库的分布...

  • RDIFramework.NET框架基于Quartz.Net实现

    在上一篇Quartz.Net实现作业定时调度详解,我们通过实例代码详细讲解与演示了基于Quartz.NET开发的详...

  • Quartz框架入门一

    一 简介 (1)为什么使用Quartz 首先Quartz框架的作用是进行作业调度的,但是进行作业调度已经存在了Ja...

  • springboot使用quartz集群定时任务

    简介 Quartz是一个完全由java编写的开源作业调度框架。不要让作业调度这个术语吓着你。尽管Quartz框架整...

网友评论

    本文标题:[干货]基于Quartz搭建动态作业调度器

    本文链接:https://www.haomeiwen.com/subject/ncwcwttx.html