基于线上环境的jvm堆栈分析,jmap+MAT

1 篇文章 0 订阅
1 篇文章 0 订阅

一.先安装必要的工具和环境

    1.jmap只要jdk正常安装就默认就有,

    2.MAT安装,个人一般使用独立插件的形式安装,下载地址: http://www.eclipse.org/mat 安装方式请自行查找

二.生成堆栈文件并下载到本地

    1.进入线上环境,使用jmap生成堆栈文件,其中查看jmap的路径命令:which jmap


         查看对应的java服务进程命令:jps -v|grep server_name


         生成堆栈文件:jmap -dump:live,format=b,file=./jmap/map.bin  20874,目录就是./jmap/map.bin

    2.通过sz命令或者类Xftp工具把map.bin文件烤到本地。

三.利用MAT分析map.bin文件

    通过MAT中的File-》Open Heap Dump...      打开map.bin文件,接下来就可以分析内存溢出原因了。

四.MAT中的两个关键字:Shallow Heap,Retained Heap

Shallow Size
对象自身占用的内存大小,不包括它引用的对象。
针对非数组类型的对象,它的大小就是对象与它所有的成员变量大小的总和。当然这里面还会包括一些java语言特性的数据存储单元。
针对数组类型的对象,它的大小是数组元素对象的大小总和。

Retained Size
Retained Size=当前对象大小+当前对象可直接或间接引用到的对象的大小总和。(间接引用的含义:A->B->C, C就是间接引用)
换句话说,Retained Size就是当前对象被GC后,从Heap上总共能释放掉的内存。
不过,释放的时候还要排除被GC Roots直接或间接引用的对象。他们暂时不会被被当做Garbage


jmap的一些命令

  • jmap pid #打印内存使用的摘要信息
  • jmap –heap pid #java heap信息
  • jmap -histo:live pid #统计对象count ,live表示在使用
  • jmap -histo pid >mem.txt #打印比较简单的各个有多少个对象占了多少内存的信息,一般重定向的文件
  • jmap -dump:format=b,file=mem.dat pid #将内存使用的详细情况输出到mem.dat 文件







  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值