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.主要關注下面這兩個。點進去查看~

六、總結,大概就能找到問題所在的類,進而閱讀代碼稍微分析就能找出原因。

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