过高问题定位笔记"/>
CPU过高问题定位笔记
CPU过高定位一般有以上两种方案查询定位:
第一种:top+jstack
结果如下:
由上图可知,进程36032的CPU占用过高
接着用如下指令查看进程36032下的各线程信息
结果如下:
由上图可知,线程36044占用CPU过高
首先,我们将线程PID36044转换为16进制 :8ccc
然后用: jstack 进程PID > 路径 命令
将进程36032信息输出到1.txt文件中
然后用cat 读出信息,再加grep过滤输出与线程 8ccc相关的信息,如下图:
结果定位为在 函数第13行:
果然,一个死循环,造成了CPU过高。
第二种,下面用JMC来分析:
打开JMC,点击线程查看
结果如下:
CPU过高原因及解决方案分析如下:
一个反序列化引起的例子,详情请参考如下链接:
XStream在反序列化大对象时有严重的性能问题
一个参考的链接如下:
正则表达式和 CPU 100%有什么故事
更多推荐
CPU过高问题定位笔记
发布评论