HDFS-14889. Ability to check if a block has a replica on provided storage. Contributed by Ashvin Agrawal. (#1573)"

This commit is contained in:
Virajith Jalaparti 2019-10-03 21:31:23 -07:00
parent 9700e2003a
commit 844b766da5
4 changed files with 65 additions and 0 deletions

View File

@ -181,6 +181,12 @@ public abstract class BlockInfo extends Block
/** @return true if there is no datanode storage associated with the block */
abstract boolean hasNoStorage();
/**
* Checks whether this block has a Provided replica.
* @return true if this block has a replica on Provided storage.
*/
abstract boolean isProvided();
/**
* Find specified DatanodeStorageInfo.
* @return DatanodeStorageInfo or null if not found.

View File

@ -19,6 +19,7 @@ package org.apache.hadoop.hdfs.server.blockmanagement;
import com.google.common.base.Preconditions;
import org.apache.hadoop.classification.InterfaceAudience;
import org.apache.hadoop.fs.StorageType;
import org.apache.hadoop.hdfs.protocol.Block;
import org.apache.hadoop.hdfs.protocol.BlockType;
@ -80,6 +81,19 @@ public class BlockInfoContiguous extends BlockInfo {
return true;
}
@Override
boolean isProvided() {
int len = getCapacity();
for (int idx = 0; idx < len; idx++) {
DatanodeStorageInfo storage = getStorageInfo(idx);
if (storage != null
&& storage.getStorageType().equals(StorageType.PROVIDED)) {
return true;
}
}
return false;
}
@Override
public int numNodes() {
assert this.storages != null : "BlockInfo is not initialized";

View File

@ -244,6 +244,15 @@ public class BlockInfoStriped extends BlockInfo {
return true;
}
/**
* Striped blocks on Provided Storage is not supported. All blocks on
* Provided storage are assumed to be "contiguous".
*/
@Override
boolean isProvided() {
return false;
}
/**
* This class contains datanode storage information and block index in the
* block group.

View File

@ -19,7 +19,10 @@ package org.apache.hadoop.hdfs.server.blockmanagement;
import static org.apache.hadoop.hdfs.server.namenode.INodeId.INVALID_INODE_ID;
import static org.hamcrest.core.Is.is;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.apache.hadoop.fs.StorageType;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.apache.hadoop.hdfs.DFSTestUtil;
@ -64,6 +67,39 @@ public class TestBlockInfo {
Assert.assertEquals(storage, blockInfo.getStorageInfo(0));
}
@Test
public void testAddProvidedStorage() throws Exception {
// block with only provided storage
BlockInfo blockInfo = new BlockInfoContiguous((short) 3);
DatanodeStorageInfo providedStorage = mock(DatanodeStorageInfo.class);
when(providedStorage.getStorageType()).thenReturn(StorageType.PROVIDED);
boolean added = blockInfo.addStorage(providedStorage, blockInfo);
Assert.assertTrue(added);
Assert.assertEquals(providedStorage, blockInfo.getStorageInfo(0));
Assert.assertTrue(blockInfo.isProvided());
}
@Test
public void testAddTwoStorageTypes() throws Exception {
// block with only disk storage
BlockInfo blockInfo = new BlockInfoContiguous((short) 3);
DatanodeStorageInfo diskStorage = mock(DatanodeStorageInfo.class);
DatanodeDescriptor mockDN = mock(DatanodeDescriptor.class);
when(diskStorage.getDatanodeDescriptor()).thenReturn(mockDN);
when(diskStorage.getStorageType()).thenReturn(StorageType.DISK);
boolean added = blockInfo.addStorage(diskStorage, blockInfo);
Assert.assertTrue(added);
Assert.assertEquals(diskStorage, blockInfo.getStorageInfo(0));
Assert.assertFalse(blockInfo.isProvided());
// now add provided storage
DatanodeStorageInfo providedStorage = mock(DatanodeStorageInfo.class);
when(providedStorage.getStorageType()).thenReturn(StorageType.PROVIDED);
added = blockInfo.addStorage(providedStorage, blockInfo);
Assert.assertTrue(added);
Assert.assertTrue(blockInfo.isProvided());
}
@Test
public void testReplaceStorage() throws Exception {