diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/DatanodeAdminManager.java b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/DatanodeAdminManager.java index a1dff08b5d4..09298f25429 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/DatanodeAdminManager.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/blockmanagement/DatanodeAdminManager.java @@ -345,7 +345,9 @@ public class DatanodeAdminManager { * @return true if sufficient, else false. */ private boolean isSufficient(BlockInfo block, BlockCollection bc, - NumberReplicas numberReplicas, boolean isDecommission) { + NumberReplicas numberReplicas, + boolean isDecommission, + boolean isMaintenance) { if (blockManager.hasEnoughEffectiveReplicas(block, numberReplicas, 0)) { // Block has enough replica, skip LOG.trace("Block {} does not need replication.", block); @@ -379,6 +381,10 @@ public class DatanodeAdminManager { } } } + if (isMaintenance + && numLive >= blockManager.getMinReplicationToBeInMaintenance()) { + return true; + } return false; } @@ -706,6 +712,7 @@ public class DatanodeAdminManager { // Schedule low redundancy blocks for reconstruction // if not already pending. boolean isDecommission = datanode.isDecommissionInProgress(); + boolean isMaintenance = datanode.isEnteringMaintenance(); boolean neededReconstruction = isDecommission ? blockManager.isNeededReconstruction(block, num) : blockManager.isNeededReconstructionForMaintenance(block, num); @@ -724,7 +731,7 @@ public class DatanodeAdminManager { // Even if the block is without sufficient redundancy, // it might not block decommission/maintenance if it // has sufficient redundancy. - if (isSufficient(block, bc, num, isDecommission)) { + if (isSufficient(block, bc, num, isDecommission, isMaintenance)) { if (pruneReliableBlocks) { it.remove(); } diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestMaintenanceState.java b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestMaintenanceState.java index 7c536e913be..279e0936484 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestMaintenanceState.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/TestMaintenanceState.java @@ -373,6 +373,7 @@ public class TestMaintenanceState extends AdminStatesBaseTest { testExpectedReplication(2); testExpectedReplication(3); testExpectedReplication(4); + testExpectedReplication(10); } private void testExpectedReplication(int replicationFactor)