在日常的学习、工作、生活中,肯定对各类范文都很熟悉吧。范文怎么写才能发挥它最大的作用呢?下面是小编为大家收集的优秀范文,供大家参考借鉴,希望可以帮助到有需要的朋友。
开源任务调度系统篇一
quartz 是 opensymphony 开源组织在任务调度领域的一个开源项目,完全基于 java 实现。该项目于 2009 年被 terracotta 收购,目前是 terracotta 旗下的一个项目。读者可以到 http:///站点下载 quartz 的发布版本及其源代码。在产品开发中使用的是版本 1.8.4,因此本文内容基于该版本。
强大的调度功能,例如支持丰富多样的调度方法,可以满足各种常规及特殊需求;
灵活的应用方式,例如支持任务和调度的多种组合方式,支持调度数据的多种存储方式;
分布式和集群能力,terracotta 收购后在原来功能基础上作了进一步提升。本文暂不讨论该部分内容
另外,作为 spring 默认的调度框架,quartz 很容易与 spring 集成实现灵活可配置的调度功能。
下面是本文中用到的一些专用词汇,在此声明:
scheduler:任务调度器 trigger:触发器,用于定义任务调度时间规则 job:任务,即被调度的任务 misfire:错过的,指本来应该被执行但实际没有被执行的任务调度
quartz 任务调度的基本实现原理
quartz 任务调度的核心元素是 scheduler, trigger 和 job,其中 trigger 和 job 是任务调度的元数据, scheduler 是实际执行调度的控制器。
在 quartz 中,trigger 是用于定义调度时间的元素,即按照什么时间规则去执行任务。quartz 中主要提供了四种类型的 trigger:simpletrigger,crontirgger,dateintervaltrigger,和 nthincludeddaytrigger。这四种 trigger 可以满足企业应用中的绝大部分需求。我们将在企业应用一节中进一步讨论四种 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 类。
quartz 中的 trigger 和 job 需要存储下来才能被使用。quartz 中有两种存储方式:ramjobstore, jobstoresupport,其中 ramjobstore 是将 trigger 和 job 存储在内存中,而 jobstoresupport 是基于 jdbc 将 trigger 和 job 存储到数据库中。ramjobstore 的存取速度非常快,但是由于其在系统被停止后所有的数据都会丢失,所以在通常应用中,都是使用 jobstoresupport。
在 quartz 中,jobstoresupport 使用一个驱动代理来操作 trigger 和 job 的数据存储:stdjdbcdelegate。stdjdbcdelegate 实现了大部分基于标准 jdbc 的功能接口,但是对于各种数据库来说,需要根据其具体实现的特点做某些特殊处理,因此各种数据库需要扩展 stdjdbcdelegate 以实现这些特殊处理。
s("content_relate");【quartz开发企业级任务调度应用】相关文章:
1.j2ee企业级应用开发
2.jsp应用开发的特点
3.web service的开发与应用基础
4.办公自动化的应用与开发
5.利用powerbuilder开发计算机web应用
6.ntserver中层企业级试题及答案
7.j2ee应用技术开发结构
8.机械数控技术的开发方向与应用前景