@Schedule 解决定时任务推迟执行

1 篇文章 0 订阅


前言

SpringBoot 实现定时任务很简单,只需要使用**@Scheduled**注解即可,但是该注解是实现的定时任务默认是单线程的,也就意味着多个定时任务执行时就可能导致线程堵塞,延缓定时任务的执行。下面就一步一步来解决这个问题。


一、@Scheduled

1、代码

// 启用定时任务
@EnableScheduling 
@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}
@Component
public class Task {
    Logger logger = LoggerFactory.getLogger(Task.class);
	// 每五秒执行一次
    @Scheduled(cron = "0/5 * * * * ?")
    public void taskTestA() throws InterruptedException {
        logger.info("A:");
        TimeUnit.SECONDS.sleep(20);
    }
  
    // 每十秒执行一次
    @Scheduled(cron = "0/10 * * * * ?")
    public void taskTestB() {
        logger.info("B:");
    }
}

2、结果

代码

由图可知,首先这两个定时任务都是单线程的,但是当定时A执行了一次后,由于定时A中有个休眠20秒,然后执行定时任务B,所以线程A第二次执行在25秒后才执行,这就是由于@Scheduled定时任务是单线程,造成的线程堵塞,导致定时任务推迟执行。

二、@Scheduled + 配置线程池

1、代码

和前面@Scheduled 相比,仅仅增加了配置线程池

// 若不设置默认为单线程,这里设置使用线程池,大小为4
spring:
  task:
    scheduling:
      pool:
        size: 4

2、结果

在这里插入图片描述

由图可知,增加了线程池,这样使得定时任务A和B在不同的线程进行执行,但是定时任务A的第二次执行,依旧是在25秒后执行,由此可知这种方式其实解决的是不同定时任务之间的进程堵塞。

二、@Scheduled + @Async

1、代码

和前面相比,仅仅增加了配置

// 启用异步,动态创建线程
@EnableAsync  
@EnableScheduling
@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}
@Component
public class Task { 
    Logger logger = LoggerFactory.getLogger(Task.class);
    // 异步,动态创建线程
    @Async
    @Scheduled(cron = "0/5 * * * * ?")
    public void taskTestA() throws InterruptedException {
        logger.info("A:");
        TimeUnit.SECONDS.sleep(20);
    }
    // 异步,动态创建线程
    @Async
    @Scheduled(cron = "0/10 * * * * ?")
    public void taskTestB() {
        logger.info("B:");
    }
}

2、结果

在这里插入图片描述

由图可知,启用了异步,使用了spring 默认的线程池,动态创建线程,这样使得定时任务A和B在不同的线程进行执行,同时任务A的多次运行也是异步执行,这样就能确保所有定时任务不会延迟执行!

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值