欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

java内存溢出(OutOfMemoryError)————dump文件以及内存分析

程序员文章站 2022-07-15 14:51:00
...

java内存溢出(OutOfMemoryError)————dump文件以及内存分析


当程序出现以下错误时:

  1. java.lang.OutOfMemoryError: Java heap space
  2. java.lang.OutOfMemoryError: Java metaspace
  3. java.lang.OutOfMemoryError: Java Perm Gen

1.dump内存快照

1.1.测试环境(程序启动)

##启动时加上下面两个参数

#1.开启程序出现内存溢出错误时自动dump出内存快照文件,后缀:.hprof  强烈建议无论何种环境,加上此参数
-XX:+HeapDumpOnOutOfMemoryError 
#2.指定出内存快照文件的路径
-XX:HeapDumpPath=./

1.2.生产环境(程序运行时)

##如果生产环境中启动时未加上-XX:+HeapDumpOnOutOfMemoryError参数,如果想在不关闭程序的情况下dump内存快照文件

#1.获取java程序的pid,使用jps命令获取pid
jps
#2.使用jmap命令dump文件到指定路径:filepath:文件路径 xxx.hprof pid:java程序的pid
#示例:jmap -dump:live,format=b,file=./test.hprof 42156
jmap -dump:live,format=b,file=<filepath> <pid>

2.分析快照文件

  1. 使用Jprofiler(收费,功能强大)
  2. 使用MAT(MemoryAnalyzerTool,免费)

3.测试

3.1.程序(运行时)

public static void main(String[] args) throws InterruptedException {
        Map<String,Object> memMap=new HashMap<>();
        for (int i = 0; i <128 ; i++) {
            byte [] b=new byte[1024*1024];
            memMap.put("k"+i,b);
            //模拟程序运行中
            Thread.sleep(1000);
        }
    }

//启动参数: -Xmx128m -Xms128m

3.2.jmap生成内存快照文件

#1.获取java程序的pid,使用jps命令获取pid
jps
#2.使用jmap命令dump文件到指定路径:filepath:文件路径 xxx.hprof pid:java程序的pid
#示例:jmap -dump:live,format=b,file=./test.hprof 42156
jmap -dump:live,format=b,file=<filepath> <pid>

3.3.MAT分析

3.3.1.下载

路径:https://www.eclipse.org/mat/downloads.php

3.3.2.使用

1.打开文件

java内存溢出(OutOfMemoryError)————dump文件以及内存分析
java内存溢出(OutOfMemoryError)————dump文件以及内存分析

2.内存溢出的可能原因
java内存溢出(OutOfMemoryError)————dump文件以及内存分析

3.java对象引用分析(树形)

java内存溢出(OutOfMemoryError)————dump文件以及内存分析
java内存溢出(OutOfMemoryError)————dump文件以及内存分析