From 0eaadfbb25c6a004816bbd2dfd8693f1a78d6fd4 Mon Sep 17 00:00:00 2001 From: Danny Thomas Date: Fri, 18 Nov 2022 15:27:06 +1100 Subject: [PATCH 1/2] Add ZGC generational memory managers --- .../main/java/com/netflix/spectator/gc/HelperFunctions.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java b/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java index ed238fe54..16c7b5603 100644 --- a/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java +++ b/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java @@ -43,6 +43,10 @@ private static Map knownCollectors() { m.put("ZGC", GcType.OLD); m.put("ZGC Cycles", GcType.OLD); m.put("ZGC Pauses", GcType.OLD); + m.put("ZGC Minor Cycles", GcType.YOUNG); + m.put("ZGC Minor Pauses", GcType.YOUNG); + m.put("ZGC Major Cycles", GcType.OLD); + m.put("ZGC Major Pauses", GcType.OLD); m.put("Shenandoah Cycles", GcType.OLD); m.put("Shenandoah Pauses", GcType.OLD); return Collections.unmodifiableMap(m); From 19760baa8fb69a987aac5e21eca834aa9a232ad1 Mon Sep 17 00:00:00 2001 From: Danny Thomas Date: Fri, 18 Nov 2022 16:04:15 +1100 Subject: [PATCH 2/2] Match Shenandoah and ZGC generational pool names --- .../main/java/com/netflix/spectator/gc/HelperFunctions.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java b/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java index 16c7b5603..9311038ad 100644 --- a/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java +++ b/spectator-ext-gc/src/main/java/com/netflix/spectator/gc/HelperFunctions.java @@ -65,7 +65,7 @@ static boolean isOldGcType(String name) { /** Returns true if memory pool name matches an old generation pool. */ static boolean isOldGenPool(String name) { - return name.endsWith("Old Gen") + return name.contains("Old Gen") || name.endsWith("Tenured Gen") || "Shenandoah".equals(name) || "ZHeap".equals(name); @@ -73,7 +73,8 @@ static boolean isOldGenPool(String name) { /** Returns true if memory pool name matches an young generation pool. */ static boolean isYoungGenPool(String name) { - return name.endsWith("Eden Space") + return name.contains("Young Gen") + || name.endsWith("Eden Space") || "Shenandoah".equals(name) || "ZHeap".equals(name); }