diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/JvmPauseMonitor.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/JvmPauseMonitor.java index 882e4a73285..17a19521364 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/JvmPauseMonitor.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/JvmPauseMonitor.java @@ -185,6 +185,7 @@ public class JvmPauseMonitor extends AbstractService { public void run() { StopWatch sw = new StopWatch(); Map gcTimesBeforeSleep = getGcTimes(); + LOG.info("Starting JVM pause monitor"); while (shouldRun) { sw.reset().start(); try { diff --git a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt index 83b60a15373..e734ba50735 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt +++ b/hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt @@ -932,6 +932,9 @@ Release 2.8.0 - UNRELEASED HDFS-9415. Document dfs.cluster.administrators and dfs.permissions.superusergroup. (Xiaobing Zhou via Arpit Agarwal) + HDFS-9655. NN should start JVM pause monitor before loading fsimage. + (John Zhuge via Lei (Eddy) Xu) + OPTIMIZATIONS HDFS-8026. Trace FSOutputSummer#writeChecksumChunks rather than diff --git a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NameNode.java b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NameNode.java index 9cbde90aa9d..9b41a56526d 100644 --- a/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NameNode.java +++ b/hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/NameNode.java @@ -671,6 +671,11 @@ public class NameNode implements NameNodeStatusMXBean { NameNode.initMetrics(conf, this.getRole()); StartupProgressMetrics.register(startupProgress); + pauseMonitor = new JvmPauseMonitor(); + pauseMonitor.init(conf); + pauseMonitor.start(); + metrics.getJvmMetrics().setPauseMonitor(pauseMonitor); + if (NamenodeRole.NAMENODE == role) { startHttpServer(conf); } @@ -690,12 +695,7 @@ public class NameNode implements NameNodeStatusMXBean { httpServer.setNameNodeAddress(getNameNodeAddress()); httpServer.setFSImage(getFSImage()); } - - pauseMonitor = new JvmPauseMonitor(); - pauseMonitor.init(conf); - pauseMonitor.start(); - metrics.getJvmMetrics().setPauseMonitor(pauseMonitor); - + startCommonServices(conf); startMetricsLogger(conf); }