分析java应用cpu使用率飙升

本文探讨了JAVA应用中CPU使用率飙升的原因,包括while死循环、频繁Young GC、线程上下文切换等。分析了CPU使用率与线程、进程的关系,并提供了如何定位和解决CPU过高问题的方法,如通过jstack分析线程状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

疑惑

  • 一个 while 死循环,会不会引起 CPU 使用率飚升?
  • 频繁 Young GC 会不会引起 CPU 使用率飚升?
  • 线程数很高的应用,CPU 使用率一定高么?
  • CPU 使用率高的应用,线程数一定高么?
  • BLOCKED 状态的线程会不会引起 CPU 使用率飚升?
  • 分时操作系统 CPU 是耗费 us ? 还是耗费 sy ?

思考

1、CPU 使用率怎么计算?

CPU% = 1 - idleTime / sysTime * 100

  • idleTime:CPU处于空闲状态的时间
  • sysTime:CPU处于用户态和内核台的时间总和

2、CPU 使用率跟啥有关系?

常听说计算密集型的程序是比较耗 CPU 使用率的。

那 JAVA 应用中哪些操作是比较耗 CPU 使用的?

列举日常程序中常见的耗CPU的操作:

  • 频繁GC,访问量高时,有可能造成频繁的GC、甚至FGC。当调用量大时,内存分配过快,就会造成GC线程不停的执行,导致CPU飙高
  • 序列化与反序列化,后文中举了一个真实的案例,程序执行xml解析的时,调用量增大的情况下,导致了CPU被打满
  • 加密、解密
  • 正则表达式校验,曾经线上发生一次血案,正则校验将CPU打满。大概原因是:Java 正则表达式使用的引擎实现是 NFA 自动机,这种引擎在进行字符匹配会发生回溯(backtracking)
  • 线程上下文切换、当启动了很多线程,而这些线程都处于不断的阻塞状态(锁等待、IO等待等)和执行状态的变化过程中。当锁竞争激烈时,很容易出现这种情况
  • 某些线程在做无阻塞的运算,简单的例子while(true)中不停的做运算,没有任何阻塞。写程序时,如果需要做很
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值