CPU密集orIO密集or混合型
看应用是CPU密集型的还是IO密集型的,还是混合型的。
CPU密集
CPU密集型的话,一般配置CPU处理器个数+/-1个线程,所谓CPU密集型就是指系统大部分时间是在做程序正常的计算任务,例如数字运算、赋值、分配内存、内存拷贝、循环、查找、排序等,这些处理都需要CPU来完成。IO密集
IO密集型的话,是指系统大部分时间在跟I/O交互,而这个时间线程不会占用CPU来处理,即在这个时间范围内,可以由其他线程来使用CPU,因而可以多配置一些线程。混合型
混合型的话,是指两者都占有一定的时间。
估算的经验公式
Ncpu=CPU的数量
Ucpu=目标CPU使用率
W/C=等待时间与计算时间的比率
为保持处理器达到期望的使用率,最优的线程池的大小等于
Nthreads=Ncpu*Ucpu*(1+W/C)
观察线程池统计信息
Java中,可以通过Runtime.getRuntime().availableProcessors()获取可以用的cpu数量。
具体线程池大小观测,可以通过覆盖executor的钩子方法,进行线程池的监控,查看等待队列大小等等,主要观察等待队列的大小以及拒绝的任务多少。