YARN-2753. Fixed a bunch of bugs in the NodeLabelsManager classes. Contributed by Zhihai xu.

(cherry picked from commit 4cfd5bc7c1)
This commit is contained in:
Vinod Kumar Vavilapalli 2014-11-07 14:15:53 -08:00
parent 9fe9ee1c16
commit 6593aaf117
3 changed files with 46 additions and 11 deletions

View File

@ -831,6 +831,9 @@ Release 2.6.0 - UNRELEASED
YARN-2803. MR distributed cache not working correctly on Windows after YARN-2803. MR distributed cache not working correctly on Windows after
NodeManager privileged account changes. (Craig Welch via cnauroth) NodeManager privileged account changes. (Craig Welch via cnauroth)
YARN-2753. Fixed a bunch of bugs in the NodeLabelsManager classes. (Zhihai xu
via vinodkv)
Release 2.5.2 - UNRELEASED Release 2.5.2 - UNRELEASED
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -144,9 +144,7 @@ public class CommonNodeLabelsManager extends AbstractService {
@Override @Override
public void handle(NodeLabelsStoreEvent event) { public void handle(NodeLabelsStoreEvent event) {
if (isInState(STATE.STARTED)) { handleStoreEvent(event);
handleStoreEvent(event);
}
} }
} }
@ -256,7 +254,7 @@ public class CommonNodeLabelsManager extends AbstractService {
if (null == labels || labels.isEmpty()) { if (null == labels || labels.isEmpty()) {
return; return;
} }
Set<String> newLabels = new HashSet<String>();
labels = normalizeLabels(labels); labels = normalizeLabels(labels);
// do a check before actual adding them, will throw exception if any of them // do a check before actual adding them, will throw exception if any of them
@ -266,11 +264,15 @@ public class CommonNodeLabelsManager extends AbstractService {
} }
for (String label : labels) { for (String label : labels) {
this.labelCollections.put(label, new Label()); // shouldn't overwrite it to avoid changing the Label.resource
if (this.labelCollections.get(label) == null) {
this.labelCollections.put(label, new Label());
newLabels.add(label);
}
} }
if (null != dispatcher) { if (null != dispatcher && !newLabels.isEmpty()) {
dispatcher.getEventHandler().handle( dispatcher.getEventHandler().handle(
new StoreNewClusterNodeLabels(labels)); new StoreNewClusterNodeLabels(newLabels));
} }
LOG.info("Add labels: [" + StringUtils.join(labels.iterator(), ",") + "]"); LOG.info("Add labels: [" + StringUtils.join(labels.iterator(), ",") + "]");
@ -453,12 +455,15 @@ public class CommonNodeLabelsManager extends AbstractService {
LOG.error(msg); LOG.error(msg);
throw new IOException(msg); throw new IOException(msg);
} }
if (labels == null || labels.isEmpty()) { // the labels will never be null
if (labels.isEmpty()) {
continue; continue;
} }
if (!originalLabels.containsAll(labels)) { // originalLabels may be null,
// because when a Node is created, Node.labels can be null.
if (originalLabels == null || !originalLabels.containsAll(labels)) {
String msg = String msg =
"Try to remove labels = [" + StringUtils.join(labels, ",") "Try to remove labels = [" + StringUtils.join(labels, ",")
+ "], but not all labels contained by NM=" + nodeId; + "], but not all labels contained by NM=" + nodeId;

View File

@ -74,6 +74,13 @@ public class TestRMNodeLabelsManager extends NodeLabelTestBase {
Assert.assertEquals(mgr.getResourceByLabel("p1", null), Assert.assertEquals(mgr.getResourceByLabel("p1", null),
Resources.add(SMALL_RESOURCE, LARGE_NODE)); Resources.add(SMALL_RESOURCE, LARGE_NODE));
// check add labels multiple times shouldn't overwrite
// original attributes on labels like resource
mgr.addToCluserNodeLabels(toSet("p1", "p4"));
Assert.assertEquals(mgr.getResourceByLabel("p1", null),
Resources.add(SMALL_RESOURCE, LARGE_NODE));
Assert.assertEquals(mgr.getResourceByLabel("p4", null), EMPTY_RESOURCE);
// change the large NM to small, check if resource updated // change the large NM to small, check if resource updated
mgr.updateNodeResource(NodeId.newInstance("n1", 2), SMALL_RESOURCE); mgr.updateNodeResource(NodeId.newInstance("n1", 2), SMALL_RESOURCE);
Assert.assertEquals(mgr.getResourceByLabel("p1", null), Assert.assertEquals(mgr.getResourceByLabel("p1", null),
@ -374,7 +381,7 @@ public class TestRMNodeLabelsManager extends NodeLabelTestBase {
Assert.assertEquals(clusterResource, Assert.assertEquals(clusterResource,
mgr.getQueueResource("Q5", q5Label, clusterResource)); mgr.getQueueResource("Q5", q5Label, clusterResource));
} }
@Test(timeout=5000) @Test(timeout=5000)
public void testGetLabelResourceWhenMultipleNMsExistingInSameHost() throws IOException { public void testGetLabelResourceWhenMultipleNMsExistingInSameHost() throws IOException {
// active two NM to n1, one large and one small // active two NM to n1, one large and one small
@ -401,4 +408,24 @@ public class TestRMNodeLabelsManager extends NodeLabelTestBase {
mgr.getResourceByLabel("p1", null), mgr.getResourceByLabel("p1", null),
Resources.multiply(SMALL_RESOURCE, 2)); Resources.multiply(SMALL_RESOURCE, 2));
} }
@Test(timeout = 5000)
public void testRemoveLabelsFromNode() throws Exception {
mgr.addToCluserNodeLabels(toSet("p1", "p2", "p3"));
mgr.replaceLabelsOnNode(ImmutableMap.of(toNodeId("n1"), toSet("p1"),
toNodeId("n2"), toSet("p2"), toNodeId("n3"), toSet("p3")));
// active one NM to n1:1
mgr.activateNode(NodeId.newInstance("n1", 1), SMALL_RESOURCE);
try {
mgr.removeLabelsFromNode(ImmutableMap.of(toNodeId("n1:1"), toSet("p1")));
Assert.fail("removeLabelsFromNode should trigger IOException");
} catch (IOException e) {
}
mgr.replaceLabelsOnNode(ImmutableMap.of(toNodeId("n1:1"), toSet("p1")));
try {
mgr.removeLabelsFromNode(ImmutableMap.of(toNodeId("n1:1"), toSet("p1")));
} catch (IOException e) {
Assert.fail("IOException from removeLabelsFromNode " + e);
}
}
} }