1. 找出占内存比较大的内存的PID(使用top命令)
比如找出PID为8763
2. 查看当前Java进程创建的活跃对象数目和占用内存大小
jmap -histo:live $pid > jmap.log
比如查看24102进程的存活对象:
jmap -histo:live 24102 | more
例如:
$ /usr/java/default/bin/jmap -histo:live 8763 > ~/jmap.log
3. 将当前Java进程的内存占用情况导出来,方便用专门的内存分析工具(例如:MAT)来分析。
jmap -dump:live,format=b,file=jmap.log [pid]
--dump堆到文件,live指明是活着的对象,file指定文件名
因为在dump:live前会进行full gc,因此不加live的堆大小要大于加live堆的大小
-heap 打印堆总结
-histo[:live] 打印堆的对象统计,包括对象数、内存大小等等
例如:
$ /usr/java/default/bin/jmap -dump:live,format=b,file=jmap.log 8763
提示:Dumping heap to /home/dmadmin/jmap.log ...
Heap dump file created
本文介绍如何使用jmap命令分析Java应用程序的内存使用情况,包括查找消耗内存较大的进程、获取存活对象的数量及大小,并导出内存快照以供进一步分析。
3677

被折叠的 条评论
为什么被折叠?



