性能測試之JVM的故障排查-堆內存泄漏

JVM異常說明(超鏈接) 一文中已介紹了磅氨,JVM每個運行時區(qū)域——程序計數(shù)器 、Java虛擬機棧冒窍、本地方法棧、Java堆豺鼻、方法區(qū)综液、直接內存發(fā)生OutOfMemoryError的不同原因和不同錯誤信息。


Java堆儒飒,是線程共享內存谬莹,幾乎所有的對象實例以及數(shù)組都應在堆上分配。如下堆的內存泄漏錯誤也是我們常常遇到的

java.lang.OutOfMemoryError: Java heap space

工具VisualVM的介紹

使用VisualVM排查堆內存泄漏

  1. 查看GC

    老年代Old和年輕代Eden區(qū)在不斷增長,幾乎已滿附帽。Full GC次數(shù)增多埠戳,內存沒有有效釋放。這是內存泄漏的明顯跡象
  1. 查看系統(tǒng)日志

    已有Full GC的日志蕉扮,緊接著開始報錯OutOfMemoryError

  2. 分析Heap Dump

    導入Dump后整胃,可以看到占用內存最大的類和實例——OOMMonitor類中的placeholder變量



  1. 示例代碼
public class OOMMonitor {
    static class OOMobject {
        public byte[] placeholder = new byte[64 * 1024];
    }
    public static void fillHeap(int num) throws InterruptedException {
        List<OOMobject> list = new ArrayList<OOMobject>();
        for (int i = 0; i < num; i++) {
            //稍作延時,令監(jiān)視曲線的變化更加明顯
            Thread.sleep(500);
            list.add(new OOMobject());
            System.out.println("Hello World");
        }
    }
    public static void main(String[] args) throws Exception {
        fillHeap(1000);
    }
}
  1. 示例VM配置參數(shù)
-Xms20m
-Xmx20m
-verbose:gc
-XX:+PrintGCDetails
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=/data/heapdump.hprof

公號:大道測試

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市喳钟,隨后出現(xiàn)的幾起案子屁使,更是在濱河造成了極大的恐慌,老刑警劉巖奔则,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛮寂,死亡現(xiàn)場離奇詭異,居然都是意外死亡应狱,警方通過查閱死者的電腦和手機共郭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來疾呻,“玉大人,你說我怎么就攤上這事写半“段希” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵叠蝇,是天一觀的道長璃岳。 經常有香客問我,道長悔捶,這世上最難降的妖魔是什么铃慷? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮蜕该,結果婚禮上犁柜,老公的妹妹穿的比我還像新娘。我一直安慰自己堂淡,他們只是感情好馋缅,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著绢淀,像睡著了一般萤悴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上皆的,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天覆履,我揣著相機與錄音,去河邊找鬼。 笑死硝全,一個胖子當著我的面吹牛怪嫌,可吹牛的內容都是我干的。 我是一名探鬼主播柳沙,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼岩灭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赂鲤?” 一聲冷哼從身側響起噪径,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎数初,沒想到半個月后找爱,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡泡孩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年车摄,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片仑鸥。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡吮播,死狀恐怖,靈堂內的尸體忽然破棺而出眼俊,到底是詐尸還是另有隱情意狠,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布疮胖,位于F島的核電站环戈,受9級特大地震影響,放射性物質發(fā)生泄漏澎灸。R本人自食惡果不足惜院塞,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望性昭。 院中可真熱鬧拦止,春花似錦、人聲如沸巩梢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽括蝠。三九已至鞠抑,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間忌警,已是汗流浹背搁拙。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工秒梳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人箕速。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓酪碘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親盐茎。 傳聞我的和親對象是個殘疾皇子兴垦,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345