quartz对任务超时和misfire的处理

quartz有个全局的参数misfireThreshold设置可以允许的超时时间,超过了就不执行,未超过就执行。
比如设置了misfireThreshold=30分钟,如果一个任务定时在10:30执行,但在10:29服务器挂了,在10:50启动,虽然任务超时了21分钟,但小于misfireThreshold,所以还是可以执行。而如果服务器11:10才启动,那就misfire了。

对于周期性的任务,如果有misfire的情况出现,则会自动更新CronTrigger的时间周期
默认情况下会在当前时间马上执行前一个被misfire的任务
而如果设置MISFIRE_INSTRUCTION_DO_NOTHING,则不对misfire的任务做特殊处理,只从当前时间之后的下一次正常调度时间开始执行
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Quartz可以通过JobExecutionContext来获取任务的开始时间,从而计算任务执行的时间,可以通过在Job中设置一个超时时间,以保证任务不会执行太久时间。具体实现步骤如下: 1. 在Job实现类中定义一个计时器,用于计算任务执行的时间。 ``` private long startTime; ``` 2. 在Job的execute方法中,记录任务开始时间。 ``` @Override public void execute(JobExecutionContext context) throws JobExecutionException { startTime = System.currentTimeMillis(); // 任务执行的代码 } ``` 3. 在Job的execute方法中,加入任务执行超时的检查,并在超时时停止任务的执行。 ``` @Override public void execute(JobExecutionContext context) throws JobExecutionException { startTime = System.currentTimeMillis(); while (true) { if (System.currentTimeMillis() - startTime > timeout) { // 超时了,停止任务的执行 break; } // 任务执行的代码 } } ``` 其中,timeout表示任务超时时间,单位为毫秒。 4. 配置JobDetail时,设置JobDataMap,将超时时间传递给Job实现类。 ``` JobDataMap jobDataMap = new JobDataMap(); jobDataMap.put("timeout", timeout); JobDetail jobDetail = JobBuilder.newJob(YourJob.class) .withIdentity(jobName, jobGroup) .usingJobData(jobDataMap) .build(); ``` 5. 在Job实现类中,获取JobDataMap中的超时时间。 ``` private long timeout; @Override public void execute(JobExecutionContext context) throws JobExecutionException { JobDataMap jobDataMap = context.getMergedJobDataMap(); timeout = jobDataMap.getLong("timeout"); // 任务执行的代码 } ``` 这样就可以在Spring Quartz中设置任务超时时间了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值