关闭

ThreadPoolTaskExecutor的配置解释

908人阅读 评论(0) 收藏 举报
分类:

ThreadPoolTaskExecutor是一个spring的线程池技术,它是使用jdk中的java.util.concurrent.ThreadPoolExecutor进行实现。

<bean id ="taskExecutor"  class ="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor" >
    <property name ="corePoolSize" value ="5" /> 
    <property name ="keepAliveSeconds" value ="300" /> 
    <property name ="maxPoolSize" value ="10" /> 
    <property name ="queueCapacity" value ="25" /> 
  </bean> 线程的配置文件:

corePoolSize: 线程池维护线程的最少数量

keepAliveSeconds  线程池维护线程所允许的空闲时间

maxPoolSize   线程池维护线程的最大数量

queueCapacity 线程池所使用的缓冲队列

当一个任务通过execute(Runnable)方法欲添加到线程池时:

l  如果此时线程池中的数量小于corePoolSize,即使线程池中的线程都处于空闲状态,也要创建新的线程来处理被添加的任务。

l  如果此时线程池中的数量等于 corePoolSize,但是缓冲队列 workQueue未满,那么任务被放入缓冲队列。

l  如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量小于maximumPoolSize,建新的线程来处理被添加的任务。

l  如果此时线程池中的数量大于corePoolSize,缓冲队列workQueue满,并且线程池中的数量等于maximumPoolSize,那么通过 handler所指定的策略来处理此任务。也就是:处理任务的优先级为:核心线程corePoolSize、任务队列workQueue、最大线程 maximumPoolSize,如果三者都满了,使用handler处理被拒绝的任务。

l  当线程池中的线程数量大于 corePoolSize时,如果某线程空闲时间超过keepAliveTime,线程将被终止。这样,线程池可以动态的调整池中的线程数。


在spring中使用ThreadPoolTaskExecutor的配置:

<!-- 异步线程池 -->
    <bean id="threadPool"
        class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
        <!-- 核心线程数 -->
        <property name="corePoolSize" value="3" />
        <!-- 最大线程数 -->
        <property name="maxPoolSize" value="10" />
        <!-- 队列最大长度 >=mainExecutor.maxSize -->
        <property name="queueCapacity" value="25" />
        <!-- 线程池维护线程所允许的空闲时间 -->
        <property name="keepAliveSeconds" value="300" />
        <!-- 线程池对拒绝任务(无线程可用)的处理策略 ThreadPoolExecutor.CallerRunsPolicy策略 ,调用者的线程会执行该任务,如果执行器已关闭,则丢弃.  -->
        <property name="rejectedExecutionHandler">
            <bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />
        </property>
    </bean>


Reject策略预定义有四种: 

断策略实际上是指饱和策略(concurent包中的RejectedExecutionHandler接口),这里需要先解释一下,什么叫饱和策略, 实际就是说, 线程池中的线程容器已经放不下新的任务了,饱和了, 必须要有一个相应的策略来处理。 ThreadPoolExecutor内部,已经定义了4种饱和策略。

AbortPolicy(中止):它是默认的策略。
CallerRunsPolicy (调用者运行):它既不会丢弃任务,也不会抛出任何异常,它会把任务推回到调用者那里去,以此缓解任务流
DiscardPolicy(遗弃)策略:它默认会放弃这个任务
DiscardOldestPolicy(遗弃最旧的):它选择的丢弃的任务,是它本来要执行的(可怜的娃,就这样被新加入的给排挤了).
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

ThreadPoolTaskExecutor 使用和原理

使用ThreadPoolTaskExecutor是一个spring的线程池技术,利用他可以轻松的视线线程池,下面代码是具体的使用pom.xml org.springfra...
  • benbendy1984
  • benbendy1984
  • 2017-02-08 20:04
  • 6976

spring 集成线程池(TaskExecutor)

本文转载至:http://rainyear.iteye.com/blog/1466140 Spring 线程池使用  /**  *  */  一个日志管理的类:  在批理更新,插入...
  • zhouzhiwengang
  • zhouzhiwengang
  • 2016-04-12 13:32
  • 2576

ThreadPoolTaskExecutor线程池

1.了解 TaskExecutor接口 Spring的TaskExecutor接口等同于java.util.concurrent.Executor接口。 实际上,它存在的主要原因是为了在使用线程池的时...
  • Howie_zhw
  • Howie_zhw
  • 2016-08-06 16:46
  • 1875

使用SPRING中的线程池ThreadPoolTaskExecutor并且得到任务执行的结果

XML配置 =notifyScheduledMainExecutor.maxNum;默认为Integer.MAX_VALUE -->
  • dearfellow
  • dearfellow
  • 2016-09-20 09:13
  • 3422

spring-boot @Async 的使用、自定义Executor的配置方法

简单几步,实现异步新线程调用。
  • ClementAD
  • ClementAD
  • 2016-12-13 11:16
  • 15902

spring4+ThreadPoolTaskExecutor创建线程 两种方式发送邮件

百度云代码下载地址包含测试用例 :点击后跳转 ThreadService package com.konglingfu.service;public interface ThreadService...
  • PYouLing123456789
  • PYouLing123456789
  • 2016-03-18 14:11
  • 2361

使用SPRING中的线程池ThreadPoolTaskExecutor实现JAVA并发

使用SPRING中的线程池ThreadPoolTaskExecutor实现并发。 一:不需要返回值的情况  1,初始化线程池 Java代码   ThreadPool...
  • JIESA
  • JIESA
  • 2016-05-26 21:26
  • 1289

利用spring的线程池ThreadPoolTaskExecutor对多个库进行数据归档

使用多线程ThreadPoolTaskExecutor对多个数据库中的数据进行数据归档
  • wangzuojia001
  • wangzuojia001
  • 2017-01-16 17:31
  • 754

使用SPRING中的线程池ThreadPoolTaskExecutor实现JAVA并发

ThreadPoolTaskExecutor是一个spring的线程池技术,它是使用jdk中的java.util.concurrent.ThreadPoolExecutor进行实现。 Threa...
  • lipc_
  • lipc_
  • 2016-10-11 11:22
  • 9046

使用SPRING中的线程池ThreadPoolTaskExecutor实现并发

使用SPRING中的线程池ThreadPoolTaskExecutor实现并发。 一:不需要返回值的情况  1,初始化线程池 Java代码   ThreadPool...
  • twj13162380953
  • twj13162380953
  • 2017-04-16 23:05
  • 918
    个人资料
    • 访问:302088次
    • 积分:8545
    • 等级:
    • 排名:第2670名
    • 原创:601篇
    • 转载:26篇
    • 译文:0篇
    • 评论:25条