最近在做压力测试时,经常会出现内存溢出,总结一下排查步骤。
一、使用如下命令启动springboot工程
nohup java -jar -Dcom.sun.management.jmxremote.port=9000 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=10.20.23.xxx springbootxxx.jar
如:
说明:1、端口9000是自定义的端口,使用jvisualvm工具连接时需要用到;
2、10.20.23.xxx是springboot工程所在机器的ip;
3、springbootxxx.jar是工程的jar包。
等springboot工程启动成功后进行一下步骤。
二、双击jvisualvm.exe启动工具
三、远程——>右键,添加远程主机,输入ip地址,点击确定。
四、右键——添加JMX连接,输入9000端口,点击确定
五、双击JMX,点击抽样器——>点击内存
可以查看到有三个对象一直不停的增加,占用字节数一直在增加,经过分析代码中用到这三个对象地方的程序,
原因是高并发时,一直在不停的创建这三个对象,线程有大量堆积,并且这三个对象是非常大的对象,
解决办法是提高线程处理速度,避免创建大对象,该大对象可拆分其他小对象,使用其他方式解决线程流程。