浅谈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

相关推荐
SamDeepThinking8 分钟前
第1篇-开篇词:几亿用户规模下,我们是怎么做C端高并发商品系统的
java·后端·架构
weisian1519 分钟前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao10 分钟前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
冷小鱼17 分钟前
MyBatis 与 MyBatis-Plus:从入门到精通的完整指南
java·tomcat·mybatis
DolphinScheduler社区27 分钟前
DolphinScheduler 3.3.2 如何调用 DataX 3.0 + SeaTunnel 2.3.12?附 Demo演示!
java·spark·apache·海豚调度·大数据工作流调度
亦暖筑序1 小时前
AI 客服系统安全加固:JWT 鉴权 + Bucket4j 三层限流
java·架构
xhuiting1 小时前
项目技术总结
java
某人辛木1 小时前
JDK安装配置
java·开发语言
counting money1 小时前
Spring框架基础(依赖注入-全注解形式)
java·数据库·spring
小王师傅661 小时前
【Java结构化梳理】泛型-初步了解-下
java·开发语言