【jvm】09-full gc分析思路

【jvm】09-full gc分析思路

欢迎关注b站账号/公众号【六边形战士夏宁】,一个要把各项指标拉满的男人。该文章已在github目录收录。
屏幕前的大帅比大漂亮如果有帮助到你的话请顺手点个赞、加个收藏这对我真的很重要。别下次一定了,都不关注上哪下次一定。

1.命令界面

1.1.Jmap堆命令

jmap -histo:live {pid} | head -13

  • num:序号
  • instances:实例数量
  • bytes:占用空间大小
  • class name:类名称,[C is a char[],[S is a short[],[I is a int[],[B is a byte[],[[I is a int[][]

1.2.Jstack线程命令

执行 jstack -l {pid}

1.3.Jinfo运行参数命令

jinfo {pid}

1.4.Jstat综合命令

垃圾回收统计jstat -gc {pid}

  • NGCMN:新生代最小容量
  • NGCMX:新生代最大容量
  • NGC:当前新生代容量
  • S0C:第一个幸存区大小
  • S1C:第二个幸存区的大小
  • EC:伊甸园区的大小
  • OGCMN:老年代最小容量
  • OGCMX:老年代最大容量
  • OGC:当前老年代大小
  • OC:当前老年代大小
  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:年轻代gc次数
  • FGC:老年代GC次数

2.可视化界面

2.1.jvisualvm

2.2.Arthas

  • 下载:curl -O https://arthas.aliyun.com/arthas-boot.jar
  • 启动 java -jar arthas-boot.jar
    |命令|介绍|
    |–|--|
    |dashboard|当前系统的实时数据面板|
    |thread|查看当前 JVM 的线程堆栈信息|
    |watch|方法执行数据观测|
    |trace|方法内部调用路径,并输出方法路径上的每个节点上耗时|
    |stack|输出当前方法被调用的调用路径|
    |tt|方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测|
    |jvm|查看当前 JVM 信息|
    |vmoption|查看,更新 JVM 诊断相关的参数|
    |sc|查看 JVM 已加载的类信息|
    |sm|查看已加载类的方法信息|
    |jad|反编译指定已加载类的源码|
    |classloader|查看 classloader 的继承树,urls,类加载信息|
    |heapdump|类似 jmap 命令的 heap dump 功能|

3.线上参数

堆溢出自动打印日志
‐XX:+HeapDumpOnOutOfMemoryError
打印路径
‐XX:HeapDumpPath=D:\jvm.dump
如果有设置Xms,需要设置Xmx并保持一致防止堆抖动,元空间同理
‐Xms1536M(默认是物理内存的1/64) ‐Xmx1536(默认是物理内存的1/4)
禁止调用system.gc
­XX:+DisableExplicitGC
gc日志相关
‐Xloggc:./gc‐%t.log‐XX:+PrintGCDetails‐XX:+PrintGCDateStamps‐XX:+PrintGCTimeStamps‐XX:+PrintGCCause ‐XX:+UseGCLogFileRotation‐XX:NumberOfGCLogFiles=10‐XX:GCLogFileSize=100M

参考资料

《深入理解Java虚拟机》-周志明

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

seal_li

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值