Quartz与Terracotta的集成
• 综述
• 配置模块
• 支持的功能
• 与基于数据库的Quartz集群的对比
• 公开源代码库
• 内部源代码库(为代码提交者使用)
综述
Quartz是开源Java任务调度系统,它可以与几乎所有的J2EE或者J2SE应用整合在一起使用。Quartz可以用来调度执行几十、成百甚至上万个任务。任务里面的具体工作则可以用标准的Java空间或者EJB构成。
Quartz和Terracotta的整合使得Quartz可以基于RAMJobStore来构建集群。与现有的JobStoreTx或者JboStoreCMT等基于数据库的Quartz集群相比,Terracotta实现的基于RAMJobStore的集群具有更高的效率和易用性。
配置模块
最快、最简单配置Quartz集群的方式就是在您Terracotta XML配置文件中包含Quartz配置模块。只需要从Terracotta Forge中下载如下Quartz相关的jar包,并且把它加到配置文件中:
Code:
<clients> <modules>
<repository>./modules</repository>
<module name="tim-quartz-1.5.1" version="1.2.0"/>
</modules>
</clients>
* 模块位置
要注意确认模块放置在正确的位置。模块位置是在<repository>元素中配制的。最简单的办法是把模块的jar包拷贝到TC_INSTALL_DIR/modules目录下,这样您就不需要配置<repository>了。如果您要把模块放在自定义的位置,就一定要配置<repository>。
比如上面的配置文件就假定模块放在当前目录的modules子目录下。
* 模块名
注意模块的jar文件名和配置文件中的模块名有相关性。jar文件名一定要符合 <模块名>-<版本>的格式。
有关模块配置的详细信息可以参考:
http://www.terracotta.org/web/display/docs/Configuration+Guide+and+Reference#ConfigurationGuideandReference-configmodules
支持的功能
1. 在Terracotta中使用tim-quartz,提供了一个Quartz RAMNJobStore的集群话的版本。
2. 调度任务的执行负载被均衡分配到整个集群中:集群中每一个调度器(Scheduler)都视图根据调度器的权限触发调度任务触发器(trigger)。所有的调度器实例都争抢触发调度任务的权利。当一个任务被触发以后,其它的调度器在下次调度时间到来之前,就不能触发相同的触发器了。
3. 从失败的调度器实例中回复:当调度器实例出现故障时,Terracotta能够自动检测到故障,并且将自动恢复任务,使得它能够被其它的调度器在他们下一次执行时间得到执行。
4. 任务和触发器信息在节点发生故障时不会丢失:如果Terracotta服务器配置为持久化模式(persistent mode),这些信息将在服务器启动过程部得以保留。比如:A任务在一个节点上被激活,当当前节点宕机或者死机的时候,它可以在其它节点上继续执行。
5. 被恢复的任务立即被执行。如果他们的调度器出现故障,他们将在集群中其它调度器上被立即执行。
与基于数据库的Quartz集群的对比
1. 与基于数据库的JobStoreTx或JobStoreCMT实现的Quartz集群相比较,Terracotta基于内存的实现执行起来会快很多。Terracotta基于字段的数据变化处理使得任务和触发器的修改速度超快。
2. 简单易用。不需要任何数据库的安装配置。
3. 失败的任务可以立即被恢复。而基于数据库的实现则需要在制定的时间间隔内对调度器作检查才能完成恢复。
4. 不需要JGroups或者其它集群配置。
公共源代码库
SVN: http://svn.terracotta.org/svn/forge/projects/tim-quartz
内部源代码库(为代码提交者使用)
SVN: https://svn.terracotta.org/svn/forge/projects/tim-quartz