You are viewing a plain text version of this content. The canonical link for it is here.
Posted to common-commits@hadoop.apache.org by he...@apache.org on 2020/07/07 04:10:26 UTC
[hadoop] branch branch-3.2 updated: HDFS-15451. Do not discard
non-initial block report for provided storage. (#2119). Contributed by
Shanyu Zhao.
This is an automated email from the ASF dual-hosted git repository.
hexiaoqiao pushed a commit to branch branch-3.2
in repository https://gitbox.apache.org/repos/asf/hadoop.git
The following commit(s) were added to refs/heads/branch-3.2 by this push:
new 8d40288 HDFS-15451. Do not discard non-initial block report for provided storage. (#2119). Contributed by Shanyu Zhao.
8d40288 is described below
commit 8d4028864d0492e8f64f94db2339fbd55f97083a
Author: Shanyu Zhao <sh...@microsoft.com>
AuthorDate: Mon Jul 6 08:43:34 2020 -0700
HDFS-15451. Do not discard non-initial block report for provided storage. (#2119). Contributed by Shanyu Zhao.
Signed-off-by: He Xiaoqiao <he...@apache.org>
---
.../hdfs/server/blockmanagement/BlockManager.java | 1 +
.../server/blockmanagement/TestBlockManager.java | 53 ++++++++++++++++++++++
2 files changed, 54 insertions(+)
diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/BlockManager.java b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/BlockManager.java
index 3185f1d..4486e47 100644
--- a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/BlockManager.java
+++ b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/BlockManager.java
@@ -2702,6 +2702,7 @@ public class BlockManager implements BlockStatsMXBean {
storageInfo = node.updateStorage(storage);
}
if (namesystem.isInStartupSafeMode()
+ && !StorageType.PROVIDED.equals(storageInfo.getStorageType())
&& storageInfo.getBlockReportCount() > 0) {
blockLog.info("BLOCK* processReport 0x{}: "
+ "discarded non-initial block report from {}"
diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/blockmanagement/TestBlockManager.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/blockmanagement/TestBlockManager.java
index d393eaa..fea80e5 100644
--- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/blockmanagement/TestBlockManager.java
+++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/server/blockmanagement/TestBlockManager.java
@@ -46,9 +46,11 @@ import org.apache.hadoop.hdfs.protocol.ExtendedBlock;
import org.apache.hadoop.hdfs.protocol.LocatedBlock;
import org.apache.hadoop.hdfs.protocol.LocatedBlocks;
import org.apache.hadoop.hdfs.server.blockmanagement.DatanodeDescriptor.BlockTargetPair;
+import org.apache.hadoop.hdfs.server.common.blockaliasmap.BlockAliasMap;
import org.apache.hadoop.hdfs.server.common.HdfsServerConstants;
import org.apache.hadoop.hdfs.server.datanode.DataNode;
import org.apache.hadoop.hdfs.server.datanode.FinalizedReplica;
+import org.apache.hadoop.hdfs.server.datanode.fsdataset.impl.TestProvidedImpl;
import org.apache.hadoop.hdfs.server.datanode.InternalDataNodeTestUtils;
import org.apache.hadoop.hdfs.server.datanode.ReplicaBeingWritten;
import org.apache.hadoop.hdfs.server.namenode.CacheManager;
@@ -1002,6 +1004,57 @@ public class TestBlockManager {
}
@Test
+ public void testSafeModeWithProvidedStorageBR() throws Exception {
+ DatanodeDescriptor node0 = spy(nodes.get(0));
+ DatanodeStorageInfo ds0 = node0.getStorageInfos()[0];
+ node0.setAlive(true);
+ DatanodeDescriptor node1 = spy(nodes.get(1));
+ DatanodeStorageInfo ds1 = node1.getStorageInfos()[0];
+ node1.setAlive(true);
+
+ String providedStorageID = DFSConfigKeys.DFS_PROVIDER_STORAGEUUID_DEFAULT;
+ DatanodeStorage providedStorage = new DatanodeStorage(
+ providedStorageID, DatanodeStorage.State.NORMAL, StorageType.PROVIDED);
+
+ // create block manager with provided storage enabled
+ Configuration conf = new HdfsConfiguration();
+ conf.setBoolean(DFSConfigKeys.DFS_NAMENODE_PROVIDED_ENABLED, true);
+ conf.setClass(DFSConfigKeys.DFS_PROVIDED_ALIASMAP_CLASS,
+ TestProvidedImpl.TestFileRegionBlockAliasMap.class,
+ BlockAliasMap.class);
+ BlockManager bmPs = new BlockManager(fsn, false, conf);
+ bmPs.setBlockPoolId("BP-12344-10.1.1.2-12344");
+
+ // pretend to be in safemode
+ doReturn(true).when(fsn).isInStartupSafeMode();
+
+ // register new node
+ DatanodeRegistration nodeReg0 =
+ new DatanodeRegistration(node0, null, null, "");
+ bmPs.getDatanodeManager().registerDatanode(nodeReg0);
+ bmPs.getDatanodeManager().addDatanode(node0);
+ DatanodeRegistration nodeReg1 =
+ new DatanodeRegistration(node1, null, null, "");
+ bmPs.getDatanodeManager().registerDatanode(nodeReg1);
+ bmPs.getDatanodeManager().addDatanode(node1);
+
+ // process reports of provided storage and disk storage
+ bmPs.processReport(node0, providedStorage, BlockListAsLongs.EMPTY, null);
+ bmPs.processReport(node0, new DatanodeStorage(ds0.getStorageID()),
+ BlockListAsLongs.EMPTY, null);
+ bmPs.processReport(node1, providedStorage, BlockListAsLongs.EMPTY, null);
+ bmPs.processReport(node1, new DatanodeStorage(ds1.getStorageID()),
+ BlockListAsLongs.EMPTY, null);
+
+ // The provided stoage report should not affect disk storage report
+ DatanodeStorageInfo dsPs =
+ bmPs.getProvidedStorageMap().getProvidedStorageInfo();
+ assertEquals(2, dsPs.getBlockReportCount());
+ assertEquals(1, ds0.getBlockReportCount());
+ assertEquals(1, ds1.getBlockReportCount());
+ }
+
+ @Test
public void testFullBR() throws Exception {
doReturn(true).when(fsn).isRunning();
---------------------------------------------------------------------
To unsubscribe, e-mail: common-commits-unsubscribe@hadoop.apache.org
For additional commands, e-mail: common-commits-help@hadoop.apache.org