springboot主线程_SpringBoot多线程执行task任务

本文主要介绍了SpringBoot中定时任务Task默认单线程执行可能导致的问题,并提供了三种解决方案,包括设置TaskScheduler线程池大小,创建配置类以及实现SchedulingConfigurer接口,以实现多线程执行定时任务,确保任务的准时执行。
摘要由CSDN通过智能技术生成

SpringBoot添加定时任务入门请看这里=>SpringBoot入门八,添加定时任务

一.问题描述

Task定时任务默认都是使用单线程执行的,如果定时任务有很多的话,那么可能会导致很多任务无法按时准确执行,示例如下:

import java.text.SimpleDateFormat;

import java.util.Date;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.scheduling.annotation.Scheduled;

import org.springframework.stereotype.Component;

@Component

public class TaskTest {

private final Logger log = LoggerFactory.getLogger(TaskTest02.class);

//输出时间格式

private static final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss:sss");

@Scheduled(cron = "0/15 * * * * ? ")

private void sayHello(){

String dateTime = format.format(new Date());

log.info("{} 向宇宙发出了一声问候: Hello World!", dateTime);

try {

Thread.sleep(10000);

} catch (InterruptedException e) {

e.printStackTrace();

}

}

@Scheduled(cron = "0/16 * * * * ? ")

private void sayHello2(){

String dateTime = format.format(new Date());

log.info("{} 向宇宙发出了一声问候: 你好,世界", dateTime);

}

}

当sayHello()方法执行的时候,因为长时间占用任务执行线程,导致sayHello2()被迫向后延时执行,如图:

二.解决方案

方案1

添加以下代码块,可放置在任意一个类中,整个工程只需要添加一个即可

@Bean

public TaskScheduler taskScheduler() {

ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();

// 设置scheduler执行线程为3个

scheduler.setPoolSize(3);

return scheduler;

}

方案2(个人推荐)

添加一个配置类即可,定时任务类或方法不用做任何改变

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

import org.springframework.scheduling.TaskScheduler;

import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;

/**

* @描述: 多线程执行定时任务

* @日期 2019年5月28日

*/

@Configuration

public class TaskConfig {

/**

* @描述: 所有的定时任务都放在一个线程池中,定时任务启动时使用不同的线程

* @return

* @日期 2019年5月28日

*/

@Bean

public TaskScheduler taskScheduler() {

ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();

// 设置scheduler执行线程为3个

scheduler.setPoolSize(3);

return scheduler;

}

}

方案3

添加一个配置类即可(实现SchedulingConfigurer接口),定时任务类或方法不用做任何改变

import java.util.concurrent.Executors;

import org.springframework.context.annotation.Configuration;

import org.springframework.scheduling.annotation.SchedulingConfigurer;

import org.springframework.scheduling.config.ScheduledTaskRegistrar;

/**

* @描述: 多线程执行定时任务

* @日期 2019年5月27日

*/

@Configuration

public class SchedulingConfig implements SchedulingConfigurer {

/**

* @描述: 所有的定时任务都放在一个线程池中,定时任务启动时使用不同的线程

* @param taskRegistrar

* @日期 2019年5月27日

*/

@Override

public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {

//设定一个定时任务线程池,数量为3

taskRegistrar.setScheduler(Executors.newScheduledThreadPool(3));

}

}

三.执行结果

可以看到两个定时任务已经分别由不同的线程执行了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值