记录一次内存泄漏追踪(二)

简介: 记录一次内存泄漏追踪(二)

一 背景

项目上线后出现jvm内存过高的情况,并且运行一段时间后会出现内存溢出。

二 分析

上一篇我们通过将内存快照导入visualvm来查看具体的内存情况,但是遗憾的是并没有发现具体的问题,于是这次选择使用MAT工具来定位问题

  1. MAT简介

    memory analyzer是一个java监控分析工具,作为跨平台的开源工具,您不仅可以用它来分析内存问题,也可以用来监控整个 Java 应用程序的状态和行为。通过读取应用程序运行时由 Java 运行时环境生成的转储文件快照,Memory Analyzer 使您能够分析那些调试代码可能无法发现的复杂问题。

  2. 安装MAT

    下载链接
    https://www.eclipse.org/downloads/ 其实他有两种方式一个是直接下载安装包,一个是直接在eclipse中安装插件,由于我没有安装eclipse所以就直接下载了这个安装包,但是出现一个问题,网站只提供最新版本的安装包,没有以前版本,但是最新版本要求运行环境最低是java11,而我本地环境是java8,所以无法运行
    所以我又下载了我本机支持的其他版本的MAT。有需要可联系我
    下载好不需要安装直接点击直接可以运行

    image.png

  3. 启动并装入快照文件
![image.png](https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ac5162435f1549d9bcc46d3866f94827~tplv-k3u1fbpfcp-watermark.image)



![image.png](https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/401ea08431d0420ea601e7c8bd5c946d~tplv-k3u1fbpfcp-watermark.image)

MAT直接帮助我们分析出可能发生内存泄漏的点,查看第一个

![image.png](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/9541ad93ee3d430993c95ac4290f769d~tplv-k3u1fbpfcp-watermark.image)

这里有两个参数
Shallow Heap 以及 Retained Head,Shallow Heap就是对象本身的内存,Retained Head为对象及其引用所占用内存的总和
相关文章
|
存储 网络虚拟化 索引
【OSTEP】分页(Paging) | 页表中究竟有什么 | 页表存在哪 | 内存追踪
【OSTEP】分页(Paging) | 页表中究竟有什么 | 页表存在哪 | 内存追踪
575 0
|
9月前
|
缓存 运维 监控
Anolis OS深度集成运维利器 阿里云操作系统控制台上线
阿里云在百万服务器运维领域的丰富经验打造。
Anolis OS深度集成运维利器 阿里云操作系统控制台上线
|
9月前
|
缓存 运维 监控
追踪隐式资源,巧解内存难题!阿里云操作系统控制台上线
在云计算和容器化部署环境中,云原生容器化已成为行业标准,带来高效部署和成本控制优势的同时,也伴随新的挑战。通过操作系统内存全景功能,可一键扫描诊断,提升运维效率、降低成本,并显著提高系统稳定性。
|
Ubuntu 架构师 Linux
内存泄露专题(5)动态内存追踪大杀器:bcc
内存泄露专题(5)动态内存追踪大杀器:bcc
462 0
|
架构师 Unix Linux
内存泄露专题(4)mtrace内存追踪
内存泄露专题(4)mtrace内存追踪
508 0
|
存储 Java 容器
记录一次内存泄漏追踪(一)
记录一次内存泄漏追踪(一)
|
编解码 监控 NoSQL
疑案追踪:Spring Boot内存泄露排查记
疑案追踪:Spring Boot内存泄露排查记
1078 0
疑案追踪:Spring Boot内存泄露排查记
|
4月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
1425 0
|
4月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
414 1

热门文章

最新文章