jmap和jhat

jmap -heap PID

比如Eden区总容量、已经使用的容量、剩余的空间容量,两个Survivor区的总容量、已经使用的容量和剩余的空间容量,老年代的总容
量、已经使用的容量和剩余的容量。
但是这些信息大家会想了,其实jstat已经有了啊!对的,所以一般不会用jmap去看这些信息,毕竟他信息还没jstat全呢,因为没有gc
相关的统计。

使用jmap了解系统运行时的对象分布

其实jmap命令比较有用的一个使用方式,是如下的:
jmap -histo PID
这个命令会打印出来类似下面的信息:
jmap和jhat
这个就很有意思了,各位同学看上述打印出来的东西,他会按照各种对象占用内存空间的大小降序排列,把占用内存最多的对象放在最
上面。
所以如果你只是想要简单的了解一下当前jvm中的对象对内存占用的情况,只要直接用jmap -histo命令即可,非常好用
你可以快速了解到当前内存里到底是哪个对象占用了大量的内存空间。

使用jmap生成堆内存转储快照

jmap -dump:live,format=b,file=dump.hprof PID
这个命令会在当前目录下生成一个dump.hrpof文件,这里是二进制的格式,你不能直接打开看的,他把这一时刻JVM堆内存里所有对
象的快照放到文件里去了,供你后续去分析。

使用jhat在浏览器中分析堆转出快照

接着就可以使用jhat去分析堆快照了,jhat内置了web服务器,他会支持你通过浏览器来以图形化的方式分析堆转储快照
使用如下命令即可启动jhat服务器,还可以指定自己想要的http端口号,默认是7000端口号:
jhat dump.hprof -port 7000
接着你就在浏览器*问当前这台机器的7000端口号,就可以通过图形化的方式去分析堆内存里的对象分布情况了。

上一篇:如何分析jvm内存快照dump文件


下一篇:Laravel使用redis的GEO地理信息类型