Quartz.NET 架构与源代码分析系列 part 1 :Quartz.NET 入门

概述

作业调度的目标在于按照预先确定的时间和指定的顺序来确保高效的数据处理流程,从而最大限度的使用系统资源。批处理流程是一种在无需最终用户干预的方式下在后台通过顺序方式运行的操作。

Windows XP系统也自带了“任务计划”,它是一个简单任务调度应用,可以在“开始”->“所有程序”->“附件”->“系统工具”->“任务计划”里找到。如图1;

image

图1.Windows 的任务计划

Quartz.NET 是一个开源的作业调度框架,它可以被在小型应用程序甚至是企业级的应用程序。它有如下几个特点:

  • API 操作简单,只要几行简单的代码你就可以在应用程序里面实现自己的作业调度,并实时监视作业执行情况
  • 触发器功能强大,比 Windows 的任务计划提供更细的触发粒度,你可以使用“Cron表达式(后文将介绍)”来实现如:每周星期一到星期五 8:00am,5:00pm(工作时间) 执行某一件任务
  • 良好的可扩展性,它基于接口编程,你可以实现自己的 Schedule 调度器,Job 作业,以及 Trigger 触发器等
  • 作业可以保存在 RAM 中,也可以持久化到数据库,支持多种数据库类型:SqlServer、Oracle、MySql等
  • 集群,这是一个高级应用,可以在多台计算机之间创建负载平衡、容错处理

使用

最新的版本是1.0 正式版,有 Quartz.2008.sln 和 Quartz.Server.2008.sln(分步式应用,将在下面的系列分析) ,用 Visual Studio 2008 打开 Quartz.2008.sln ,方案如图2 所示:

image

图2. Quartz.NET解决方案

Quartz.NET是核心的 Quartz 库,它的文件组织结构及作用如图3所示:

image

图3.Quartz.NET文件组织结构

Quartz.NET 的文件组织结构并不遵循一定的规范,比如“SPI” 文件夹存放调度器、作业、线程池接口,最外层也放了很多接口,如图3所示。但是大部分都可以直接辨别出来,所以这不会对我们阅读代码造成很大的影响。

下面是一个 Quartz.NET 的简单例子:

ContractedBlock.gifExpandedBlockStart.gifCode
None.gif//初始化调度器工厂 
None.gif
ISchedulerFactory sf = new StdSchedulerFactory(); 
None.gif
//获取默认调度器 
None.gif
IScheduler scheduler = sf.GetScheduler(); 
None.gif
None.gif
//作业 
None.gif
JobDetail job = new JobDetail("计算作业""组1"typeof(Job1)); 
None.gif
None.gif
//触发器 
None.gif
SimpleTrigger trigger = new SimpleTrigger("触发器1""触发器组1"5new TimeSpan(005)); 
None.gif
None.gif
//关联任务和触发器 
None.gif
scheduler.ScheduleJob(job, trigger); 
None.gif
//开始任务 
None.gif
scheduler.Start();
None.gif

首先,我们初始化一个标准的调度器工厂 StdSchedulerFactory ,并用 GetScheduler() 方法创建一个调度器。下一步是声明一个作业对象 JobDetail,它有3 个参数:作业名称、作业组名称、作业的类型。接着,实例化一个 SimpleTrigger 触发器对象,SimpleTrigger 类有6 个构造函数,上面例子的 4 个参数分别为:触发器名称、触发器组名称、循环执行次数、执行间隔。调度器调用 ScheduleJob 方法把作业对象和触发器关联起来,打开触发器就可以开始作业了。

要执行的作业 Job1 是实现了 IJob 接口的类,IJob 接口只有一个简单的方法:

ContractedBlock.gifExpandedBlockStart.gifCode
void Execute(JobExecutionContext context)

每一个要执行的作业都要继承 IJob 接口并实现 Execute 方法。

下面是Job1 的定义:

ContractedBlock.gifExpandedBlockStart.gifCode
None.gifpublic class Job1 :IJob 
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
InBlock.gif     
private int i = 0
InBlock.gif     
public void Execute(JobExecutionContext context) 
ExpandedSubBlockStart.gifContractedSubBlock.gif     
dot.gif
InBlock.gif        Console.WriteLine(
++i); 
ExpandedSubBlockEnd.gif     }
 
ExpandedBlockEnd.gif}

上面代码的执行结果是连续输出6 个1(重复执行5次,加上第一次执行,一共6 次)。

下一篇我将要介绍 Job 作业。

思想,原理,技术,应用

参考文章

1.Microsoft 管理解决方案:作业调度

2.Quartz.NET

 

目录:Quartz.NET 架构与源代码分析系列
下一篇:Quartz.NET 架构与源代码分析系列 part 2 :Job 作业

转载于:https://www.cnblogs.com/Doho/archive/2009/03/11/1408886.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/262626.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Request登录案例

一、分析和设计 1、需求 2、页面 3、druid连接池 4、jar包 5、需求设计 二、代码实现 1、web_WEB-INFO_lib使用之前要先将jar包加入工作空间, 2、JDBC工具类 3、Dao层持久化层 其中,有异常除了输出控制台日志,还可以输出流写入到一个文件中记…

基于winpcap的NDIS在IE浏览器,360安全浏览器hackwww.360.cn

winpcap(windows packet capture)是windows平台下一个免费,公共的网络访问系统。开发winpcap这个项目的目的在于为win32应用程序提供访问网络底层的能力。winpcap 驱动各项功能1. 捕获原始数据包,包括在共享网络上各主机发送/接收的以及相互之间交换的数…

斑马Zebra驱动下载

Zebra GT800 点击进入下载页-> 自动安装包【WINXP/WIN7/WIN8】点击进入下载页-> 添加打印机向导【WINXP/WIN7/WIN8】热门下载 Zebra GK888t Zebra 888-TT/888-DT Zebra 105SL Zebra ZM400 Zebra TLP 2844 Zebra GT800 Zebra GK888d Zebra LP 2844 Zebra Z4Mplus Zebra S4…

HTTP响应消息

一、数据格式 二、相应行状态码 其中,304常见于请求图片,一个图片就是一次请求,但是后面再请求若服务器图片没有修改,则304,访问本地缓存; 500一般见于服务器代码异常,如3/0; 三、响…

javafx如何调节按钮位置_安全带高度调节器的小知识

对于开车的小伙伴对安全带已经再熟悉不过了,但是有很多车,在安全带上有一个小秘密,那就是高度调节器。高度调节器的作用:为了调节安全带上固定点的高度,使安全带能够适应不同体格的乘员,都能达到最好的保护…

Response对象

一、输出流返回响应数据 二、重定向 1、重定向代码以及和转发的区别 2、相对路径 ./ 和 / 都是表示当前路径下 3、绝对路径 三、Response输出数据 1、字符输出流 其中,浏览器打开默认和操作系统使用一样的GBK编码字符集(国标码,中文&#xf…

combox 增加请选择_本命佛怎么请?

佛,从古到今都是人们在憧憬美好未来时一种精神上的象征,它能为世间众生带来好运。而我们所知道的本命佛是与十二生肖属相感应力较强的佛,佩戴与自己生肖相对应的本命佛具有增加财运,保佑健康平安、守护家庭和睦的作用。所以很多人…

cap理论具体含义_分布式系统:CAP 理论的前世今生

CAP 理论是分布式系统设计中的一个重要理论,虽然它为系统设计提供了非常有用的依据,但是也带来了很多误解。本文将从 CAP 诞生的背景说起,然后对理论进行解释,最后对 CAP 在当前背景下的一些新理解进行分析,澄清一些对…

文件下载案例

一、需求分析 其中,浏览器可以直接解析图片,不能解析视频,所以视频的超链接是下载; 加载文件,则需要知道文件的真是路径(ServletContext); 前端: 二、代码实现 其中,Serv…

[转]TortoiseSVN客户端重新设置用户名和密码

在第一次使用TortoiseSVN从服务器CheckOut的时候,会要求输入用户名和密码,这时输入框下面有个选项是保存认证信息,如果选了这个选项,那么以后就不用每次都输入一遍用户名密码了。 不过,如果后来在服务器端修改了用户名…

python实现截图范围框跟随_教你用Python实现截图和文字识别,就是这么简单

Author: By Runsenkeyboard是一个监控键盘输入的库安装:pip install keyboradimport keyboardimport timefrom PIL import ImageGrabdef screen(): print(开始截图) # 使用微信的截图热键 keyboard.wait(hotkeyalta) # 保存 keyboard.wait(hotkeyent…

进制转化

将N转化成R进制 View Code 1 /*进制转换2 将一个数n装化成R进制(2<R<16)3 4 Sample Input5 7 26 23 127 -4 38 9 Sample output 10 111 11 1B 12 -11 13 */ 14 #include<stdio.h> 15 int main() 16 { 17 int n,r,i,k,t; 18 char f[1000],g[18]{"0123…

JDBC基础和使用

内存泄漏意思就是内存越来越少了&#xff0c;因为垃圾太多&#xff1b; 线程泄露就是线程池中线程越来越少&#xff0c;执行过程中异常&#xff0c;没有返回给线程池&#xff0c;线程池中线程越来越少&#xff1b; 一、概念 二、快速入门 三、JDBC各个类详解 1、driverManager …

车间生产能耗管控方案_SAREN三仁净化工程:锂电池生产车间的设计规范及方案...

对于锂电池厂厂房装修而言&#xff0c;必须做好车间设计&#xff0c;因为锂电池的生产需要一个洁净的车间环境。锂电池厂厂房装修的车间设计要领主要体现在5方面&#xff0c;即&#xff1a;人员与物料布局、确定清洁度等级、确定空间压力差、确定空间空气平衡、确定机械系统布局…

将uglifyjs添加到鼠标右键菜单

之前几天根据YUICompressor和TBCompressor整合到鼠标右键菜单自己将uglifyjs也添加到了右键菜单&#xff0c;下面简单记录下过程。效果如下 uglifyjs添加到鼠标右键菜单配置windows nodepath环境 鼠标右键我的电脑&#xff0c;选择属性→高级属性管理→高级选项卡→环境变量&am…

1标志图片_这四种情况将不再扣分罚款!11月起,全国高速统一限速标志

如果你经常跑高速&#xff0c;那么你可能经常会有这样的经历&#xff1a;本来开车开得好好的&#xff0c;忽然遇到限速标志&#xff0c;赶紧进行紧急刹车。又或者限速标志在不醒目的地方&#xff0c;完全没有发现&#xff0c;等到下了高速才知道自己因为超速被扣分了~这些问题不…

NPOI 菜鸟实践行之根据指定的模板生成Excel 2003格式的文件 (一)

感谢群里的各位朋友的指导和教学&#xff0c;感谢Tony Qu的热心指导&#xff0c;感谢阿修罗兄提供的Excelhelper类 谈谈个人对Excel的理解&#xff0c;结合NPOI&#xff0c;个人水平一般般&#xff0c;菜鸟一只 Excel 打开后&#xff0c;分为sheet-文件簿&#xff0c;Rows-行&a…

Java设计模式12:装饰器模式

装饰器模式 装饰器模式又称为包装&#xff08;Wrapper&#xff09;模式。装饰器模式以多客户端透明的方式扩展对象的功能&#xff0c;是继承关系的一个替代方案。 装饰器模式的结构 通常给对象添加功能&#xff0c;要么直接修改对象添加相应的功能&#xff0c;要么派生子类来扩…

JDBC使用案例

一、结果集中获取数据并对实体set值&#xff0c;封装成对象返回&#xff1b; 2、封装JDBC工具类 只要执行一次的&#xff0c;如读取配置文件&#xff0c;则写静态代码块&#xff1b; 异常抛出要写明方法才可以throw&#xff0c;静态代码块异常只能捕捉try catch; 类加载器两个作…

Android入门:Log介绍

一、Log类介绍 在Logcat视图中查看Android日志信息&#xff1b; (1)Log.v()&#xff1a;任意信息&#xff1b; (2)Log.e()&#xff1a;error信息&#xff1b; (3)Log.w()&#xff1a;warning信息&#xff1b; (4)Log.i()&#xff1a;提示信息&#xff1b; (5)Log.d()&#xff1…