MAPREDUCE-6967. gridmix/SleepReducer should use Time.monotonicNow for measuring durations. Contributed by Chetna Chaudhari

(cherry picked from commit b133dc5700)
This commit is contained in:
Jason Lowe 2017-09-22 15:21:42 -05:00
parent 5eb1f9f7b3
commit 0eb0298027
1 changed files with 3 additions and 2 deletions

View File

@ -52,6 +52,7 @@ import org.apache.hadoop.tools.rumen.TaskAttemptInfo;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.hadoop.util.Time;
public class SleepJob extends GridmixJob {
public static final Log LOG = LogFactory.getLog(SleepJob.class);
@ -184,7 +185,7 @@ public class SleepJob extends GridmixJob {
TimeUnit.MILLISECONDS.convert(sleepInterval, TimeUnit.SECONDS);
//This is to stop accumulating deviation from expected sleep time
//over a period of time.
long start = System.currentTimeMillis();
long start = Time.monotonicNow();
long slept = 0L;
long sleep = 0L;
while (slept < duration) {
@ -192,7 +193,7 @@ public class SleepJob extends GridmixJob {
sleep = Math.min(rem, RINTERVAL);
context.setStatus("Sleeping... " + rem + " ms left");
TimeUnit.MILLISECONDS.sleep(sleep);
slept = System.currentTimeMillis() - start;
slept = Time.monotonicNow() - start;
}
}