内存泄漏排查

  1. 查看进程ID:

    jps
    

    例:
    请添加图片描述

  2. 查看堆内存占用及GC情况,每5秒刷新一次:

    jstat -gcutil 17488 5000
    

    例:
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kH7M0sD4-1665243214720)(images/image-20221008214750836-1665236875666-3.png)]
    发现问题: 老年代内存使用率一直接近100%,Full GC次数一直增长

  3. 排除堆内存过小的可能:增大Xmx参数值

    查看命令行初始堆大小及最大堆大小:

    java -XX:+PrintCommandLineFlags -version
    

    例: [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lnmEcilH-1665243214720)(images/image-20221008220712164-1665238034541-5.png)]

    ​ 在/bin/catalina.sh文件下修改初始堆及最大堆大小:

    JAVA_OPTS='-Xms4096m -Xmx4096m'
    

    ​ 根据阿里规范两个参数大小最好保持一致,减少堆扩张带来的问题

    ​ 最后使用 jstat -gcutil 查看老年代空间占用,如果还是满的,说明存在内存泄漏

  4. 查找内存泄漏具体对象:

    jmap -histo 17488 
    

    根据占用空间大小降序输出

    例:

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6XIeCRF7-1665243214720)(images/image-20221008223706420-1665239831187-7.png)]

    也可只查询前10个最大占用的对象:jmap -histo 17488 | head -n 10

    ​ 回收掉无用对象,再次查看存活对象:

    jmap -histo:live 17488 
    

    该命令会执行一次GC,之后打印存活对象

    ​ 例:

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lplMRKI4-1665243214720)(images/image-20221008223953400.png)]

    结果: 发现某个类对象GC前后实例数变化不大,这个应该就是内存泄漏的类了

  5. 如果代码中很多地方用到了这个类,则需要Dump转存成文件:

    jmap  -dump:file=app.dump  17488
    

    例: [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vFPaZVTh-1665243214721)(images/image-20221008230201948.png)]

    也可以通过参数设置,内存溢出时自动生成dump文件:

    ‐XX:+HeapDumpOnOutOfMemoryError ‐XX:HeapDumpPath=D:jvm.dump
    

    注:内存泄漏dump文件也会很大,可能卡死,可以将Xmx限制在2G,重现问题后再dump

  6. 使用jhat分析dump文件,寻找GC Root

    jhat  -J-Xmx2G  app.dump
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZpFbyMLj-1665243214721)(images/image-20221008232831669.png)]
    访问网址:http://localhost:7000 在这里插入图片描述

    最后:链接到嫌疑类的具体某个对象页面,分析这个对象的引用情况是否正常,再通过“Reference chains from Rootset ”获取所有的GC Root ,进而定位到具体代码位置。

    参考博客:(2条消息) 使用jstat排查内存泄漏 - CSDN

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值