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

一、 命令

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

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

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

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

4. jmap -dump:format=b,file=/tmp/文件名.hprof  PID (打印正在运行的程序的堆信息,可通过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,对程序运行的堆文件进行分析,内存泄露问题建议打印运行堆文件,用此工具分析。

 

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

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

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

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

 

 

 

posted @ 2018-04-11 14:49  elisun  阅读(385)  评论(0编辑  收藏  举报