HDFS-17135. Update fsck -blockId to display excess state info of blocks (#5904)
Reviewed-by: He Xiaoqiao <hexiaoqiao@apache.org> Reviewed-by: Shilun Fan <slfan1989@apache.org> Signed-off-by: Tao Li <tomscut@apache.org>
This commit is contained in:
parent
688f76a822
commit
6cc56d40f5
@ -127,6 +127,7 @@ public class NamenodeFsck implements DataEncryptionKeyFactory {
|
|||||||
"is ENTERING MAINTENANCE";
|
"is ENTERING MAINTENANCE";
|
||||||
public static final String IN_MAINTENANCE_STATUS = "is IN MAINTENANCE";
|
public static final String IN_MAINTENANCE_STATUS = "is IN MAINTENANCE";
|
||||||
public static final String STALE_STATUS = "is STALE";
|
public static final String STALE_STATUS = "is STALE";
|
||||||
|
public static final String EXCESS_STATUS = "is EXCESS";
|
||||||
public static final String NONEXISTENT_STATUS = "does not exist";
|
public static final String NONEXISTENT_STATUS = "does not exist";
|
||||||
public static final String FAILURE_STATUS = "FAILED";
|
public static final String FAILURE_STATUS = "FAILED";
|
||||||
public static final String UNDEFINED = "undefined";
|
public static final String UNDEFINED = "undefined";
|
||||||
@ -373,6 +374,8 @@ public class NamenodeFsck implements DataEncryptionKeyFactory {
|
|||||||
out.print(IN_MAINTENANCE_STATUS);
|
out.print(IN_MAINTENANCE_STATUS);
|
||||||
} else if (dn.isStale(this.staleInterval)) {
|
} else if (dn.isStale(this.staleInterval)) {
|
||||||
out.print(STALE_STATUS);
|
out.print(STALE_STATUS);
|
||||||
|
} else if (blockManager.isExcess(dn, blockManager.getStoredBlock(block))) {
|
||||||
|
out.print(EXCESS_STATUS);
|
||||||
} else {
|
} else {
|
||||||
out.print(HEALTHY_STATUS);
|
out.print(HEALTHY_STATUS);
|
||||||
}
|
}
|
||||||
|
@ -396,6 +396,8 @@ public class DFSck extends Configured implements Tool {
|
|||||||
errCode = 0;
|
errCode = 0;
|
||||||
} else if (lastLine.contains("Incorrect blockId format:")) {
|
} else if (lastLine.contains("Incorrect blockId format:")) {
|
||||||
errCode = 0;
|
errCode = 0;
|
||||||
|
} else if (lastLine.endsWith(NamenodeFsck.EXCESS_STATUS)) {
|
||||||
|
errCode = 0;
|
||||||
} else if (lastLine.endsWith(NamenodeFsck.DECOMMISSIONED_STATUS)) {
|
} else if (lastLine.endsWith(NamenodeFsck.DECOMMISSIONED_STATUS)) {
|
||||||
errCode = 2;
|
errCode = 2;
|
||||||
} else if (lastLine.endsWith(NamenodeFsck.DECOMMISSIONING_STATUS)) {
|
} else if (lastLine.endsWith(NamenodeFsck.DECOMMISSIONING_STATUS)) {
|
||||||
|
@ -1056,8 +1056,6 @@ public class TestFsck {
|
|||||||
assertTrue(fsckOut.contains("(DECOMMISSIONED)"));
|
assertTrue(fsckOut.contains("(DECOMMISSIONED)"));
|
||||||
assertFalse(fsckOut.contains("(ENTERING MAINTENANCE)"));
|
assertFalse(fsckOut.contains("(ENTERING MAINTENANCE)"));
|
||||||
assertFalse(fsckOut.contains("(IN MAINTENANCE)"));
|
assertFalse(fsckOut.contains("(IN MAINTENANCE)"));
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Test if fsck can return -1 in case of failure.
|
/** Test if fsck can return -1 in case of failure.
|
||||||
@ -1834,6 +1832,51 @@ public class TestFsck {
|
|||||||
assertTrue(outStr.contains(NamenodeFsck.CORRUPT_STATUS));
|
assertTrue(outStr.contains(NamenodeFsck.CORRUPT_STATUS));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test for blockIdCK with block excess.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testBlockIdCKExcess() throws Exception {
|
||||||
|
final Configuration configuration = new Configuration();
|
||||||
|
// Disable redundancy monitor check so that excess block can be verified.
|
||||||
|
configuration.setLong(DFSConfigKeys.DFS_NAMENODE_REDUNDANCY_INTERVAL_SECONDS_KEY, 5000);
|
||||||
|
|
||||||
|
try (MiniDFSCluster cluster = new MiniDFSCluster.Builder(configuration).
|
||||||
|
numDataNodes(2).build()) {
|
||||||
|
cluster.waitActive();
|
||||||
|
final DistributedFileSystem fs = cluster.getFileSystem();
|
||||||
|
|
||||||
|
// Create file.
|
||||||
|
Path file = new Path("/test");
|
||||||
|
long fileLength = 512;
|
||||||
|
DFSTestUtil.createFile(fs, file, fileLength, (short) 2, 0L);
|
||||||
|
DFSTestUtil.waitReplication(fs, file, (short) 2);
|
||||||
|
|
||||||
|
List<LocatedBlock> locatedBlocks = DFSTestUtil.getAllBlocks(fs, file);
|
||||||
|
assertEquals(1, locatedBlocks.size());
|
||||||
|
String blockName = locatedBlocks.get(0).getBlock().getBlockName();
|
||||||
|
|
||||||
|
// Validate block is HEALTHY.
|
||||||
|
String outStr = runFsck(configuration, 0, true,
|
||||||
|
"/", "-blockId", blockName);
|
||||||
|
assertTrue(outStr.contains(NamenodeFsck.HEALTHY_STATUS));
|
||||||
|
assertTrue(outStr.contains("No. of Expected Replica: " + 2));
|
||||||
|
assertTrue(outStr.contains("No. of live Replica: " + 2));
|
||||||
|
assertTrue(outStr.contains("No. of excess Replica: " + 0));
|
||||||
|
|
||||||
|
// Make the block on one datanode enter excess state.
|
||||||
|
fs.setReplication(file, (short)1);
|
||||||
|
|
||||||
|
// Validate the one block is EXCESS.
|
||||||
|
outStr = runFsck(configuration, 0, true,
|
||||||
|
"/", "-blockId", blockName);
|
||||||
|
assertTrue(outStr.contains(NamenodeFsck.EXCESS_STATUS));
|
||||||
|
assertTrue(outStr.contains("No. of Expected Replica: " + 1));
|
||||||
|
assertTrue(outStr.contains("No. of live Replica: " + 1));
|
||||||
|
assertTrue(outStr.contains("No. of excess Replica: " + 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void writeFile(final DistributedFileSystem dfs,
|
private void writeFile(final DistributedFileSystem dfs,
|
||||||
Path dir, String fileName) throws IOException {
|
Path dir, String fileName) throws IOException {
|
||||||
Path filePath = new Path(dir.toString() + Path.SEPARATOR + fileName);
|
Path filePath = new Path(dir.toString() + Path.SEPARATOR + fileName);
|
||||||
@ -1961,7 +2004,7 @@ public class TestFsck {
|
|||||||
|
|
||||||
// check the replica status should be healthy(0) after decommission
|
// check the replica status should be healthy(0) after decommission
|
||||||
// is done
|
// is done
|
||||||
String fsckOut = runFsck(conf, 0, true, testFile);
|
runFsck(conf, 0, true, testFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user