`
dannyhz
  • 浏览: 401231 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

如何查内存泄漏的好文章

 
阅读更多
http://www.cnblogs.com/nsw2018/p/6361666.html

最近一段时间一直在研究热部署,热部署中涉及到一个比较头痛的问题就是查内存泄露(Memory Leak),于是乎在研究热部署的过程中,干的最多的一件事就是查内存泄露。
       查内存泄露,最开始尝试用JDK自身的工具去解决这件事,通过jstat和jmap,去发现是否有内存泄露,当判断有内存泄露存在时,试图要去寻找内存泄露的点时,发现单纯使用JDK自身提供的工具没有什么很好的办法,我尝试过Jhat,发现查起来太困难了,后来对比网上推荐的工具,我选择了MAT(Memory Analyzer Tool)。
       MAT是一个eclipse的插件,上手起来比较快。它能够快速的分析dump文件,可以直观的看到各个对象在内存占用的量大小,以及类实例的数量,对象之间的引用关系,找出对象的GC Roots相关的信息,此外还能生成内存泄露报表,疑似泄露大对象的报表等等。

安装MAT
可以选择eclipse插件的方式安装
http://download.eclipse.org/mat/1.3/update-site/
也可以选择单独MAT程序下载安装
http://www.eclipse.org/mat/downloads.php
使用MAT查内存溢出
生成dump
生成dump文件,可以直接用 jmap -dump:format=b,file=xxx.bin ${pid}的方式
也可以直接用MAT生成,File-》Acquire Heap Dump -》选择要dump的java进程-》finish就可以了

生成完dump后,可以用MAT打开 dump(如果是MAT dump完后会自动进行解析),File-》Open Heap Dump 对dump文件进行解析,最终生成一个Overview视图,这个图是一个概要图,显示了一些统计信息,包括整个size大小,class数量,以及对象 的数量,同时还将生成一个大对象的top图,并线显示大对象占用内存的百分比。
类似:size:2.2MB Classes:3.3k Objects:50.1k ClassLoader:84 Unreachable Objects Histogram

找出溢出源
Histogram视图(截图里柱子那个,边上的是Dominator Tree ):列出每個class产生了多少個实例,以及占有多大内存,所占百分比

可以很容易找出站内存最多的几个类,根据Retained Heap排序,找出前几个。
可以分不同的维度来查看类的Histogram视图,Group by class、Group by superclass、Group by class  loader、Group by package
只要有溢出,时间久了,溢出类的实例数量或者其占有的内存会越来越多,排名也就越来越前,通过多次对比不同时间点下的Histogram图对比就能很容易把溢出类找出来。



Dominator Tree(支配树):列出每个对象(Object instance)与其引用关系的树状结构,还包含了占有多大内存,所占百分比
可以很容易的找出占用内存最多的几个对象,根据Percentage(百分比)来排序。
可以分不同维度来查看对象的Dominator Tree视图,Group by class、Group by class  loader、Group by package
和Histogram类似,时间久了,通过多次对比也可以把溢出对象找出来,Dominator Tree和Histogram的区别是站的角度不一样,Histogram是站在类的角度上去看,Dominator Tree是站的对象实例的角度上看,Dominator Tree可以更方便的看出其引用关系。



定位溢出的原因
通过Path to GC Roots或者Merge Shortest Paths to GC Roots



通 过Histogram视图或者Dominator Tree视图,找到疑似溢出的对象或者类后,选择Path to GC Roots或者Merge Shortest Paths to GC Roots,这里有很多过滤选项,一般来讲可以选择exclude all plantom/weak/soft etc. references。这样就排除了虚引用、弱引用、以及软引用,剩下的就是强引用。从GC上说,除了强引用外,其他的引用在JVM需要的情况下是都可以 被GC掉的,如果一个对象始终无法被GC,就是因为强引用的存在,从而导致在GC的过程中一直得不到回收,因此就内存溢出了。
接下来就需要直接定位具体的代码,看看如何释放这些不该存在的对象,比如是否被cache住了,还是其他什么原因。
找到原因,清理干净后,再对照之前的操作,看看对象是否还再持续增长,如果不在,那就说明这个溢出点被成功的堵住了。
最后用jstat跟踪一段时间,看看Old和Perm区的内存是否最终稳定在一个范围内,如果长时间稳定在一个范围,那溢出的问题就解决了,如果还再继续增长,那继续用上述方法,看看是否存在其他代码的溢出点,继续找出,将其堵住。





此外通过list objects或show objects by class也可以达到类似的效果,不过没看GC Roots的方式直观,这里就不细说了。
list objects -- with outgoing references : 查看这个对象持有的外部对象引用。
list objects -- with incoming references : 查看这个对象被哪些外部对象引用。
show objects by class  --  with outgoing references :查看这个对象类型持有的外部对象引用
show objects by class  --  with incoming references :查看这个对象类型被哪些外部对象引用  
分享到:
评论

相关推荐

    Android App调试内存泄露之Cursor.zip

    在Android应用开发中,内存泄漏是一个非常重要的问题,它会导致应用程序性能下降,甚至崩溃。本话题将深入探讨如何针对特定的内存泄漏问题——Cursor泄漏进行调试。Cursor对象是Android数据库操作中的关键组件,用于...

    内存状态查看工具(MemoryViewer)

    3. **内存泄漏检测**:查找可能存在的内存泄漏问题,即程序错误导致无法释放的内存。 4. **性能图表**:通过图表形式展示内存使用趋势,便于用户识别系统性能瓶颈。 5. **报告生成**:提供详细的内存使用报告,便于...

    Sun 用 swing写的内存监控小工具,很强

    4. 解析和处理这些数据,可能包括计算利用率、检查内存泄漏迹象等。 5. 更新GUI组件以显示最新的内存使用信息,可能包括图表、百分比或详细的内存区域使用情况。 6. 提供交互式功能,如触发垃圾收集或设置内存阈值...

    C库函数查询

    理解这些函数对于避免内存泄漏至关重要。 5. 格式化和类型转换:`printf`和`scanf`系列函数可以进行格式化输入输出,`atoi`、`atof`和`strtol`将字符串转换为整数、浮点数和长整数。 6. 时间和日期处理:`time.h`...

    医疗床位查询小程序.rar

    利用Android Studio的调试工具进行性能分析和内存泄漏检测。 9. 发布与更新:发布至Google Play或其他应用市场,同时考虑版本升级和用户反馈机制,持续优化和改进产品。 总结来说,医疗床位查询小程序的开发融合了...

    windows存储管理.doc

    通过监控工具,我们可以分析系统内存使用情况,找出可能的内存泄漏,从而提高系统的稳定性和效率。 总结,Windows存储管理涉及内存的物理和虚拟层面,以及文件的存储和复制。理解这些基本概念和操作,有助于我们更...

    C#语言参考-入门及使用查询较好

    5. **自动内存管理**:C#使用垃圾回收机制来自动管理内存,程序员无需手动释放内存,这降低了内存泄漏的风险。 6. **表达式**:表达式是C#代码中计算的部分,它们可以是运算符、函数调用等,最终产生一个值。 7. *...

    【Android 文件管理】分区存储 ( 创建与查询图片文件 )

    - 及时释放Bitmap内存,避免内存泄漏。 - 使用异步操作处理大文件,防止阻塞主线程。 - 请求权限时,遵循最小权限原则,只申请必要的权限。 综上所述,Android的分区存储为开发者提供了安全、有序的文件管理方式...

    Delphi 编译运行错误中文速查

    2. **资源管理**:确保正确地创建和释放对象,避免内存泄漏。在使用后及时释放动态分配的内存和资源,如数据库连接、文件句柄等。 3. **输入验证**:对用户输入或程序中的数据进行检查,确保它们符合预期的格式和...

    delphi常用技术文章集锦

    Delphi使用引用计数进行自动内存管理,但开发者仍需关注内存泄漏和资源释放。异常处理则通过try...except...finally结构实现,用于捕获和处理运行时错误。 7. **数据库访问**: Delphi的ADO(ActiveX Data ...

    检测codeigniter脚本消耗内存情况的方法

    这个方法可以帮助开发者监控代码执行过程中内存的增长,从而识别可能导致内存泄漏或资源消耗过大的部分。 相关伪变量 `{memory_usage}` 提供了一种模板化的方式来显示内存使用情况,这在模板引擎如Smarty中可能会...

    查询IE Cookie C++

    7. **释放资源**:在完成所有操作后,记得释放所有创建的对象,调用`Release`方法以防止内存泄漏。 在实际应用中,你可能还会遇到一些挑战,比如处理Unicode编码、错误处理以及优化性能。例如,对于非ASCII字符,...

    QTreeWidget的增与删的基本的操作

    - 谨慎处理删除操作,避免产生内存泄漏。删除项后,确保释放了内存,或者将其设置为nullptr。 通过以上介绍,你应该对QTreeWidget的增删操作有了清晰的理解。在实际编程中,根据需求灵活运用这些方法,可以构建出...

    Java优化策略在铁路互联网售票系统中的应用研究.pdf

    同时,优化新生代和老年代的垃圾回收策略,确保内存高效利用且避免内存泄漏。 - 类加载机制:理解和优化类加载机制,避免类的频繁加载和卸载,从而减少系统开销。 3. 测试与分析: - 文章以余票查询业务系统模块...

    学生管理系统VS2010

    了解如何合理分配和释放内存对于避免内存泄漏至关重要。在实现学生管理系统时,我们需要确保正确使用new和delete,避免内存泄露。 最后,编程规范是提高代码可读性和可维护性的基石。遵循一定的命名规则、注释规范...

    Android 中文API以及精品文章

    - 内存管理:避免内存泄漏,使用LeakCanary检测。 6. **Android测试**: - 单元测试:JUnit和Mockito进行代码单元测试。 - UI测试:Espresso进行界面交互测试。 - 性能测试: MonkeyRunner和Systrace进行压力和...

    利用itext操作pdf从数据库导出大量数据

    本篇文章将详细介绍如何利用iText库操作PDF,从数据库中导出大量数据。 首先,我们需要理解iText的基本概念和功能。iText提供了丰富的API,可以用于创建新的PDF文档、添加文本、图像、表格、链接等元素,以及对已有...

    LAMP系统性能调优(apache+php+mysql)参考.pdf

    5. MaxRequestsPerChild:每个子进程处理的最大请求数,超过后会重启,减少内存泄漏风险。 对于Worker MPM,除了上述选项外,还需要关注线程的数量和进程的配置,以达到最佳性能和资源利用。 PHP的性能优化通常...

    ASP源码—CMS ASP文章管理系统GBK.zip

    4. **性能优化**:合理设计数据库索引,避免内存泄漏,优化脚本执行效率,提升系统响应速度。 5. **版本控制**:使用Git等工具进行源代码管理,便于团队协作和代码版本追踪。 总结来说,"ASP源码—CMS ASP文章管理...

    好的程序结构是这样的

    这一步骤看似简单,却能有效预防内存泄漏,保持应用的稳定运行。 三、逻辑独立:模块化设计原则 模块化是提高代码可读性和可维护性的基石。对于具有独立逻辑的程序块,应当封装为单独的方法。例如,注册流程中检查...

Global site tag (gtag.js) - Google Analytics