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