林炳文Evankaka原创作品。转载请注明出处http://blog.youkuaiyun.com/evankaka
Quartz 在开源任务调度框架中的翘首,它提供了强大任务调度机制,难能可贵的是它同时保持了使用的简单性。Quartz 允许开发人员灵活地定义触发器的调度时间表,并可以对触发器和任务进行关联映射。
此外,Quartz提供了调度运行环境的持久化机制,可以保存并恢复调度现场,即使系统因故障关闭,任务调度现场数据并不会丢失。此外,Quartz还提供了组件式的侦听器、各种插件、线程池等功能。
一、Quartz功能概述
Quartz是一个开源的任务调度系统,它能用来调度很多任务的执行。
运行环境
- Quartz 能嵌入在其他应用程序里运行。
- Quartz 能在一个应用服务器里被实例化(或servlet容器), 并且参与XA事务
- Quartz能独立运行(通过JVM),或者通过RMI
- Quartz能被集群实例化
任务调度
当一个指定给任务的触发器发生时,任务就被调度执行.触发器能被创建为:
- 一天的某个时间(精确到毫秒级)
- 一周的某些天
- 一个月的某些天
- 一年的某些天
- 不在一个Calendar列出的某些天 (例如工作节假日)
- 在一个指定的次数重复
- 重复到一个指定的时间/日期
- 无限重复
- 在一个间隔内重复
能够给任务指定名称和组名.触发器也能够指定名称和组名,这样可以很好的在调度器里组织起来.一个加入到调度器里的任务可以被多个触发器注册。在J2EE环境里,任务能作为一个分布式(XA)事务的一部分来执行。
任务执行
- 任务能够是任何实现Job接口的Java类。
- 任务类能够被Quartz实例化,或者被你的应用框架。
- 当一个触发器触发时,调度器会通知实例化了JobListener 和TriggerListener 接口的0个或者多个Java对象(监听器可以是简单的Java对象, EJBs, 或JMS发布者等). 在任务执行后,这些监听器也会被通知。
- 当任务完成时,他们会返回一个JobCompletionCode ,这个代码告诉调度器任务执行成功或者失败.这个代码 也会指示调度器做一些动作-例如立即再次执行任务。
任务持久化
- Quartz的设计包含JobStore接口,这个接口能被实现来为任务的存储提供不同的机制。 </