Quartz任务调度基本实现原理

(1)什么是quartz?
quartz是一个完全由java编写的开源作业调度框架,为在java应用程序中进行作业调度提供了简单却强大的机制。quartz允许开发人员根据时间间隔来调度作业。它实现了作业和触发器的多对多的关系,还能把多个作业与不同的触发器关联。简单地创建一个org.quarz.job接口的java类。
(2)quartz的特点;
作为一个优秀的开源调度框架,quartz 具有以下特点:
① 强大的调度功能,例如支持丰富多样的调度方法,可以满足各种常规及特殊需求;
② 灵活的应用方式,例如支持任务和调度的多种组合方式,支持调度数据的多种存储方式;
③ 分布式和集群能力,terracotta 收购后在原来功能基础上作了进一步提升。
④ quartz 很容易与 spring 集成实现灵活可配置的调度功能。
(3)quartz专用词汇说明;
下面是本文中用到的一些专用词汇,在此声明:
scheduler :
任务调度器
trigger :
触发器,用于定义任务调度时间规则
job :
任务,即被调度的任务
misfire :
错过的,指本来应该被执行但实际没有被执行的任务调度
(4)quartz任务调度基本实现原理;
quartz 任务调度的核心元素是 scheduler, trigger 和 job,其中 trigger 和 job 是任务调度的元数据, scheduler 是实际执行调度的控制器。
在 quartz 中,trigger 是用于定义调度时间的元素,即按照什么时间规则去执行任务。quartz 中主要提供了四种类型的 trigger:simpletrigger,crontirgger,dateintervaltrigger,和 nthincludeddaytrigger。这四种 trigger 可以满足企业应用中的绝大部分需求。
在 quartz 中,job 用于表示被调度的任务。主要有两种类型的 job:无状态的(stateless)和有状态的(stateful)。对于同一个 trigger 来说,有状态的 job 不能被并行执行,只有上一次触发的任务被执行完之后,才能触发下一次执行。job 主要有两种属性:volatility 和 durability,其中 volatility 表示任务是否被持久化到数据库存储,而 durability 表示在没有 trigger 关联的时候任务是否被保留。两者都是在值为 true 的时候任务被持久化或保留。一个 job 可以被多个 trigger 关联,但是一个 trigger 只能关联一个 job。
在 quartz 中, scheduler 由 scheduler 工厂创建:directschedulerfactory 或者 stdschedulerfactory。 第二种工厂 stdschedulerfactory 使用较多,因为 directschedulerfactory 使用起来不够方便,需要作许多详细的手工编码设置。 scheduler 主要有三种:remotembeanscheduler, remotescheduler 和 stdscheduler。本文以最常用的 stdscheduler 为例讲解。这也是笔者在项目中所使用的 scheduler 类。

热设计软件在电源适配器设计中的应用有哪些?
移动Andon安灯呼叫系统的组成
工业机器人与数控机床集成的四大应用
专用通信三网融合方式探讨
BLE/2.4G/USB 三模无线键盘鼠标方案
Quartz任务调度基本实现原理
荧光分光光度计是紫外么_荧光分光光度计原理是什么
计算机网络管理技术的应用
数字万用表应该怎么选?
可穿戴设备市场正向医疗健康领域靠拢 近年来销量也是呈现了爆发式的增长
回顾云知声打造开放共赢的儿童智能产品平台细节内容
柔性电路板上倒装芯片组装技巧
华为鸿蒙分布式能力加速落地,避免使用设备来回切换
“太行110”重型燃气轮机通过鉴定
助力AI算法芯片化 新思科技推出ASIP Designer
利扬芯片受邀出席第23届中国集成电路制造年会(CICD 2020)
华为Mate X折叠手机曝光采用鹰翼式外折方案可实现0-180度自由翻折
5G产业将在2020年达到爆发期会给传统产业提供更多可能
VCSEL激光技术为光伏设备的可靠检测降本增效
石头扫地机器人开箱测评 高度探测省心省力