场景题:CPU 100% 问题怎么排查?

CPU 100% 问题怎么排查?

方案 1:传统命令行( jstack )排查

++步骤 1:定位高 CPU 的 Java 进程++

执行 top 命令,按 P 键按 CPU 使用率排序,找到占用 CPU 最高的 Java 进程 PID(比如 13731)。

++步骤 2:定位进程内高 CPU 的线程++

执行 top -Hp 进程PID(如 top -Hp 13731-H 表示显示线程级信息,找到该进程内占用 CPU 最高的线程 PID(比如 13756)。

++步骤 3:转换线程++ ++PID++ ++为 16 进制++

因为 Java 线程栈中线程 ID 是 16 进制格式,需将线程 PID(13756)转成 16 进制(比如 0x35bc),可通过在线工具或命令 printf "%x\n" 13756 转换。

++步骤 4:导出线程栈并定位问题代码++

执行 jstack 进程PID > thread_stack.log (如 jstack 13731 > thread_stack.log),导出整个 Java 进程的线程堆栈;

打开 thread_stack.log,搜索 16 进制的线程 ID(0x35bc),即可看到该线程的完整堆栈:包括线程状态、执行的方法、代码行号(比如 TestController.java:23),从而定位到耗 CPU 的代码(通常是死循环、频繁 GC、高频循环计算等)。

方案 2:Arthas 工具排查

Arthas 是阿里开源的线上诊断工具,无需导出日志,实时排查更高效:

++步骤 1:安装并启动 Arthas++

java 复制代码
# 下载Arthas包
curl -O https://arthas.aliyun.com/arthas-boot.jar

# 启动并attach到目标Java进程
java -jar arthas-boot.jar

启动后会列出服务器上所有 Java 进程,输入对应编号选择高 CPU 的进程,进入 Arthas 控制台。

++步骤 2:实时查看线程 CPU 占用++

执行 dashboard 命令:查看实时面板(5 秒刷新),直观看到线程、内存、GC 等状态;

执行 thread 命令:按 CPU 使用率排序显示所有线程,直接找到占用 CPU 最高的线程 ID(比如 18)。

++步骤 3:查看线程堆栈定位代码++

执行 thread 线程ID(如 thread 18),直接输出该线程的完整堆栈,一眼看到耗 CPU 的方法和代码行(比如 TestController.high(TestController.java:23))。

相关推荐
电商API_180079052472 小时前
批量获取电商商品数据的主流技术方法全解析
大数据·数据库·人工智能·数据分析·网络爬虫
qq_336313932 小时前
java基础-IO流(网络爬虫/工具包生成假数据)
java·爬虫·php
我是谁的程序员2 小时前
iOS 文件管理,在不越狱的前提下管理 iPhone / iPad 文件
后端
v***59832 小时前
springBoot连接远程Redis连接失败(已解决)
spring boot·redis·后端
rgeshfgreh3 小时前
Python流程控制:从条件到循环实战
前端·数据库·python
桦说编程3 小时前
滑动窗口限流器的演进之路:从调度器实现到 Packed CAS
java·后端·性能优化
煎蛋学姐3 小时前
SSM校园物品交易系统ua3tg(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理·ssm 框架·商品信息管理·校园物品交易系统·商品分类
狗头大军之江苏分军3 小时前
告别旧生态:Ant Design 6 不再支持 IE 与现代前端趋势解读
前端·javascript·后端