HDFS-15438. Setting dfs.disk.balancer.max.disk.errors = 0 will fail the block copy. Contributed by AMC-team.

(cherry picked from commit 2377df38ad2396f8b42d60031001a25d9d6fa32e)
This commit is contained in:
Ayush Saxena 2020-09-18 17:28:11 +05:30 committed by S O'Donnell
parent 9665a0be73
commit 0b43c65816
2 changed files with 3 additions and 3 deletions

View File

@ -902,7 +902,7 @@ public class DiskBalancer {
*/
private ExtendedBlock getBlockToCopy(FsVolumeSpi.BlockIterator iter,
DiskBalancerWorkItem item) {
while (!iter.atEnd() && item.getErrorCount() < getMaxError(item)) {
while (!iter.atEnd() && item.getErrorCount() <= getMaxError(item)) {
try {
ExtendedBlock block = iter.nextBlock();
if(null == block){
@ -923,7 +923,7 @@ public class DiskBalancer {
item.incErrorCount();
}
}
if (item.getErrorCount() >= getMaxError(item)) {
if (item.getErrorCount() > getMaxError(item)) {
item.setErrMsg("Error count exceeded.");
LOG.info("Maximum error count exceeded. Error count: {} Max error:{} ",
item.getErrorCount(), item.getMaxDiskErrors());

View File

@ -757,7 +757,7 @@ public class TestDiskBalancer {
}
}, 1000, 100000);
assertTrue("Disk balancer operation hit max errors!", errorCount.get() <
assertTrue("Disk balancer operation hit max errors!", errorCount.get() <=
DFSConfigKeys.DFS_DISK_BALANCER_MAX_DISK_ERRORS_DEFAULT);
createWorkPlanLatch.await();
removeDiskLatch.await();