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

x33g5p2x  于2021-10-29 转载在 Linux  
字(0.8k)|赞(0)|评价(0)|浏览(563)

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命令。可以查看某个进程的当前线程栈运行情况。

相关文章