ThreadPoolTaskExecutor使用实践

后台开发中,经常有一些非主流程业务要处理,为了提升主业务处理速度,可使用ThreadPoolTaskExecutor线程池来异步处理

配置

java config

  @Bean
  public ThreadPoolTaskExecutor taskExecutor() {
    ThreadPoolTaskExecutor poolExecutor = new ThreadPoolTaskExecutor();
    // 核心线程数
    poolExecutor.setCorePoolSize(5);
    // 最大线程数
    poolExecutor.setMaxPoolSize(15);
    // 队列大小
    poolExecutor.setQueueCapacity(100);
    // 线程最大空闲时间
    poolExecutor.setKeepAliveSeconds(300);
    // 拒绝策略
    poolExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
    // 线程名称前缀
    poolExecutor.setThreadNamePrefix("my-pool-");

    return poolExecutor;
  }

xml config

  <bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
    <property name="corePoolSize" value="8"/> <!--核心线程数 -->
    <property name="maxPoolSize" value="16"/> <!--最大线程数 -->
    <property name="keepAliveSeconds" value ="3000"/> <!--线程最大空闲时间 -->
    <property name="queueCapacity" value="200"/> <!-- 队列大小 -->
    <property name="threadNamePrefix" value="my-pool-"/>
    <property name="rejectedExecutionHandler">
      <bean class="java.util.concurrent.ThreadPoolExecutor.CallerRunsPolicy"/>
    </property>
  </bean>

任务处理流程及参数

新任务提交时:若当前线运行的程数量小于核心线程数,则创建一条新线程;
若已经超过核心线程数,则先放入队列中; 队列满后,创建新线程;
当线程总数等于最大线程数时,则执行拒绝策略

ThreadPoolTaskExecutorInitializingBeanDisposableBean的实现类,
spring容器后会自动处理其初始化方法和注销方法,我们只需配置bean即可

java提供的拒绝策略

  • AbortPolicy,直接抛出RejectedExecutionException
  • CallerRunsPolicy,直接在主线程中执行
  • DiscardOldestPolicy 抛弃队列头的任务,然后重试execute。
  • DiscardPolicy,直接丢弃

使用

  @Autowired
  private ThreadPoolTaskExecutor taskExecutor;

  public void testExecutor(final String str) {
    taskExecutor.execute(new Runnable() {
      @Override
      public void run() {
        System.out.println(Thread.currentThread().getName() + "--" + str);
      }
    });
  }

参考资料

ThreadPoolTaskExecutor使用详解

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 【JAVA 线程】 线程 进程:是一个正在执行中的程序。每一个进程执行都有一个执行顺序。该顺序是一个执行路径,或者...
    Rtia阅读 2,788评论 2 20
  • 一.线程安全性 线程安全是建立在对于对象状态访问操作进行管理,特别是对共享的与可变的状态的访问 解释下上面的话: ...
    黄大大吃不胖阅读 880评论 0 3
  • 三个孩子都有每天阅读15分钟的英语作业,让他们独立完成的话,极有可能被偷偷溜过,不留下任何的痕迹。 昨天用击鼓传花...
    JC贾阅读 303评论 3 1
  • 无为,第一次知道是个地名。也没啥,中国九百六十万平方公里,那么多地方,熟悉的能有几个。无为是个市还是个县,我不知道...
    象兔阅读 238评论 0 0
  • 定义 软件架构是指:对于软件的各个方面做出的设计决定,包括行为上的和结构上的。 架构与设计的关系 架构是设计的一部...
    Android技术分享阅读 1,017评论 0 7