quartz在项目启动时,首次执行定时任务时出现重复执行的问题

quartz.properties配置文件中的属性:激活失败临界,org.quartz.jobStore.misfireThreshold(单位毫秒)默认为60秒。 如果我们在创建trigger实例时指定启动时间在60秒内,那么就会出现首次执行定时任务时出现重复执行的问题。

		        // 3、构建Trigger实例
		        Trigger trigger = TriggerBuilder.newTrigger().withIdentity("export_trigger", "export_trigger_group")
		        		.forJob("export_job","export_group")       //Trigger找到对应的名称为export_job、组为export_group的Job,如果不存在则会在执行scheduler.scheduleJob(jobDetail,trigger);报错
		                .startAt(DateBuilder.futureDate(90, IntervalUnit.SECOND))//90秒后生效,不能<=60秒,要不然项目启动后,首次执行2遍job
		                .withSchedule(SimpleScheduleBuilder.simpleSchedule()
		                .withIntervalInSeconds(100)//每隔60秒执行一次
		                .repeatForever()//永远重复执行
		                ).build();

quartz的misfire机制

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Quartz项目启动时,会自动从数据库或配置文件中加载任务信息,并将任务的执行间计算出来并存储在内存中。如果需要在项目启动时更新内存中的执行间,可以通过以下两种方式实现: 1. 手动触发任务执行 可以在项目启动时,手动触发任务执行,让 Quartz 重新计算任务的下一次执行间并更新存储在内存中。这样可以确保内存中的执行间与数据库或配置文件中的信息保持一致。具体实现可以参考上一个问题的解答。 2. 使用 Quartz 的 API 更新内存中的执行Quartz 提供了一些 API 可以用来更新内存中的任务信息,包括任务的执行间。你可以在项目启动时,通过这些 API 更新内存中的执行间,以确保任务的下一次执行间与数据库或配置文件中的信息保持一致。具体实现可以参考以下代码: ``` // 获取调度器 Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); // 获取指定任务的 Trigger TriggerKey triggerKey = TriggerKey.triggerKey("job1", "group1"); Trigger trigger = scheduler.getTrigger(triggerKey); // 更新 Trigger 的执行间 Date newDate = new Date(); trigger = trigger.getTriggerBuilder().startAt(newDate).build(); // 重新安排任务的执行间 scheduler.rescheduleJob(triggerKey, trigger); ``` 以上代码的作用是获取名为 "job1" 的任务的 Trigger,然后将其执行间更新为当前间,并重新安排任务的执行间。你可以根据自己的需求,修改任务名称和执行间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值