步骤1:
下载quartz-1.6.6.zip解压缩后 因为使用的是weblogic集群和oracle数据库 所以导入包:quartz-all-1.6.6.jar,quartz-oracle-1.6.6.jar,quartz-weblogic-1.6.6.jar,commons-logging-1.1.jar
步骤2:
复制quartz-1.6.6\docs\wikidocs\QuickStart_attachments目录下的example_quartz.properties到classpath下,重命名为quartz.properties
步骤3:
建表,SQL语句在quartz-1.6.6\docs\dbTables文件夹中可以找到,介绍下主要的几张表:
表qrtz_job_details: 保存job详细信息,该表需要用户根据实际情况初始化
job_name:集群中job的名字,该名字用户自己可以随意定制,无强行要求
job_group:集群中job的所属组的名字,该名字用户自己随意定制,无强行要求
job_class_name:集群中个note job实现类的完全包名,quartz就是根据这个路径到classpath找到该job类
is_durable:是否持久化,把该属性设置为1,quartz会把job持久化到数据库中
job_data:一个blob字段,存放持久化job对象
表qrtz_triggers: 保存trigger信息
trigger_name: trigger的名字,该名字用户自己可以随意定制,无强行要求
trigger_group:trigger所属组的名字,该名字用户自己随意定制,无强行要求
job_name: qrtz_job_details表job_name的外键
job_group: qrtz_job_details表job_group的外键
trigger_state:当前trigger状态,设置为ACQUIRED,如果设置为WAITING,则job不会触发
trigger_cron:触发器类型,使用cron表达式
表qrtz_cron_triggers:存储cron表达式表
trigger_name: qrtz_triggers表trigger_name的外键
trigger_group: qrtz_triggers表trigger_group的外键
cron_expression:cron表达式
表qrtz_scheduler_state:存储集群中note实例信息,quartz会定时读取该表的信息判断集群中每个实例的当前状态
instance_name:之前配置文件中org.quartz.scheduler.instanceId配置的名字,就会写入该字段,如果设置为AUTO,quartz会根据物理机名和当前时间产生一个名字
last_checkin_time:上次检查时间
checkin_interval:检查间隔时间
步骤4:
配置quartz.properties文件
#调度标识名 集群中每一个实例都必须使用相同的名称
org.quartz.scheduler.instanceName = scheduler
#ID设置为自动获取 每一个必须不同
org.quartz.scheduler.instanceId = AUTO
#数据保存方式为持久化
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
#数据库平台
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.weblogic.WebLogicOracleDelegate
#数据库别名 随便取
org.quartz.jobStore.dataSource = myXADS
#表的前缀
org.quartz.jobStore.tablePrefix = QRTZ_
#设置为TRUE不会出现序列化非字符串类到 BLOB 时产生的类版本问题
org.quartz.jobStore.useProperties = true
#加入集群
org.quartz.jobStore.isClustered = true
#调度实例失效的检查时间间隔
org.quartz.jobStore.clusterCheckinInterval = 20000
#容许的最大作业延长时间
org.quartz.jobStore.misfireThreshold = 60000
#ThreadPool 实现的类名
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
#线程数量
org.quartz.threadPool.threadCount = 10
#线程优先级
org.quartz.threadPool.threadPriority = 5
#自创建父线程
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true
#设置数据源
org.quartz.dataSource.myXADS.jndiURL = CT
#jbdi类名
org.quartz.dataSource.myXADS.java.naming.factory.initial = weblogic.jndi.WLInitialContextFactory
#URL
org.quartz.dataSource.myXADS.java.naming.provider.url = t3://localhost:7001
分享到:
相关推荐
在实际应用中,你可能还会遇到如负载均衡、任务同步、节点间的通信等问题,需要对Quartz的API和原理有深入理解才能更好地应对。通过阅读官方文档、源码分析和实践操作,可以进一步掌握Quartz集群的精髓,提高系统...
在实际应用中,根据业务需求和环境的不同,可能还需要对Quartz的配置进行更深入的调整,例如设置调度器的线程池大小、调整触发器的优先级等。总之,理解和掌握这些SQL脚本以及Quartz集群的工作原理,是确保Quartz在...
标题 "spring quartz 集群模式" 涉及到的是Spring框架与Quartz调度器在集群环境下的集成和配置。Quartz是一个开源任务...在实际应用中,需要结合数据库配置、集群设置以及Spring的整合来构建高效稳定的定时任务系统。
在实际应用中,可能会使用如ZooKeeper这样的分布式协调服务来帮助Quartz集群管理状态。 在压缩包文件"oa_ssh"中,可能包含了项目的所有源代码、配置文件、数据库脚本等资源,开发者可以通过这些文件了解和学习SSH...
在IT行业中,Spring框架是Java应用开发中的基石,而Quartz则是广泛...通过上述步骤,你已经掌握了Spring集成Quartz集群配置的基本概念。在实践中,根据具体需求调整配置,可以实现高效、稳定且可扩展的任务调度系统。
5. **集群配置**:为了实现高可用的Quartz集群,你需要配置多个节点共享同一个数据库存储的作业和触发器信息。Quartz支持多种持久化策略,如JDBC、RAMJobStore等,选择数据库存储能保证在集群中的任务状态一致性。 ...
集群中的每个节点都是一个独立的Quartz实例,它们共享同一个作业和触发器的存储,这就是所谓的Quartz集群。 集群的关键在于保持所有节点的任务状态同步,这就需要用到数据库来存储任务信息。"quartz集群各种数据库...
这一步骤是确保Quartz集群能够正确识别和同步任务的关键。此外,还要注意数据库的连接配置,例如数据库URL、用户名、密码以及JDBC驱动类名,这些信息需要在Quartz的配置文件中指定。 在实际操作中,可能还需要对表...
Quartz 是一个开源的作业调度框架,常用于在Java应用中执行定时任务。Spring 是一个广泛应用的Java企业级开发框架,它可以与Quartz紧密结合,...在实际应用中,需要根据业务需求调整配置,以达到最佳的性能和可靠性。
在提供的压缩包中,可能包含了一个简单的Quartz集群应用示例,源码通常会包括以下部分: - **Job类**:实现`org.quartz.Job`接口,定义具体的任务逻辑。 ```java public class MyJob implements Job { @Override ...
3. **监控和管理**: 实现对Quartz集群的监控,如任务状态、运行时性能等,以便及时发现和解决问题。 总结,Quartz+Spring的分布式集群调度方案能够帮助开发者构建稳定且可扩展的定时任务系统。通过合理配置和实践,...
7. **性能优化**:在实际应用中,可能会涉及Quartz集群的性能优化,比如调整并发执行的Job数量,或者设置合适的调度策略以避免过多的数据库交互。 8. **监控与管理**:Quartz提供了Web界面(如QConsole)用于监控和...
文件“quartz集群完整应用实例 2.docx”可能包含了一个完整的Quartz集群配置示例,包括具体的Spring配置、Quartz配置以及可能的数据库脚本。通过阅读和分析这个文档,你可以获得更深入的理解和实践经验。 总之,...
Quartz集群是基于Java的开源任务调度框架,用于在分布式环境中执行定时任务。它提供了高度可配置性、...博客文章中的内容可能详细解析了如何设置、配置和管理Quartz集群,以及在实际项目中应用Quartz的技巧和最佳实践。
至于博文链接中的内容,虽然无法直接查看,但通常会包含如何在实际项目中设置Quartz集群和Spring Data集成的详细步骤,包括配置示例、代码示例以及可能遇到的问题和解决方案。 在使用过程中,可能会遇到如任务并发...
Quartz是开源的作业调度框架,常用于Java应用程序中,以执行定时任务。在分布式环境中,Quartz集群能够实现任务的高可用性...在实际应用中,根据具体业务需求进行适当的优化和调整,可以进一步提高系统的性能和可靠性。
在Quartz集群中,每个节点都是一个独立的Quartz Scheduler实例,它们通过共享同一份Job Store来保持状态的一致性。Job Store可以是内存型的,也可以是持久化的,如数据库存储,这样能确保任何节点上的改动都能被其他...
通过上述步骤,你已经成功配置了一个基于内存的Quartz集群,利用Terracotta实现了任务的分布式管理和负载均衡。在实际生产环境中,这种配置可以提高系统的稳定性和可扩展性,确保即使在单个服务器故障时,任务仍能...