IT评测·应用市场-qidao123.com

标题: [开源项目]可观测、易使用的SpringBoot线程池 [打印本页]

作者: 铁佛    时间: 2022-9-16 17:14
标题: [开源项目]可观测、易使用的SpringBoot线程池
在开发spring boot应用服务的时候,难免会使用到异步任务及线程池。spring boot的线程池是可以自定义的,所以我们经常会在项目里面看到类似于下面这样的代码
  1. @Bean
  2. public Executor taskExecutor() {
  3.     ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
  4.     executor.setCorePoolSize(config.getCorePoolSize());
  5.     executor.setMaxPoolSize(config.getMaxPoolSize());
  6.     executor.setQueueCapacity(config.getQueueCapacity());
  7.     executor.setThreadNamePrefix("TaskExecutePool-");
  8.     executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
  9.     executor.setWaitForTasksToCompleteOnShutdown(true);
  10.     executor.initialize();
  11.     return executor;
  12. }
复制代码
使用起来很方便,但是这样做有几个问题:
为了解决上述的问题,我开发了一个Spring Boot Starter(开源项目地址:https://gitee.com/hanxt/zimug-monitor-threadpool ),方便集成到Spring Boot项目里面去。目标是:在不改变SpringBoot线程池的核心实现的基础上,使其可视化、易观测、易配置、易使用
需要说明的是:zimug-monitor-threadpool并未改变SpringBoot线程池的实现,只是在其基础上添加了初始化阶段的配置自动化加载,运行时的状态监控。所以任何有关Spring Boot线程池运行时性能的讨论,都与本文及其实现无关。
一、易集成、易配置

通过上文的项目地址获取源码,然后maven编译install本地m2仓库。然后通过下面的maven坐标引入
  1. <dependency>
  2.     <groupId>com.zimug</groupId>
  3.     <artifactId>zimug-monitor-threadpool</artifactId>
  4.     <version>1.0</version>
  5. </dependency>
复制代码
如下配置spring boot YAML(application.yml)所示,配置了两个线程池,分别是test、test2。当thread-pool.enable=true的时候线程池配置生效。
  1. thread-pool:
  2.   enable: true
  3.   poolLists:
  4.     - poolId: test    #线程池唯一标识
  5.       poolName: 测试1   #线程池的中文描述,比如线程池给谁用?
  6.       coreSize: 5  #线程池初始化核心线程数量
  7.       maxSize: 10  #线程池最大线程容量
  8.       queueCapacity: 10  #线程池等待队列的容量
  9.     - poolId: test2
  10.       poolName: 测试2
  11.       coreSize: 5
  12.       maxSize: 10
  13.       queueCapacity: 10
复制代码
通过下面的这张图理解上面的配置信息

二、易使用

使用方式和SpringBoot 代码方式自定义线程池的使用方式是一样的。使用@Async注解的值是test,调用该注解标识的函数就会放入上文中配置的test线程池里面去执行。
  1. @Component
  2. public class TestTask {
  3.     @Async("test")   //注意这里,test是线程池配置的poolId
  4.     public Future<String> test() throws Exception {
  5.         System.out.println("当前线程:" + Thread.currentThread().getName());
  6.         return new AsyncResult<>("测试任务");
  7.     }
  8. }
复制代码
三、可视化易观测

在项目中引入zimug-monitor-threadpool之后,进行线程池配置,使用线程池。访问服务的/pool.html即可获取当前SpringBoot服务的线程池配置信息,以及运行时状态信息。

四、实现原理

zimug-monitor-threadpool的实现原理也非常简单,简单说一下原理,具体实现参考源码。
  1. configurableBeanFactory.registerSingleton(pool.getPoolId(), taskExecutor);
复制代码
  1. ThreadPoolTaskExecutor memThreadPool = (ThreadPoolTaskExecutor) applicationContext.getBean(poolModel.getPoolId());
复制代码
字母哥博客:zimug.com


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4