一次关于Netty+Gson造成内存泄露 Memory Analysis分析

本文通过jmap导出内存日志,使用Memory Analysis工具分析,发现9个NIO线程引用大量对象导致内存占用高。进一步追踪发现,线程局部变量持有Gson序列化的业务数据,引发内存泄露。建议对所有使用Gson的地方进行排查,以解决此问题。内存泄露分析依赖于经验、分析能力和系统理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://just2do.iteye.com/admin/blogs/2181293  之前写过一篇使用java自带工具去分析内存泄露问题,今天使用 Memory Analysis重做一次,看看高级工具是否能一针见血地更方便地发现问题。

 

第一步:

 

jmap -dump:format b,file=abc.hprof <pid>

dump出内存日志

 

 第二部:

 

使用Memory Analysis打开abc.hpro

 

 

 

从上图可以看到,泄露内存部分占用了快500M了。而整个应用也就分配了500M。

 

 

 

从直方图可以看到,前五位对象已经占用了快300M的内存。所以我们焦点放在这里,去排查内存泄露点。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值