@Scheduled不生效了:有一天我的定时任务突然不执行了

一、问题:

之前定时任务一致好好的,某天突然服务没有执行,重启之后也不执行,本地起服务也不执行。。。。

二、检查

@EnableScheduling 这个注解一直都有加的

声明为 

@Scheduled(fixedDelay = 2) 的任务可以很好的执行
@Scheduled(cron = "0 30 19 * * ?") cron表达式的 到点了就是不执行

三、解决

上网看了, 可能原因 任务是懒加载的,调用一次之后才会加载执行(但是为什么 之前好好的呢?)

解决方法:手动配置了 定时任务的  ScheduledThreadPoolExecutor  代码如下:

@Configuration
public class ScheduleConfig implements SchedulingConfigurer {

    @Override
    public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
        scheduledTaskRegistrar.setScheduler(new ScheduledThreadPoolExecutor(Runtime.getRuntime().availableProcessors(),
                new ThreadFactory() {
                    @Override
                    public Thread newThread(Runnable r) {
                        return new Thread(r,"my-schedule");
                    }
                }));
    }
}

然后好了

四、附送

基于 @Scheduled 的定时任务,其实会在 bean 实例化阶段 的  BeanPostProcessor(的具体子类实现ScheduledAnnotationBeanPostProcessor  的 postProcessAfterInitialization)将 所有附带  @Scheduled注解的方法检测出,分析对应的 参数内容, 然后加入各个任务队列之中。

我们配置了 定时任务 使用自己的 ScheduledThreadPoolExecutor  内部其实 基于 DelayQueue,每次任务执行完成之后会计算是否需要下次执行,以及下次执行的时间,然后将任务在放入队列之中。

关于 @EnableScheduling,不加这个注解,在项目启动时  @Scheduled(cron = "0 30 19 * * ?") 这个不会执行, 但是 @Scheduled(fixedDelay = 2)会执行, 因为  initialDelay是默认值的缘故,在将任务加入队列之前会 先 调用一下当前的任务,所以项目启动时 会执行一次。

  • 6
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
当@Scheduled定时任务执行时,可以根据以下步骤进行排查和解决: 1. 首先,检查代码中是否正确添加了定时任务的注解和相应的配置。确保在启动类上添加了@EnableScheduling注解,定时任务类上添加了@Component注解,定时方法上添加了@Scheduled注解,并且指定了正确的cron表达式。 2. 排查是否有任务阻塞的情况发生。如果定时任务出现异常阻塞后,将不会再次执行。可以查看日志或调试信息,确定是否有其他任务在同一时间段内执行,导致当前定时任务被阻塞。 3. 如果存在多个定时任务,并且其中有一个任务比较耗时,可能会导致其他任务等待执行。这是因为默认情况下,@Scheduled定时任务是单线程执行的。可以考虑将定时任务设置为多线程执行的方式,以避免任务等待现象。可以使用@Async注解或手动配置定时任务的线程池大小来实现多线程执行定时任务。 若以上步骤都检查并确定没有问题,还可以进一步排查其他可能的原因,例如系统负载过高、定时任务类未被扫描到或定时任务方法未被调用等。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [@Scheduled 定时任务执行](https://blog.csdn.net/m0_46459413/article/details/129819464)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [@Scheduled定时任务没有按时执行的问题与解决方法](https://blog.csdn.net/administratop/article/details/129984412)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值