码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • jvm oom内存溢出,导出dump,使用mat进行问题分析


    文章目录

    • 前言
      • 1.生成Dump文件
        • 1.1 让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件
        • 1.2 在服务僵死时,jmap导出
      • 2. 分析dump文件(使用eclipse的mat图形化工具)
        • 2.1 下载windows版本,直接打开(若dump文件很小)
        • 2.2 下载linux版本,上传到服务器后解压(若dump文件很大)
      • 3. 打开分析报告
        • 3.1 使用浏览器浏览
        • 3.2 使用eclipse的mat工具

    前言

    当需要的内存空间大于系统分配的内存空间时,发生OOM;客户线上环境基本每2周挂一次,暂时编写了脚本自启动应用,需要去定位原因


    1.生成Dump文件

    1.1 让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件

    在应用中添加JVM参数:

    -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/sdc
    
    • 1

    1.2 在服务僵死时,jmap导出

    执行jmap -dump:format=b,file=文件名 进程对应的pid

    如:

    jmap -dump:format=b,file=sdc.hprof 124108
    
    • 1

    在这里插入图片描述

    file:保存路径及文件名
    pid:进程编号(linux通过ps aux查看)


    2. 分析dump文件(使用eclipse的mat图形化工具)

    mat工具下载
    在这里插入图片描述
    注: 生成环境使用的版本为jdk8,最新的mat不支持,需要用 之前发行的版本,使用1.11.0版本
    在这里插入图片描述

    2.1 下载windows版本,直接打开(若dump文件很小)

    2.2 下载linux版本,上传到服务器后解压(若dump文件很大)

    进入解压后的mat目录,查看所有文件:

    在这里插入图片描述
    编辑MemoryAnalyzer.ini,调大最大使用内存
    在这里插入图片描述

    配置完成后,在服务中分析dump文件./ParseHeapDump.sh dump文件路径 org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components

    ./ParseHeapDump.sh /data/log/sdc/sdc.hprof org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components
    
    • 1

    在dump文件所在的路径下生成报告文件
    在这里插入图片描述

    把报告文件拷贝到本地磁盘
    在这里插入图片描述


    3. 打开分析报告

    3.1 使用浏览器浏览

    解压缩以.zip结尾的文件,解压后,使用浏览器打开index.html文件内容,查看分析报告

    查看内存泄漏排查: 查看对象占据内存空间的比例
    在这里插入图片描述

    查看线程:
    在这里插入图片描述

    3.2 使用eclipse的mat工具


  • 相关阅读:
    SpringCloud Alibaba - Sentinel 高级玩法,修改 Sentinel-dashboard 源码,实现 push 模式
    前端品优购项目准备工作
    计算机网络 | 网络层
    软件工程毕业设计课题(7)基于python的毕业设计python外卖点餐系统毕设作品源码
    .NET 线程 Thread 进程 Process、线程池 pool、Invoke、begininvoke、异步回调
    Flink报错could not be loaded due to a linkage failure
    [附源码]java毕业设计 宠物医院管理系统
    windows编译zlmediakit
    【带头学C++】----- 三、指针章 ---- 3.10 函数指针(补充基础知识)
    指针经典笔试题
  • 原文地址:https://blog.csdn.net/m0_67403240/article/details/126409703
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号