目录
前言
近阶段工作中遇到需要自定义拒绝策略的情况,网上查阅资料,大多文章都写的比较简单,所以花点时间自己研究下。
线程池拒绝策略的触发条件
一般情况下,我们都会手动创建一个有界线程池
@Bean("myThread")
public ThreadPoolTaskExecutor myThread(){
ThreadPoolTaskExecutor executor=new ThreadPoolTaskExecutor();
//核心线程数
executor.setCorePoolSize(2);
//队列容量
executor.setQueueCapacity(2);
//最大线程数
executor.setMaxPoolSize(2);
//拒绝策略
executor.setRejectedExecutionHandler(ThreadPoolExecutor.AbortPolicy);
return executor;
}
创建任务执行时首先判断是否大于核心线程数,超过核心线程数后,新进入的任务开始进入队列中,再大于队列数后会继续创建线程执行任务,直到大于最大线程数后就会开始执行拒绝策略。
上面代码里使用了自带的拒绝策略,总共有4种,可以看下源码比较好理解:
AbortPolicy拒绝并抛出异常
public static class AbortPolicy implements RejectedExecutionHandler {
public AbortPolicy() { }
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {
throw new RejectedExecutionException("Task"+r.toString+" rejected from "+e.toString);
}
}