springboot中定时任务cron不生效,fixedRate指定间隔失效,只执行一次的问题

在调试计算任务的时候,手动重置任务为初始状态,但是并没有重新开始计算,检查定时任务代码:
springboot中定时任务cron不生效,fixedRate指定间隔失效,只执行一次的问题_第1张图片
@Scheduled(fixedRate = 120000)可以看到,应该是间隔120秒执行一次该定时任务,查看后台日志,并没有重新计算,重启服务的时候,仅在初始阶段执行了一次startRelCalculateTask(),后面并没有执行,猜测是fixedRate的原因,这里换上cron表达式:
@Scheduled(cron = "0/10 * * * * ?"),结果更出乎意料了,后台日志根本就没打印,也就是cron根本就没执行,在另外写一个demo测试:
springboot中定时任务cron不生效,fixedRate指定间隔失效,只执行一次的问题_第2张图片
奇怪的是都有在执行,后来经过排查,是定时任务线程的原因:Scheduled定时任务默认的线程数只有一个,进行定时任务调度时会同步的去调度,一个执行完成后再执行另一个,项目中定时任务非常多,所以没能异步执行,解决方法是添加一个配置类,设置TaskScheduler线程数为多个,这样再执行时就会异步执行了,各个定时任务间互不影响。

@Configuration
public class ScheduledPool {

    @Bean
    public TaskScheduler taskScheduler() {
        ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler();
        // 设置定时任务线程数量
        taskScheduler.setPoolSize(50);
        return taskScheduler;
    }
}

奇怪的是不知道是不是cron与项目的配置什么冲突了,在不配线程池的情况下,cron注解的任务是无法执行的,配置了以后,是可以识别的:
springboot中定时任务cron不生效,fixedRate指定间隔失效,只执行一次的问题_第3张图片

springboot中定时任务cron不生效,fixedRate指定间隔失效,只执行一次的问题_第4张图片
参考链接:解决SpringBoot中的Scheduled单线程执行问题

你可能感兴趣的:(work,springboot,spring,boot,后端,java)