线上排除问题流程

Posted wx60f90dec4c4e0

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线上排除问题流程相关的知识,希望对你有一定的参考价值。

 排查CPU占用高的代码


1. 编写代码

public class Demo 
public static void main(String[] args)
System.err.println("测试开始");
while(true)



编写一个死循环代码。

执行此代码

2.找到CPU占用率高的进程

我们可以观察到top查看cpu占用高的进程。

线上排除问题流程_java


找到cpu占用率为 100%的线程。

3.导出执行堆栈

 jstack 3417 >> java.txt

3417 为进程号


4.查占用率高的线程

top -H -p 3417


线上排除问题流程_堆栈_02


 找到线程号 为3418 

5.转换16进制

 printf "%x\\n" 3418

执行后 为  d5a


6.在之前导出的堆栈文件查找

查找d5a

"main" #1 prio=5 os_prio=0 tid=0x00007f3ef804b000 nid=0xd5a runnable [0x00007f3efef94000]
java.lang.Thread.State: RUNNABLE
at Demo.main(Demo.java:4)

发现是我们的Demo第四行出了问题,这样找回源码,去掉死循环即可。


以上是关于线上排除问题流程的主要内容,如果未能解决你的问题,请参考以下文章

线上Java程序导致服务器CPU占用率过高的问题排除过程

线上Java程序导致服务器CPU占用率过高的问题排除过程

记一次线上Java程序导致服务器CPU占用率过高的问题排除过程

记一次线上Java程序导致服务器CPU占用率过高的问题排除过程

记一次线上Java程序导致服务器CPU占用率过高的问题排除过程

制度&罚则--线上疑似问题处理流程