JAVA应用中线程池设置多少合适?

本文探讨了如何确定Java应用中线程池的合适设置,包括核心线程数应等于CPU核心数,最大线程数与CPU利用率、IO操作频率相关,并通过测试验证了不同线程数对CPU利用率的影响。文章还提出了计算公式和决定最大线程数的流程,考虑了CPU利用率、GC频率和暂停时间等因素。
摘要由CSDN通过智能技术生成

目录

1、机器配置:

2、核心线程数

3、最大线程数多少合适?

4、理论基础

5、测试验证

一个线程跑满一个核心的利用率

6个线程

12 个线程:所有核的cpu利用率都跑满

有io操作

6、计算公式

7、决定最大线程数的流程:


1、机器配置:

        4核8g内存

2、核心线程数

        就是cpu核数就行

3、最大线程数多少合适?

    线程池设置多大,并没有固定答案, 需要结合实际情况不断的测试才能得出最准确的数据.

4、理论基础

  • 一个 CPU 核心,某一时刻只能执行一个线程的指令
  • 一个极端的线程,就可以把单个核心的利用率跑满,多核心 CPU 最多同时执行等于核心数的 “极端” 线程数
  • 如果每个线程都这么 “极端”,且同时执行的线程数超过核心数,会导致不必要的切换,造成负载过高,只会让执行更慢
  • I/O 等暂停类操作时,CPU 处于空闲状态,操作系统调度 CPU 执行其他线程,可以提高 CPU 利用率,同时执行更多的线程
  • I/O 事件的频率频率越高,或者等待 / 暂停时间越长,CPU 的空闲时间也就更长,利用率越低,操作系统可以调度 CPU 执行更多的线程

5、测试验证(测试机器12cpu)

一个线程跑满一个核心的利用率

public class CPUUtilizationTest {
	public static void main(String[] args) {
		//死循环,什么都不做
		while (true){
		}
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值