1. 背景
对于一个应用服务,在持续运行几个月的情况下,处理了大量的请求,如果代码存在问题,那么服务器java应用内存溢出OOM的现象。此类情况不会在平时的测试中发现,是比较隐匿的。因此,在出现内存溢出之后,如何分析显得至关重要,eclipse memory analyzer,
2. 解决方法
问题:服务器java应用内存溢出。
文件:java_pid990.hprof
大小:1.88G
hprof 文件 是 Java 的 内存快照文件(Heap Profile 的缩写),格式为
java_pid*.hprof
用于分析 OOM: OutOfMemoryError(堆)内存不足错误
是 JVM 设置 -XX:+HeapDumpOnOutOfMemoryError 参数时打印的内容
可以用JDK自带Java Visual VM工具查看
也可以本文所介绍的Memory Analyzer工具查看
1、下载工具Memory Analyzer
https://projects.eclipse.org/projects/tools.mat/downloads
2、打开hprof文件
3、选择分析动作
勾第一个,单击确认后会自动出来Leak Suspects(问题原因猜疑结果),这里较Java Visual VM工具更加便捷。
Leak Suspects 能基本定出问题相关的类及方法
位置:Overview-->Reports-->Leak Suspects
点当前Leak Suspects页面下面的Thread Detail, Thead Stack中有更精准的方法:
另外,还可以看Top Consumers,Overview-->Actions-->Top Consumers
另外,还可以看Biggest Objects,点第一行-->Java Basics-->Thread Overview and Stacks
参考:
https://blog.csdn.net/jjk_02027/article/details/135024648
https://blog.csdn.net/qq_35485206/article/details/144623337
https://www.cnblogs.com/letcafe/p/mat.html