网站首页 > 技术文章 正文
JVM 在遇到OOM(OutOfMemoryError)时生成Dump文件的三种方式,以及如何使用Eclips Memory Analyzer(MAT)插件进行堆内存分析。
方法一:
jmap -dump:format=b,file=文件名 [pid]
例如:
jmap -dump:format=b,file=/usr/local/base/02.hprof 12942
方法二:
让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件,需要配置一些信息
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/base
比如:我用eclipse配置一下。如下图所示:
方法三:
使用 jcmd 命令生成 dump 文件
jcmd <pid> GC.heap_dump d:\dump\heap.hprof
此方法没有经过博主的测试。
分析:
dump文件可以通过MemoryAnalyzer(MAT)分析查看,可以查看dump时对象数量,内存占用,线程情况等。
我们现在来安装一下eclipse MAT插件
打开Help -> new install software
名字可以随便起,插件地址:http://archive.eclipse.org/mat/1.3/update-site
剩下的就不做多的介绍了,安装完成后,我们来使用方法二来营造一个内存溢出的例子:
比如我写的Java内存溢出程序是:
import java.util.ArrayList; import java.util.List; public class OOM { public static void main(String[] args) { List<Object> list = new ArrayList<>(); // 创建n个1M大小的数组,耗尽内存 for (int i = 0; i < 10000; i++) { list.add(new byte[1024 * 1024]); } } }
控制台打印:
java.lang.OutOfMemoryError: Java heap space Dumping heap to /Users/sun/Documents/java_pid31782.hprof ... Heap dump file created [1943907998 bytes in 5.035 secs]
下边我们切换eclipse视图到 Memory Analysis,点击File -> Open Heap Dump,选择生成的hprof文件,如下图所示
打开完成后,如下所示:圈起来的这三个是常用的分析方式
现在我们点击 Leak Suspects 来看一下
点击 Histogram 来看一下
byte 数组创建的很大,溢出的问题一目了然。
- 上一篇: 面试被问到“零拷贝”!你真的理解吗?
- 下一篇: JVM优化:实战OutOfMemoryError异常
猜你喜欢
- 2024-10-12 SpringBoot执行jar报错java.lang.OutOfMemoryError_指定内存大小
- 2024-10-12 几种内存溢出(内存溢出类型)
- 2024-10-12 JVM优化:实战OutOfMemoryError异常
- 2024-10-12 线上故障排查全套路,总有一款适合你
- 2024-10-12 面试被问到“零拷贝”!你真的理解吗?
- 2024-10-12 面试夺命三问之《内存溢出和逃逸分析》
- 2024-10-12 阿里面试官:Exception和Error有什么区别?
- 2024-10-12 Eclipse运行大量文件异常OutOfMemoryError: GC overhead limit
- 2024-10-12 记一次线上内存异常排查实战(线上内存泄漏如何定位)
- 2024-10-12 jmeter内存溢出解决方法(jmeter 内存溢出)
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)