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

   在日常的开发中,运行定时任务基本上已经是很普遍的需求了,可以通过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搭建动态作业调度器)