Java进程CPU100%打满分析

背景

最近发现测试服务器经常触发CPU90%报警,这次有空了,决定上服务器分析一下,居然发现是最近新上线的日志收集服务消耗大量CPU:

top 资源消耗分析, shift + p 根据CPU消耗排序,shift + m 根据内存消耗排序

一个进程CPU消耗超过90%CPU,第一眼感觉不正常,因此进行了一番分析。

CPU分析

1.使用 top -p 命令(为Java进程的id号)查看Java进程的cpu占用:

top -p 29595

查看指定进程资源使用情况

2.使用 top -Hp 命令(为Java进程的id号)查看该Java进程内所有线程的资源占用情况

top -Hp 29595

线程资源消耗分析, shift + p 根据CPU消耗排序,shift + m 根据内存消耗排序

3.终端上使用 printf "%x\n" 命令(tid指线程的id号)将以上10进制的线程号转换为16进制

printf "%x\n" 29631 -> 73bf -> 及 0x73bf

16进制进程号用于后面查询日志

4.使用 JDK 自带命令 jstack 获取此时的所有线程快照并输入到文件中

jstack -l <pid> > jstack.txt

命令(为Java进程的id号)来获取线程快照结果并输入到指定文件

jstack -l 29595 > jstack.txt

5.查看第4步生成的txt文件,搜索上述高CPU的tid信息 -> 0x73bf

在根据日志中的代码位置分析,进行代码优化

最后发现此处代码是一个死循环,一直在监测日志文件状态,并且无等待

额,原来是这里会产生长时间的循环空转,消耗大量CPU

注: 业务上这里日志收集管理是持续检测日志目录,进行日志收集,包装日志收集的实时性和准确性

知道问题就好办,这里每一轮循环增加等待 1 秒,让出 CPU 资源。发布部署之后发现 CPU 顿时降下来了

修改后,CPU 消耗很低

总结

遇到 java 进程 CPU 占用较高级别就是这个分析思路:

  1. 确定高CPU进程的具体线程信息 top -Hp <pid>
  2. 通过命令输出当前各线程栈快照信息 jstack -l <pid> > jstack.txt
  3. 根据16进制线程ID在快照信息中查找定位具体代码
  4. 结合日志,调整优化代码,再次验证情况

完...

参考

www.cnblogs.com/dennyzhangd...

blog.csdn.net/chenfei3306...

blog.csdn.net/lq0954/arti...

相关推荐
何中应4 分钟前
EasyExcel使用(二:写出)
java·后端·maven·excel
minji...1 小时前
数据结构 堆(4)---TOP-K问题
java·数据结构·算法
命苦的孩子1 小时前
Java 中的排序算法详解
java·开发语言·排序算法
Seven971 小时前
Spring AI 框架中如何集成 MCP?
java
开往19822 小时前
spring boot整合mybatis
java·spring boot·mybatis
北京_宏哥2 小时前
《刚刚问世》系列初窥篇-Java+Playwright自动化测试-27- 操作单选和多选按钮 - 上篇(详细教程)
java·前端·面试
回家路上绕了弯2 小时前
Java双亲委派机制:从原理到实践的全面解析
java·后端
努力的小郑2 小时前
亿级流量下的生死抉择:Apache BeanUtils vs MapStruct性能差距32倍!架构师选型指南
java·spring·apache
努力的小郑2 小时前
BeanUtils拷贝大对决:Spring与Apache Commons的差异与妙用
java·spring·apache
求知摆渡2 小时前
Spring Boot 3.5 + Spring Cloud Stream:邮件发送与幂等实战
java·spring boot·spring cloud