`

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.不实现集群的实例不使用同一套表

分享到:
评论

相关推荐

    quartz-2.4.0-SNAPSHOT-distribution.tar.gz

    5. **配置文件**:`config`目录可能包含Quartz的默认配置文件,如`quartz.properties`,开发者可以根据需求修改这些配置来定制Quartz的行为。 Quartz的核心特性包括: - **灵活性**:支持各种类型的触发器,如简单...

    spring-boot-2.1.3.RELEASE.jar.rar

    spring-boot-2.1.3.RELEASE.jar -autoconfigure- -devtools- -maven-plugin- -starter- -starter-jdbc- -starter-json- -starter-logging- -starter-test- -starter-tomcat- -starter-web- ...-test-autoconfigure-

    quartz-1.6.0.jar和quartz-all-1.6.0.jar

    在给定的压缩包文件中,我们有两个版本为1.6.0的Quartz JAR包:`quartz-1.6.0.jar`和`quartz-all-1.6.0.jar`。这两个JAR包虽然名字相似,但它们的内涵有所不同。 `quartz-1.6.0.jar`是Quartz的基本库,包含了核心的...

    quartz-2.2.3-distribution.tar.gz

    这个"quartz-2.2.3-distribution.tar.gz"压缩包包含的是Quartz库的2.2.3版本,它是专门为Java开发人员设计的,便于在Java应用中实现定时任务的管理和执行。 Quartz的核心功能包括: 1. **任务调度**:它允许开发者...

    spring-context-support-4.0.5.RELEASE.jar

    spring-context-support-4.0.5.RELEASE.jar

    shiro-jar.zip

    shiro-crypto-hash-1.7.1.jar,shiro-ehcache-1.7.1.jar,shiro-event-1.7.1.jar,shiro-guice-1.7.1.jar,shiro-hazelcast-1.7.1.jar,shiro-lang-1.7.1.jar,shiro-quartz-1.7.1.jar,shiro-spring-1.7.1.jar,shiro-web-...

    quartz-jobs-2.3.2.jar中文-英文对照文档.zip

    注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【***.jar下载地址(官方地址+国内镜像地址).txt】 ...

    quartz-all-1.8.5.jar

    quartz-all-1.8.5.jar quartz-all-1.8.5.jar quartz-all-1.8.5.jar quartz-all-1.8.5.jar

    resin-pro-4.0.65.zip下载

    2. 集成支持:Resin Pro支持多种技术,如JSP、Servlet、EJB、Quartz Job Scheduler、JMS和JMX,使得开发者可以方便地集成各种服务和框架。 3. 部署便捷:Resin Pro提供了一个直观的管理控制台,便于用户部署、管理和...

    quartz-2.3.0-distribution.tar.gz

    在这个版本的分布文件 "quartz-2.3.0-distribution.tar.gz" 中,包含了 "quartz-2.3.0-SNAPSHOT" 这个子目录,这通常意味着这是一个开发中的版本,尽管它在发布时可能是稳定的,但仍然带有 "SNAPSHOT" 标记,提示...

    Quartzs -- JDBC-JobStore - Oracle 实现 + Cluster

    在 `quartz.properties` 文件中,你需要指定 JobStore 类型为 JDBC 并提供数据库相关的配置,如: ``` org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX org.quartz.jobStore....

    spring-context-support.jar

    spring-context-support.jar spring整合任务调度quartz必需jar 还需要quartz-all-x.x.x.jar quartz版本必需在1.8.x以下

    spring-context-support-4.2.2.RELEASE.jar 的jar包

    1. **任务调度支持**: `spring-context-support`包含了对Quartz和Commons JEXL的支持,允许开发者在Spring容器中配置和管理定时任务。例如,你可以通过XML配置或者使用`@Scheduled`注解来定义周期性执行的任务,这...

    spring-context-support.jar,quartz-all-1.6.0.jar

    而当我们提到`spring-context-support.jar`和`quartz-all-1.6.0.jar`时,我们是在讨论Spring框架中的任务调度功能,特别是与Quartz库的集成。 `spring-context`是Spring框架的核心模块之一,它提供了上下文...

    quartz-all-1.6.0.jar包定时任务jar

    这个"quartz-all-1.6.0.jar"包包含了Quartz库的完整功能,适用于1.6.0版本。Quartz的核心特性是能够创建、触发和管理定时任务,这些任务可以在指定的时间点或按照预定义的频率执行。 Quartz的主要组件包括Job(任务...

    spring-boot-quartz.zip

    当我们结合Spring Boot与Quartz时,可以利用Spring的自动配置特性来轻松地集成和管理定时任务。 在Spring Boot项目中集成Quartz,首先需要添加相关的依赖到项目的pom.xml或build.gradle文件中。对于Maven项目,可以...

    spring-boot-Quartz-1.zip

    本案例中,我们将深入探讨如何在SpringBoot应用中集成Quartz定时任务框架,以及如何配置和运行每20秒执行一次的任务。 首先,我们需要在项目中添加Quartz的依赖。在SpringBoot应用的`pom.xml`或`build.gradle`文件...

    quartz-2.3.0-distribution.zip

    "quartz-2.3.0-distribution.zip"这个压缩包包含了Quartz库的2.3.0版本及相关资源,对于开发者来说是学习和使用Quartz的重要资料。 1. **Quartz的核心概念** - **Job**:Quartz中的工作单元,代表一个需要执行的...

    quartz.properties

    quartz.properties

    spring-timer-quartz.zip_namegnd_spring定时任务

    在`quartz.properties`中,我们可以设置Quartz的详细配置,如数据库连接、线程池大小等。 接下来,定义Spring Bean来表示Job。Job是Quartz中的核心概念,代表要执行的任务。Spring允许我们将任何实现了`org.spring...

Global site tag (gtag.js) - Google Analytics