Spring Boot配置和使用多线程池

发表于:2018-6-08 11: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。如果还有任务,则根据拒绝策略进行处理。
  拒绝策略有多种:
  · 由任务调用线程执行
  · 抛异常
  · 多余的直接抛弃
  · 根据FIFO(先进先出)抛弃队列里任务

上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。

【有奖活动】填问卷 送70G测试大牛精品资料(干货+视频)!

评 论

论坛新帖

顶部 底部


建议使用IE 6.0以上浏览器,800×600以上分辨率,法律顾问:上海瀛东律师事务所 张楠律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2018, 沪ICP备05003035号
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪公网安备 31010102002173号

51Testing官方微信

51Testing官方微博

扫一扫 测试知识全知道