线程池的理想大小取决于被提交任务的类型以及所部属系统的特性。在系统中一般不固定线程池的大小,而是通过某种配置机制来提供。或则根据处理器的数量来决定:
我们可以通过如下代码来获取处理器的数量:
- 1
- 2
- 1
- 2
这行代码可以直接输出当前机器处理器的数量。
对于线程池的大小不能过大也不能过小。过大就会有大量的线程在相对较少的CPU和内存上竞争,过小会导致许多空闲的处理器无法工作,从而降低吞吐率。
对于设置线程池的大小我们需要考虑的问题有:
1、机器有多少个CPU?
2、多大内存?
3、任务是计算密集型还是IO密集型?
4、是否需要像JDBC这种稀缺资源?
NT(最佳线程数量)= N * U * (1+W/C)
上面:NT:最优线程数量
N:服务器CPU的数量
U:CPU的利用率;
W/C: 是线程等待时间与线程CPU时间之比
当然上面只是一个估计值,也不是绝对的,具体的还得通过监控服务器的运行状态来确定。但是大致可以推断出一个结论:
可以得出一个结论:
线程等待时间所占比例越高,需要越多线程。线程CPU时间所占比例越高,需要越少线程。