文章图片标题

Java高CPU占用原因排查

分类:linux系统 作者:默然 评论:0 点击: 465 次 日期:2016-08-07

top命令发现某个进程占用了100%的CPU
这里写图片描述
通过ps命令,进一步确定哪个进程出了问题
这里写图片描述
再查看线程占用CPU的列表

# ps -mp PID -o THREAD,tid,time

这里写图片描述
找到占用CPU最高的线程,查看TID,将其转换为16进制格式

# printf "%x\n" TID

这里写图片描述
而后查看堆栈信息

# jstack PID |grep 16进制TID -A 60

这里写图片描述
这里报错是因为tomcat进程运行用户为tomcat,而当前以root用户查看堆栈信息
这里写图片描述
因此切换为tomcat执行命令
这里写图片描述

# sudo -u tomcat  jstack 32072 |grep 1541 -A 60# sudo -u tomcat jstack -J-d64 -m 32072

更多内容请长按二维码关注(更有不定期发红包活动吆^0^):
致儒先生

转载自:http://www.linuxidc.com/Linux/2016-08/133859.htm




声明: 除非注明,本文属( 默然 )原创,转载请保留链接: http://www.tomrrow.com/archives-7945.html