V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
csidez
V2EX  ›  程序员

Java 系统内存泄漏定位

  •  
  •   csidez · 2019-10-10 16:00:29 +08:00 · 2531 次点击
    这是一个创建于 1869 天前的主题,其中的信息可能已经有所发展或是发生改变。

    系统运行久了就会崩溃,有没有办法定位是什么地方内存泄漏导致的? 有什么案例可以参考一下嘛

    10 条回复    2019-10-10 21:31:44 +08:00
    xaoduer
        1
    xaoduer  
       2019-10-10 16:10:51 +08:00
    内存泄露不是有 OOM 日志吗
    arrow8899
        2
    arrow8899  
       2019-10-10 16:14:55 +08:00   ❤️ 2
    -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp
    dump 出来后直接上 mat 分析
    xionghongzhi
        3
    xionghongzhi  
       2019-10-10 16:22:21 +08:00
    你可以在它出现问题的时候, jstack 查看下具体哪里有问题.

    jstack -l pid > xx.dump

    然后找一下里面有没有你写的代码...
    yidinghe
        4
    yidinghe  
       2019-10-10 16:23:35 +08:00
    https://segmentfault.com/a/1190000020513539
    看这篇文章,介绍内存分析工具的使用。如果想了解内存结构和垃圾回收,请从头看完该篇文章的整个系列。
    csidez
        5
    csidez  
    OP
       2019-10-10 16:25:44 +08:00
    @arrow8899 感谢
    aguesuka
        6
    aguesuka  
       2019-10-10 16:47:36 +08:00 via Android
    jmap 可以看类的内存占用
    luozic
        7
    luozic  
       2019-10-10 18:02:36 +08:00
    现在有 GUI 的也有命令行的,刚开始玩推荐用 GUi 的定位,jprofiler 等等
    zazalu
        8
    zazalu  
       2019-10-10 18:24:04 +08:00 via Android
    太大的系统 dump 要半天呢。
    timepast
        9
    timepast  
       2019-10-10 21:06:14 +08:00 via iPhone
    上面的方式应该能解决,我们前两天刚定位了相关问题
    Raymon111111
        10
    Raymon111111  
       2019-10-10 21:31:44 +08:00
    最直接的方法是分析 dump 堆文件, 看看有什么不太符合预期类
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1006 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 20ms · UTC 19:54 · PVG 03:54 · LAX 11:54 · JFK 14:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.