java中GC的日志認識詳解

不同的垃圾回收器 他們的日志都是完成不一樣的,看懂日志是解決和發現問題的重中之重 。
Parallel Scavenge + Parallel Old 日志啟動參數
-XX:+UseParallelGC -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.logygc日志

java中GC的日志認識詳解

文章插圖
fullgc日志 如下圖 主要是 gc日志上多了回收老年代、元空間、GC類型變為Full GC
java中GC的日志認識詳解

文章插圖
年輕代的total=eden+1個s區 如圖中 10752+1536=12288k
GC觸發原因常見的有
  • Allocation Failure年輕代中沒有足夠區域能夠存放需要分配的數據而失敗
  • Ergonomics 常見于FullGc中是因為 UseAdaptiveSizePolicy 開啟了自適應調整策略而發生的GC 很正常的
  • Metadata GC Threshold 常見于Full Gc 元空間不足
G1G1有幾種類型的gc , YGC (僅回收年輕代),Miexd GC(年輕代和部分老年代都回收 也叫混合GC),Full GC (整堆回收 g1中一般很少出現fullgc),啟動參數如下
-XX:+UseG1GC -XX:InitiatingHeapOccupancyPercent=40 -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.logMiexdGc 回收流程參考 回收流程
YGC 日志格式
java中GC的日志認識詳解

文章插圖
Miexd GC日志格式miexd gc日志就能完全體現出G1回收流程的幾個階段 初始標記-并發標記-最終標記-篩選回收
java中GC的日志認識詳解

文章插圖
Full gc日志格式Full Gc日志看起來很輕松 在G1中應該避免不要產生FullGC
java中GC的日志認識詳解

文章插圖
CMScms是老年代回收器 日志格式也是分階段打印的具體流程可以參考 cms回收階段流程 啟動參數如下
-Xms50m-Xmx50m -XX:+UseConcMarkSweepGC-XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:gc.log
java中GC的日志認識詳解

文章插圖
老版的垃圾回收器如 parNew 串行不再去花太多時間研究了 一般也用不上 有更好的選擇 。
在線日志分析工具https://gceasy.io/gc-index.jsp
沒怎么用過 https://sourceforge.net/projects/gcviewer/
參考 https://zhuanlan.zhihu.com/p/267388951
【java中GC的日志認識詳解】

    推薦閱讀