java 内存分析命令_java内存分析常用命令及工具

一、 命令

1. jmap -heap pid (打印堆配置信息,可以看到目前内存分配和占用情况)

2. jstat -gcutil pid (打印当前堆区使用情况)

下图内存正处于近乎崩溃的状态,已经疯狂的进行FullGC来释放内存

223ceff659e317ee50836039afc0dad1.png

3. jstack -l pid(打印线程堆信息)

4. jmap -dump:format=b,file=/tmp/文件名.hprofPID (打印正在运行的程序的堆信息,可通过Memory Analyzer工具进行分析,该文件大小一般为几个G)

5. GC日志打印

在启动脚本catalina.sh中JAVA_OPTS后追加

-verbose:gc -XX:+PrintGCTimeStamps -XX:+PrintGCDetails -Xloggc:/tmp/gc.log

6. 其它命令记录

- 生成或查看配置信息

jinfo -flags pid

- 查看metaspace信息

jstat -gcmetacapacity pid

二、 工具

1. Memory Analyzer,一款强大的内存分析工具简称MAT,对程序运行的堆文件进行分析,内存泄露问题建议打印运行堆文件,用此工具分析。

9a30ae8a828b325252afe64feffde27a.png

2. JVisualVM,Tomcat自带图形工具。

- 通过JMX监控:被监控的Tomcat需要开启JMX支持。

- 通过jstatd监控:被监控的Tomcat需要开启JMX支持。(为了支持Visual gc插件)

图片有些模糊,可以直观动态实时地看到当前内存的使用情况。

8372d0f050954e5d8c2f270cb1ec8c48.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值