91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JVM中如何獲取OOM時的堆信息

發布時間:2021-05-25 09:30:45 來源:億速云 閱讀:206 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關JVM中如何獲取OOM時的堆信息的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

JVM的框架知識了解之后,實際的項目里發生了OOM異常的話,怎么獲取以及分析異常信息后怎么分析呢。

這里稍微做一下歸納。

第一步,首先通過下面兩個方法的任何一種,把發生OOM時的heap信息dump下來。

有兩個方法,通過設置可以把OOM時的dump信息獲取到:

1)方法1:在JVM的啟動參數里添加如下命令

-XX:+HeapDumpOnOutOfMemoryError

2)方法2:在JDK的安裝目錄下,找到bin目錄,然后雙擊執行"jvisualvm.exe"

執行程序之后,在視圖里可以看到正在執行的java程序和Java線程ID(PID:xxx)。

右鍵選中"在OOM時生成dump"。

第二步,執行如下代碼(本例使用方法1。如果使用方法2時需要先執行代碼,再在JvirtualVM中選中java程序設置OOM時生成dump):

代碼的意義是每一次創建一個1*1024*1024大小的int數組。在While中循環,引起Heap的OutOfMemory異常發生。

有一個小知識點共享下,map進行containsKey的處理時,key如果是javabean對象,判斷時使用的是對象的引用。所以每次判斷都是新的對象。

最好key的數據類型定義為值類型等(String作為key時使用常量字符串對String賦值如String key ="key",不要用String key = new String(“key”)的形式,這樣又變成了一個引用對象了)。

package com.chong.studyparalell.jvm.heap;

import java.util.HashMap;
import java.util.Map;

public class HeapLeakage {

static class MapKey{
Integer key;
MapKey(Integer key){
this.key = key;
}
}

public static void main(String []args){

Map<MapKey,Integer[]> localMap = new HashMap();
while(true){
for(int i = 0;i<10;i++){
try{
Thread.sleep(100);
}catch(Exception e){
e.printStackTrace();
}
MapKey mapKey = new MapKey(new Integer(i));
if(!localMap.containsKey(mapKey)){
localMap.put(mapKey, new Integer[1*1024*1024]);
}
}
}
}
}

日志如下:

JAVAGENT: call premain instrumentation for class SizeOf
java.lang.OutOfMemoryError: Java heap space
Dumping heap to java_pid31512.hprof ...
Heap dump file created [491663234 bytes in 0.930 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.chong.studyparalell.jvm.heap.HeapLeakage.main(HeapLeakage.java:38)

第三步,在項目的classpath目錄下確認"java_pidXXX.hprof"文件是否存在,正常情況下應該存在的。

在jvirtualvm中,點擊"文件"->"裝入"->選中上述hprof文件。

點擊“類”tab頁,通過"大小"排序,可以看出java.lang.Integer占用了99%以上的空間。

雙擊這一行,可以進入進去看到,各個Integer的具體內容。這里的目的是發生OOM,所以Integer的內容沒有設值,進去可以發現值都是null。

JVM中如何獲取OOM時的堆信息

JVM中如何獲取OOM時的堆信息

JVM中如何獲取OOM時的堆信息

那么實際的項目里,可以觀看發生問題線程里哪些對象的一直是活著的,并且size遠遠超出預期,重點分析這些可疑對象。推測的方向:是否在循環里大量的實例化對象,加載DB數據時一次加載了大量的數據,以及是否發生了內存泄露(如長生命周期的Map和Set,List中一直保存在大量的不再使用的對象引用。),以及靜態變量的使用等。

感謝各位的閱讀!關于“JVM中如何獲取OOM時的堆信息”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

普宁市| 陇川县| 聂荣县| 乐山市| 武冈市| 阿巴嘎旗| 富蕴县| 荣昌县| 蒙阴县| 贵南县| 永福县| 无极县| 义马市| 若羌县| 梁山县| 遵义市| 邢台县| 海宁市| 南丹县| 左贡县| 华阴市| 云林县| 新闻| 阿拉善盟| 辉南县| 吴江市| 瓦房店市| 饶阳县| 永济市| 天津市| 乌鲁木齐县| 青铜峡市| 合江县| 青浦区| 龙胜| 北海市| 宁武县| 那曲县| 涿州市| 双柏县| 巴彦县|