亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JVM 心得 OOM時(shí)的堆信息獲取方法與分析

 更新時(shí)間:2017年10月17日 09:36:54   作者:Michael_Chong  
下面小編就為大家?guī)硪黄狫VM 心得 OOM時(shí)的堆信息獲取方法與分析。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

JVM的框架知識(shí)了解之后,實(shí)際的項(xiàng)目里發(fā)生了OOM異常的話,怎么獲取以及分析異常信息后怎么分析呢。

這里稍微做一下歸納。

第一步,首先通過下面兩個(gè)方法的任何一種,把發(fā)生OOM時(shí)的heap信息dump下來。

有兩個(gè)方法,通過設(shè)置可以把OOM時(shí)的dump信息獲取到:

1)方法1:在JVM的啟動(dòng)參數(shù)里添加如下命令

-XX:+HeapDumpOnOutOfMemoryError

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

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

右鍵選中"在OOM時(shí)生成dump"。

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

代碼的意義是每一次創(chuàng)建一個(gè)1*1024*1024大小的int數(shù)組。在While中循環(huán),引起Heap的OutOfMemory異常發(fā)生。

有一個(gè)小知識(shí)點(diǎn)共享下,map進(jìn)行containsKey的處理時(shí),key如果是javabean對(duì)象,判斷時(shí)使用的是對(duì)象的引用。所以每次判斷都是新的對(duì)象。

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

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)

第三步,在項(xiàng)目的classpath目錄下確認(rèn)"java_pidXXX.hprof"文件是否存在,正常情況下應(yīng)該存在的。

在jvirtualvm中,點(diǎn)擊"文件"->"裝入"->選中上述hprof文件。

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

雙擊這一行,可以進(jìn)入進(jìn)去看到,各個(gè)Integer的具體內(nèi)容。這里的目的是發(fā)生OOM,所以Integer的內(nèi)容沒有設(shè)值,進(jìn)去可以發(fā)現(xiàn)值都是null。

那么實(shí)際的項(xiàng)目里,可以觀看發(fā)生問題線程里哪些對(duì)象的一直是活著的,并且size遠(yuǎn)遠(yuǎn)超出預(yù)期,重點(diǎn)分析這些可疑對(duì)象。推測(cè)的方向:是否在循環(huán)里大量的實(shí)例化對(duì)象,加載DB數(shù)據(jù)時(shí)一次加載了大量的數(shù)據(jù),以及是否發(fā)生了內(nèi)存泄露(如長(zhǎng)生命周期的Map和Set,List中一直保存在大量的不再使用的對(duì)象引用。),以及靜態(tài)變量的使用等。

后記:

通過這幾天的JVM復(fù)習(xí),以及OOM發(fā)生時(shí)的dump分析,再次做項(xiàng)目時(shí),頭腦會(huì)更清晰一些。^-^
JVM告一段落了,接下來會(huì)發(fā)一些跟SpringBoot和Redis相關(guān)的學(xué)習(xí)心得。

相關(guān)文章

  • Java中的接口回調(diào)實(shí)例

    Java中的接口回調(diào)實(shí)例

    今天小編就為大家分享一篇關(guān)于Java中的接口回調(diào)實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Java多線程基礎(chǔ)——Lock類

    Java多線程基礎(chǔ)——Lock類

    Lock類是Java類來提供的功能,豐富的api使得Lock類的同步功能比synchronized的同步更強(qiáng)大。本文對(duì)此進(jìn)行詳細(xì)介紹,下面跟著小編一起來看下吧
    2017-02-02
  • SpringBoot執(zhí)行異步任務(wù)Async介紹

    SpringBoot執(zhí)行異步任務(wù)Async介紹

    這篇文章主要為大家介紹了SpringBoot執(zhí)行異步任務(wù)Async示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • IDEA上實(shí)現(xiàn)JDBC編程的方法步驟

    IDEA上實(shí)現(xiàn)JDBC編程的方法步驟

    本文主要介紹了IDEA上實(shí)現(xiàn)JDBC編程的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • spring-shiro權(quán)限控制realm實(shí)戰(zhàn)教程

    spring-shiro權(quán)限控制realm實(shí)戰(zhàn)教程

    這篇文章主要介紹了spring-shiro權(quán)限控制realm實(shí)戰(zhàn)教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java ArrayList擴(kuò)容機(jī)制原理深入分析

    Java ArrayList擴(kuò)容機(jī)制原理深入分析

    在Java中,ArrayList是最常用的集合之一。它是一種容器,它的內(nèi)部定義了一個(gè)Object類型的數(shù)組elementData,因此可用于存儲(chǔ)任意類型的數(shù)據(jù)。我們知道,數(shù)組是長(zhǎng)度恒定的。而ArrayList相當(dāng)于是一個(gè)長(zhǎng)度可變的動(dòng)態(tài)數(shù)組,一起來看看的它的擴(kuò)容機(jī)制
    2023-02-02
  • 淺談Spring解決循環(huán)依賴的三種方式

    淺談Spring解決循環(huán)依賴的三種方式

    本篇文章主要介紹了淺談Spring循環(huán)依賴的三種方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • spring boot中使用@Async實(shí)現(xiàn)異步調(diào)用任務(wù)

    spring boot中使用@Async實(shí)現(xiàn)異步調(diào)用任務(wù)

    本篇文章主要介紹了spring boot中使用@Async實(shí)現(xiàn)異步調(diào)用任務(wù),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • 基于Java網(wǎng)絡(luò)編程和多線程的多對(duì)多聊天系統(tǒng)

    基于Java網(wǎng)絡(luò)編程和多線程的多對(duì)多聊天系統(tǒng)

    這篇文章主要介紹了基于Java網(wǎng)絡(luò)編程和多線程的多對(duì)多聊天系統(tǒng),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java網(wǎng)絡(luò)編程的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法

    MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法

    MyBatis 是一個(gè)可以自定義SQL、存儲(chǔ)過程和高級(jí)映射的持久層框架。這篇文章主要介紹了MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法,需要的朋友可以參考下
    2017-04-04

最新評(píng)論