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. ListView与ScrollView冲突的4种解决方案

    问题解决方案1.手动设置ListView高度    经过测试发现,在xml中直接指定ListView的高度,是可以解决这个问题的,但是ListView中的数据是可变的,实际高度还需要实际测量.于是手动 ...

  2. TFS数据库分离附加经验总结

    因TFS数据库已经100多G,所在的服务器D盘已没有空间满足tfs数据库的增长速度,故必须分离复制到其它盘.在分离过程中,先后分离了ReportServer.ReportServerTempDB.Tf ...

  3. LR11安装和配置教程

    LoadRunner11安装教程 #安装包文件.汉化文件.破解文件,可以自行百科来获得,这边仅提供安装步骤. 1.前期准备1)安装前需要关闭防火墙及杀毒软件2)安装路径不能包含中文字符,同时需要以管理 ...

  4. Hyperledger Fabric on SAP Cloud Platform

    今天的文章来自Wen Aviva, 坐Jerry面对面的程序媛. Jerry在之前的公众号文章<在SAP UI中使用纯JavaScript显示产品主数据的3D模型视图>已经介绍过Aviva ...

  5. Android(java)学习笔记147:自定义SmartImageView(继承自ImageView,扩展功能为自动获取网络路径图片)

    1. 有时候Android系统配置的UI控件,不能满足我们的需求,Android开发做到了一定程度,多少都会用到自定义控件,一方面是更加灵活,另一方面在大数据量的情况下自定义控件的效率比写布局文件更高 ...

  6. Ace 在Vue中使用方法

    var Vue = require('vue/dist/vue.common.js'); document.querySelector('body').append(document.createEl ...

  7. 引入了junit为什么还是用不了@Test注解

    pom文件明明引入了unit,为什么还是用不了@Test? 配置如下: <dependency> <groupId>junit</groupId> <arti ...

  8. 【转载】WPF DataGrid 性能加载大数据

    作者:过客非归 来源:CSDN 原文:https://blog.csdn.net/u010265681/article/details/76651725 WPF(Windows Presentatio ...

  9. Bootstrap历练实例:禁用的按钮

    <!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...

  10. git 不完全教程

    概念 工作目录:当前所见,Working directory 暂存区域:以后要提交到仓库的文件,称为Index或者staging area Git 仓库:持久化存储快照的地方,HEAD指针所指向的地方 ...