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接口,这个接口能被实现来为任务的存储提供不同的机制。
- 应用JDBCJobStore, 所有被配置成“稳定”的任务和触发器能通过JDBC存储在关系数据库里。
- 应用RAMJobStore, 所有任务和触发器能被存储在RAM里因此不必在程序重起之间保存-一个好处就是不必使用数据库。
事务
- 使用JobStoreCMT(JDBCJobStore的子类),Quartz 能参与JTA事务。
- Quartz 能管理JTA事务(开始和提交)在执行任务之间,这样,任务做的事就可以发生在JTA事务里。
集群
- Fail-over.
- Load balancing.
监听器和插件
- 通过实现一个或多个监听接口,应用程序能捕捉调度事件来监控或控制任务/触发器的行为。
- 插件机制可以给Quartz增加功能,例如保持任务执行的历史记录,或从一个定义好的文件里加载任务和触发器。
- Quartz 装配了很多插件和监听器。