HDFS-16089. Add metric EcReconstructionValidateTimeMillis for StripedBlockReconstructor (#3146)
(cherry picked from commit 95454d821c
)
This commit is contained in:
parent
8538881710
commit
4ee7bd345f
@ -135,9 +135,16 @@ private void reconstructTargets(int toReconstructLen) throws IOException {
|
||||
resetBuffers(inputs);
|
||||
|
||||
DataNodeFaultInjector.get().badDecoding(outputs);
|
||||
long start = Time.monotonicNow();
|
||||
try {
|
||||
getValidator().validate(inputs, erasedIndices, outputs);
|
||||
long validateEnd = Time.monotonicNow();
|
||||
getDatanode().getMetrics().incrECReconstructionValidateTime(
|
||||
validateEnd - start);
|
||||
} catch (InvalidDecodingException e) {
|
||||
long validateFailedEnd = Time.monotonicNow();
|
||||
getDatanode().getMetrics().incrECReconstructionValidateTime(
|
||||
validateFailedEnd - start);
|
||||
getDatanode().getMetrics().incrECInvalidReconstructionTasks();
|
||||
throw e;
|
||||
}
|
||||
|
@ -168,6 +168,8 @@ public class DataNodeMetrics {
|
||||
private MutableCounterLong ecReconstructionDecodingTimeMillis;
|
||||
@Metric("Milliseconds spent on write by erasure coding worker")
|
||||
private MutableCounterLong ecReconstructionWriteTimeMillis;
|
||||
@Metric("Milliseconds spent on validating by erasure coding worker")
|
||||
private MutableCounterLong ecReconstructionValidateTimeMillis;
|
||||
@Metric("Sum of all BPServiceActors command queue length")
|
||||
private MutableCounterLong sumOfActorCommandQueueLength;
|
||||
@Metric("Num of processed commands of all BPServiceActors")
|
||||
@ -605,6 +607,10 @@ public void incrECReconstructionDecodingTime(long millis) {
|
||||
ecReconstructionDecodingTimeMillis.incr(millis);
|
||||
}
|
||||
|
||||
public void incrECReconstructionValidateTime(long millis) {
|
||||
ecReconstructionValidateTimeMillis.incr(millis);
|
||||
}
|
||||
|
||||
public DataNodeUsageReport getDNUsageReport(long timeSinceLastReport) {
|
||||
return dnUsageReportUtil.getUsageReport(bytesWritten.value(), bytesRead
|
||||
.value(), totalWriteTime.value(), totalReadTime.value(),
|
||||
|
@ -364,7 +364,7 @@ public void testCountLiveReplicas() throws Exception {
|
||||
}
|
||||
}
|
||||
|
||||
@Test(timeout=120000) // 1 min timeout
|
||||
@Test(timeout=120000) // 2 min timeout
|
||||
public void testReconstructionWork() throws Exception {
|
||||
Configuration conf = new HdfsConfiguration();
|
||||
conf.setLong(DFSConfigKeys.DFS_NAMENODE_MIN_BLOCK_SIZE_KEY, 0);
|
||||
|
Loading…
Reference in New Issue
Block a user