0


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 压力测试

本文转载自: https://blog.csdn.net/u011397981/article/details/123589718
版权归原作者 逆流°只是风景-bjhxcc 所有, 如有侵权,请联系我们删除。

“java获取内存dump的几种方式”的评论:

还没有评论