0

现在有个定时任务在项目里面,是每天凌晨执行一次,但是有一天数据量特别大,任务跑了一天还没跑完,一直执行到了第二天,然后这个任务又开始执行了。所以造成了数据的重复

相关代码

    /***
     * 每天凌晨一点sqlserver数据库抓取数据
     * @throws Exception 系统异常
     */
    @Scheduled(cron = "0 0 1 * * ?")
    public void switchDate(){}

这么写的,现在我想让任务执行的时候看上一次同一任务执行完没,如果没有执行完就推迟任务执行时间。我查过资料就是类似 Quartzconcurrent 属性,是这么说的:

其中 concurrent 属性标识的解释为:对于相同的 JobDetail ,当指定多个 Trigger 时, 很可能第一个job 完成之前,第二个 job 就开始了。指定 concurrent 设为 false,多个 job 不会并发运行,第二个job 将不会在第一个 job 完成之前开始。

那么此处的第二个 job 到底是被推迟执行了,还是被取消了呢? 今天带着这个疑问做了一个小实验,具体做法如下:将任务的 Trigger 设置为每 10 秒钟执行一次,然后在执行的任务体内让 Thread 暂停 15 秒钟,这样不同的 job 之间肯定会有时间上的重叠。当启动程序之后,发现前一个 job 执行结束的时刻的秒数为15,而且第二个本来在 10s 就执行的 job 马上就启动了。

由此可见,concurrent属性实际是将job推迟执行了。

各位有谁知道吗?小弟表述不清的地方...对不住了( •̀ ω •́ )y

2018-07-27 提问
1 个回答
0

已采纳

spring默认使用的是单线程executor,应该不会有第一个没执行完就执行第二个这种情况发生。或者你可以整合quartz: https://docs.spring.io/spring...

撰写答案

推广链接