HDFS-15369. Refactor method VolumeScanner#runLoop(). Contributed by Yang Yun.

This commit is contained in:
Ayush Saxena 2020-05-24 18:03:41 +05:30
parent c44d8b8bdf
commit 718c8a5868
1 changed files with 47 additions and 34 deletions

View File

@ -483,6 +483,50 @@ public class VolumeScanner extends Thread {
return shouldScan; return shouldScan;
} }
/**
* Get next block and check if it's needed to scan.
*
* @return the candidate block.
*/
ExtendedBlock getNextBlockToScan() {
ExtendedBlock block;
try {
block = curBlockIter.nextBlock();
} catch (IOException e) {
// There was an error listing the next block in the volume. This is a
// serious issue.
LOG.warn("{}: nextBlock error on {}", this, curBlockIter);
// On the next loop iteration, curBlockIter#eof will be set to true, and
// we will pick a different block iterator.
return null;
}
if (block == null) {
// The BlockIterator is at EOF.
LOG.info("{}: finished scanning block pool {}",
this, curBlockIter.getBlockPoolId());
saveBlockIterator(curBlockIter);
return null;
} else if (conf.skipRecentAccessed) {
// Check the access time of block file to avoid scanning recently
// changed blocks, reducing disk IO.
try {
BlockLocalPathInfo blockLocalPathInfo =
volume.getDataset().getBlockLocalPathInfo(block);
BasicFileAttributes attr = Files.readAttributes(
new File(blockLocalPathInfo.getBlockPath()).toPath(),
BasicFileAttributes.class);
if (System.currentTimeMillis() - attr.lastAccessTime().
to(TimeUnit.MILLISECONDS) < conf.scanPeriodMs) {
return null;
}
} catch (IOException ioe) {
LOG.debug("Failed to get access time of block {}",
block, ioe);
}
}
return block;
}
/** /**
* Run an iteration of the VolumeScanner loop. * Run an iteration of the VolumeScanner loop.
* *
@ -507,10 +551,10 @@ public class VolumeScanner extends Thread {
return 30000L; return 30000L;
} }
// Find a usable block pool to scan.
if (suspectBlock != null) { if (suspectBlock != null) {
block = suspectBlock; block = suspectBlock;
} else { } else {
// Find a usable block pool to scan.
if ((curBlockIter == null) || curBlockIter.atEnd()) { if ((curBlockIter == null) || curBlockIter.atEnd()) {
long timeout = findNextUsableBlockIter(); long timeout = findNextUsableBlockIter();
if (timeout > 0) { if (timeout > 0) {
@ -528,40 +572,9 @@ public class VolumeScanner extends Thread {
} }
return 0L; return 0L;
} }
try { block = getNextBlockToScan();
block = curBlockIter.nextBlock();
} catch (IOException e) {
// There was an error listing the next block in the volume. This is a
// serious issue.
LOG.warn("{}: nextBlock error on {}", this, curBlockIter);
// On the next loop iteration, curBlockIter#eof will be set to true, and
// we will pick a different block iterator.
return 0L;
}
if (block == null) { if (block == null) {
// The BlockIterator is at EOF. return 0L;
LOG.info("{}: finished scanning block pool {}",
this, curBlockIter.getBlockPoolId());
saveBlockIterator(curBlockIter);
return 0;
} else if (conf.skipRecentAccessed) {
// Check the access time of block file to avoid scanning recently
// changed blocks, reducing disk IO.
try {
BlockLocalPathInfo blockLocalPathInfo =
volume.getDataset().getBlockLocalPathInfo(block);
BasicFileAttributes attr = Files.readAttributes(
new File(blockLocalPathInfo.getBlockPath()).toPath(),
BasicFileAttributes.class);
if (System.currentTimeMillis() - attr.lastAccessTime().
to(TimeUnit.MILLISECONDS) < conf.scanPeriodMs) {
return 0;
}
} catch (IOException ioe) {
LOG.debug("Failed to get access time of block {}",
block, ioe);
}
} }
} }
if (curBlockIter != null) { if (curBlockIter != null) {