YARN-9858. Optimize RMContext getExclusiveEnforcedPartitions. Contributed by Jonathan Hung.
This commit is contained in:
parent
5e56914650
commit
6529a30d9e
|
@ -23,7 +23,9 @@ import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.hadoop.HadoopIllegalArgumentException;
|
import org.apache.hadoop.HadoopIllegalArgumentException;
|
||||||
import org.apache.hadoop.classification.InterfaceAudience.Private;
|
import org.apache.hadoop.classification.InterfaceAudience.Private;
|
||||||
|
@ -3487,6 +3489,20 @@ public class YarnConfiguration extends Configuration {
|
||||||
public static final String EXCLUSIVE_ENFORCED_PARTITIONS = NODE_LABELS_PREFIX
|
public static final String EXCLUSIVE_ENFORCED_PARTITIONS = NODE_LABELS_PREFIX
|
||||||
+ EXCLUSIVE_ENFORCED_PARTITIONS_SUFFIX;
|
+ EXCLUSIVE_ENFORCED_PARTITIONS_SUFFIX;
|
||||||
|
|
||||||
|
@Private
|
||||||
|
public static Set<String> getExclusiveEnforcedPartitions(
|
||||||
|
Configuration conf) {
|
||||||
|
Set<String> exclusiveEnforcedPartitions = new HashSet<>();
|
||||||
|
String[] configuredPartitions = conf.getStrings(
|
||||||
|
EXCLUSIVE_ENFORCED_PARTITIONS);
|
||||||
|
if (configuredPartitions != null) {
|
||||||
|
for (String partition : configuredPartitions) {
|
||||||
|
exclusiveEnforcedPartitions.add(partition);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return exclusiveEnforcedPartitions;
|
||||||
|
}
|
||||||
|
|
||||||
public static final String MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY =
|
public static final String MAX_CLUSTER_LEVEL_APPLICATION_PRIORITY =
|
||||||
YARN_PREFIX + "cluster.max-application-priority";
|
YARN_PREFIX + "cluster.max-application-priority";
|
||||||
|
|
||||||
|
|
|
@ -109,6 +109,7 @@ final class DefaultAMSProcessor implements ApplicationMasterServiceProcessor {
|
||||||
private RMContext rmContext;
|
private RMContext rmContext;
|
||||||
private ResourceProfilesManager resourceProfilesManager;
|
private ResourceProfilesManager resourceProfilesManager;
|
||||||
private boolean timelineServiceV2Enabled;
|
private boolean timelineServiceV2Enabled;
|
||||||
|
private Set<String> exclusiveEnforcedPartitions;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init(ApplicationMasterServiceContext amsContext,
|
public void init(ApplicationMasterServiceContext amsContext,
|
||||||
|
@ -117,6 +118,8 @@ final class DefaultAMSProcessor implements ApplicationMasterServiceProcessor {
|
||||||
this.resourceProfilesManager = rmContext.getResourceProfilesManager();
|
this.resourceProfilesManager = rmContext.getResourceProfilesManager();
|
||||||
this.timelineServiceV2Enabled = YarnConfiguration.
|
this.timelineServiceV2Enabled = YarnConfiguration.
|
||||||
timelineServiceV2Enabled(rmContext.getYarnConfiguration());
|
timelineServiceV2Enabled(rmContext.getYarnConfiguration());
|
||||||
|
this.exclusiveEnforcedPartitions = YarnConfiguration
|
||||||
|
.getExclusiveEnforcedPartitions(rmContext.getYarnConfiguration());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -227,8 +230,7 @@ final class DefaultAMSProcessor implements ApplicationMasterServiceProcessor {
|
||||||
}
|
}
|
||||||
if (ResourceRequest.ANY.equals(req.getResourceName())) {
|
if (ResourceRequest.ANY.equals(req.getResourceName())) {
|
||||||
SchedulerUtils.enforcePartitionExclusivity(req,
|
SchedulerUtils.enforcePartitionExclusivity(req,
|
||||||
getRmContext().getExclusiveEnforcedPartitions(),
|
exclusiveEnforcedPartitions, asc.getNodeLabelExpression());
|
||||||
asc.getNodeLabelExpression());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -121,7 +121,8 @@ public class RMAppManager implements EventHandler<RMAppManagerEvent>,
|
||||||
this.authorizer = YarnAuthorizationProvider.getInstance(conf);
|
this.authorizer = YarnAuthorizationProvider.getInstance(conf);
|
||||||
this.timelineServiceV2Enabled = YarnConfiguration.
|
this.timelineServiceV2Enabled = YarnConfiguration.
|
||||||
timelineServiceV2Enabled(conf);
|
timelineServiceV2Enabled(conf);
|
||||||
this.exclusiveEnforcedPartitions = context.getExclusiveEnforcedPartitions();
|
this.exclusiveEnforcedPartitions = YarnConfiguration
|
||||||
|
.getExclusiveEnforcedPartitions(rmContext.getYarnConfiguration());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager;
|
package org.apache.hadoop.yarn.server.resourcemanager;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.Set;
|
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
|
@ -178,7 +177,4 @@ public interface RMContext extends ApplicationMasterServiceContext {
|
||||||
|
|
||||||
void setPlacementConstraintManager(
|
void setPlacementConstraintManager(
|
||||||
PlacementConstraintManager placementConstraintManager);
|
PlacementConstraintManager placementConstraintManager);
|
||||||
|
|
||||||
Set<String> getExclusiveEnforcedPartitions();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,8 +21,6 @@ package org.apache.hadoop.yarn.server.resourcemanager;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
|
@ -35,7 +33,6 @@ import org.apache.hadoop.yarn.LocalConfigurationProvider;
|
||||||
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
||||||
import org.apache.hadoop.yarn.api.records.NodeId;
|
import org.apache.hadoop.yarn.api.records.NodeId;
|
||||||
import org.apache.hadoop.yarn.conf.ConfigurationProvider;
|
import org.apache.hadoop.yarn.conf.ConfigurationProvider;
|
||||||
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
|
||||||
import org.apache.hadoop.yarn.event.Dispatcher;
|
import org.apache.hadoop.yarn.event.Dispatcher;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.ahs.RMApplicationHistoryWriter;
|
import org.apache.hadoop.yarn.server.resourcemanager.ahs.RMApplicationHistoryWriter;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.metrics.SystemMetricsPublisher;
|
import org.apache.hadoop.yarn.server.resourcemanager.metrics.SystemMetricsPublisher;
|
||||||
|
@ -623,20 +620,4 @@ public class RMContextImpl implements RMContext {
|
||||||
this.activeServiceContext.setResourceProfilesManager(mgr);
|
this.activeServiceContext.setResourceProfilesManager(mgr);
|
||||||
}
|
}
|
||||||
// Note: Read java doc before adding any services over here.
|
// Note: Read java doc before adding any services over here.
|
||||||
|
|
||||||
public Set<String> getExclusiveEnforcedPartitions() {
|
|
||||||
Set<String> exclusiveEnforcedPartitions = new HashSet<>();
|
|
||||||
Configuration conf = getYarnConfiguration();
|
|
||||||
if (conf == null) {
|
|
||||||
return new HashSet<>();
|
|
||||||
}
|
|
||||||
String[] configuredPartitions = conf.getStrings(
|
|
||||||
YarnConfiguration.EXCLUSIVE_ENFORCED_PARTITIONS);
|
|
||||||
if (configuredPartitions != null) {
|
|
||||||
for (String partition : configuredPartitions) {
|
|
||||||
exclusiveEnforcedPartitions.add(partition);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return exclusiveEnforcedPartitions;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -166,6 +166,7 @@ public class TestAppManager{
|
||||||
metricsPublisher = mock(SystemMetricsPublisher.class);
|
metricsPublisher = mock(SystemMetricsPublisher.class);
|
||||||
context.setSystemMetricsPublisher(metricsPublisher);
|
context.setSystemMetricsPublisher(metricsPublisher);
|
||||||
context.setRMApplicationHistoryWriter(writer);
|
context.setRMApplicationHistoryWriter(writer);
|
||||||
|
((RMContextImpl) context).setYarnConfiguration(new YarnConfiguration());
|
||||||
return context;
|
return context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue