操作步骤
1、用cmd命令打开dos窗口,操作进入jdk的bin目录
或者path环境变量包含jdk的bin目录,也可执行后续命令。
2、查看堆内存快照,输出jvm的heap内容到文件, live子选项是可选的,假如指定live选项,那么只输出活的对象到文件
jmap -dump:live,format=b,file=myjmapfile.txt <进程id>
3、jhat 查看dump的文件内容的分析内容,会显示端口并提示打开浏览器查看
jhat <文件名>
4、根据提示的端口,打开浏览器,访问该http地址
http://localhost:<port>
其他命令
获取heap的概要信息,GC使用的算法,heap(堆)的配置及JVM堆内存的使用情况
jmap -heap <进程id>
获取每个class的实例数目,字节数,类全名信息。如果live子参数加上后,只统计活的对象数量。
jmap -histo:live <进程id>
查看对象数最多的对象,并按降序排序输出:
jmap -histo <进程id>|grep alibaba|sort -k 2 -g -r|less
查看占用内存最多的最象,并按降序排序输出:
jmap -histo <进程id>|grep alibaba|sort -k 3 -g -r|less
获取正等候回收的对象的信息
jmap -finalizerinfo <进程id>