Spring Boot 配置和使用多线程池的实现

作者:阿懒土灵 时间:2022-09-04 19:53:02 

某些情况下,我们需要在项目中对多种任务分配不同的线程池进行执行。从而通过监控不同的线程池来控制不同的任务。为了达到这个目的,需要在项目中配置多线程池。

spring boot 提供了简单高效的线程池配置和使用方案。

配置

首先是配置线程池的bean交给spring 管理:


@Configuration

public class TaskExecutePool {

@Bean(name ="threadPoolA")

public ThreadPoolTaskExecutormyTaskAsyncPool() {

ThreadPoolTaskExecutor executor =new ThreadPoolTaskExecutor();
 executor.setCorePoolSize(4);

executor.setMaxPoolSize(8);

executor.setQueueCapacity(100);

executor.setKeepAliveSeconds(60);

executor.setThreadNamePrefix("Pool-A");

executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());

executor.initialize();

return executor;

}

@Bean(name ="ThreadPoolB")

public ThreadPoolTaskExecutorAsyncPoolB() {

ThreadPoolTaskExecutor executor =new ThreadPoolTaskExecutor();

executor.setCorePoolSize(2);

executor.setMaxPoolSize(4);

executor.setQueueCapacity(8);

executor.setKeepAliveSeconds(60);

executor.setThreadNamePrefix("Pool-B");
 //当任务数量超过MaxPoolSize和QueueCapacity时使用的策略,该策略是又调用任务的线程执行
 executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());

executor.initialize();

return executor;

}

}

使用

使用线程只需要在执行方法上加上注释,同时该方法的类必须被定义为bean,交由spring管理。

可以在类上使用注解@Component、@Service等


@Async(value="ThreadPoolA")
public void taskA(){
...
}

查看线程活跃数:


@Autowired
private ThreadPoolTaskExecutor threadPoolA;//变量名称为定义的线程池bean定义的name属性名。

public void checkAvtiveThreadNum() {
 int num = threadPoolA.getActiveCount();
}

当然还有其他一些方法,这里不再举例。

线程池各属性理解:

corePoolSize:表示线程池核心线程,正常情况下开启的线程数量。

queueCapacity:当核心线程都在跑任务,还有多余的任务会存到此处。

maxPoolSize:如果queueCapacity存满了,还有任务就会启动更多的线程,直到线程数达到maxPoolSize。如果还有任务,则根据拒绝策略进行处理。

拒绝策略有多种:

  1. 由任务调用线程执行

  2. 抛异常

  3. 多余的直接抛弃

  4. 根据FIFO(先进先出)抛弃队列里任务

来源:https://www.jianshu.com/p/0170d71dc502

标签:Spring,Boot,多线程池
0
投稿

猜你喜欢

  • 全面理解Java类和对象

    2021-11-17 11:11:50
  • Android网络工具类NetworkUtils详解

    2022-12-08 05:18:43
  • Java 反射调用静态方法的简单实例

    2021-10-09 06:47:58
  • SpringBoot集成阿里云OSS图片上传

    2021-08-15 21:01:55
  • 简单总结C++中指针常量与常量指针的区别

    2022-06-28 17:33:12
  • 浅析C# 9.0 新特性之 Lambda 弃元参数

    2022-05-08 16:28:22
  • SpringSecurity认证流程详解

    2022-06-25 21:44:49
  • c#学习之30分钟学会XAML

    2022-02-08 03:09:52
  • Lombok使用@Tolerate实现冲突兼容问题

    2021-06-27 06:50:55
  • c#数据绑定之删除datatable数据示例

    2022-03-18 03:42:24
  • 浅谈React Native打包apk的坑

    2022-07-26 05:44:28
  • android 分辨率适配的方法

    2023-03-09 09:21:47
  • Java多线程实现Callable接口

    2022-09-01 17:53:54
  • java模拟实现双向链表

    2022-06-05 09:16:16
  • C#中泛型举例List<T>与DataTable相互转换

    2021-07-06 18:54:08
  • Java多态成员访问的特点是什么?

    2022-08-23 03:07:22
  • Android NDK开发(C语言-文件读写)

    2022-07-04 17:02:09
  • spring boot入门之诞生背景及优势影响

    2021-09-16 06:31:57
  • java实现163邮箱发送邮件到qq邮箱成功案例

    2023-09-18 02:38:09
  • Java事件机制要素及实例详解

    2022-11-27 07:10:53
  • asp之家 软件编程 m.aspxhome.com