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:
parent
9fe9ee1c16
commit
6593aaf117
|
@ -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
|
||||||
|
|
|
@ -144,11 +144,9 @@ 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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Dispatcher related code
|
// Dispatcher related code
|
||||||
protected void handleStoreEvent(NodeLabelsStoreEvent event) {
|
protected void handleStoreEvent(NodeLabelsStoreEvent 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) {
|
||||||
|
// shouldn't overwrite it to avoid changing the Label.resource
|
||||||
|
if (this.labelCollections.get(label) == null) {
|
||||||
this.labelCollections.put(label, new Label());
|
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(), ",") + "]");
|
||||||
|
@ -454,11 +456,14 @@ public class CommonNodeLabelsManager extends AbstractService {
|
||||||
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;
|
||||||
|
|
|
@ -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),
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue