OOM内存泄露模拟以及定位

一、场景:假如是线上环境,没有IDE,我们在本地用IDEA模拟测试。

二、代码:

package com.play.english.jdk;

import java.util.ArrayList;
import java.util.List;

/**
 * @author chaiqx on 2019/12/24
 */
public class Oom {


    private List list = new ArrayList<>(100000);

    public List getList() {
        return list;
    }

    public void setList(List list) {
        this.list = list;
    }

    public static void main(String[] args){
        List list = new ArrayList<>();
        while(true){
            list.add(new Oom());
        }
    }
}

三、设置JVM运行参数

OOM内存泄露模拟以及定位_第1张图片

-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=/Users/chaiqunxing/Desktop/java_error_in_idea.hprof

这参数的意义,可以自行搜索理解。

四:运行程序,果不其然,heap溢出,目前是在IDEA上直接能看到OOM,但是线上的话也许只会有OOM报警。

 

五、分析dump出来的hprof文件,利用jhat

jhat java_error_in_idea.hprof   

OOM内存泄露模拟以及定位_第2张图片

打开浏览器,端口号为7000.主要关注下面这两个。点进去查看~

OOM内存泄露模拟以及定位_第3张图片

OOM内存泄露模拟以及定位_第4张图片

六、总结,大概就能找到问题所在的类,进而阅读代码稍微分析就能找出原因。

你可能感兴趣的:(OOM内存泄露模拟以及定位)