第二课:QuartzAPI,Jobs和Triggers简介

Quartz API

Quartz API 关键的几个接口:

Scheduler:跟任务调度相关的最主要的API接口。

Job:你期望任务调度执行的组件定义(调度器执行的内容),都必须实现该接口。

JobDetail:用来定义Job的实例。

Trigger:定义一个指定的Job何时被执行的组件,也叫触发器。

JobBuilder:用来定义或创建JobDetail的实例,JobDetail限定了只能是Job的实例。

TriggerBuilder:用来定义或创建触发器的实例。

调度器的生命周期,起始于SchedulerFactory的创建,终止于调用shutdown方法。当调度器接口实例创建完成后,就可以添加,删除和查询Jobs和Triggers对象,也可以执行其它的跟调度器相关的操作,比如中止触发器的触发。并且,调度器在调用start方法之前,不会触发任何一个触发器去执行作业任务,如第一课所示的例子。

Quartz框架提供许多构造器类来定义一套领域特定语言,简称DSL,有时候也称为“流接口”。在上一课中我们看到的示例,现在重新展示一部分代码如下:

    // define the job and tie it to our HelloJob class
IJobDetail job = JobBuilder.Create<HelloJob>()
.WithIdentity("myJob", "group1") // name "myJob", group "group1"
.Build(); // Trigger the job to run now, and then every 40 seconds
ITrigger trigger = TriggerBuilder.Create()
.WithIdentity("myTrigger", "group1")
.StartNow()
.WithSimpleSchedule(x => x
.WithIntervalInSeconds()
.RepeatForever())
.Build(); // Tell quartz to schedule the job using our trigger
sched.scheduleJob(job, trigger);

上面的代码,使用JoBuilder创建了IJobDetail对象,同样,TriggerBuilder创建了ITrigger对象。IJobDetail:定义工作的使用,ITrigger:定义触发器。

其他的扩展方法:

WithCalendarIntervalSchedule
        WithCronSchedule
        WithDailyTimeIntervalSchedule
        WithSimpleSchedule

功能各样的Schedule类提供多种方法来定义不同类型的调度器。

DateBuilder类包含了许多方法可以更简捷地构建Date实例对象,尤其针对特定的时间点,比如下一个的整点时间,换言之现在是9:43:27,我需要得到10:00:00的时间对象。

Jobs和Triggers

作业任务类实现Job接口,只有一个方法

IJob接口

 namespace Quartz
{
public interface IJob
{
void Execute(JobExecutionContext context);
}
}

当作业任务的触发器被触发的那一刻,调度器的一个工作线程,将会调用该Job的execute方法。JobExecutionContext对象会向execute方法传递运行时环境的工作任务信息:执行该方法的调度器引用,触发该方法执行的触发器引用,Job实例的JobDetail对象,以及一些其它信息。

当调度器添加Job实例时,会在Quartz客户端程序中(咱们自己开发的代码)创建JobDetail对象。JobDetail为Job实例提供了许多设置属性,以及JobDataMap成员变量属性,它用来存储特定Job实例的状态信息。这是从本质上定义Job实例,我们将会在下一节中深入地讨论相关的细节。

触发器对象用来触发Job对象的执行,当你希望调度一项作业任务,你可以实例化一个触发器并且将触发时间属性调整为你期望的时间表。触发器也可以关联JobDataMap对象,可以非常方便地将具体的被触发的触发器当作参数传递给Job实例。

Quartz框架附带少数不同类型的触发器,但最常用的类型是SimpleTrigger和CronTrigger。

SimpleTrigger适用于一次性的任务执行(在给定的时间段只执行一次的作业任务),或者你需要在指定时间多次触发作业任务,每次触发都延迟固定的时间。CronTrigger适用于基于类似日历时间表的触发,比如“每个周五的下午”或是“每月10号的10:15”。

为什么要分别定义作业任务和触发器?许多作业调度并没有区分作业任务和触发器的概念。有些框架把作业任务简单定义成执行时间(或计划)以及一些小作业标识符,其他框架更像是整合了Quartz框架的作业和触发器对象。因此我们设计Quartz时,我们决定构建调度器时拆分开调度和任务是有意义的,在我看来,这样做还是有许多好处。

例如,作业任务可以独立于触发器在作业调度中创建和存储,多个触发器可以关联到相同的作业任务中。另一个好处是在作业任务关联的触发器失效后,仍然能够在调度器上松耦合地配置作业任务,因此该作业不需要重新定义,一段时间后能够重新调度。它还允许你在不重新实例化关联的作业任务下修改和替换触发器。

Identites(标识符)
        作业任务和触发器被注册到Quartz调度器时需要提供标识信息。这种标识信息(也称作作业任务键和触发器键)允许作业任务和触发器按组存放,这样可以很方便地将你的作业任务和触发器分组,比如分为“报表类Job”和“维护类Job”。作业任务和触发器的键的名称部分在同一个组内必须唯一,换句话说,作业任务和触发器的键(或标识符)的名字是由键名和组名共同组成的。

现在你对作业任务和触发器有一个大概的了解了,你可以在“第三课 更多关于Jobs和JobDetails”和“第四课 更多关于Triggers”学到更多关于它们的知识。

[译]Quartz 框架 教程(中文版)2.2.x 之第二课 Quartz API,Jobs和Triggers简介的更多相关文章

  1. Quartz 框架 教程(中文版)2.2.x

    Quartz 框架 教程(中文版)2.2.x 之第一课 开始使用Quartz框架 Quartz 框架 教程(中文版)2.2.x 之第二课 Quartz API,Jobs和Triggers简介 Quar ...

  2. [译]Quartz 框架 教程(中文版)2.2.x 之第一课 开始使用Quartz框架

    第一课:开始使用Quartz框架 在你使用调度器之前,需要借助一些具体的例子去理解(谁愿意只是猜啊?).你可以使用SchedulerFactory类来达到程序调度的目的.有一些Quartz框架的用户可 ...

  3. Quartz框架调用——运行报错:ThreadPool class not specified

    Quartz框架调用——运行报错:ThreadPool class not specified 问题是在于Quartz框架在加载的时候找不到quartz.properties配置文件: 解决方案一: ...

  4. [译]Quartz.Net 框架 教程(中文版)2.2.x 之第三课 更多关于Jobs和JobDetails

    第三课 更多关于Jobs和JobDetails 在这二课我们已经学习到,Jobs接口非常容易实现,只有一个execute方法.我们需要再学习一些知识去理解jobs的本质,Job接口的execute方法 ...

  5. (转)Java任务调度框架Quartz入门教程指南(二) 使用job、trigger、schedule调用定时任务

    http://blog.csdn.net/zixiao217/article/details/53044890 读完第一节,我们已经对Quartz有了一个大体的认识,它可以定时帮我们执行一些处理程序, ...

  6. Quartz框架(第一版)

    任务调度 在企业级应用中,经常会制定一些"计划任务",即在某个时间点做某件事情 核心是以时间为关注点,即在一个特定的时间点,系统执行指定的一个操作 任务调度涉及多线程并发.线程池维 ...

  7. Tensorflow 官方版教程中文版

    2015年11月9日,Google发布人工智能系统TensorFlow并宣布开源,同日,极客学院组织在线TensorFlow中文文档翻译.一个月后,30章文档全部翻译校对完成,上线并提供电子书下载,该 ...

  8. Quartz框架

    Quartz框架 Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制.Quartz 允许开发人员根据时间间隔(或天)来调度作业.它实现了作业和触发器的多 ...

  9. 【淘淘】Spring整合Quartz框架

    我在外面工作实习的时候,我们做的项目是一个日报子系统,也就是定时定点为公司生成一些报表数据还有一些数据反馈.这时候我们会经常用到定时任务,比如每天凌晨生成前天报表,每一小时生成汇总数据等等.当时,我做 ...

随机推荐

  1. a5

    今日内容: 今天主要还是素材的查找,图标的制作以及调整. 明日计划: 主要还是完成图标,尽可能的美化 困难: 一个是直男式的审美吧,另一个是PS的技术还不够深

  2. Redis 列表(List)

    Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素到列表的头部(左边)或者尾部(右边),一个列表最多可以包含2^32-1个元素(4294967295,每个列表超过40亿个元素). ...

  3. 《剑指offer》--- 两个链表的第一个公共结点

    本文算法使用python3实现 1. 问题   输入两个链表,找出它们的第一个公共结点.   时间限制:1s:空间限制:32768K 2 思路描述   使用两个指针 $ p1,p2 $ 分别指向两个链 ...

  4. 使用Python 、 go 语言测试rabbitmq的工作机制

    1:在haproxy 和 rabbitmq上安装Python.python2-pip,默认是Python2 yum install -y python python2-pip   2:在haproxy ...

  5. 团队作业05——测试与发布(alpha阶段)

    测试 请根据团队项目中软件的需求文档.功能说明.系统设计和测试计划,写出软件的测试过程和测试结果,并回答下述问题. 在测试过程中总共发现了多少Bug?每个类别的Bug分别为多少个? 显示计算结果超过看 ...

  6. 【Django】Django迁移数据库

    我们已经编写了博客数据库模型的代码,但那还只是 Python 代码而已,Django 还没有把它翻译成数据库语言,因此实际上这些数据库表还没有真正的在数据库中创建 为了让 Django 完成翻译,创建 ...

  7. BZOJ 2004 公交线路(状压DP+矩阵快速幂)

    注意到每个路线相邻车站的距离不超过K,也就是说我们可以对连续K个车站的状态进行状压. 然后状压DP一下,用矩阵快速幂加速运算即可. #include <stdio.h> #include ...

  8. Catalan数,括号序列和栈

    全是入门的一些东西.基本全是从别处抄的. 栈: 支持单端插入删除的线性容器. 也就是说,仅允许在其一端加入一个新元素或删除一个元素. 允许操作的一端也叫栈顶,不允许操作的一端也叫栈底. 数个箱子相叠就 ...

  9. 题解 P1628 【合并序列】

    看到这个题,小金羊第一秒的反应就是: 优先队列可解! 看到楼上某同学一个个比较, find()函数是时候现身了! string//类型库 //find具体用法可以自行百度 //这里仅说这里的用法(逃) ...

  10. <深入理解计算机系统>第七章读书笔记

    第七章读书笔记 链接 链接:将各种代码和数据部分收集起来并组合成为一个单一文件的过程.(这个文件可被加载或拷贝到存储器并执行) 链接可以执行于编译,加载或运行时. 静态链接: 两个主要任务: 1 符号 ...