浅谈eclipse memory analyzer的应用

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

https://blog.51cto.com/xcbeyond/6169966

https://cloud.tencent.com/developer/article/2109322

相关推荐
代码匠心6 分钟前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
zhougl99615 分钟前
Java内部类详解
java·开发语言
茶本无香21 分钟前
设计模式之十二:模板方法模式Spring应用与Java示例详解
java·设计模式·模板方法模式
灯火不休ᝰ1 小时前
[kotlin] 从Java到Kotlin:掌握基础语法差异的跃迁指南
java·kotlin·安卓
KoiHeng1 小时前
Java的文件知识与IO操作
java·开发语言
czlczl200209251 小时前
Spring Data Redis
java·redis·spring
知识即是力量ol1 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传
闻哥1 小时前
深入理解 Spring @Conditional 注解:原理与实战
java·jvm·后端·python·spring
煜磊1 小时前
MD5加盐值-注册与登录
java·开发语言
东东5161 小时前
校园求职招聘系统设计和实现 springboot +vue
java·vue.js·spring boot·求职招聘·毕设