查找消耗cpu的操作

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

1,首先 登到线上机器上去,top命令,查看当前机器的负载,查看当前哪个进程在消耗资源。

top

找到CPU或者内存占用过高的那个进程。发现有一个进程,CPU 居高不下,保留进程id

2,top命令,继续跟踪该进程里的所有线程,找到占用CPU过高的线程。

top -Hp [进程ID]

3,找到线程ID,正在消耗CPU,把线程ID转换为16进制,执行 jstack 命令保留当前java进程堆栈

jstack [进程ID] > jstack_01

然后,在该文件jstack_01 里搜索 线程id为[16进制的线程id]的线程,查看堆栈信息

一般情况下,这三部就能找到消耗资源的线程的情况,看到该线程的运行堆栈信息。

转载于:https://my.oschina.net/u/2000675/blog/3059127

你可能感兴趣的:(查找消耗cpu的操作)