|
@@ -30,21 +30,28 @@ import static org.mockito.Mockito.verify;
|
|
|
import java.io.IOException;
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.Arrays;
|
|
|
+import java.util.EnumSet;
|
|
|
import java.util.LinkedList;
|
|
|
import java.util.List;
|
|
|
import java.util.Map.Entry;
|
|
|
|
|
|
import org.apache.hadoop.conf.Configuration;
|
|
|
+import org.apache.hadoop.fs.CreateFlag;
|
|
|
+import org.apache.hadoop.fs.FSDataInputStream;
|
|
|
import org.apache.hadoop.fs.FileSystem;
|
|
|
import org.apache.hadoop.fs.Path;
|
|
|
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
|
|
+import org.apache.hadoop.hdfs.DFSOutputStream;
|
|
|
import org.apache.hadoop.hdfs.DFSTestUtil;
|
|
|
+import org.apache.hadoop.hdfs.DistributedFileSystem;
|
|
|
import org.apache.hadoop.hdfs.HdfsConfiguration;
|
|
|
import org.apache.hadoop.hdfs.StorageType;
|
|
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
|
|
import org.apache.hadoop.hdfs.protocol.Block;
|
|
|
import org.apache.hadoop.hdfs.protocol.BlockListAsLongs;
|
|
|
+import org.apache.hadoop.hdfs.protocol.ExtendedBlock;
|
|
|
import org.apache.hadoop.hdfs.protocol.HdfsConstants;
|
|
|
+import org.apache.hadoop.hdfs.protocol.LocatedBlock;
|
|
|
import org.apache.hadoop.hdfs.server.blockmanagement.DatanodeDescriptor.BlockTargetPair;
|
|
|
import org.apache.hadoop.hdfs.server.datanode.DataNodeTestUtils;
|
|
|
import org.apache.hadoop.hdfs.server.datanode.FinalizedReplica;
|
|
@@ -54,8 +61,11 @@ import org.apache.hadoop.hdfs.server.namenode.FSNamesystem;
|
|
|
import org.apache.hadoop.hdfs.server.namenode.NameNodeAdapter;
|
|
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeRegistration;
|
|
|
import org.apache.hadoop.hdfs.server.protocol.DatanodeStorage;
|
|
|
+import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocols;
|
|
|
import org.apache.hadoop.hdfs.server.protocol.ReceivedDeletedBlockInfo;
|
|
|
import org.apache.hadoop.hdfs.server.protocol.StorageReceivedDeletedBlocks;
|
|
|
+import org.apache.hadoop.io.EnumSetWritable;
|
|
|
+import org.apache.hadoop.io.IOUtils;
|
|
|
import org.apache.hadoop.ipc.RemoteException;
|
|
|
import org.apache.hadoop.net.NetworkTopology;
|
|
|
import org.junit.Assert;
|
|
@@ -373,8 +383,59 @@ public class TestBlockManager {
|
|
|
bm.processMisReplicatedBlocks();
|
|
|
assertEquals(0, bm.numOfUnderReplicatedBlocks());
|
|
|
}
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ @Test(timeout = 60000)
|
|
|
+ public void testNeededReplicationWhileAppending() throws IOException {
|
|
|
+ Configuration conf = new HdfsConfiguration();
|
|
|
+ String src = "/test-file";
|
|
|
+ Path file = new Path(src);
|
|
|
+ MiniDFSCluster cluster = new MiniDFSCluster.Builder(conf).build();
|
|
|
+ cluster.waitActive();
|
|
|
+ try {
|
|
|
+ BlockManager bm = cluster.getNamesystem().getBlockManager();
|
|
|
+ FileSystem fs = cluster.getFileSystem();
|
|
|
+ NamenodeProtocols namenode = cluster.getNameNodeRpc();
|
|
|
+ DFSOutputStream out = null;
|
|
|
+ try {
|
|
|
+ out = (DFSOutputStream) (fs.create(file).
|
|
|
+ getWrappedStream());
|
|
|
+ out.write(1);
|
|
|
+ out.hflush();
|
|
|
+ out.close();
|
|
|
+ FSDataInputStream in = null;
|
|
|
+ ExtendedBlock oldBlock = null;
|
|
|
+ LocatedBlock oldLoactedBlock = null;
|
|
|
+ try {
|
|
|
+ in = fs.open(file);
|
|
|
+ oldLoactedBlock = DFSTestUtil.getAllBlocks(in).get(0);
|
|
|
+ oldBlock = oldLoactedBlock.getBlock();
|
|
|
+ } finally {
|
|
|
+ IOUtils.closeStream(in);
|
|
|
+ }
|
|
|
+ String clientName =
|
|
|
+ ((DistributedFileSystem) fs).getClient().getClientName();
|
|
|
+ namenode.append(src, clientName);
|
|
|
+ LocatedBlock newLocatedBlock =
|
|
|
+ namenode.updateBlockForPipeline(oldBlock, clientName);
|
|
|
+ ExtendedBlock newBlock =
|
|
|
+ new ExtendedBlock(oldBlock.getBlockPoolId(), oldBlock.getBlockId(),
|
|
|
+ oldBlock.getNumBytes(),
|
|
|
+ newLocatedBlock.getBlock().getGenerationStamp());
|
|
|
+ namenode.updatePipeline(clientName, oldBlock, newBlock,
|
|
|
+ oldLoactedBlock.getLocations(), oldLoactedBlock.getStorageIDs());
|
|
|
+ BlockInfo bi = bm.getStoredBlock(newBlock.getLocalBlock());
|
|
|
+ assertFalse(
|
|
|
+ bm.isNeededReplication(bi, oldLoactedBlock.getLocations().length,
|
|
|
+ bm.countLiveNodes(bi)));
|
|
|
+ } finally {
|
|
|
+ IOUtils.closeStream(out);
|
|
|
+ }
|
|
|
+ } finally {
|
|
|
+ cluster.shutdown();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
/**
|
|
|
* Tell the block manager that replication is completed for the given
|
|
|
* pipeline.
|