quartz定时任务如果上一个还没结束,下一个开始了,怎么办

Quartz定时任务默认并发执行可能导致数据不正确。解决方案包括在Spring配置文件中设置concurrent为false,或者在Job实现类上使用@DisallowConcurrentExecution注解,防止同一任务的并发执行。这两种方法不影响其他Job实现类的任务执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Quartz定时任务默认都是并发执行的,不会等待上一次任务执行完毕,只要间隔时间到就会执行,这样往往会导致我们执行的数据不正确。

  • 解决方式1:

在Spring配置文件中设置concurrent的值为false, 禁止并发执行。

 <property name="concurrent" value="false" />
  • 解决方式2:

可以通过在实现Job接口的类上加注解的方式

@DisallowConcurrentExecution
public class TestJob implements Job{
	 @Override
	 public void execute(JobExecutionContext arg0) throws JobExecutionException {
		  System.out.println("test");
	 }
}

这里的禁止并发是同一个Job实现类中的同一个任务不能并发,其他的实现类任务不受影响。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值