HDFS-14298. Improve log messages of ECTopologyVerifier. Contributed by Kitti Nanasi.

This commit is contained in:
Surendra Singh Lilhore 2019-02-23 01:08:15 +05:30
parent ed13cf8406
commit 7d3b567194
3 changed files with 128 additions and 128 deletions

View File

@ -93,18 +93,19 @@ public final class ECTopologyVerifier {
final int numOfRacks, final int numOfDataNodes, String readablePolicies) { final int numOfRacks, final int numOfDataNodes, String readablePolicies) {
String resultMessage; String resultMessage;
if (numOfDataNodes < minDN) { if (numOfDataNodes < minDN) {
resultMessage = String.format("The number of DataNodes (%d) is less " + resultMessage = String.format("%d DataNodes are required for " +
"than the minimum required number of DataNodes (%d) for the " + "the erasure coding policies: %s. " +
"erasure coding policies: %s", numOfDataNodes, minDN, "The number of DataNodes is only %d.",
readablePolicies); minDN, readablePolicies, numOfDataNodes);
LOG.debug(resultMessage); LOG.debug(resultMessage);
return new ECTopologyVerifierResult(false, resultMessage); return new ECTopologyVerifierResult(false, resultMessage);
} }
if (numOfRacks < minRack) { if (numOfRacks < minRack) {
resultMessage = String.format("The number of racks (%d) is less than " + resultMessage = String.format("%d racks are required for " +
"the minimum required number of racks (%d) for the erasure " + "the erasure coding policies: %s. " +
"coding policies: %s", numOfRacks, minRack, readablePolicies); "The number of racks is only %d.",
minRack, readablePolicies, numOfRacks);
LOG.debug(resultMessage); LOG.debug(resultMessage);
return new ECTopologyVerifierResult(false, resultMessage); return new ECTopologyVerifierResult(false, resultMessage);
} }

View File

@ -1032,8 +1032,8 @@ public class TestNameNodeMXBean {
assertFalse("Test cluster does not support all enabled " + assertFalse("Test cluster does not support all enabled " +
"erasure coding policies.", isSupported); "erasure coding policies.", isSupported);
assertTrue(resultMessage.contains("The number of racks")); assertTrue(resultMessage.contains("3 racks are required for " +
assertTrue(resultMessage.contains("is less than the minimum required " + "the erasure coding policies: RS-6-3-1024k. " +
"number of racks")); "The number of racks is only 1."));
} }
} }

View File

@ -53,6 +53,19 @@ public class TestECAdmin {
private static final PrintStream OLD_OUT = System.out; private static final PrintStream OLD_OUT = System.out;
private static final PrintStream OLD_ERR = System.err; private static final PrintStream OLD_ERR = System.err;
private final static String RS_3_2 =
SystemErasureCodingPolicies.getByID(
SystemErasureCodingPolicies.RS_3_2_POLICY_ID).getName();
private final static String RS_6_3 =
SystemErasureCodingPolicies.getByID(
SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName();
private final static String RS_10_4 =
SystemErasureCodingPolicies.getByID(
SystemErasureCodingPolicies.RS_10_4_POLICY_ID).getName();
private final static String XOR_2_1 =
SystemErasureCodingPolicies.getByID(
SystemErasureCodingPolicies.XOR_2_1_POLICY_ID).getName();
@Rule @Rule
public Timeout globalTimeout = public Timeout globalTimeout =
new Timeout(300000, TimeUnit.MILLISECONDS); new Timeout(300000, TimeUnit.MILLISECONDS);
@ -82,99 +95,77 @@ public class TestECAdmin {
@Test @Test
public void testRS63MinDN() throws Exception { public void testRS63MinDN() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 6, 3, 0); final int numDataNodes = 6;
String[] args = {"-verifyClusterSetup"}; final int numRacks = 3;
final int ret = admin.run(args); final int expectedNumDataNodes = 9;
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString()); cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
int ret = runCommandWithParams("-verifyClusterSetup");
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughDataNodesMessage(RS_6_3, numDataNodes, expectedNumDataNodes);
"should be logged correctly", out.toString()
.contains("less than the minimum required number of DataNodes"));
assertTrue("Error output should be empty", err.toString().isEmpty());
} }
@Test @Test
public void testRS104MinRacks() throws Exception { public void testRS104MinRacks() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 15, 3, 0); final String testPolicy = RS_10_4;
cluster.getFileSystem().enableErasureCodingPolicy( final int numDataNodes = 15;
SystemErasureCodingPolicies final int numRacks = 3;
.getByID(SystemErasureCodingPolicies.RS_10_4_POLICY_ID).getName()); final int expectedNumRacks = 4;
String[] args = {"-verifyClusterSetup"};
final int ret = admin.run(args); cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
LOG.info("Command stdout: {}", out.toString()); cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
LOG.info("Command stderr: {}", err.toString()); cluster.getFileSystem().enableErasureCodingPolicy(testPolicy);
int ret = runCommandWithParams("-verifyClusterSetup");
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughRacksMessage(testPolicy, numRacks, expectedNumRacks);
"should be logged correctly", out.toString()
.contains("less than the minimum required number of racks"));
assertTrue("Error output should be empty", err.toString().isEmpty());
} }
@Test @Test
public void testXOR21MinRacks() throws Exception { public void testXOR21MinRacks() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 5, 2, 0); final String testPolicy = XOR_2_1;
cluster.getFileSystem().disableErasureCodingPolicy( final int numDataNodes = 5;
SystemErasureCodingPolicies final int numRacks = 2;
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName()); final int expectedNumRacks = 3;
cluster.getFileSystem().enableErasureCodingPolicy(
SystemErasureCodingPolicies cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
.getByID(SystemErasureCodingPolicies.XOR_2_1_POLICY_ID).getName()); cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
String[] args = {"-verifyClusterSetup"}; cluster.getFileSystem().enableErasureCodingPolicy(testPolicy);
final int ret = admin.run(args); int ret = runCommandWithParams("-verifyClusterSetup");
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughRacksMessage(testPolicy, numRacks, expectedNumRacks);
"should be logged correctly", out.toString()
.contains("less than the minimum required number of racks"));
assertTrue("Error output should be empty", err.toString().isEmpty());
} }
@Test @Test
public void testRS32MinRacks() throws Exception { public void testRS32MinRacks() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 5, 2, 0); final String testPolicy = RS_3_2;
cluster.getFileSystem().disableErasureCodingPolicy( final int numDataNodes = 5;
SystemErasureCodingPolicies final int numRacks = 2;
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName()); final int expectedNumRacks = 3;
cluster.getFileSystem().enableErasureCodingPolicy(
SystemErasureCodingPolicies cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
.getByID(SystemErasureCodingPolicies.RS_3_2_POLICY_ID).getName()); cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
String[] args = {"-verifyClusterSetup"}; cluster.getFileSystem().enableErasureCodingPolicy(testPolicy);
final int ret = admin.run(args); int ret = runCommandWithParams("-verifyClusterSetup");
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughRacksMessage(testPolicy, numRacks, expectedNumRacks);
"should be logged correctly", out.toString()
.contains("less than the minimum required number of racks"));
assertTrue("Error output should be empty", err.toString().isEmpty());
} }
@Test @Test
public void testRS63Good() throws Exception { public void testRS63Good() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 9, 3, 0); cluster = DFSTestUtil.setupCluster(conf, 9, 3, 0);
String[] args = {"-verifyClusterSetup"}; int ret = runCommandWithParams("-verifyClusterSetup");
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is successful", 0, ret); assertEquals("Return value of the command is successful", 0, ret);
assertTrue("Result of cluster topology verify " + assertTrue("Result of cluster topology verify " +
"should be logged correctly", out.toString().contains( "should be logged correctly", out.toString().contains(
"The cluster setup can support EC policies: RS-6-3-1024k")); "The cluster setup can support EC policies: " + RS_6_3));
assertTrue("Error output should be empty", err.toString().isEmpty()); assertTrue("Error output should be empty", err.toString().isEmpty());
} }
@Test @Test
public void testNoECEnabled() throws Exception { public void testNoECEnabled() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 9, 3, 0); cluster = DFSTestUtil.setupCluster(conf, 9, 3, 0);
cluster.getFileSystem().disableErasureCodingPolicy( cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
SystemErasureCodingPolicies int ret = runCommandWithParams("-verifyClusterSetup");
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName());
String[] args = {"-verifyClusterSetup"};
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is successful", 0, ret); assertEquals("Return value of the command is successful", 0, ret);
assertTrue("Result of cluster topology verify " + assertTrue("Result of cluster topology verify " +
"should be logged correctly", "should be logged correctly",
@ -184,40 +175,38 @@ public class TestECAdmin {
@Test @Test
public void testUnsuccessfulEnablePolicyMessage() throws Exception { public void testUnsuccessfulEnablePolicyMessage() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 5, 2, 0); final String testPolicy = RS_3_2;
cluster.getFileSystem().disableErasureCodingPolicy( final int numDataNodes = 5;
SystemErasureCodingPolicies final int numRacks = 2;
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName());
String[] args = {"-enablePolicy", "-policy", "RS-3-2-1024k"}; cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
final int ret = runCommandWithParams("-enablePolicy", "-policy",
testPolicy);
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is successful", 0, ret); assertEquals("Return value of the command is successful", 0, ret);
assertTrue("Enabling policy should be logged", out.toString() assertTrue("Enabling policy should be logged", out.toString()
.contains("Erasure coding policy RS-3-2-1024k is enabled")); .contains("Erasure coding policy " + testPolicy + " is enabled"));
assertTrue("Warning about cluster topology should be printed", assertTrue("Warning about cluster topology should be printed",
err.toString().contains("Warning: The cluster setup does not support " + err.toString().contains("Warning: The cluster setup does not support " +
"EC policy RS-3-2-1024k. Reason:")); "EC policy " + testPolicy + ". Reason:"));
assertTrue("Warning about cluster topology should be printed", assertTrue("Warning about cluster topology should be printed",
err.toString() err.toString()
.contains("less than the minimum required number of racks")); .contains(" racks are required for the erasure coding policies: " +
testPolicy));
} }
@Test @Test
public void testSuccessfulEnablePolicyMessage() throws Exception { public void testSuccessfulEnablePolicyMessage() throws Exception {
final String testPolicy = RS_3_2;
cluster = DFSTestUtil.setupCluster(conf, 5, 3, 0); cluster = DFSTestUtil.setupCluster(conf, 5, 3, 0);
cluster.getFileSystem().disableErasureCodingPolicy( cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
SystemErasureCodingPolicies final int ret = runCommandWithParams("-enablePolicy", "-policy",
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName()); testPolicy);
String[] args = {"-enablePolicy", "-policy", "RS-3-2-1024k"};
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is successful", 0, ret); assertEquals("Return value of the command is successful", 0, ret);
assertTrue("Enabling policy should be logged", out.toString() assertTrue("Enabling policy should be logged", out.toString()
.contains("Erasure coding policy RS-3-2-1024k is enabled")); .contains("Erasure coding policy " + testPolicy + " is enabled"));
assertFalse("Warning about cluster topology should not be printed", assertFalse("Warning about cluster topology should not be printed",
out.toString().contains("Warning: The cluster setup does not support")); out.toString().contains("Warning: The cluster setup does not support"));
assertTrue("Error output should be empty", err.toString().isEmpty()); assertTrue("Error output should be empty", err.toString().isEmpty());
@ -226,14 +215,10 @@ public class TestECAdmin {
@Test @Test
public void testEnableNonExistentPolicyMessage() throws Exception { public void testEnableNonExistentPolicyMessage() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 5, 3, 0); cluster = DFSTestUtil.setupCluster(conf, 5, 3, 0);
cluster.getFileSystem().disableErasureCodingPolicy( cluster.getFileSystem().disableErasureCodingPolicy(RS_6_3);
SystemErasureCodingPolicies final int ret = runCommandWithParams("-enablePolicy", "-policy",
.getByID(SystemErasureCodingPolicies.RS_6_3_POLICY_ID).getName()); "NonExistentPolicy");
String[] args = {"-enablePolicy", "-policy", "NonExistentPolicy"};
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is unsuccessful", 2, ret); assertEquals("Return value of the command is unsuccessful", 2, ret);
assertFalse("Enabling policy should not be logged when " + assertFalse("Enabling policy should not be logged when " +
"it was unsuccessful", out.toString().contains("is enabled")); "it was unsuccessful", out.toString().contains("is enabled"));
@ -244,48 +229,31 @@ public class TestECAdmin {
@Test @Test
public void testVerifyClusterSetupWithGivenPolicies() throws Exception { public void testVerifyClusterSetupWithGivenPolicies() throws Exception {
cluster = DFSTestUtil.setupCluster(conf, 5, 2, 0); final int numDataNodes = 5;
final int numRacks = 2;
cluster = DFSTestUtil.setupCluster(conf, numDataNodes, numRacks, 0);
String[] args = new String[]{"-verifyClusterSetup", "-policy", int ret = runCommandWithParams("-verifyClusterSetup", "-policy", RS_3_2);
"RS-3-2-1024k"};
int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughRacksMessage(RS_3_2, numRacks, 3);
"should be logged correctly", out.toString()
.contains("less than the minimum required number of racks (3) " +
"for the erasure coding policies: RS-3-2-1024k"));
assertTrue("Error output should be empty", err.toString().isEmpty());
resetOutputs(); resetOutputs();
args = new String[]{"-verifyClusterSetup", "-policy", ret = runCommandWithParams("-verifyClusterSetup", "-policy",
"RS-10-4-1024k", "RS-3-2-1024k"}; RS_10_4, RS_3_2);
ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", 2, ret); assertEquals("Return value of the command is not successful", 2, ret);
assertTrue("Result of cluster topology verify " + assertNotEnoughDataNodesMessage(RS_10_4 + ", " + RS_3_2,
"should be logged correctly", out.toString() numDataNodes, 14);
.contains(
"for the erasure coding policies: RS-10-4-1024k, RS-3-2-1024k"));
assertTrue("Error output should be empty", err.toString().isEmpty());
resetOutputs(); resetOutputs();
args = new String[]{"-verifyClusterSetup", "-policy", "invalidPolicy"}; ret = runCommandWithParams("-verifyClusterSetup", "-policy",
ret = admin.run(args); "invalidPolicy");
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", -1, ret); assertEquals("Return value of the command is not successful", -1, ret);
assertTrue("Error message should be logged", err.toString() assertTrue("Error message should be logged", err.toString()
.contains("The given erasure coding policy invalidPolicy " + .contains("The given erasure coding policy invalidPolicy " +
"does not exist.")); "does not exist."));
resetOutputs(); resetOutputs();
args = new String[]{"-verifyClusterSetup", "-policy"}; ret = runCommandWithParams("-verifyClusterSetup", "-policy");
ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
assertEquals("Return value of the command is not successful", -1, ret); assertEquals("Return value of the command is not successful", -1, ret);
assertTrue("Error message should be logged", err.toString() assertTrue("Error message should be logged", err.toString()
.contains("NotEnoughArgumentsException: Not enough arguments: " + .contains("NotEnoughArgumentsException: Not enough arguments: " +
@ -296,4 +264,35 @@ public class TestECAdmin {
out.reset(); out.reset();
err.reset(); err.reset();
} }
private void assertNotEnoughDataNodesMessage(String policy,
int numDataNodes,
int expectedNumDataNodes) {
assertTrue("Result of cluster topology verify " +
"should be logged correctly", out.toString()
.contains(expectedNumDataNodes + " DataNodes are required " +
"for the erasure coding policies: " +
policy + ". The number of DataNodes is only " + numDataNodes));
assertTrue("Error output should be empty",
err.toString().isEmpty());
}
private void assertNotEnoughRacksMessage(String policy,
int numRacks,
int expectedNumRacks) {
assertTrue("Result of cluster topology verify " +
"should be logged correctly", out.toString()
.contains(expectedNumRacks + " racks are required for " +
"the erasure coding policies: " +
policy + ". The number of racks is only " + numRacks));
assertTrue("Error output should be empty",
err.toString().isEmpty());
}
private int runCommandWithParams(String... args) throws Exception{
final int ret = admin.run(args);
LOG.info("Command stdout: {}", out.toString());
LOG.info("Command stderr: {}", err.toString());
return ret;
}
} }