HDFS-14889. Ability to check if a block has a replica on provided storage. Contributed by Ashvin Agrawal. (#1573)"
This commit is contained in:
parent
9700e2003a
commit
844b766da5
@ -181,6 +181,12 @@ public int getCapacity() {
|
|||||||
/** @return true if there is no datanode storage associated with the block */
|
/** @return true if there is no datanode storage associated with the block */
|
||||||
abstract boolean hasNoStorage();
|
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.
|
* Find specified DatanodeStorageInfo.
|
||||||
* @return DatanodeStorageInfo or null if not found.
|
* @return DatanodeStorageInfo or null if not found.
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
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.Block;
|
||||||
import org.apache.hadoop.hdfs.protocol.BlockType;
|
import org.apache.hadoop.hdfs.protocol.BlockType;
|
||||||
|
|
||||||
@ -80,6 +81,19 @@ boolean removeStorage(DatanodeStorageInfo storage) {
|
|||||||
return true;
|
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
|
@Override
|
||||||
public int numNodes() {
|
public int numNodes() {
|
||||||
assert this.storages != null : "BlockInfo is not initialized";
|
assert this.storages != null : "BlockInfo is not initialized";
|
||||||
|
@ -244,6 +244,15 @@ final boolean hasNoStorage() {
|
|||||||
return true;
|
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
|
* This class contains datanode storage information and block index in the
|
||||||
* block group.
|
* block group.
|
||||||
|
@ -19,7 +19,10 @@
|
|||||||
|
|
||||||
import static org.apache.hadoop.hdfs.server.namenode.INodeId.INVALID_INODE_ID;
|
import static org.apache.hadoop.hdfs.server.namenode.INodeId.INVALID_INODE_ID;
|
||||||
import static org.hamcrest.core.Is.is;
|
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.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.apache.hadoop.hdfs.DFSTestUtil;
|
import org.apache.hadoop.hdfs.DFSTestUtil;
|
||||||
@ -64,6 +67,39 @@ public void testAddStorage() throws Exception {
|
|||||||
Assert.assertEquals(storage, blockInfo.getStorageInfo(0));
|
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
|
@Test
|
||||||
public void testReplaceStorage() throws Exception {
|
public void testReplaceStorage() throws Exception {
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user