当前位置: 首页 > news >正文

Java 应用 CPU 过高排查全流程

Java CPU 飙高90% 都是业务代码死循环、频繁GC、密集计算、死锁/自旋导致的,排查有标准、固定、可落地的流程,不需要猜。

下面给你一套从登录服务器到定位代码行的完整实战步骤,直接照着做就能定位问题。


一、快速定位:哪个进程占用 CPU 最高

1. 查看系统整体 CPU 占用

top

找到CPU 使用率最高的 Java 进程 PID(第一列)。


二、精准定位:这个进程里哪个线程在耗 CPU

2. 查看该 Java 进程内的线程排行

top-H-p<PID>

会列出该 Java 进程内部所有线程,找到CPU 最高的线程 TID

3. 把线程 TID 转成 16 进制(JVM 栈用 16 进制标识线程)

printf"%x\n"<TID>

得到一个16 进制线程 ID(记下来,后面要用)。


三、抓取线程栈:找到耗 CPU 的代码

4. 导出 Java 线程栈

jstack<PID>>stack.log

5. 在栈文件里搜索刚才的 16 进制线程 ID

grep-A20<16进制TID>stack.log

-A 20 表示显示后 20 行,直接就能看到:

  • 线程名称
  • 线程状态
  • 具体耗 CPU 的代码类、方法、行号

四、最常见的 4 种 CPU 飙高原因(一看栈就知道)

1. 死循环 / 无限递归(最常见)

栈特征:

com.xxx.service.UserService.getUserList(UserService.java:88)

代码一直卡在同一行,没有阻塞,一直在跑。

2. 频繁 Full GC / Young GC

栈特征:

VM Thread GC task thread

排查命令:

jstat-gc<PID>100010

如果FGC(FullGC次数)每秒涨好几次,就是内存泄漏/GC 导致 CPU 高。

3. 大量锁自旋 / CAS 空循环

栈特征:

sun.misc.Unsafe.park java.util.concurrent.locks

线程处于RUNNABLE 但一直在自旋

4. 密集计算(加密、循环、正则、JSON 解析)

栈会停留在:

  • 加密工具类
  • 复杂 for 循环
  • 正则表达式(灾难性回溯)
  • JSON/XML 序列化

五、1 分钟快速排查脚本(直接复制用)

把下面内容保存为check_cpu.sh,一键定位耗 CPU 代码行:

#!/bin/bashPID=$1jstack$PID>stack.logTID=$(top-b-n1-H-p$PID|grepjava|sort-nrk9|head-1|awk'{print $1}')HEX_TID=$(printf"%x\n"$TID)echo"高耗CPU线程16进制:$HEX_TID"grep-A30$HEX_TIDstack.log

使用:

chmod+x check_cpu.sh ./check_cpu.sh<Java进程PID>

六、定位到代码后怎么解决?

  1. 死循环:检查循环条件、边界值、迭代逻辑
  2. 频繁GC:查内存泄漏(用 jmap 堆 dump)、调整堆大小
  3. 锁自旋:改用公平锁、减少锁竞争、异步化
  4. 密集计算:异步执行、分片、缓存结果、优化算法

七、必备工具(无需安装)

Linux + JDK 自带,生产环境直接用

  • top:看进程/线程 CPU
  • jstack:线程栈
  • jstat:GC 监控
  • jmap:堆内存 dump(定位内存泄漏)

总结

  1. top找 Java 进程 PID
  2. top -H找耗 CPU 线程 TID
  3. 转 16 进制
  4. jstack + grep定位代码行
  5. 按栈特征判断是死循环/GC/锁/密集计算

整个流程不重启、不影响业务、1~3 分钟定位根因

http://www.jsqmd.com/news/941184/

相关文章:

  • AI 简历到底能不能过企业 ATS 系统?实测对比
  • 2026石家庄名包回收店铺多店横评,教你轻松选出高性价比渠道 - 奢侈品回收测评
  • 【真实经验分享】Oracle Data Guard 化身分裂之谜:一个 VALID_FOR 参数引发的级联灾难
  • 404 Media 起诉 ICE,索要 200 万美元间谍软件合同文件,获大量涂黑内容
  • 《First Article》:工业 CT 扫描剖析产品,揭示设计、质量与材料问题
  • T113-S3上给Tina5.0系统加装USB WiFi(RTL8188FU)的保姆级避坑指南
  • C# WinForms工程直连S7-1200:Sharp7实现浮点数与布尔量双向读写(含完整通信封装)
  • 怀化市全品类贵金属黄金回收白银回收门店推荐 2026年最新黄金回收门店口碑排行榜+联系方式 - 前途无量YY
  • 三分钟实战:让GitHub说中文的完整解决方案
  • WeChatPad:突破微信设备限制的技术方案
  • 线上辅导班系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
  • 不止是格式:Pattern Recognition投稿中那些没人告诉你的‘潜规则’与编辑视角
  • C# .NET项目一键接入微信、支付宝、银联支付的开箱即用封装包
  • 别再只盯着RMSE了!用sklearn的mean_absolute_error评估模型,这份避坑指南请收好
  • 淮安市全品类贵金属黄金回收白银回收门店推荐 2026年最新黄金回收门店口碑排行榜+联系方式 - 前途无量YY
  • Java 频繁GC 完整排查流程
  • SNAP 9.0处理Sentinel-1 SLC数据:一个简化流程的实战分享(避坑PolSARpro导入失败)
  • AI学习——FastAPI 接口封装
  • FunASR实战:如何用Python给会议录音自动加标点和分段?
  • 别再被AI培训割韭菜了!从战略到变现,老板必知的AI智能体应用部署4大内幕
  • 2026 台北国际电脑展开幕,英伟达、英特尔等科技巨头发布多款新品
  • 免费微信聊天记录永久保存终极指南:WeChatMsg让数据真正属于你
  • 手机号码定位神器:3分钟免费查询归属地,地图精准标注
  • AWR2944开发板实测DDM雷达原始数据+MATLAB一键处理脚本
  • 淮北市全品类贵金属黄金回收白银回收门店推荐 2026年最新黄金回收门店口碑排行榜+联系方式 - 前途无量YY
  • 5分钟高效部署Poppler Windows完整方案:专业级PDF处理实战指南
  • 从‘算得对’到‘证得清’:一个非数学专业生的《数学分析》自学踩坑与上岸心得
  • 7-Zip-zstd终极指南:让文件压缩速度提升300%的智能解决方案
  • 零基础入门计算机网络:一文搞懂体系结构与分层思想
  • 告别手抖废片:用DeblurGAN-v2的MobileNet-DSC版,手机也能实时搞定图像去模糊