2019独角兽企业重金招聘Python工程师标准>>>
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]的线程,查看堆栈信息
一般情况下,这三部就能找到消耗资源的线程的情况,看到该线程的运行堆栈信息。