• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

java获取内存dump的几种方式

武飞扬头像
逆流°只是风景-bjhxcc
帮助1

前不久,上线了一个新项目,这个项目是一个压测系统,可以简单的看做通过回放词表(http请求数据),不断地向服务发送请求,以达到压测服务的目的。在测试过程中,一切还算顺利,修复了几个小bug后,就上线了。在上线后给到第一个业务方使用时,就发现来一个严重的问题,应用大概跑了10多分钟,就收到了大量的Full GC 的告警。
针对这一问题,我们首先和业务方确认了压测的场景内容,回放的词表数量大概是10万条,回放的速率单机在 100qps左右,按照我们之前的预估,这远远低于单机能承受的极限。按道理是不会产生内存问题的。

java获取内存dump的几种方式

  1. 获取内存详情:jmap -dump:format=b,file=e.bin pid
    这种方式可以用 jvisualvm.exe 进行内存分析,或者采用 Eclipse Memory Analysis Tools (MAT)这个工具

  2. 获取内存dump: jmap -histo:live pid
    这种方式会先出发fullgc,所有如果不希望触发fullgc 可以使用jmap -histo pid

  3. 第三种方式:jdk启动加参数:
    -XX: HeapDumpBeforeFullGC
    -XX:HeapDumpPath=/httx/logs/dump
    这种方式会产生dump日志,再通过jvisualvm.exe 或者Eclipse Memory Analysis Tools 工具进行分析

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhiakihi
系列文章
更多 icon
同类精品
更多 icon
继续加载