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<Oom> list = new ArrayList<>(100000);

    public List<Oom> getList() {
        return list;
    }

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

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

三、设置JVM运行参数

-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   

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

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章