- 文件加载位置
默认:优先顺序 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.不实现集群的实例不使用同一套表
相关推荐
5. **配置文件**:`config`目录可能包含Quartz的默认配置文件,如`quartz.properties`,开发者可以根据需求修改这些配置来定制Quartz的行为。 Quartz的核心特性包括: - **灵活性**:支持各种类型的触发器,如简单...
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-
在给定的压缩包文件中,我们有两个版本为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版本,它是专门为Java开发人员设计的,便于在Java应用中实现定时任务的管理和执行。 Quartz的核心功能包括: 1. **任务调度**:它允许开发者...
spring-context-support-4.0.5.RELEASE.jar
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-...
注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-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
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-SNAPSHOT" 这个子目录,这通常意味着这是一个开发中的版本,尽管它在发布时可能是稳定的,但仍然带有 "SNAPSHOT" 标记,提示...
在 `quartz.properties` 文件中,你需要指定 JobStore 类型为 JDBC 并提供数据库相关的配置,如: ``` org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX org.quartz.jobStore....
spring-context-support.jar spring整合任务调度quartz必需jar 还需要quartz-all-x.x.x.jar quartz版本必需在1.8.x以下
1. **任务调度支持**: `spring-context-support`包含了对Quartz和Commons JEXL的支持,允许开发者在Spring容器中配置和管理定时任务。例如,你可以通过XML配置或者使用`@Scheduled`注解来定义周期性执行的任务,这...
而当我们提到`spring-context-support.jar`和`quartz-all-1.6.0.jar`时,我们是在讨论Spring框架中的任务调度功能,特别是与Quartz库的集成。 `spring-context`是Spring框架的核心模块之一,它提供了上下文...
这个"quartz-all-1.6.0.jar"包包含了Quartz库的完整功能,适用于1.6.0版本。Quartz的核心特性是能够创建、触发和管理定时任务,这些任务可以在指定的时间点或按照预定义的频率执行。 Quartz的主要组件包括Job(任务...
当我们结合Spring Boot与Quartz时,可以利用Spring的自动配置特性来轻松地集成和管理定时任务。 在Spring Boot项目中集成Quartz,首先需要添加相关的依赖到项目的pom.xml或build.gradle文件中。对于Maven项目,可以...
本案例中,我们将深入探讨如何在SpringBoot应用中集成Quartz定时任务框架,以及如何配置和运行每20秒执行一次的任务。 首先,我们需要在项目中添加Quartz的依赖。在SpringBoot应用的`pom.xml`或`build.gradle`文件...
"quartz-2.3.0-distribution.zip"这个压缩包包含了Quartz库的2.3.0版本及相关资源,对于开发者来说是学习和使用Quartz的重要资料。 1. **Quartz的核心概念** - **Job**:Quartz中的工作单元,代表一个需要执行的...
quartz.properties
在`quartz.properties`中,我们可以设置Quartz的详细配置,如数据库连接、线程池大小等。 接下来,定义Spring Bean来表示Job。Job是Quartz中的核心概念,代表要执行的任务。Spring允许我们将任何实现了`org.spring...