From 9971a2cab3892a17f3fd39243df5ecfff5b9f108 Mon Sep 17 00:00:00 2001 From: Severin Gehwolf Date: Tue, 2 Nov 2021 10:39:41 +0000 Subject: [PATCH] 8275735: [linux] Remove deprecated Metrics api (kernel memory limit) Reviewed-by: hseigel, mchung --- .../internal/platform/CgroupV1Metrics.java | 20 ----------- .../platform/CgroupV1MetricsImpl.java | 10 ------ .../platform/cgroupv1/CgroupV1Subsystem.java | 8 ----- .../platform/docker/MetricsMemoryTester.java | 20 ----------- .../docker/TestDockerMemoryMetrics.java | 36 +++---------------- .../cgroup/MetricsTesterCgroupV1.java | 14 -------- 6 files changed, 4 insertions(+), 104 deletions(-) diff --git a/src/java.base/linux/classes/jdk/internal/platform/CgroupV1Metrics.java b/src/java.base/linux/classes/jdk/internal/platform/CgroupV1Metrics.java index cf8230b0bfc..c7e83faa59d 100644 --- a/src/java.base/linux/classes/jdk/internal/platform/CgroupV1Metrics.java +++ b/src/java.base/linux/classes/jdk/internal/platform/CgroupV1Metrics.java @@ -53,16 +53,6 @@ public interface CgroupV1Metrics extends Metrics { */ public long getKernelMemoryFailCount(); - /** - * Returns the maximum amount of kernel physical memory, in bytes, that - * can be allocated in the Isolation Group. - * - * @return The maximum amount of memory in bytes or -1 if - * there is no limit set. - * - */ - public long getKernelMemoryLimit(); - /** * Returns the largest amount of kernel physical memory, in bytes, that * have been allocated in the Isolation Group. @@ -93,16 +83,6 @@ public interface CgroupV1Metrics extends Metrics { */ public long getTcpMemoryFailCount(); - /** - * Returns the maximum amount of networking physical memory, in bytes, - * that can be allocated in the Isolation Group. - * - * @return The maximum amount of memory in bytes or -1 if - * there is no limit. - * - */ - public long getTcpMemoryLimit(); - /** * Returns the largest amount of networking physical memory, in bytes, * that have been allocated in the Isolation Group. diff --git a/src/java.base/linux/classes/jdk/internal/platform/CgroupV1MetricsImpl.java b/src/java.base/linux/classes/jdk/internal/platform/CgroupV1MetricsImpl.java index 443b58f1f9d..ce9b0c2cc20 100644 --- a/src/java.base/linux/classes/jdk/internal/platform/CgroupV1MetricsImpl.java +++ b/src/java.base/linux/classes/jdk/internal/platform/CgroupV1MetricsImpl.java @@ -48,11 +48,6 @@ public class CgroupV1MetricsImpl extends CgroupMetrics implements CgroupV1Metric return metrics.getKernelMemoryFailCount(); } - @Override - public long getKernelMemoryLimit() { - return metrics.getKernelMemoryLimit(); - } - @Override public long getKernelMemoryMaxUsage() { return metrics.getKernelMemoryMaxUsage(); @@ -68,11 +63,6 @@ public class CgroupV1MetricsImpl extends CgroupMetrics implements CgroupV1Metric return metrics.getTcpMemoryFailCount(); } - @Override - public long getTcpMemoryLimit() { - return metrics.getTcpMemoryLimit(); - } - @Override public long getTcpMemoryMaxUsage() { return metrics.getTcpMemoryMaxUsage(); diff --git a/src/java.base/linux/classes/jdk/internal/platform/cgroupv1/CgroupV1Subsystem.java b/src/java.base/linux/classes/jdk/internal/platform/cgroupv1/CgroupV1Subsystem.java index b928e83093e..5a49aa7833e 100644 --- a/src/java.base/linux/classes/jdk/internal/platform/cgroupv1/CgroupV1Subsystem.java +++ b/src/java.base/linux/classes/jdk/internal/platform/cgroupv1/CgroupV1Subsystem.java @@ -332,10 +332,6 @@ public class CgroupV1Subsystem implements CgroupSubsystem, CgroupV1Metrics { return getLongValue(memory, "memory.kmem.failcnt"); } - public long getKernelMemoryLimit() { - return CgroupV1SubsystemController.longValOrUnlimited(getLongValue(memory, "memory.kmem.limit_in_bytes")); - } - public long getKernelMemoryMaxUsage() { return getLongValue(memory, "memory.kmem.max_usage_in_bytes"); } @@ -348,10 +344,6 @@ public class CgroupV1Subsystem implements CgroupSubsystem, CgroupV1Metrics { return getLongValue(memory, "memory.kmem.tcp.failcnt"); } - public long getTcpMemoryLimit() { - return CgroupV1SubsystemController.longValOrUnlimited(getLongValue(memory, "memory.kmem.tcp.limit_in_bytes")); - } - public long getTcpMemoryMaxUsage() { return getLongValue(memory, "memory.kmem.tcp.max_usage_in_bytes"); } diff --git a/test/jdk/jdk/internal/platform/docker/MetricsMemoryTester.java b/test/jdk/jdk/internal/platform/docker/MetricsMemoryTester.java index f170458893c..08773b3e8b5 100644 --- a/test/jdk/jdk/internal/platform/docker/MetricsMemoryTester.java +++ b/test/jdk/jdk/internal/platform/docker/MetricsMemoryTester.java @@ -39,9 +39,6 @@ public class MetricsMemoryTester { case "memoryswap": testMemoryAndSwapLimit(args[1], args[2]); break; - case "kernelmem": - testKernelMemoryLimit(args[1]); - break; case "oomkill": testOomKillFlag(Boolean.parseBoolean(args[2])); break; @@ -119,23 +116,6 @@ public class MetricsMemoryTester { System.out.println("TEST PASSED!!!"); } - private static void testKernelMemoryLimit(String value) { - Metrics m = Metrics.systemMetrics(); - if (m instanceof CgroupV1Metrics) { - CgroupV1Metrics mCgroupV1 = (CgroupV1Metrics)m; - System.out.println("TEST PASSED!!!"); - long limit = getMemoryValue(value); - long kmemlimit = mCgroupV1.getKernelMemoryLimit(); - if (kmemlimit != UNLIMITED && limit != kmemlimit) { - throw new RuntimeException("Kernel Memory limit not equal, expected : [" - + limit + "]" + ", got : [" - + kmemlimit + "]"); - } - } else { - throw new RuntimeException("kernel memory limit test not supported for cgroups v2"); - } - } - private static void testMemoryAndSwapLimit(String memory, String memAndSwap) { long expectedMem = getMemoryValue(memory); long expectedMemAndSwap = getMemoryValue(memAndSwap); diff --git a/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java b/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java index ca75aa745e0..4ec77d08d04 100644 --- a/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java +++ b/test/jdk/jdk/internal/platform/docker/TestDockerMemoryMetrics.java @@ -61,18 +61,14 @@ public class TestDockerMemoryMetrics { testMemoryAndSwapLimit("100m", "200m"); Metrics m = Metrics.systemMetrics(); - // kernel memory, '--kernel-memory' switch, and OOM killer, - // '--oom-kill-disable' switch, tests not supported by cgroupv2 - // runtimes + // OOM killer disable, '--oom-kill-disable' switch, test not supported + // by cgroupv2 if (m != null) { if ("cgroupv1".equals(m.getProvider())) { - testKernelMemoryLimit("100m"); - testKernelMemoryLimit("1g"); - testOomKillFlag("100m", false); } else { - System.out.println("kernel memory tests and OOM Kill flag tests not " + - "possible with cgroupv2."); + System.out.println("OOM kill disable test not " + + "supported with cgroupv2."); } } testOomKillFlag("100m", true); @@ -149,30 +145,6 @@ public class TestDockerMemoryMetrics { DockerTestUtils.dockerRunJava(opts).shouldHaveExitValue(0).shouldContain("TEST PASSED!!!"); } - private static void testKernelMemoryLimit(String value) throws Exception { - Common.logNewTestCase("testKernelMemoryLimit, value = " + value); - DockerRunOptions opts = - new DockerRunOptions(imageName, "/jdk/bin/java", "MetricsMemoryTester"); - opts.addDockerOpts("--volume", Utils.TEST_CLASSES + ":/test-classes/") - .addDockerOpts("--kernel-memory=" + value) - .addJavaOpts("-cp", "/test-classes/") - .addJavaOpts("--add-exports", "java.base/jdk.internal.platform=ALL-UNNAMED") - .addClassOptions("kernelmem", value); - OutputAnalyzer oa = DockerTestUtils.dockerRunJava(opts); - - // Some container runtimes (e.g. runc, docker 18.09) - // have been built without kernel memory accounting. In - // that case, the runtime issues a message on stderr saying - // so. Skip the test in that case. - if (oa.getStderr().contains("kernel memory accounting disabled")) { - System.out.println("Kernel memory accounting disabled, " + - "skipping the test case"); - return; - } - - oa.shouldHaveExitValue(0).shouldContain("TEST PASSED!!!"); - } - private static void testOomKillFlag(String value, boolean oomKillFlag) throws Exception { Common.logNewTestCase("testOomKillFlag, oomKillFlag = " + oomKillFlag); DockerRunOptions opts = diff --git a/test/lib/jdk/test/lib/containers/cgroup/MetricsTesterCgroupV1.java b/test/lib/jdk/test/lib/containers/cgroup/MetricsTesterCgroupV1.java index 6239a6de769..7b78ad8eef4 100644 --- a/test/lib/jdk/test/lib/containers/cgroup/MetricsTesterCgroupV1.java +++ b/test/lib/jdk/test/lib/containers/cgroup/MetricsTesterCgroupV1.java @@ -247,13 +247,6 @@ public class MetricsTesterCgroupV1 implements CgroupMetricsTester { fail(Controller.MEMORY, "memory.kmem.failcnt", oldVal, newVal); } - oldVal = metrics.getKernelMemoryLimit(); - newVal = getLongValueFromFile(Controller.MEMORY, "memory.kmem.limit_in_bytes"); - newVal = newVal > unlimited_minimum ? CgroupSubsystem.LONG_RETVAL_UNLIMITED : newVal; - if (!CgroupMetricsTester.compareWithErrorMargin(oldVal, newVal)) { - fail(Controller.MEMORY, "memory.kmem.limit_in_bytes", oldVal, newVal); - } - oldVal = metrics.getKernelMemoryMaxUsage(); newVal = getLongValueFromFile(Controller.MEMORY, "memory.kmem.max_usage_in_bytes"); if (!CgroupMetricsTester.compareWithErrorMargin(oldVal, newVal)) { @@ -273,13 +266,6 @@ public class MetricsTesterCgroupV1 implements CgroupMetricsTester { fail(Controller.MEMORY, "memory.kmem.tcp.failcnt", oldVal, newVal); } - oldVal = metrics.getTcpMemoryLimit(); - newVal = getLongValueFromFile(Controller.MEMORY, "memory.kmem.tcp.limit_in_bytes"); - newVal = newVal > unlimited_minimum ? CgroupSubsystem.LONG_RETVAL_UNLIMITED: newVal; - if (!CgroupMetricsTester.compareWithErrorMargin(oldVal, newVal)) { - fail(Controller.MEMORY, "memory.kmem.tcp.limit_in_bytes", oldVal, newVal); - } - oldVal = metrics.getTcpMemoryMaxUsage(); newVal = getLongValueFromFile(Controller.MEMORY, "memory.kmem.tcp.max_usage_in_bytes"); if (!CgroupMetricsTester.compareWithErrorMargin(oldVal, newVal)) {