一、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=<filename>
如果线上经常经常出现OOM问题也可以在JVM参数里加上-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=<filePath> 在进程OOM时自动dump出内存堆栈
有了内存堆栈就好办了,给大家介绍个工具MAT,是我觉得最好用的内存分析工具http://www.eclipse.org/mat/
三、句柄泄露
句柄泄露,常见查看方法通过lsof -p <pid]> 指令来查看 某个进程打开的句柄情况。
通过ulimit -a 可以查看默认的打开句柄数目限制。