常用性能调试手段

5 篇文章 0 订阅

一、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 可以查看默认的打开句柄数目限制。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值