码迷,mamicode.com
首页 > 其他好文 > 详细

JVM笔记1-内存溢出分析问题与解决

时间:2018-02-11 19:51:00      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:准备   nload   static   rgs   因此   bsp   nis   col   地方   

假设我们项目中JVM内存溢出了,大项目中上百万行代码,是很难定位的。因此我们需要借用一个Memory Analyzer工具,

官网地址为:http://www.eclipse.org/downloads/download.php?file=/mat/1.7/rcp/MemoryAnalyzer-1.7.0.20170613-win32.win32.x86_64.zip&mirror_id=1142,如下图,点击click here即可下载:

技术分享图片

 

准备工作做好后,看一下代码模拟内存溢出:

先建立一个空类,如下:

public class Demo {

}

再建立一个主类:

public class Main {
    public static void main(String[] args) {
        List<Demo> demoList = new ArrayList<>();
        while (true){
            demoList.add(new Demo());
        }
    }
}

看运行如下:

技术分享图片

可以观察到运行内存不断升高,直到到达一个默认的限定值。可以看出图中报出的是内存溢出错误。那么我们如何解决,和定位问题呢?这就需要上述的工具和虚拟机调参一起定位问题所在了。如下:

技术分享图片

快照就保存在我们项目中来,如下图:

技术分享图片

可以看到.hprof后缀的快照文件,直接打开是一片乱码来的,需要上述的分析工具打开,如下:

技术分享图片

 

 然后打开上面的快照文件,步骤:file -- open heap Dump

技术分享图片

点击finish 即可,如下:

技术分享图片

如图,我们设置的堆内存一共就20M,但是那片区域就占用15.9M,所以该片区域很有可能出现问题。

详细信息如下:

技术分享图片

各个信息如下图:

技术分享图片

 

点击占用最多的那一行,如下:

技术分享图片

可以看到问题出现在Demo这个类,可以看到new了很多遍这个类,所以可以定位到该类创建的地方,进行审查。发现无限创建类该类,如下图:
技术分享图片

 

JVM笔记1-内存溢出分析问题与解决

标签:准备   nload   static   rgs   因此   bsp   nis   col   地方   

原文地址:https://www.cnblogs.com/huangjuncong/p/8442674.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!