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:

  1. <clients>
  2.  
  3. <modules>
  4. <repository>./modules</repository>
  5. <module name="tim-quartz-1.5.1" version="1.2.0"/>
  6. </modules>
  7. </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

Quartz与Terracotta的集成的更多相关文章

  1. quartz与spring进行集成

    上一篇将了quartz框架的使用,spring同样也提供了对quartz的集成.这次就尝试一下在spring中集成quartz. 要在spring中使用job,Trigger和Scheduler,就要 ...

  2. Quartz与Spring Boot集成使用

    上次自己搭建Quartz已经是几年前的事了,这次项目中需要定时任务,需要支持集群部署,想到比较轻量级的定时任务框架就是Quartz,于是来一波. 版本说明 通过搜索引擎很容易找到其官网,来到Docum ...

  3. 定时任务quartz与spring的集成

    我想要在spring的集成框架中使用spring , 暂时采用quartz 根据下面的几篇博客实现了(懒得说了,直接丢链接): Quartz实现动态定时任务 Spring 3整合Quartz 2实现定 ...

  4. Quartz学习总结(1)——Spring集成Quartz框架

    一.Quartz简介 Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用.Quartz可以用来创建简 ...

  5. 关于Quartz.NET作业调度框架的一点小小的封装,实现伪AOP写LOG功能

    Quartz.NET是一个非常强大的作业调度框架,适用于各种定时执行的业务处理等,类似于WINDOWS自带的任务计划程序,其中运用Cron表达式来实现各种定时触发条件是我认为最为惊喜的地方. Quar ...

  6. springmvc+spring+mybatis+maven项目集成shiro进行用户权限控制【转】

    项目结构:   1.maven项目的pom中引入shiro所需的jar包依赖关系 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...

  7. Quartz 在 Spring 中如何动态配置时间--转

    原文地址:http://www.iteye.com/topic/399980 在项目中有一个需求,需要灵活配置调度任务时间,并能自由启动或停止调度. 有关调度的实现我就第一就想到了Quartz这个开源 ...

  8. spring 定时器Quartz

    一.Quartz是什么 二.  核心接口 scheduler  --- 核心调度器 Job  --- 任务 JobDetail  --- 任务描述 Tigger  --- 触发器 三 . 核心接口之间 ...

  9. 【Quartz】Quartz的搭建、应用(单独使用Quartz)

    Quartz在Java构建的系统中,是十分常用的定时任务框架. 本文,记录.介绍Quartz的简单入门的单独搭建(此文入门学习Quartz为主,并非基于Spring托管形式). > 参考的优秀资 ...

随机推荐

  1. Hadoop集群_VSFTP安装配置

    原作者写的太好了,我这个菜鸟不自觉就转载了,原文链接:http://www.cnblogs.com/xia520pi/archive/2012/05/16/2503864.html 如果,您认为阅读这 ...

  2. 基于eclipse搭建android开发环境-win7 32bit

    基于eclipse搭建android开发环境-win7 32bit 前言:在使用朋友已搭建的Android开发环境时,发现朋友的开发环境版本较低且在update SDk时失败,便决定根据网上文章提示从 ...

  3. MySQL分表操作的例子

    USE project;DROP PROCEDURE IF EXISTS project.delete_test_user;delimiter $$CREATE PROCEDURE project.d ...

  4. (一)maven之创建一个maven项目

    为什么要使用Maven? 1.  maven使用的是本地仓库存储jar,所有项目都会共用仓库中的同一份jar. 2.  Spring core.jar必须同时引用版本兼容的common-logging ...

  5. O2O的十八个细分市场,运营模式如何?

    社区O2O,这个行业也被媒体热炒有三年多时间了,有没有做的还算不错的案例呢?万科.龙湖.恒大.保利.易居中国.彩生活.拉卡拉.顺丰?哪个可以称得上是成功案例?战略变来变去,方向换来换去,基本上都是雷声 ...

  6. UVA 10003 cuting sticks 切木棍 (区间dp)

    区间dp,切割dp[i][j]的花费和切法无关(无后效性) dp[i][j]表示区间i,j的花费,于是只要枚举切割方法就行了,区间就划分成更小的区间了.O(n^3) 四边形不等式尚待学习 #inclu ...

  7. WPF中Canvas使用

    首先知道Canvas有Left.Right.Top和Bottom这四个属性,放入Canvas的元素通过这四个属性来决定它们在Canvas里面的位置. 比如: Xaml: <Canvas Hori ...

  8. 第009课 gcc和arm-linux-gcc和MakeFile

    from:第009课 gcc和arm-linux-gcc和MakeFile 第001节_gcc编译器1_gcc常用选项_gcc编译过程详解 gcc的使用方法 gcc [选项] 文件名 gcc常用选项 ...

  9. 数组初始化 和 vector初始化

    ] = {}; 整个数组都初始化为0 vector<); 整个vector初始化为1 如果你定义的vector是这样定义的: vector<int> B; 去初始化,千万不要用: ; ...

  10. CPP-练习

    HW: 1.局部变量能否和全局变量重名? 答:能,局部会屏蔽全局.要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会 ...