这两个工具可以帮助我们观察线上JVM中的对象分布,了解到你的系统平时运行过程中,到底哪些对象占据了主角位置,他们占据了多少内存空间,让你对你的系统运行有更加细致的了解。
一.jmap
1. heap
jmap -heap PID
会打印出来堆内存相关的一些参数设置,然后就是当前堆内存里的一些基本各个区域的情况
比如Eden区总容量、已经使用的容量、剩余的空间容量,两个Survivor区的总容量、已经使用的容量和剩余的空间容量,老年代的总容量、已经使用的容量和剩余的容量。
一般不会用jmap去看这些信息,jstat更加全。
2.histo
jmap -histo PID
按照各种对象占用内存空间的大小降序排列,把占用内存最多的对象放在最上面。
快速了解到当前内存里到底是哪个对象占用了大量的内存空间。
3.使用jmap生成堆内存转储快照
jmap -dump:live,format=b,file=dump.hprof PID
命令会在当前目录下生成一个dump.hrpof文件,这里是二进制的格式,你不能直接打开看的,他把这一时刻JVM堆内存里所有对象的快照放到文件里去了,供你后续去分析
二.jhat
jhat内置了web服务器,他会支持你通过浏览器来以图形化的方式分析堆转储快照.
jhat dump.hprof -port 7000
该命令即可启动jhat服务器,还可以指定自己想要的http端口号,默认是7000端口号。
接着你就在浏览器上访问当前这台机器的7000端口号,就可以通过图形化的方式去分析堆内存里的对象分布情况了。