Browse Source

HDFS-4208. Reverting change r1412218 which committed the wrong version of the patch.

git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/branch-1@1413887 13f79535-47bb-0310-9956-ffa450edef68
Suresh Srinivas 12 years ago
parent
commit
5a0b962535

+ 0 - 3
CHANGES.txt

@@ -381,9 +381,6 @@ Release 1.1.1 - Unreleased
     HADOOP-8745. Incorrect version numbers in hadoop-core POM.
     (Matthias Friedrich via eli)
 
-    HDFS-4208. NameNode could be stuck in SafeMode due to never-created
-    blocks. (Brandon Li via suresh)
-
 Release 1.1.0 - 2012.09.28
 
   INCOMPATIBLE CHANGES

+ 1 - 45
src/hdfs/org/apache/hadoop/hdfs/server/namenode/FSNamesystem.java

@@ -5339,7 +5339,7 @@ public class FSNamesystem implements FSConstants, FSNamesystemMBean, FSClusterSt
   void setBlockTotal() {
     if (safeMode == null)
       return;
-    safeMode.setBlockTotal((int)getSafeBlockCount());
+    safeMode.setBlockTotal(blocksMap.size());
   }
 
   /**
@@ -5349,50 +5349,6 @@ public class FSNamesystem implements FSConstants, FSNamesystemMBean, FSClusterSt
     return blocksMap.size();
   }
 
-  /**
-   * There are times when blocks are allocated by a client but was never used to
-   * write to. This could happen because the response to block allocation
-   * request never made it to the client or the client failed right after block
-   * allocation. In such a case, NameNode might get stuck in safemode waiting
-   * for such blocks to be reported. To handle this, such blocks should not be
-   * counted toward total blocks needed to exit safemode.
-   * <br>
-   * This method returns the total number of blocks excluding the last blocks of
-   * files under construction with length zero.
-   */
-  long getSafeBlockCount() {
-    // Calculate number of blocks excluded by SafeMode
-    long numExculdedBlocks = 0;
-    for (Lease lease : leaseManager.getSortedLeases()) {
-      for (String path : lease.getPaths()) {
-        INode node = dir.getFileINode(path);
-        if (node == null) {
-          LOG.error("Found a lease for nonexisting file: " + path);
-          continue;
-        }
-        if (!node.isUnderConstruction()) {
-          LOG.error("Found a lease for file that is not under construction:"
-              + path);
-          continue;
-        }
-        INodeFileUnderConstruction cons = (INodeFileUnderConstruction) node;
-        BlockInfo[] blocks = cons.getBlocks();
-        if (blocks == null) {
-          continue;
-        }
-        // Exclude the last block of a file under construction with zero length
-        if (blocks[blocks.length - 1].getNumBytes() == 0) {
-          numExculdedBlocks++;
-        }
-      }
-    }
-    LOG.info("Number of blocks excluded by SafeMode: " + numExculdedBlocks
-        + " total blocks: " + getBlocksTotal() + " and thus the safe blocks: "
-        + (getBlocksTotal() - numExculdedBlocks));
-
-    return getBlocksTotal() - numExculdedBlocks;
-  }
-  
   /**
    * Enter safe mode manually.
    * @throws IOException

+ 0 - 29
src/test/org/apache/hadoop/hdfs/server/namenode/TestStartup.java

@@ -15,17 +15,12 @@ import org.apache.hadoop.fs.FSDataOutputStream;
 import org.apache.hadoop.fs.FileSystem;
 import org.apache.hadoop.fs.FileUtil;
 import org.apache.hadoop.fs.Path;
-import org.apache.hadoop.fs.permission.FsPermission;
-import org.apache.hadoop.hdfs.DFSClient;
-import org.apache.hadoop.hdfs.DFSConfigKeys;
 import org.apache.hadoop.hdfs.MiniDFSCluster;
-import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
 import org.apache.hadoop.hdfs.server.common.HdfsConstants.StartupOption;
 import org.apache.hadoop.hdfs.server.common.Storage.StorageDirectory;
 import org.apache.hadoop.hdfs.server.namenode.FSImage.NameNodeDirType;
 import org.apache.hadoop.hdfs.server.namenode.FSImage.NameNodeFile;
 import org.apache.hadoop.util.StringUtils;
-import org.junit.Test;
 
 /**
  * Startup and checkpoint tests
@@ -308,28 +303,4 @@ public class TestStartup extends TestCase {
         cluster.shutdown();
     }
   }
-  
-  /** Test SafeMode counts only complete blocks */
-  @Test(timeout=60000)
-  public void testGetBlocks() throws Exception {
-    final Configuration CONF = new Configuration();
-
-    config.set(DFSConfigKeys.DFS_NAMENODE_SAFEMODE_THRESHOLD_PCT_KEY, "1.0f");
-    MiniDFSCluster cluster = new MiniDFSCluster(CONF, 2, true, null);
-    try {
-      cluster.waitActive();
-
-      // Create a file and add one block, but not write to DataNode
-      DFSClient client = new DFSClient(CONF);
-      client.namenode.create("/tmp1.txt", new FsPermission("755"),
-          "clientName", false, (short) 2, 1024);
-      client.namenode.addBlock("/tmp1.txt", "clientName", new DatanodeInfo[0]);
-
-      // Should not be stuck in safe mode
-      cluster.restartNameNode();
-
-    } finally {
-      cluster.shutdown();
-    }
-  }
 }