quartz在创建定时任务时,首次执行定时任务时出现多次重复执行的问题

2023-12-21 04:28

本文主要是介绍quartz在创建定时任务时,首次执行定时任务时出现多次重复执行的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原因:

在Quartz中,一旦创建了一个触发器(Trigger),它会按照设定的时间表执行与之关联的作业(Job)。当项目启动时,Quartz调度器会检查所有的触发器,如果有任何一个触发器的开始时间在当前时间之前,那么与这个触发器关联的作业将会立即执行一次。

如果触发器的开始时间非常接近当前时间,例如只相差几秒,那么在项目启动后确实可能会出现多次执行作业的情况。这是因为在极短的时间间隔内,Quartz调度器可能会多次检查并执行与触发器相关联的作业。(本次由于某种原因,项目中设置的定时任务在创建后,出现了几十秒的延迟调度情况,但是调度时间又设置的很短,导致的在延迟结束后,触发器多次执行相关联的作业)

代码片段

        // 如果设定的定时时间很短String cronExpression = "0/6 * * * * ? ";sched.start();  // 构建job信息  JobDetail jobDetail = JobBuilder.newJob(getClass(jobClassName)  .getClass())  .withIdentity(jobClassName)  .storeDurably()  .build();  // 表达式调度构建器(即任务执行的时间)  CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(cronExpression);  // 按新的cronExpression表达式构建一个新的trigger  CronTrigger trigger = TriggerBuilder.newTrigger()  .withIdentity("trigger","group1")  .withSchedule(scheduleBuilder)  .forJob(jobDetail)  // 60秒后生效,要不然调度启动后如果延迟,可能出现首次执行多遍job.startAt(DateBuilder.futureDate(60, DateBuilder.IntervalUnit.SECOND)).usingJobData("parameter",parameter)  .build();  try {  Thread.sleep(30000);  } catch (InterruptedException e) {  e.printStackTrace();  }  sched.addJob(jobDetail, true);  sched.scheduleJob(trigger);

解决方案


// .startAt(DateBuilder.futureDate(60, DateBuilder.IntervalUnit.SECOND))  CronTrigger trigger = TriggerBuilder.newTrigger()  .withIdentity("trigger","group1")  .withSchedule(scheduleBuilder)  .forJob(jobDetail)  .startNow()  // 60秒后生效,要不然调度启动后如果延迟,可能出现首次执行多遍job.startAt(DateBuilder.futureDate(60, DateBuilder.IntervalUnit.SECOND))  .usingJobData("parameter",parameter)  .build();

这篇关于quartz在创建定时任务时,首次执行定时任务时出现多次重复执行的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/518630

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出