【转载】定时调度篇

   原文地址:http://www.cnblogs.com/yaopengfei/p/8449846.html

    声明:转载的定时调度篇系列章节,讲得很不错,很有见地,确实是原创作者用心之作,特此转载,以作技术交流。

    原创作者博客地址:http://www.cnblogs.com/yaopengfei。里边有很多不错的文章。

一. 背景

  我们在日常开发中,可能你会遇到这样的需求:"每个月的3号给用户发信息,提醒用户XXX "、"每天的0点需要统计前一天的考勤记录"、"每个月的1号计算上个月的库存情况"、"定时初始化数据供其它业务使用"、"每隔2分钟轮询查数据库看某业务是否被审核通过,并提示用户" 等等。

  以上需求在开发中都非常常见,但它们仅仅属于低端一点的需求,稍高端一点的需求比如:" 客服派车给调度,如果调度3天内没有执行任何操作,需要提示调度要抓紧派车了 ",到这一步为止看起来和上面的需求并没有什么两样,但如果我要求,系统管理员可以动态配置提示时间呢?即管理员可以配置调度几天没有执行任何操作,系统需要给出提示。这么一改的话,对于一些新手而已,难度就陡然上升了。

  下面我们接着升级需求,系统中有A、B、C、D。。。。等等多个业务,系统管理员可以动态配置每个业务的执行时间情况(如:每隔2s执行一次、每月3号执行一次等等),并且可以动态的控制每个业务的开启、关闭、暂停、全部关闭、全部暂停等。需求升级到这个程度,估计新手就抓虾了,有一定经验的人但是没有接触过类似框架,面对这样的需求,也需要一定的时间去研究。

解惑:

  需求1:也就是我们常说的定时任务,简答一点的可以借助Timer类来实现,对时间要求复杂的需要借助第三方的框架来实现,如:Quartz.Net.

  需求2:需要我们动态配置定时任务的执行时间。

  需求3:需要我们自己搭建一个定时调度框架,然后来动态配置任务的开启、关闭和触发器的情况。

   需求三就是我们最终的目标,即我们要搭建一套通用的定时调度框架,可以手动增加定时任务,配置其触发器,手动控制任务的开启、关闭(B/S 架构);或者C/S架构,最终部署成windows服务的形式。

  综上所述:Quartz.Net将是我们的最佳选择。

 

二. Quartz.Net简介

 1. Quartz.Net是一个强大、开源、轻量的作业调度框架,是 OpenSymphony 的 Quartz API 的.NET移植,用C#改写,可用于winform和asp.net应用中。它灵活而不复杂。你能够用它来为执行一个作业而创建简单的或复杂的作业调度。

它有几大优势:

  a.持久化数据库:SQLServer、MySQL、MongoDB、Redis

  b.集群支持:双机热备

  c.支持Web B/S架构和WinForm C/S架构

  d.trigger可以灵活的控制时间各类苛刻的时间要求

2. Quartz.Net框架的使用

①.引入方式:

  a. 通过NuGet引入搜索Quartz引入相应的程序集。

  (2.x版本需要会引入三个程序集:Common.Logging、Common.Logging.Core、Quartz和一个xsd文件用于xml配置进行代码提示)

  b. 去官网下载源码,通过引入源码的形式进行引入(http://www.quartz-scheduler.net/)。

  PS:目前最新版本为3.0.5(2018-06-23),这里采用的是2.6.1 即2x的最后一个版本,3x起支持.netcore,且基本用法发生一些变化,最好使用vs2017

②.基本使用:

  a.创建作业调度池(Scheduler)

  b.创建一个具体的作业即job (具体的job需要单独在一个文件中执行)

  c.创建并配置一个触发器即trigger 

  d.将job和trigger加入到作业调度池中

  e.开始调度 start

3. 官方地址

  官网:http://www.quartz-scheduler.net/

  示例:http://www.quartz-scheduler.net/documentation/quartz-2.x/quick-start.html

 

三. 转载的系列章节 

        第1节: 使用Timer编写定时任务、Quartz.Net入门、Aop思想的体现

        第2节:比较DateTime和DateTimeOffset两种时间类型并介绍Quartz.Net中用到的几类时间形式(定点、四舍五入、倍数、递增)

        第3节: Quartz.Net五大构件之Scheduler(创建、封装、基本方法等)和Job(创建、关联等)

        第4节: Quartz.Net五大构件之Trigger通用用法(常用方法、优先级、与job关联等)

        第5节: Quartz.Net五大构件之Trigger的四大触发类

        第6节: 六类Calander处理六种不同的时间场景

        第7节:Trigger(SimpleTrigger、CronTrigger)哑火(MisFire)策略

        第8节: Quartz.Net五大构件之SimpleThreadPool及其四种配置方案

        第9节: 利用RemoteScheduler实现Sheduler的远程控制

        第10节: 利用SQLServer实现Quartz的持久化和双机热备的集群模式

        第11节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借助TopSelf、服务类】)

  

    原文地址:http://www.cnblogs.com/yaopengfei/p/8449846.html

    原创作者博客地址:http://www.cnblogs.com/yaopengfei

 

posted @ 2018-06-05 16:56  BruceLee1123  阅读(140)  评论(0编辑  收藏  举报