关于线程池的创建
来源:3-10 线程池状态

徐子与
2020-01-07
目前课程中的线程池的创建 都有点违规阿里规范,老师那边有一些好的方法么? 看到 阿里建议 使用线程工厂,谷歌插件,xml配置。老师那边有一些好的资料么
2回答
-
悟空
2020-01-07
课程里有讲到,自动创建线程池的弊端,还演示了OOM的实际发生。
阿里规范对于线程池的说法如下:
【强制】线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor的方式,
这样的处理方式让写的同学更加明确线程池的运行规则,规避资源耗尽的风险。
说明:Executors各个方法的弊端:
1)newFixedThreadPool和newSingleThreadExecutor:
主要问题是堆积的请求处理队列可能会耗费非常大的内存,甚至OOM。
2)newCachedThreadPool和newScheduledThreadPool:
主要问题是线程数最大数是Integer.MAX_VALUE,可能会创建数量非常多的线程,甚至OOM。
Positive example 1:
//org.apache.commons.lang3.concurrent.BasicThreadFactory
ScheduledExecutorService executorService = new ScheduledThreadPoolExecutor(1,
new BasicThreadFactory.Builder().namingPattern("example-schedule-pool-%d").daemon(true).build());
Positive example 2:
ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
.setNameFormat("demo-pool-%d").build();
//Common Thread Pool
ExecutorService pool = new ThreadPoolExecutor(5, 200,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
pool.execute(()-> System.out.println(Thread.currentThread().getName()));
pool.shutdown();//gracefully shutdown
Positive example 3:
<bean id="userThreadPool"
class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<property name="corePoolSize" value="10" />
<property name="maxPoolSize" value="100" />
<property name="queueCapacity" value="2000" />
<property name="threadFactory" value= threadFactory />
<property name="rejectedExecutionHandler">
<ref local="rejectedExecutionHandler" />
</property>
</bean>
//in code
上面给出了3个阿里推荐的方式,第一个是用线程工厂为每个业务指定“线程名”,这一点可以直接用org.apache.commons.lang3.concurrent.BasicThreadFactory,第二点就是对于各个参数的配置,不存在设置为无限线程数或者是阻塞队列为无限的情况。即便是用xml配置,本质也是保证第二点,我们只要根据需求对参数进行合理配置,就是符合规范的。
30 -
徐子与
提问者
2020-01-07
谢谢您
10
相似问题