欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

聊聊SpringBoot的@Scheduled的并发问题

时间:2022-05-22 08:20:38|栏目:JAVA代码|点击:

SpringBoot @Scheduled的并发

由于SpringBoot自带的@Scheduled是一个阻塞执行的定时任务,所以效率会很慢,就会造成同一个时间段内只有一个定时任务在执行,其余的就会阻塞

现有两个定时任务

@Component("aa")
public class aa {
    @Scheduled(cron = "0 44 17 * * ?")
    public void bb() {
        try {
            System.out.println("aa执行时间:" + new Date());
            Thread.sleep(65000);
            System.out.println("aa完成时间:" + new Date());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
@Component("bb")
public class bb {
    @Scheduled(cron = "0 55 17 * * ?")
    public void aa() {
        try {
            System.out.println("bb执行时间:" + new Date());
            Thread.sleep(10000);
            System.out.println("bb完成时间:" + new Date());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

默认的在启动项加入@EnableScheduling注解就可以运行了

在这里插入图片描述

最终,执行的结果令人大跌眼镜。

在这里插入图片描述

aa的任务由于执行时间需要65秒,超过了bb任务执行的时间,结果bb任务执行的时间被阻塞掉,延迟了5秒执行。

解决方法是在启动项类中加入如下配置即可

 @Bean
    public TaskScheduler taskScheduler() {
        ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler();
        taskScheduler.setPoolSize(50);
        return taskScheduler;
    }

如果是xml

 <!-- 注解式 -->
 <task:annotation-driven executor="myExecutor" scheduler="myScheduler"/>
 <task:executor id="myExecutor" pool-size="5"/>
 <task:scheduler id="myScheduler" pool-size="10"/>

spring @Scheduled 并发执行

spring @Scheduled ,默认基于单线程执行,如果需要基于多线程执行,需要在配置文件中配置如下

queue-capacity="500" rejection-policy="CALLER_RUNS" />
scheduler="scheduler" />

具体可以参考spring 帮助文档对annotation-driven的executor和scheduler的解释

上一篇:SpringMVC解析post请求参数详解

栏    目:JAVA代码

下一篇:Java中浅拷贝和深拷贝详解

本文标题:聊聊SpringBoot的@Scheduled的并发问题

本文地址:http://www.codeinn.net/misctech/202530.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有