常用性能调试手段

一、CPU负载过高

步骤一:

先利用top查找占用cpu最高的进程pid

 

步骤二:

 top -H -p pid

查看耗时较长、占用CPU资源较多的线程  找出其对应的tid

ps H -eo user,pid,ppid,tid,time,%cpu,cmd --sort=%cpu

 

步骤三:

通过jstack打印堆栈日志 查找对应线程的方法栈信息

需将上步骤找到的tid 转换成十六进制进行查找

jstack pid | grep `printf "%x\n" tid`

 

步骤三:

分析该线程的方法栈信息,找出代码逻辑是否异常。

 

 

二、内存OOM:

内存OOM是大家常见的问题,线上遇到OOM不要慌,别先记着重启,第一步先把内存堆栈打印出来
jmap -dump:live,format=b,file=

如果线上经常经常出现OOM问题也可以在JVM参数里加上-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=  在进程OOM时自动dump出内存堆栈

有了内存堆栈就好办了,给大家介绍个工具MAT,是我觉得最好用的内存分析工具http://www.eclipse.org/mat/

三、句柄泄露

句柄泄露,常见查看方法通过lsof -p 指令来查看 某个进程打开的句柄情况。

通过ulimit -a 可以查看默认的打开句柄数目限制。

你可能感兴趣的:(JVM,Linux,开发工具)