`
zengshaotao
  • 浏览: 796279 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

quartz集群问题

 
阅读更多

根据需求,新增一个定时任务,单元测试通过之后,通过本地功能新增调度任务。随后发现一个诡异问题,那就是只执行一次,然后状态成为了error状态。

 

原因:本地和uat环境共用一个库,quartz被集群,但是因为代码还未发布到uat环境,导致任务在uat执行时报错,所以一定要保证quartz的job在各个环境下代码都是一致的。

 

通过观察instance_name的记录,可以发现是由服务器节点的实例名加数字组成,这时将instance的地址与集群中每个节点进行对比,可以发现,uat的instance id并不在集群节点中,但是与集群共用一个数据库

 

总结:

当使用quartz集群模式时,集群中的代码版本不一致,会出现qrtz_triggers中trigger_state的状态变为”error”的情况,是原因,在集群模式下quartz执行调度任务时是根据数据库表中的调度记录来进行的,当执行到有对应代码的节点上,不会出现问题,但是当执行到没有对应代码的节点上,就会变为”error”, 

因此在集群环境下,节点较多的时候使用quartz,需要注意每个节点的代码版本一定要保持一致

 

分享到:
评论

相关推荐

    quartz集群调度机制调研及源码分析

    Quartz集群调度机制的核心在于通过数据库来协调多个节点之间的工作,以达到负载均衡和高可用性(HA)的目的。 当在集群模式下运行Quartz时,所有参与集群的节点都访问同一个数据库。这个数据库作为所有节点间通讯的...

    quartz 集群解决方法

    Quartz集群需要将所有调度信息(如Job、Trigger)存储在一个共享的持久化存储中,以便所有集群节点都能访问。这通常通过实现`ISchedulerFactory`接口的`StdSchedulerFactory`类和数据库连接来完成。数据库可以选择...

    spring quartz集群配置

    在Quartz集群中,多个Quartz服务器共享同一个“作业存储”(Job Store),这个存储可以是关系数据库或者分布式的存储系统。当一个服务器触发一个作业时,其他服务器会看到这个作业已经被触发,因此不会重复执行。这...

    quartz集群Sql大放送

    Quartz集群是为了实现高可用性和负载均衡,当一个节点故障时,其他节点能够接管任务,保证服务不中断。 在Quartz集群中,数据库扮演了至关重要的角色,因为它存储了所有关于作业和触发器的信息。集群中的各个节点...

    quartz集群完整应用实例

    本篇将基于"quartz集群完整应用实例"来深入探讨Quartz的集群配置与实现。 Quartz的核心概念包括Job(任务)、Trigger(触发器)和Scheduler(调度器)。Job是执行的具体任务,Trigger定义了任务何时运行,而...

    spring boot quartz集群实现

    一个基于springboot的quartz集群dome。 向http://localhost:9090/job/addjob注入3个参数 类名:(及时定时任务的类如:com.ybjdw.site.job.NewJob) 组名:随意 定时启动方法:如“0/3 * * * * ?”(每3秒启动一次...

    SSH框架+Quartz集群

    在压缩包文件"oa_ssh"中,可能包含了项目的所有源代码、配置文件、数据库脚本等资源,开发者可以通过这些文件了解和学习SSH框架与Quartz集群的整合实现,以及RABC权限管理的具体细节。通过研究和实践,可以深入理解...

    spring quartz 集群模式

    Quartz集群通过共享内存中的状态来实现任务的分配和执行,当一个节点失败时,其他节点能够接管未完成的任务。实现Quartz集群,需要配置多个Quartz服务器共享同一份数据库存储,用于保存Job、Trigger以及运行状态等...

    Quartz集群配置源码和可执行脚本

    Quartz集群配置是一项重要的技术,它可以确保在多个服务器之间分布任务,提高系统的可用性和容错性。集群模式下,如果一个节点失败,其他节点可以接管工作,保持服务的连续性。 在Quartz集群配置中,主要涉及以下几...

    spring集成quartz集群配置

    在IT行业中,Spring框架是Java应用开发中的基石,而Quartz则是广泛...通过上述步骤,你已经掌握了Spring集成Quartz集群配置的基本概念。在实践中,根据具体需求调整配置,可以实现高效、稳定且可扩展的任务调度系统。

    Springboot集成quartz集群

    本文章是关于springboot集成quartz集群的步骤,LZ亲测。

    quartz集群各种数据库建表脚本

    "quartz集群各种数据库建表脚本" 提供了在不同类型的数据库中创建Quartz集群所需的表结构。基于quartz2.2.1版本,这个脚本应该包含了创建必要的调度表,如QRTZ_JOB_DETAILS、QRTZ_TRIGGERS、QRTZ_SIMPLE_TRIGGERS等...

    Spring+Quartz 集群

    5. **集群配置**:为了实现高可用的Quartz集群,你需要配置多个节点共享同一个数据库存储的作业和触发器信息。Quartz支持多种持久化策略,如JDBC、RAMJobStore等,选择数据库存储能保证在集群中的任务状态一致性。 ...

    quartz集群各数据库中对应的表机构

    在构建Quartz集群时,为了实现高可用性和任务的分布式处理,需要在多个节点之间共享状态信息,这就涉及到数据库的支持。数据库在这里起到了存储作业和触发器信息的作用,确保在集群中的各个节点间能够正确协调和执行...

    spring + quartz 集群配置

    java + quartz实现定时任务,实现集群配置,在集群环境下多节点运行定时Quartz定任务,就会存在重复处理任务的现象,为解决这一问题,下面我将介绍使用 Quartz 的 TASK ( 12 张表)实例化到数据库,基于数据库自动...

    quartz 集群配置

    当需要在分布式环境中运行多个Quartz实例以实现高可用性和负载均衡时,就需要进行Quartz集群配置。 在Spring集成Quartz的过程中,主要涉及以下几个核心概念和步骤: 1. **Job与Trigger**:Job是Quartz中的任务接口...

    Quartz集群配置和示例源码

    下面将详细阐述Quartz集群的配置以及示例源码的相关知识点。 **1. Quartz集群的核心概念** - **Job Store**: Quartz集群的关键在于共享任务存储,Job Store负责存储Job(任务)和Trigger(触发器)的信息。常见的...

    quartz+spring分布式集群调度

    3. **监控和管理**: 实现对Quartz集群的监控,如任务状态、运行时性能等,以便及时发现和解决问题。 总结,Quartz+Spring的分布式集群调度方案能够帮助开发者构建稳定且可扩展的定时任务系统。通过合理配置和实践,...

    SpringBoot 整合Quartz(集群)实现定时任务调度

    对于集群环境,还需要设置`org.quartz.scheduler.instanceName`和`org.quartz.jobStore.isClustered`为集群模式: ```properties # application.properties 示例 quartz.jobStore.tablePrefix=QRTZ_ quartz....

Global site tag (gtag.js) - Google Analytics