Arpit Agarwal created HDFS-8163:
-----------------------------------
Summary: Using monotonicNow for block report scheduling causes
test failures on recently restarted systems
Key: HDFS-8163
URL: https://issues.apache.org/jira/browse/HDFS-8163
Project: Hadoop HDFS
Issue Type: Bug
Components: datanode
Affects Versions: 2.6.1
Reporter: Arpit Agarwal
Priority: Blocker
{{BPServiceActor#blockReport}} has the following check:
{code}
List<DatanodeCommand> blockReport() throws IOException {
// send block report if timer has expired.
final long startTime = monotonicNow();
if (startTime - lastBlockReport <= dnConf.blockReportInterval) {
return null;
}
{code}
Many tests set lastBlockReport to zero to trigger an immediate block report via
{{BPServiceActor#triggerBlockReportForTests}}. However if the machine was
restarted recently then this startTime could be less than
{{dnConf.blockReportInterval}} and the block report is not sent.
{{Time#monotonicNow}} uses {{System#nanoTime}} which represents time elapsed
since an arbitrary origin. The time should be used only for comparison with
values returned by {{System#nanoTime}}.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)