java线上问题排查 cpu 100%、内存泄漏排查

线上我们经常遇到 cpu 100%或者内存泄漏问题,面对这些常见的问题我们如何排查,快速定位问题?

1. cpu 100% 问题排查

1.首先找到cpu占用率较高的java进程号
主要使用命令: top -c 显示运行中进程列表信息,并且使用shift+p 使得列表按照cpu使用率进行排序
在这里插入图片描述
2.根据进程号查找到 cpu 占有率较高的线程号,具体使用命令
top -Hp pid 并且使用shift+p 使得列表按照cpu使用率进行排序
在这里插入图片描述
3.查看堆栈,定位线程在干嘛,定位对应代码
首先,将线程PID转化为16进制。
使用命令
printf ‘%x/n’ pid
在这里插入图片描述

4.利用jstack生成虚拟机中所有线程快照文件
jstack -l 2227 > /tmp/2227.stack

5.通过线程快照文件分析并且找到存在问题代码位置
cat /tmp/2227.stack | grep ‘37d0’ -C 5

2.内存溢出

1、 内存溢出的原因是什么?
内存溢出是由于没被引用的对象(垃圾)过多造成JVM没有及时回收,造成的内存溢出。如果出现这种现象可行代码排查:

一)是否应用中的类中和引用变量过多使用了Static修饰 如public staitc Student s;在类中的属性中使用 static修饰的最好只用基本类型或字符串。如public static int i = 0; //public static String str;

二)是否 应用 中使用了大量的递归或无限递归(递归中用到了大量的建新的对象)

三)是否App中使用了大量循环或死循环(循环中用到了大量的新建的对象)

四)检查 应用 中是否使用了向数据库查询所有记录的方法。即一次性全部查询的方法,如果数据量超过10万多条了,就可能会造成内存溢出。所以在查询时应采用“分页查询”。

五)检查是否有数组,List,Map中存放的是对象的引用而不是对象,因为这些引用会让对应的对象不能被释放。会大量存储在内存中。

六)检查是否使用了“非字面量字符串进行+”的操作。因为String类的内容是不可变的,每次运行"+"就会产生新的对象,如果过多会造成新String对象过多,从而导致JVM没有及时回收而出现内存溢出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值