From c8bca62718203a1dad9b70d164bdf10cc71b40cd Mon Sep 17 00:00:00 2001 From: Jing Zhao Date: Thu, 20 Aug 2015 16:31:24 -0700 Subject: [PATCH] HDFS-8809. HDFS fsck reports under construction blocks as CORRUPT. Contributed by Jing Zhao. --- hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt | 2 ++ .../hadoop/hdfs/server/namenode/NamenodeFsck.java | 10 ++++++++++ .../apache/hadoop/hdfs/server/namenode/TestFsck.java | 2 ++ 3 files changed, 14 insertions(+) diff --git a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt index dcc5d58150d..d9d176bf1b4 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt +++ b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt @@ -1194,6 +1194,8 @@ Release 2.8.0 - UNRELEASED HDFS-8922. Link the native_mini_dfs test library with libdl, since IBM Java requires it (Ayappan via Colin P. McCabe) + HDFS-8809. HDFS fsck reports under construction blocks as "CORRUPT". (jing9) + Release 2.7.2 - UNRELEASED INCOMPATIBLE CHANGES diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NamenodeFsck.java b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NamenodeFsck.java index 2f989d135c5..c7892b5386d 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NamenodeFsck.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NamenodeFsck.java @@ -528,6 +528,9 @@ private void collectBlocksSummary(String parent, HdfsFileStatus file, Result res LocatedBlocks blocks) throws IOException { String path = file.getFullName(parent); boolean isOpen = blocks.isUnderConstruction(); + if (isOpen && !showOpenFiles) { + return; + } int missing = 0; int corrupt = 0; long missize = 0; @@ -536,8 +539,15 @@ private void collectBlocksSummary(String parent, HdfsFileStatus file, Result res int misReplicatedPerFile = 0; StringBuilder report = new StringBuilder(); int blockNumber = 0; + final LocatedBlock lastBlock = blocks.getLastLocatedBlock(); for (LocatedBlock lBlk : blocks.getLocatedBlocks()) { ExtendedBlock block = lBlk.getBlock(); + if (!blocks.isLastBlockComplete() && lastBlock != null && + lastBlock.getBlock().equals(block)) { + // this is the last block and this is not complete. ignore it since + // it is under construction + continue; + } BlockManager bm = namenode.getNamesystem().getBlockManager(); final BlockInfo storedBlock = bm.getStoredBlock( diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/namenode/TestFsck.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/namenode/TestFsck.java index 8818f17db78..2226947b3ca 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/namenode/TestFsck.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/namenode/TestFsck.java @@ -65,6 +65,7 @@ import org.apache.hadoop.hdfs.DFSClient; import org.apache.hadoop.hdfs.DFSConfigKeys; import org.apache.hadoop.hdfs.DFSInputStream; +import org.apache.hadoop.hdfs.DFSOutputStream; import org.apache.hadoop.hdfs.DFSTestUtil; import org.apache.hadoop.hdfs.DFSUtil; import org.apache.hadoop.hdfs.DistributedFileSystem; @@ -612,6 +613,7 @@ public void testFsckOpenFiles() throws Exception { out.write(randomString.getBytes()); writeCount++; } + ((DFSOutputStream) out.getWrappedStream()).hflush(); // We expect the filesystem to be HEALTHY and show one open file outStr = runFsck(conf, 0, true, topDir); System.out.println(outStr);