300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > Linux(十二):CPU使用率过高问题排查 ps命令和jstack命令查看线程调用栈

Linux(十二):CPU使用率过高问题排查 ps命令和jstack命令查看线程调用栈

时间:2020-12-29 14:45:05

相关推荐

Linux(十二):CPU使用率过高问题排查 ps命令和jstack命令查看线程调用栈

目录

1、处理流程

2、总结

1、处理流程

一个应用占用CPU很高,除了确实是计算密集型应用之外,通常原因都是出现了死循环。

第一步:查看进程号

top命令发现某个进程(pid)占用cpu达到很高

第二步:查看哪个线程占用最多资源

ps p pid -L -o pcpu,pid,tid,time,tname,stat,psr |sort -n -k1 -r; (命令查看这个进程下面的所有线程占用情况,pid 替换为查找到的pid数字)

第三步:jstack输出堆栈信息:jstack pid 进行查看输出到临时文件

jstack pid | grep -A 50 tid-16进制> temp.jstack(pid 替换为查找到的pid数字,tid为其16进制)

打开txt,找到具体问题:使用命令top -p <pid> ,显示你的Java进程的内存情况,pid是你的java进程号,找到内存和cpu占用最高的线程pid,比如4977执行 System.out.println(Integer.toHexString(4977));8 得到 0x1371 ,此为线程id的十六进制执行 jstack 4977|grep -A 10 1371,得到线程堆栈信息中1371这个线程所在行的后面10行查看对应的堆栈信息找出可能存在问题的代码

2、总结

最后,总结下排查CPU故障的方法和技巧有哪些:

1、top命令:Linux命令。可以查看实时的CPU使用情况。也可以查看最近一段时间的CPU使用情况。

2、PS命令:Linux命令。强大的进程状态监控命令。可以查看进程以及进程中线程的当前CPU使用情况。属于当前状态的采样数据。

ps aux | grep xxx 中ps 是 process status 。 aux是 auxiliary: 辅助的

3、jstack:Java提供的命令。可以查看某个进程的当前线程栈运行情况。根据这个命令的输出可以定位某个进程的所有线程的当前运行状态、运行代码,以及是否死锁等等。

4、pstack:Linux命令。可以查看某个进程的当前线程栈运行情况。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。