0

0

如何排查Java应用CPU占用过高_jstack与jtop环境排查工具使用

P粉602998670

P粉602998670

发布时间:2026-03-12 08:13:52

|

811人浏览过

|

来源于php中文网

原创

用jstack定位高cpu线程需先通过top -hp获取高占用lwp id,转为16进制后在jstack输出中搜索nid;注意容器环境用hostpid、runnable不等于真占cpu、gc线程高占用需结合jstat和jmap排查根本原因。

如何排查java应用cpu占用过高_jstack与jtop环境排查工具使用

怎么用 jstack 抓到高 CPU 线程的堆栈

直接用 jstack 本身抓不到“哪个线程正在吃 CPU”,它只输出所有线程快照,但配合 top -Hps H 就能定位。关键步骤是:先找 PID,再找高 CPU 的 LWP(轻量级进程 ID),最后转成 16 进制去堆栈里对号入座。

  • top -Hp <pid></pid> 查看该 Java 进程下所有线程的 CPU 占用,记下 %CPU 最高的那个 LWP ID
  • printf "%x\n" <lwp_id></lwp_id> 把它转成小写十六进制(比如 12345 → 3039
  • jstack <pid> > thread.log</pid> 保存全量堆栈,然后 grep -A 10 -B 10 "nid=0x3039" 搜索对应线程块
  • 注意:JDK 8+ 默认开启 -XX:+UseContainerSupport,在容器里看到的 PID 可能被 cgroup 限制,jstack 要用宿主机视角的 PID(即 docker inspect 里的 HostPid

jtop 是什么?它真能替代 jstack

jtop 不是 JDK 自带工具,而是第三方命令行实时监控器(GitHub 上开源),它把 jstack + jstat + top 逻辑做了聚合,能动态刷新线程 CPU 排名。但它依赖 JVM 的 Attach API,在某些安全加固环境(如 -XX:+DisableAttachMechanism)会直接失败。

  • 启动前确认目标 JVM 没加 -XX:+DisableAttachMechanism,否则报错:Unable to open socket file: target process not responding or HotSpot VM not loaded
  • 它显示的“CPU%”是采样估算值,不是精确瞬时值;和 top -H 的结果可能有 5–10% 偏差
  • 不支持 JDK 17+ 的默认强封装(需额外加 --add-opens java.base/jdk.internal.misc=ALL-UNNAMED

线程状态为 RUNNABLE 就一定在跑 CPU 吗

不一定。RUNNABLE 表示线程处于 JVM 就绪或运行态,但操作系统层面它可能正被调度、也可能刚从阻塞中唤醒还没真正执行。真正要怀疑的是那些长期卡在 java.util.concurrentUnsafe.park 外围的 RUNNABLE 线程——它们大概率在自旋或忙等。

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载
  • 典型陷阱:AtomicInteger.incrementAndGet() 在高争用下反复 CAS 失败,线程持续 RUNNABLE 但没做有效工作
  • 另一个常见点:Thread.sleep(0) 或空 while(true) 循环,堆栈里看不到 I/O 或锁等待,只有纯 Java 方法调用链
  • 区分方法:用 perf record -e cycles:u -p <pid></pid> 看用户态指令热点,比堆栈更准

为什么 dump 出来全是 GC 相关线程,但 CPU 还是高

说明问题不在业务线程,而在 GC 本身——尤其是 CMS 或 G1 在并发阶段频繁触发、或元空间/直接内存泄漏导致 GC 压力陡增。这时候 jstack 看到的 GCTaskThreadVM Thread 高占用是结果,不是原因。

立即学习Java免费学习笔记(深入)”;

  • 先用 jstat -gc <pid> 1000</pid> 看 GC 频率和耗时,重点关注 GCTimeRatioFGC 次数
  • 如果 Metaspace 使用量持续上涨,检查是否动态生成类(如 CGLIB、Groovy、JSP 编译)没释放
  • jmap -histo:live <pid></pid> 可能看不出问题,得用 jmap -dump:format=b,file=heap.hprof <pid></pid> 配合 mat 查 dominator tree

线程堆栈只是入口,真正卡点往往藏在内存分配模式、JNI 调用、或外部资源争用里。别盯着 nid 找太久,先确认是不是 GC、锁竞争、或 native 层问题更省时间。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.09.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

887

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

461

2024.06.27

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

887

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

461

2024.06.27

printf用法大全
printf用法大全

php中文网为大家提供printf用法大全,以及其他printf函数的相关文章、相关下载资源以及各种相关课程,供大家免费下载体验。

76

2023.06.20

fprintf和printf的区别
fprintf和printf的区别

fprintf和printf的区别在于输出的目标不同,printf输出到标准输出流,而fprintf输出到指定的文件流。根据需要选择合适的函数来进行输出操作。更多关于fprintf和printf的相关文章详情请看本专题下面的文章。php中文网欢迎大家前来学习。

304

2023.11.28

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号