不同的垃圾回收器 他们的日志都是完成不一样的,看懂日志是解决和发现问题的重中之重 。
Parallel Scavenge + Parallel Old 日志启动参数
-XX:+UseParallelGC -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.log
ygc日志
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/2241093P2-0.png)
文章插图
fullgc日志 如下图 主要是 gc日志上多了回收老年代、元空间、GC类型变为Full GC
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/224109E54-1.png)
文章插图
年轻代的total=eden+1个s区 如图中 10752+1536=12288k
GC触发原因常见的有
- Allocation Failure年轻代中没有足够区域能够存放需要分配的数据而失败
- Ergonomics 常见于FullGc中是因为 UseAdaptiveSizePolicy 开启了自适应调整策略而发生的GC 很正常的
- Metadata GC Threshold 常见于Full Gc 元空间不足
-XX:+UseG1GC -XX:InitiatingHeapOccupancyPercent=40 -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.log
MiexdGc 回收流程参考 回收流程YGC 日志格式
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/224109AL-2.png)
文章插图
Miexd GC日志格式miexd gc日志就能完全体现出G1回收流程的几个阶段 初始标记-并发标记-最终标记-筛选回收
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/2241091A5-3.png)
文章插图
Full gc日志格式Full Gc日志看起来很轻松 在G1中应该避免不要产生FullGC
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/2241092O8-4.png)
文章插图
CMScms是老年代回收器 日志格式也是分阶段打印的具体流程可以参考 cms回收阶段流程 启动参数如下
-Xms50m-Xmx50m -XX:+UseConcMarkSweepGC-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.log
![java中GC的日志认识详解](http://shimg.jingyanzongjie.com/230726/22410aR0-5.png)
文章插图
老版的垃圾回收器如 parNew 串行不再去花太多时间研究了 一般也用不上 有更好的选择 。
在线日志分析工具https://gceasy.io/gc-index.jsp
【java中GC的日志认识详解】没怎么用过 https://sourceforge.net/projects/gcviewer/
参考 https://zhuanlan.zhihu.com/p/267388951
经验总结扩展阅读
- 用什么茶具
- Learning Records JavaScript进阶
- 2023年9月26日剪头发黄道吉日 2023年9月26日是剪头发的黄道吉日吗
- 淡奶油是动物奶油吗
- 31 《吐血整理》高级系列教程-吃透Fiddler抓包教程-Fiddler如何抓取Android系统中Flutter应用程序的包
- 十二星座的爱情为什么总在十万八千里
- 哪些星座女掌握诀窍才好追?
- 饺子都有什么馅儿的
- 冰箱的尺寸长宽高一般是多少
- 2023年9月26日建猪栏吉日一览表 2023年9月26日是建猪栏的黄道吉日吗