HDFS-3888. Clean up BlockPlacementPolicyDefault. Contributed by Jing Zhao
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1380939 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
f3927595cc
commit
658e7b5818
|
@ -445,6 +445,8 @@ Branch-2 ( Unreleased changes )
|
||||||
HDFS-3887. Remove redundant chooseTarget methods in BlockPlacementPolicy.
|
HDFS-3887. Remove redundant chooseTarget methods in BlockPlacementPolicy.
|
||||||
(Jing Zhao via szetszwo)
|
(Jing Zhao via szetszwo)
|
||||||
|
|
||||||
|
HDFS-3888. Clean up BlockPlacementPolicyDefault. (Jing Zhao via szetszwo)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
HDFS-2982. Startup performance suffers when there are many edit log
|
HDFS-2982. Startup performance suffers when there are many edit log
|
||||||
|
|
|
@ -27,8 +27,6 @@ import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.TreeSet;
|
import java.util.TreeSet;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
|
||||||
import org.apache.commons.logging.LogFactory;
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
import org.apache.hadoop.hdfs.DFSConfigKeys;
|
||||||
|
@ -55,9 +53,6 @@ import com.google.common.annotations.VisibleForTesting;
|
||||||
@InterfaceAudience.Private
|
@InterfaceAudience.Private
|
||||||
public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
||||||
|
|
||||||
private static final Log LOG =
|
|
||||||
LogFactory.getLog(BlockPlacementPolicyDefault.class.getName());
|
|
||||||
|
|
||||||
private static final String enableDebugLogging =
|
private static final String enableDebugLogging =
|
||||||
"For more information, please enable DEBUG log level on "
|
"For more information, please enable DEBUG log level on "
|
||||||
+ LOG.getClass().getName();
|
+ LOG.getClass().getName();
|
||||||
|
@ -124,7 +119,6 @@ public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
||||||
excludedNodes, blocksize);
|
excludedNodes, blocksize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** This is the implementation. */
|
/** This is the implementation. */
|
||||||
DatanodeDescriptor[] chooseTarget(int numOfReplicas,
|
DatanodeDescriptor[] chooseTarget(int numOfReplicas,
|
||||||
DatanodeDescriptor writer,
|
DatanodeDescriptor writer,
|
||||||
|
@ -162,7 +156,8 @@ public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
||||||
}
|
}
|
||||||
|
|
||||||
DatanodeDescriptor localNode = chooseTarget(numOfReplicas, writer,
|
DatanodeDescriptor localNode = chooseTarget(numOfReplicas, writer,
|
||||||
excludedNodes, blocksize, maxNodesPerRack, results);
|
excludedNodes, blocksize,
|
||||||
|
maxNodesPerRack, results);
|
||||||
if (!returnChosenNodes) {
|
if (!returnChosenNodes) {
|
||||||
results.removeAll(chosenNodes);
|
results.removeAll(chosenNodes);
|
||||||
}
|
}
|
||||||
|
@ -455,14 +450,29 @@ public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
||||||
* does not have too much load, and the rack does not have too many nodes
|
* does not have too much load, and the rack does not have too many nodes
|
||||||
*/
|
*/
|
||||||
private boolean isGoodTarget(DatanodeDescriptor node,
|
private boolean isGoodTarget(DatanodeDescriptor node,
|
||||||
long blockSize, int maxTargetPerLoc,
|
long blockSize, int maxTargetPerRack,
|
||||||
List<DatanodeDescriptor> results) {
|
List<DatanodeDescriptor> results) {
|
||||||
return isGoodTarget(node, blockSize, maxTargetPerLoc,
|
return isGoodTarget(node, blockSize, maxTargetPerRack,
|
||||||
this.considerLoad, results);
|
this.considerLoad, results);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if a node is a good target.
|
||||||
|
*
|
||||||
|
* @param node The target node
|
||||||
|
* @param blockSize Size of block
|
||||||
|
* @param maxTargetPerRack Maximum number of targets per rack. The value of
|
||||||
|
* this parameter depends on the number of racks in
|
||||||
|
* the cluster and total number of replicas for a block
|
||||||
|
* @param considerLoad whether or not to consider load of the target node
|
||||||
|
* @param results A list containing currently chosen nodes. Used to check if
|
||||||
|
* too many nodes has been chosen in the target rack.
|
||||||
|
* @return Return true if <i>node</i> has enough space,
|
||||||
|
* does not have too much load,
|
||||||
|
* and the rack does not have too many nodes.
|
||||||
|
*/
|
||||||
protected boolean isGoodTarget(DatanodeDescriptor node,
|
protected boolean isGoodTarget(DatanodeDescriptor node,
|
||||||
long blockSize, int maxTargetPerLoc,
|
long blockSize, int maxTargetPerRack,
|
||||||
boolean considerLoad,
|
boolean considerLoad,
|
||||||
List<DatanodeDescriptor> results) {
|
List<DatanodeDescriptor> results) {
|
||||||
// check if the node is (being) decommissed
|
// check if the node is (being) decommissed
|
||||||
|
@ -514,7 +524,7 @@ public class BlockPlacementPolicyDefault extends BlockPlacementPolicy {
|
||||||
counter++;
|
counter++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (counter>maxTargetPerLoc) {
|
if (counter>maxTargetPerRack) {
|
||||||
if(LOG.isDebugEnabled()) {
|
if(LOG.isDebugEnabled()) {
|
||||||
threadLocalBuilder.get().append(node.toString()).append(": ")
|
threadLocalBuilder.get().append(node.toString()).append(": ")
|
||||||
.append("Node ").append(NodeBase.getPath(node))
|
.append("Node ").append(NodeBase.getPath(node))
|
||||||
|
|
Loading…
Reference in New Issue