Quartzs -- Quartz.properties 配置
- 文件加载位置
默认:优先顺序 Classpath:quartz.properties --> org/quartz/quartz.properties (quartz lib)
改变默认:设置一个系统属性"org.quartz.properties"指向对应的properties文件
- 程序中显示指定
在StdSchedulerFactory.getScheduler()之前使用StdSchedulerFactory.initialize(xx)。
- properties文件中的属性关系
固定前缀org.quartz
主要分为scheduler,ThreadPool,JobStore,plugin等等部分
例如ThreadPool的配置信息
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 5
org.quartz.threadPool.threadPriority = 5
实例化ThreadPool的时候使用org.quartz.simpl.SimpleThreadPool,
实例化结束后threadCount,threadPriority 将以setter的形式注入到ThreadPool实例中
- 属性值的复用
$propertyName
$@org.quartz.scheduler.instanceName
- 官方配置文档
http://www.quartz-scheduler.org/documentation/quartz-1.x/configuration/
- threadPool
#Quartz ThreadPool
org.quartz.threadPool.class=threadPool类名(SimpleThreadPool就好)
org.quartz.threadPool.threadCount=thread数量,不会动态增长(所有的JOB)
org.quartz.threadPool.threadPriority=thread优先级
#Quartz SimpleThreadPool(使用默认就好)
#org.quartz.threadPool.makeThreadsDaemons=true/false是否为守护线程
#org.quartz.threadPool.threadsInheritGroupOfInitializingThread=true/false
#org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread=true/false
- jobStore
1)RAMJobStore
将schedule相关信息保存在RAM中,轻量级,速度快,遗憾的是应用重启时相关信息都将丢失。
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
org.quartz.jobStore.misfireThreshold = 60000
misfireThreshold : 最大能忍受的触发超时时间,如果超过则认为“失误”
2)JDBC-JobStore
将schedule相关信息保存在RDB中.有两种实现:JobStoreTX和JobStoreCMT
前者为application自己管理事务
后者为application server管理事务,即全局事务JTA
JobStoreTX
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass
#类似于Hibernate的dialect,用于处理DB之间的差异,StdJDBCDelegate能满足大部分的DB
org.quartz.jobStore.dataSource
#这个值必须存于一个datasource的配置信息
#org.quartz.dataSource.XXX.driver...
org.quartz.jobStore.tablePrefix
#存储相关信息表的前缀
org.quartz.jobStore.useProperties
#JobDataMaps是否都为String类型
org.quartz.jobStore.misfireThreshold
#与RAMJobStore中的一致
org.quartz.jobStore.isClustered
#是否是应用在集群中,当应用在集群中时必须设置为TRUE,否则会出错org.quartz.jobStore.clusterCheckinInterval
#scheduler的checkin时间,时间长短影响failure scheduler的发现速度
org.quartz.jobStore.maxMisfiresToHandleAtATime
#jobStore处理未按时触发的Job的数量
org.quartz.jobStore.dontSetAutoCommitFalse
#true/false,true则调用connection的setAutoCommit(false)方法
org.quartz.jobStore.selectWithLockSQL
#加锁的SQL语句,默认为SELECT * FROM {0}LOCKS WHERE LOCK_NAME = ? FOR UPDATE
#{0}=$@org.quartz.jobStore.tablePrefix
org.quartz.jobStore.txIsolationLevelSerializable
#true/false, true则调用connection的setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE) 方法
org.quartz.jobStore.acquireTriggersWithinLock
#触发job时是否需要拥有锁
org.quartz.jobStore.lockHandler.class
#用于管理数据库中相关信息的锁机制的类名
- dataSource
建议最大的连接数最少为ThreadPool的threadCount,并且如果应用经常访问scheduler的API的话最好是有一些额外的connection,也就是说要比ThreadPool的worker threads大一些
三种方式
1)datasource的相关信息全部定义于quartz.properties中,quartz自己创建datasource
org.quartz.dataSource.NAME.driver
org.quartz.dataSource.NAME.URL
org.quartz.dataSource.NAME.user
org.quartz.dataSource.NAME.password
org.quartz.dataSource.NAME.maxConnections
#以上为dataSource的基本属性,大家都懂的
#NAME必须与$@org.quartz.jobStore.dataSource一致
org.quartz.dataSource.NAME.validationQuery
#dataSource用于检测connection是否failed/corrupt的SQL语句
2)使用JNDI的datasource
org.quartz.dataSource.NAME.jndiURL
#JNDI URL
org.quartz.dataSource.NAME.java.naming.factory.initial
#JNDI InitialContextFactory
org.quartz.dataSource.NAME.java.naming.provider.url
org.quartz.dataSource.NAME.java.naming.security.principal
org.quartz.dataSource.NAME.java.naming.security.credentials
#后三行为连接到JNDI提供者的相关信息
3)用户自定义org.quartz.utils.ConnectionProvider实现类
org.quartz.dataSource.NAME.connectionProvider.class
org.quartz.dataSource.NAME.XXX
- Cluster

实现故障处理和负载均衡,实现高可用性和扩展性
通过共享DB Tables实现,所以必须使用JDBC-Jobstore
负载均衡 : 谁先触发谁执行,并且一次只有一个scheduler触发
故障处理 : 当一个scheduler失败后,其它的实例可以发现那些执行失败的Jobs,假如Job对应的JobDetail标记为recovery(属性"requests recovery"),那么该Job就会被其它的实例重新执行,否则对应的Job只会被释放等待下次被触发。
实现:
org.quartz.jobStore.isClustered = true
所有的实例的quartz.properties文件除了org.quartz.scheduler.instanceId和org.quartz.threadPool.threadCount必须一致,org.quartz.scheduler.instanceId = AUTO 即可实现ID的不一致
注意:
1.不在不同的机器上实现集群功能,除非他们的时钟同步精确到秒
2.不实现集群的实例不使用同一套表
Quartzs -- Quartz.properties 配置的更多相关文章
- 【Quartz】配置最简单的集群
在许多情况,我们希望我们的定时任务是可靠的,不会因系统故障.机器宕机而导致某一笔定时任务不能按时运行.这种情况下,我们就需要为Quartz做个集群. 最简单的情况,有两台机器或两个应用,同时维护一批定 ...
- Quartz的配置文件quartz.properties详解
配置 quartz.properties 文件 文件 quartz.properties 定义了 Quartz 应用运行时行为,还包含了许多能控制 Quartz 运转的属性.这个文件应该放在class ...
- 【Quartz】Quartz存储与持久化-基于quartz.properties的配置
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 一. Quartz存储与持久化 Quartz提供两种基本作业存储类型.第一种类型叫做RAM ...
- Quartz.NET配置
概述 Quartz.NET 在开源任务调度框架中的翘首,它提供了强大任务调度机制,难能可贵的是它同时保持了使用的简单性.Quartz 允许开发人员灵活地定义触发器的调度时间表,并可以对触发器和任务进行 ...
- Quartz动态配置表达的方法
在项目中有一个需求,需要灵活配置调度任务时间,并能自由启动或停止调度.有关调度的实现我就第一就想到了Quartz这个开源调度组件,因为很多项目使用过,Spring结合Quartz静态配置调度任务时间, ...
- quartz.properties完整版
我们通常是通过quartz.properties属性配置文件(默认情况下均使用该文件)结合StdSchedulerFactory 来使用Quartz的.StdSchedulerFactory 会加载属 ...
- C# Quartz的配置
1. 介绍 Quartz为后台工作者提供了得便利,我们下面介绍一下它的配置.本文配置主要针对服务程序的配置. 但是在做下面配置之前,要安装包 Install-Package Quartz 2. Qua ...
- 二)quartz.properties
The Properties File Quartz uses a properties file called (kudos on the originality) quartz.propertie ...
- Spring 与 Quartz 动态配置(数漫江湖)
因为项目的需求,需要有动态配置计划任务的功能.本文在 Quartz JobBean 中获取配置的 Quartz cronExpression 时间表达式及 Spring Bean 的对象名.方法名并运 ...
随机推荐
- Get the image file(s) some informations,Including the Make,Model,Date/Time,etc
This is a blog about how to get the image file(s) some informations.Including the Make,Model,Date/Ti ...
- SSH整合所需的jar包
Spring3.1+Hibernate3+Struts2的最新整合所需要的jar包 Spring的基本jar包: 1.org.springframework.web-3.1.4.RELEASE.jar ...
- 微课程--Android--基础控件的使用
view viewgroup是一种特殊的view,里面可以包含其他的view 如何生成view: 1 在代码里动态生成 2 写在XML里面 view的常见属性--宽度 wrap_content 随着内 ...
- serv-u and hway3.0
一个非常好用的su提权脚本,在支持php的环境下,目录可读可写,基本秒杀. <? //HWay && Serv-U by r00t //r00t@007team.net //ww ...
- [转]Visual Studio 实用扩展推荐
本文转自 http://www.cnblogs.com/stg609/p/3726898.html Visual Studio 拥有非常不错的可扩展性,在之前的文章中,我也给大家示范了如何进行编辑器的 ...
- discuz全局数组变量 后台各项设置 完整版
$_G 保存了 Discuz! 中所有的预处理数据 缓存能够很好的提高程序的性能,一些配置数据没必要每次都查询数据库,只要在修改了的时候更新下缓存即可. Discuz! 中所有的缓存保存在 $_G[c ...
- MSBuild学习记录
参考资料 官方文档 MSBuild入门 MSBuild的简单介绍与使用
- Redis 笔记与总结2 String 类型和 Hash 类型
Linux 版本信息: cat /etc/issue 或cat /etc/redhat-release(Linux查看版本当前操作系统发行版信息) CentOS release 6.6 (Final) ...
- DirectX 基础学习系列6 字体
DIRECTX9自带ID3DXFONT类 内部调用GDI的接口,效率一般,但能够处理一些复杂的字体 HRESULT D3DXCreateFontIndirect( LPDIRECT3DDEVICE9 ...
- A20的板子笔记
除了串口可以登入控制台,还可以用SSH2. ftp连接的时候要打开 vi /usr/sbin/stupid-ftpd.conf 修改端口,修改完端口,登入的时候root的密码跟以前不一样,可以从st ...