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插件)
图片有些模糊,可以直观动态实时地看到当前内存的使用情况。