java获取内存dump的几种方式

2022/3/20 7:36:06

本文主要是介绍java获取内存dump的几种方式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

前不久,上线了一个新项目,这个项目是一个压测系统,可以简单的看做通过回放词表(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 工具进行分析



这篇关于java获取内存dump的几种方式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程