一般项目如何排查JVM问题

对于还在正常运行的系统:
1.可以使用jmap来查看jvm中各个区域使用情况
2.可以使用jstack来查看线程运行情况,比如那些线程阻塞,是否出现了死锁
3.可以通过jstat命令来查看垃圾回收情况,特别是fullgc,如果发现fullgc比较频繁,那么就得进项调优了
4.通过各个命令的结果,或者jvisualvm等工具来进行分析
5.首先,初步猜测频繁fullgc的原因,如果频繁发生fullgc但是有没有出现内存溢出,那么表示fullgc实际上是回收了很多对象了,所以这些对象最好能在younggc过程直接回收掉,避免这些对象进入老年代,对于这种情况,就要考虑这些存活时间不长的对象是不是比较大,导致年轻代放不下,直接进入老年代,尝试加大年轻代大小,如果改完之后,fullgc减少,则证明修改有效
6.同时,还可以找到占用CPU最多的线程,定位具体方法,优化这个方法的执行,看看是否能避免某些对象的创建,从而节省内存
对于已经发生了oom的系统:
1.一般生产系统都会有设置当时系统发生了OOM时,生成当时的dump文件(-XX:HeapDumpOnOutOfMenoryError -XX:HeapDumpPath=/usr/local/base)
2.我们可以利用jsisualvm等工具来分析dump文件
3.根据dump文件找到异常的实例对象,和异常的线程(占用CPU高),定位具体代码
4.然后在进行详细分析和测试

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值