From 129d91f7b274be711667c33f0ea199c01955e46f Mon Sep 17 00:00:00 2001
From: Peter Szucs <116345192+p-szucs@users.noreply.github.com>
Date: Wed, 15 May 2024 16:32:49 +0200
Subject: [PATCH] YARN-11692. Support mixed cgroup v1/v2 controller structure
(#6821)
---
.../hadoop/yarn/conf/YarnConfiguration.java | 4 +
.../src/main/resources/yarn-default.xml | 14 ++
.../linux/resources/CGroupsMountConfig.java | 13 +-
.../linux/resources/CGroupsV2HandlerImpl.java | 4 +-
.../resources/ResourceHandlerModule.java | 102 +++++++-----
.../resources/TestCGroupsV2HandlerImpl.java | 149 +++++++++++++++++-
.../resources/TestResourceHandlerModule.java | 68 --------
7 files changed, 237 insertions(+), 117 deletions(-)
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-api/src/main/java/org/apache/hadoop/yarn/conf/YarnConfiguration.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-api/src/main/java/org/apache/hadoop/yarn/conf/YarnConfiguration.java
index d96cfe9150b17..2a51065404cac 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-api/src/main/java/org/apache/hadoop/yarn/conf/YarnConfiguration.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-api/src/main/java/org/apache/hadoop/yarn/conf/YarnConfiguration.java
@@ -2733,6 +2733,10 @@ public static boolean isAclEnabled(Configuration conf) {
public static final String NM_LINUX_CONTAINER_CGROUPS_MOUNT_PATH =
NM_PREFIX + "linux-container-executor.cgroups.mount-path";
+ /** Where the linux container executor should mount cgroups v2 if not found. */
+ public static final String NM_LINUX_CONTAINER_CGROUPS_V2_MOUNT_PATH =
+ NM_PREFIX + "linux-container-executor.cgroups.v2.mount-path";
+
/**
* Whether the apps should run in strict resource usage mode(not allowed to
* use spare CPU)
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/resources/yarn-default.xml b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/resources/yarn-default.xml
index aac840866ec94..275fc08cb2ca9 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/resources/yarn-default.xml
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/resources/yarn-default.xml
@@ -2087,6 +2087,20 @@
yarn.nodemanager.linux-container-executor.cgroups.mount-path
+
+ This property sets the mount path for CGroups v2.
+ This parameter is optional, and needed to be set only in mixed mode,
+ when CGroups v2 is mounted alongside with Cgroups v1.
+ For example, in hybrid mode, CGroups v1 controllers can be mounted under /sys/fs/cgroup/
+ (for example /sys/fs/cgroup/cpu,cpuacct), while v2 can be mounted in /sys/fs/cgroup/unified folder.
+
+ If this value is not set, the value of
+ yarn.nodemanager.linux-container-executor.cgroups.mount-path
+ will be used for CGroups v2 as well.
+
+ yarn.nodemanager.linux-container-executor.cgroups.v2.mount-path
+
+
Delay in ms between attempts to remove linux cgroup
yarn.nodemanager.linux-container-executor.cgroups.delete-delay-ms
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsMountConfig.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsMountConfig.java
index 6eb8667f2a808..b5a71f6072846 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsMountConfig.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsMountConfig.java
@@ -26,11 +26,17 @@ public class CGroupsMountConfig {
private final boolean enableMount;
private final String mountPath;
+ // CGroups v2 mount path is only relevant in mixed CGroups v1/v2 mode,
+ // where v2 is mounted alongside with v1.
+ private final String v2MountPath;
+
public CGroupsMountConfig(Configuration conf) {
this.enableMount = conf.getBoolean(YarnConfiguration.
NM_LINUX_CONTAINER_CGROUPS_MOUNT, false);
this.mountPath = conf.get(YarnConfiguration.
NM_LINUX_CONTAINER_CGROUPS_MOUNT_PATH, null);
+ this.v2MountPath = conf.get(YarnConfiguration.
+ NM_LINUX_CONTAINER_CGROUPS_V2_MOUNT_PATH, mountPath);
}
public boolean ensureMountPathIsDefined() throws ResourceHandlerException {
@@ -62,11 +68,16 @@ public String getMountPath() {
return mountPath;
}
+ public String getV2MountPath() {
+ return v2MountPath;
+ }
+
@Override
public String toString() {
return "CGroupsMountConfig{" +
"enableMount=" + enableMount +
- ", mountPath='" + mountPath + '\'' +
+ ", mountPath='" + mountPath +
+ ", v2MountPath='" + v2MountPath + '\'' +
'}';
}
}
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsV2HandlerImpl.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsV2HandlerImpl.java
index cd362ab9a548c..356a4c42dfb31 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsV2HandlerImpl.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/CGroupsV2HandlerImpl.java
@@ -97,8 +97,8 @@ protected List getCGroupControllers() {
@Override
protected Map> parsePreConfiguredMountPath() throws IOException {
Map> controllerMappings = new HashMap<>();
- controllerMappings.put(this.cGroupsMountConfig.getMountPath(),
- readControllersFile(this.cGroupsMountConfig.getMountPath()));
+ controllerMappings.put(this.cGroupsMountConfig.getV2MountPath(),
+ readControllersFile(this.cGroupsMountConfig.getV2MountPath()));
return controllerMappings;
}
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/ResourceHandlerModule.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/ResourceHandlerModule.java
index 118013f55a14b..98492779b01e5 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/ResourceHandlerModule.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/ResourceHandlerModule.java
@@ -63,11 +63,12 @@ public class ResourceHandlerModule {
* as resource metrics functionality. We need to ensure that the same
* instance is used for both.
*/
+ private static volatile CGroupsHandler cGroupV1Handler;
+ private static volatile CGroupsHandler cGroupV2Handler;
private static volatile TrafficControlBandwidthHandlerImpl
trafficControlBandwidthHandler;
private static volatile NetworkPacketTaggingHandlerImpl
networkPacketTaggingHandlerImpl;
- private static volatile CGroupsHandler cGroupsHandler;
private static volatile CGroupsBlkioResourceHandlerImpl
cGroupsBlkioResourceHandler;
private static volatile MemoryResourceHandler
@@ -75,23 +76,42 @@ public class ResourceHandlerModule {
private static volatile CpuResourceHandler
cGroupsCpuResourceHandler;
- /**
- * Returns an initialized, thread-safe CGroupsHandler instance.
- */
- private static CGroupsHandler getInitializedCGroupsHandler(Configuration conf)
+ private static void initializeCGroupHandlers(Configuration conf)
+ throws ResourceHandlerException {
+ initializeCGroupV1Handler(conf);
+ if (cgroupsV2Enabled) {
+ initializeCGroupV2Handler(conf);
+ }
+ }
+
+ private static void initializeCGroupV1Handler(Configuration conf)
throws ResourceHandlerException {
- if (cGroupsHandler == null) {
+ if (cGroupV1Handler == null) {
synchronized (CGroupsHandler.class) {
- if (cGroupsHandler == null) {
- cGroupsHandler = cgroupsV2Enabled
- ? new CGroupsV2HandlerImpl(conf, PrivilegedOperationExecutor.getInstance(conf))
- : new CGroupsHandlerImpl(conf, PrivilegedOperationExecutor.getInstance(conf));
- LOG.debug("Value of CGroupsHandler is: {}", cGroupsHandler);
+ if (cGroupV1Handler == null) {
+ cGroupV1Handler = new CGroupsHandlerImpl(
+ conf, PrivilegedOperationExecutor.getInstance(conf));
+ LOG.debug("Value of CGroupsV1Handler is: {}", cGroupV1Handler);
}
}
}
+ }
- return cGroupsHandler;
+ private static void initializeCGroupV2Handler(Configuration conf)
+ throws ResourceHandlerException {
+ if (cGroupV2Handler == null) {
+ synchronized (CGroupsHandler.class) {
+ if (cGroupV2Handler == null) {
+ cGroupV2Handler = new CGroupsV2HandlerImpl(
+ conf, PrivilegedOperationExecutor.getInstance(conf));
+ LOG.debug("Value of CGroupsV2Handler is: {}", cGroupV2Handler);
+ }
+ }
+ }
+ }
+
+ private static boolean isMountedInCGroupsV2(CGroupsHandler.CGroupController controller) {
+ return (cGroupV2Handler != null && cGroupV2Handler.getControllerPath(controller) != null);
}
/**
@@ -101,7 +121,7 @@ private static CGroupsHandler getInitializedCGroupsHandler(Configuration conf)
*/
public static CGroupsHandler getCGroupsHandler() {
- return cGroupsHandler;
+ return cGroupV1Handler;
}
/**
@@ -109,10 +129,10 @@ public static CGroupsHandler getCGroupsHandler() {
* not initialized, or if the path is empty.
*/
public static String getCgroupsRelativeRoot() {
- if (cGroupsHandler == null) {
+ if (getCGroupsHandler() == null) {
return null;
}
- String cGroupPath = cGroupsHandler.getRelativePathForCGroup("");
+ String cGroupPath = getCGroupsHandler().getRelativePathForCGroup("");
if (cGroupPath == null || cGroupPath.isEmpty()) {
return null;
}
@@ -153,9 +173,13 @@ private static CpuResourceHandler initCGroupsCpuResourceHandler(
synchronized (CpuResourceHandler.class) {
if (cGroupsCpuResourceHandler == null) {
LOG.debug("Creating new cgroups cpu handler");
- cGroupsCpuResourceHandler = cgroupsV2Enabled
- ? new CGroupsV2CpuResourceHandlerImpl(getInitializedCGroupsHandler(conf))
- : new CGroupsCpuResourceHandlerImpl(getInitializedCGroupsHandler(conf));
+
+ initializeCGroupHandlers(conf);
+ if (isMountedInCGroupsV2(CGroupsHandler.CGroupController.CPU)) {
+ cGroupsCpuResourceHandler = new CGroupsV2CpuResourceHandlerImpl(cGroupV2Handler);
+ } else {
+ cGroupsCpuResourceHandler = new CGroupsCpuResourceHandlerImpl(cGroupV1Handler);
+ }
return cGroupsCpuResourceHandler;
}
}
@@ -173,9 +197,11 @@ private static CpuResourceHandler initCGroupsCpuResourceHandler(
synchronized (OutboundBandwidthResourceHandler.class) {
if (trafficControlBandwidthHandler == null) {
LOG.info("Creating new traffic control bandwidth handler.");
+
+ initializeCGroupHandlers(conf);
trafficControlBandwidthHandler = new
TrafficControlBandwidthHandlerImpl(PrivilegedOperationExecutor
- .getInstance(conf), getInitializedCGroupsHandler(conf),
+ .getInstance(conf), cGroupV1Handler,
new TrafficController(conf, PrivilegedOperationExecutor
.getInstance(conf)));
}
@@ -208,10 +234,11 @@ public static ResourceHandler getNetworkTaggingHandler(Configuration conf)
synchronized (OutboundBandwidthResourceHandler.class) {
if (networkPacketTaggingHandlerImpl == null) {
LOG.info("Creating new network-tagging-handler.");
+
+ initializeCGroupHandlers(conf);
networkPacketTaggingHandlerImpl =
new NetworkPacketTaggingHandlerImpl(
- PrivilegedOperationExecutor.getInstance(conf),
- getInitializedCGroupsHandler(conf));
+ PrivilegedOperationExecutor.getInstance(conf), cGroupV1Handler);
}
}
}
@@ -239,9 +266,10 @@ private static CGroupsBlkioResourceHandlerImpl getCgroupsBlkioResourceHandler(
synchronized (DiskResourceHandler.class) {
if (cGroupsBlkioResourceHandler == null) {
LOG.debug("Creating new cgroups blkio handler");
+
+ initializeCGroupHandlers(conf);
cGroupsBlkioResourceHandler =
- new CGroupsBlkioResourceHandlerImpl(
- getInitializedCGroupsHandler(conf));
+ new CGroupsBlkioResourceHandlerImpl(cGroupV1Handler);
}
}
}
@@ -263,9 +291,13 @@ public static MemoryResourceHandler initMemoryResourceHandler(
if (cGroupsMemoryResourceHandler == null) {
synchronized (MemoryResourceHandler.class) {
if (cGroupsMemoryResourceHandler == null) {
- cGroupsMemoryResourceHandler = cgroupsV2Enabled
- ? new CGroupsV2MemoryResourceHandlerImpl(getInitializedCGroupsHandler(conf))
- : new CGroupsMemoryResourceHandlerImpl(getInitializedCGroupsHandler(conf));
+
+ initializeCGroupHandlers(conf);
+ if (isMountedInCGroupsV2(CGroupsHandler.CGroupController.MEMORY)) {
+ cGroupsMemoryResourceHandler = new CGroupsV2MemoryResourceHandlerImpl(cGroupV2Handler);
+ } else {
+ cGroupsMemoryResourceHandler = new CGroupsMemoryResourceHandlerImpl(cGroupV1Handler);
+ }
}
}
}
@@ -327,9 +359,10 @@ private static void addHandlersFromConfiguredResourcePlugins(
}
for (ResourcePlugin plugin : pluginMap.values()) {
+ initializeCGroupHandlers(conf);
addHandlerIfNotNull(handlerList,
plugin.createResourceHandler(nmContext,
- getInitializedCGroupsHandler(conf),
+ cGroupV1Handler,
PrivilegedOperationExecutor.getInstance(conf)));
}
}
@@ -360,21 +393,6 @@ static void nullifyResourceHandlerChain() throws ResourceHandlerException {
resourceHandlerChain = null;
}
- @VisibleForTesting
- static void resetCgroupsHandler() {
- cGroupsHandler = null;
- }
-
- @VisibleForTesting
- static void resetCpuResourceHandler() {
- cGroupsCpuResourceHandler = null;
- }
-
- @VisibleForTesting
- static void resetMemoryResourceHandler() {
- cGroupsMemoryResourceHandler = null;
- }
-
/**
* If a cgroup mount directory is specified, it returns cgroup directories
* with valid names.
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestCGroupsV2HandlerImpl.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestCGroupsV2HandlerImpl.java
index 1198cda7ab050..1ec952be049ff 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestCGroupsV2HandlerImpl.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestCGroupsV2HandlerImpl.java
@@ -210,6 +210,111 @@ public void testMtabParsing() throws Exception {
Assert.assertEquals(parentDir.getAbsolutePath(), memoryDir);
}
+ /*
+ * Create a mock mtab file with the following content for hybrid v1/v2:
+ * cgroup2 /path/to/parentV2Dir cgroup2 rw,nosuid,nodev,noexec,relatime,memory_recursiveprot 0 0
+ * cgroup /path/to/parentDir/memory cgroup rw,nosuid,nodev,noexec,relatime,memory 0 0
+ *
+ * Create the following cgroup hierarchy:
+ *
+ * parentDir
+ * __________________________________
+ * / \
+ * unified memory
+ * _________________________________________________
+ * / \ \
+ * cgroup.controllers cgroup.subtree_control test-hadoop-yarn (hierarchyDir)
+ * _________________
+ * / \
+ * cgroup.controllers cgroup.subtree_control
+ */
+ public File createPremountedHybridCgroups(File v1ParentDir)
+ throws IOException {
+ File v2ParentDir = new File(v1ParentDir, "unified");
+
+ String mtabContent =
+ "cgroup " + v1ParentDir.getAbsolutePath() + "/memory"
+ + " cgroup rw,nosuid,nodev,noexec,relatime,memory 0 0\n"
+ + "cgroup2 " + v2ParentDir.getAbsolutePath()
+ + " cgroup2 rw,nosuid,nodev,noexec,relatime,memory_recursiveprot 0 0\n";
+
+ File mockMtab = createFileWithContent(v1ParentDir, UUID.randomUUID().toString(), mtabContent);
+
+ String enabledV2Controllers = "cpuset cpu io hugetlb pids rdma misc\n";
+ File controllersFile = createFileWithContent(v2ParentDir,
+ CGroupsHandler.CGROUP_CONTROLLERS_FILE, enabledV2Controllers);
+
+ File subtreeControlFile = new File(v2ParentDir, CGroupsHandler.CGROUP_SUBTREE_CONTROL_FILE);
+ Assert.assertTrue("empty subtree_control file should be created",
+ subtreeControlFile.createNewFile());
+
+ File hierarchyDir = new File(v2ParentDir, hierarchy);
+ if (!hierarchyDir.mkdirs()) {
+ String message = "Could not create directory " + hierarchyDir.getAbsolutePath();
+ throw new IOException(message);
+ }
+ hierarchyDir.deleteOnExit();
+
+ FileUtils.copyFile(controllersFile, new File(hierarchyDir,
+ CGroupsHandler.CGROUP_CONTROLLERS_FILE));
+ FileUtils.copyFile(subtreeControlFile, new File(hierarchyDir,
+ CGroupsHandler.CGROUP_SUBTREE_CONTROL_FILE));
+
+ return mockMtab;
+ }
+
+ @Test
+ public void testHybridMtabParsing() throws Exception {
+ // Initialize mtab and cgroup dir
+ File v1ParentDir = new File(tmpPath);
+
+ File v2ParentDir = new File(v1ParentDir, "unified");
+ Assert.assertTrue("temp dir should be created", v2ParentDir.mkdirs());
+ v2ParentDir.deleteOnExit();
+
+ // create mock cgroup
+ File mockMtabFile = createPremountedHybridCgroups(v1ParentDir);
+
+ // create memory cgroup for v1
+ File memoryCgroup = new File(v1ParentDir, "memory");
+ assertTrue("Directory should be created", memoryCgroup.mkdirs());
+
+ // init v1 and v2 handlers
+ CGroupsHandlerImpl cGroupsHandler = new CGroupsHandlerImpl(
+ createMountConfiguration(),
+ privilegedOperationExecutorMock, mockMtabFile.getAbsolutePath());
+ CGroupsV2HandlerImpl cGroupsV2Handler = new CGroupsV2HandlerImpl(
+ createMountConfiguration(),
+ privilegedOperationExecutorMock, mockMtabFile.getAbsolutePath());
+
+ // Verify resource handlers that are enabled in v1
+ Map> newMtab =
+ cGroupsHandler.parseMtab(mockMtabFile.getAbsolutePath());
+ Map controllerv1Paths =
+ cGroupsHandler.initializeControllerPathsFromMtab(
+ newMtab);
+
+ Assert.assertEquals(1, controllerv1Paths.size());
+ assertTrue(controllerv1Paths
+ .containsKey(CGroupsHandler.CGroupController.MEMORY));
+ String memoryDir =
+ controllerv1Paths.get(CGroupsHandler.CGroupController.MEMORY);
+ Assert.assertEquals(memoryCgroup.getAbsolutePath(), memoryDir);
+
+ // Verify resource handlers that are enabled in v2
+ newMtab =
+ cGroupsV2Handler.parseMtab(mockMtabFile.getAbsolutePath());
+ Map controllerPaths =
+ cGroupsV2Handler.initializeControllerPathsFromMtab(
+ newMtab);
+
+ Assert.assertEquals(3, controllerPaths.size());
+ assertTrue(controllerPaths
+ .containsKey(CGroupsHandler.CGroupController.CPU));
+ String cpuDir = controllerPaths.get(CGroupsHandler.CGroupController.CPU);
+ Assert.assertEquals(v2ParentDir.getAbsolutePath(), cpuDir);
+ }
+
@Test
public void testManualCgroupSetting() throws Exception {
YarnConfiguration conf = new YarnConfiguration();
@@ -217,8 +322,27 @@ public void testManualCgroupSetting() throws Exception {
conf.set(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_HIERARCHY,
"/hadoop-yarn");
- File baseCgroup = new File(tmpPath);
- File subCgroup = new File(tmpPath, "/hadoop-yarn");
+ validateCgroupV2Controllers(conf, tmpPath);
+ }
+
+ @Test
+ public void testManualHybridCgroupSetting() throws Exception {
+ String unifiedPath = tmpPath + "/unified";
+
+ YarnConfiguration conf = new YarnConfiguration();
+ conf.set(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_MOUNT_PATH, tmpPath);
+ conf.set(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_V2_MOUNT_PATH, unifiedPath);
+ conf.set(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_HIERARCHY,
+ "/hadoop-yarn");
+
+ validateCgroupV1Controllers(conf, tmpPath);
+ validateCgroupV2Controllers(conf, unifiedPath);
+ }
+
+ private void validateCgroupV2Controllers(YarnConfiguration conf, String mountPath)
+ throws Exception {
+ File baseCgroup = new File(mountPath);
+ File subCgroup = new File(mountPath, "/hadoop-yarn");
Assert.assertTrue("temp dir should be created", subCgroup.mkdirs());
subCgroup.deleteOnExit();
@@ -235,8 +359,8 @@ public void testManualCgroupSetting() throws Exception {
cGroupsHandler.initializeCGroupController(CGroupsHandler.CGroupController.CPU);
Assert.assertEquals("CPU cgroup path was not set", subCgroup.getAbsolutePath(),
- new File(cGroupsHandler.getPathForCGroup(
- CGroupsHandler.CGroupController.CPU, "")).getAbsolutePath());
+ new File(cGroupsHandler.getPathForCGroup(
+ CGroupsHandler.CGroupController.CPU, "")).getAbsolutePath());
// Verify that the subtree control file was updated
String subtreeControllersEnabledString = FileUtils.readFileToString(subtreeControlFile,
@@ -276,4 +400,21 @@ public void testManualCgroupSetting() throws Exception {
Assert.assertTrue("Controllers not enabled in subtree control file",
cGroupsHandler.getValidCGroups().containsAll(subtreeControllersEnabled));
}
+
+ private void validateCgroupV1Controllers(YarnConfiguration conf, String mountPath)
+ throws ResourceHandlerException {
+ File blkio = new File(new File(mountPath, "blkio"), "/hadoop-yarn");
+
+ Assert.assertTrue("temp dir should be created", blkio.mkdirs());
+
+ CGroupsHandlerImpl cGroupsv1Handler = new CGroupsHandlerImpl(conf, null);
+ cGroupsv1Handler.initializeCGroupController(
+ CGroupsHandler.CGroupController.BLKIO);
+
+ Assert.assertEquals("BLKIO CGRoup path was not set", blkio.getAbsolutePath(),
+ new File(cGroupsv1Handler.getPathForCGroup(
+ CGroupsHandler.CGroupController.BLKIO, "")).getAbsolutePath());
+
+ FileUtils.deleteQuietly(blkio);
+ }
}
\ No newline at end of file
diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestResourceHandlerModule.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestResourceHandlerModule.java
index 9104defb92ae4..171bfafc4fe7f 100644
--- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestResourceHandlerModule.java
+++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/test/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/resources/TestResourceHandlerModule.java
@@ -49,9 +49,6 @@ public void setup() throws Exception {
networkEnabledConf.setBoolean(YarnConfiguration.NM_NETWORK_RESOURCE_ENABLED,
true);
ResourceHandlerModule.nullifyResourceHandlerChain();
- ResourceHandlerModule.resetCgroupsHandler();
- ResourceHandlerModule.resetCpuResourceHandler();
- ResourceHandlerModule.resetMemoryResourceHandler();
}
@Test
@@ -114,69 +111,4 @@ public void testDiskResourceHandler() throws Exception {
Assert.fail("Null returned");
}
}
-
- @Test
- public void testCpuResourceHandlerClassForCgroupV1() throws ResourceHandlerException {
- Configuration conf = new YarnConfiguration();
- conf.setBoolean(YarnConfiguration.NM_CPU_RESOURCE_ENABLED, true);
- conf.setBoolean(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_V2_ENABLED, false);
-
- initResourceHandlerChain(conf);
-
- Assert.assertTrue(ResourceHandlerModule.getCpuResourceHandler()
- instanceof CGroupsCpuResourceHandlerImpl);
- Assert.assertTrue(ResourceHandlerModule.getCGroupsHandler()
- instanceof CGroupsHandlerImpl);
- }
-
- @Test
- public void testCpuResourceHandlerClassForCgroupV2() throws ResourceHandlerException {
- Configuration conf = new YarnConfiguration();
- conf.setBoolean(YarnConfiguration.NM_CPU_RESOURCE_ENABLED, true);
- conf.setBoolean(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_V2_ENABLED, true);
-
- initResourceHandlerChain(conf);
-
- Assert.assertTrue(ResourceHandlerModule.getCpuResourceHandler()
- instanceof CGroupsV2CpuResourceHandlerImpl);
- Assert.assertTrue(ResourceHandlerModule.getCGroupsHandler()
- instanceof CGroupsV2HandlerImpl);
- }
-
- @Test
- public void testMemoryResourceHandlerClassForCgroupV1() throws ResourceHandlerException {
- Configuration conf = new YarnConfiguration();
- conf.setBoolean(YarnConfiguration.NM_MEMORY_RESOURCE_ENABLED, true);
- conf.setBoolean(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_V2_ENABLED, false);
-
- initResourceHandlerChain(conf);
-
- Assert.assertTrue(ResourceHandlerModule.getMemoryResourceHandler()
- instanceof CGroupsMemoryResourceHandlerImpl);
- Assert.assertTrue(ResourceHandlerModule.getCGroupsHandler()
- instanceof CGroupsHandlerImpl);
- }
-
- @Test
- public void testMemoryResourceHandlerClassForCgroupV2() throws ResourceHandlerException {
- Configuration conf = new YarnConfiguration();
- conf.setBoolean(YarnConfiguration.NM_MEMORY_RESOURCE_ENABLED, true);
- conf.setBoolean(YarnConfiguration.NM_LINUX_CONTAINER_CGROUPS_V2_ENABLED, true);
-
- initResourceHandlerChain(conf);
-
- Assert.assertTrue(ResourceHandlerModule.getMemoryResourceHandler()
- instanceof CGroupsV2MemoryResourceHandlerImpl);
- Assert.assertTrue(ResourceHandlerModule.getCGroupsHandler()
- instanceof CGroupsV2HandlerImpl);
- }
-
- private void initResourceHandlerChain(Configuration conf) throws ResourceHandlerException {
- ResourceHandlerChain resourceHandlerChain =
- ResourceHandlerModule.getConfiguredResourceHandlerChain(conf,
- mock(Context.class));
- if (resourceHandlerChain == null) {
- Assert.fail("Could not initialize resource handler chain");
- }
- }
}
\ No newline at end of file