HBASE-24367 ScheduledChore log elapsed timespan in a human-friendly format (#1749)

Signed-off-by: Nick Dimiduk <ndimiduk@apache.org>
Signed-off-by: Guanghao Zhang <zghao@apache.org>
Signed-off-by: Viraj Jasani <vjasani@apache.org>
This commit is contained in:
Andrew Purtell 2020-06-09 09:55:20 -07:00
parent dc2cf6ab5c
commit b67f896954
No known key found for this signature in database
GPG Key ID: 8597754DD5365CCD
1 changed files with 12 additions and 16 deletions

View File

@ -21,8 +21,6 @@ package org.apache.hadoop.hbase;
import java.util.concurrent.ScheduledThreadPoolExecutor; import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.apache.hadoop.hbase.util.MovingAverage;
import org.apache.hadoop.hbase.util.WindowMovingAverage;
import org.apache.yetus.audience.InterfaceAudience; import org.apache.yetus.audience.InterfaceAudience;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -81,10 +79,6 @@ public abstract class ScheduledChore implements Runnable {
*/ */
private final Stoppable stopper; private final Stoppable stopper;
private final MovingAverage<Void> timeMeasurement;
private static final long FIVE_MINUTES_IN_NANOS = TimeUnit.MINUTES.toNanos(5L);
private long lastLog = System.nanoTime();
interface ChoreServicer { interface ChoreServicer {
/** /**
* Cancel any ongoing schedules that this chore has with the implementer of this interface. * Cancel any ongoing schedules that this chore has with the implementer of this interface.
@ -165,7 +159,6 @@ public abstract class ScheduledChore implements Runnable {
this.period = period; this.period = period;
this.initialDelay = initialDelay < 0 ? 0 : initialDelay; this.initialDelay = initialDelay < 0 ? 0 : initialDelay;
this.timeUnit = unit; this.timeUnit = unit;
this.timeMeasurement = new WindowMovingAverage(name);
} }
/** /**
@ -183,18 +176,21 @@ public abstract class ScheduledChore implements Runnable {
if (LOG.isInfoEnabled()) LOG.info("Chore: " + getName() + " was stopped"); if (LOG.isInfoEnabled()) LOG.info("Chore: " + getName() + " was stopped");
} else { } else {
try { try {
// TODO: Histogram metrics per chore name.
// For now, just measure and log if DEBUG level logging is enabled.
long start = 0;
if (LOG.isDebugEnabled()) {
start = System.nanoTime();
}
if (!initialChoreComplete) { if (!initialChoreComplete) {
initialChoreComplete = initialChore(); initialChoreComplete = initialChore();
} else { } else {
timeMeasurement.measure(() -> { chore();
chore(); }
return null; if (LOG.isDebugEnabled() && start > 0) {
}); long end = System.nanoTime();
if (LOG.isInfoEnabled() && (System.nanoTime() - lastLog > FIVE_MINUTES_IN_NANOS)) { LOG.debug("{} execution time: {} ms.", getName(),
LOG.info("{} average execution time: {} ns.", getName(), TimeUnit.NANOSECONDS.toMillis(end - start));
(long)(timeMeasurement.getAverageTime()));
lastLog = System.nanoTime();
}
} }
} catch (Throwable t) { } catch (Throwable t) {
if (LOG.isErrorEnabled()) LOG.error("Caught error", t); if (LOG.isErrorEnabled()) LOG.error("Caught error", t);