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

568

被折叠的 条评论
为什么被折叠?



