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

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. 浅析 var that = this;

    在阅读别人的代码时,发现别人写的代码中有这么一句:var that = this;,这代表什么意思呢?经过一番查阅,才明白是这么回事. 在JavaScript中,this代表的是当前对象. var t ...

  2. Objective-C Loops

    There may be a situation, when you need to execute a block of code several number of times. In gener ...

  3. ABC3D创客项目:国旗

    国旗是一个国家的象征,也是一个民族的骄傲,国旗带给人们的不仅是荣耀,更多的是爱国的情结.看一场天安门的升旗仪式一度成为广大游客去到北京的必有项目,看国旗仪仗队将五星红旗与太阳同时升起,象征着我国充满活 ...

  4. 树形dp——Tree2cycle

    一.问题描述(题目链接) 给你一棵树,删除或添加一条边的费用都是1,问使它变成一个环的最小费用. 二.解题思路 回溯法,然后回溯的时候的当前节点度数>2(如果是成环的话肯定就是2或者小于2)就把 ...

  5. win7上安装虚拟机并上网

    一.安装Workstation Pro 二.下载CentOS-7-x86_64-DVD-1511.iso包 三.创建新的虚拟机,按照向导安装即可 四.使用cd /etc/sysconfig/netwo ...

  6. 【转】Spring, MyBatis 多数据源的配置和管理

    同一个项目有时会涉及到多个数据库,也就是多数据源.多数据源又可以分为两种情况: 1)两个或多个数据库没有相关性,各自独立,其实这种可以作为两个项目来开发.比如在游戏开发中一个数据库是平台数据库,其它还 ...

  7. QT+动手设计一个登陆窗口+布局

    登陆窗口的样式如下: 这里面涉及着窗口的UI设计,重点是局部布局和整体布局, 首先在ui窗口上添加一个容器类(Widget),然后将需要添加的控件放置在容器中,进行局部布局(在进行局部布局的时候可以使 ...

  8. ios 团购信息客户端demo(二)

    接上一篇,这篇我们对我们的客户端加入KissXML,MBProgressHUD,AQridView这几个库,首先我们先加入KissXML,这是XML解析库,支持Xpath,可以方便添加更改任何节点.先 ...

  9. JS与IOS、安卓的交互

    最近做的项目中涉及到了与安卓和ios的交互问题,对于一个新手来说,多多少少会有点迷糊.在调用安卓和ios的callback回调时,很轻松的就调用成功了,而且,步骤也不那么繁琐.刚开始,只知道那样使用可 ...

  10. Django项目部署:使用uwsgi和nginx的方式

    一.背景 前两天制作的个人博客网站基本完工,大致功能具备.但是在部署环节却也处处碰壁,这里也来总结以下,以备将来不时查看以及完善. 二.前提 2.1 需要的知识 django Django是一个基于p ...