blob: b72236551a642ad4969c1cca6ea6fe2afdc68e7a [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!--
| Generated by Apache Maven Doxia at 2021-06-15
| Rendered using Apache Maven Stylus Skin 1.5
-->
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Apache Hadoop 3.3.1 &#x2013; Overview</title>
<style type="text/css" media="all">
@import url("./css/maven-base.css");
@import url("./css/maven-theme.css");
@import url("./css/site.css");
</style>
<link rel="stylesheet" href="./css/print.css" type="text/css" media="print" />
<meta name="Date-Revision-yyyymmdd" content="20210615" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body class="composite">
<div id="banner">
<a href="http://hadoop.apache.org/" id="bannerLeft">
<img src="http://hadoop.apache.org/images/hadoop-logo.jpg" alt="" />
</a>
<a href="http://www.apache.org/" id="bannerRight">
<img src="http://www.apache.org/images/asf_logo_wide.png" alt="" />
</a>
<div class="clear">
<hr/>
</div>
</div>
<div id="breadcrumbs">
<div class="xleft">
<a href="http://www.apache.org/" class="externalLink">Apache</a>
&gt;
<a href="http://hadoop.apache.org/" class="externalLink">Hadoop</a>
&gt;
<a href="../index.html">Apache Hadoop Project Dist POM</a>
&gt;
<a href="index.html">Apache Hadoop 3.3.1</a>
&gt;
Overview
</div>
<div class="xright"> <a href="http://wiki.apache.org/hadoop" class="externalLink">Wiki</a>
|
<a href="https://gitbox.apache.org/repos/asf/hadoop.git" class="externalLink">git</a>
|
<a href="http://hadoop.apache.org/" class="externalLink">Apache Hadoop</a>
&nbsp;| Last Published: 2021-06-15
&nbsp;| Version: 3.3.1
</div>
<div class="clear">
<hr/>
</div>
</div>
<div id="leftColumn">
<div id="navcolumn">
<h5>General</h5>
<ul>
<li class="none">
<a href="../../index.html">Overview</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/SingleCluster.html">Single Node Setup</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/ClusterSetup.html">Cluster Setup</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/CommandsManual.html">Commands Reference</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/FileSystemShell.html">FileSystem Shell</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/Compatibility.html">Compatibility Specification</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/DownstreamDev.html">Downstream Developer's Guide</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/AdminCompatibilityGuide.html">Admin Compatibility Guide</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/InterfaceClassification.html">Interface Classification</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/filesystem/index.html">FileSystem Specification</a>
</li>
</ul>
<h5>Common</h5>
<ul>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/CLIMiniCluster.html">CLI Mini Cluster</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/FairCallQueue.html">Fair Call Queue</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/NativeLibraries.html">Native Libraries</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/Superusers.html">Proxy User</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/RackAwareness.html">Rack Awareness</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/SecureMode.html">Secure Mode</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/ServiceLevelAuth.html">Service Level Authorization</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/HttpAuthentication.html">HTTP Authentication</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/CredentialProviderAPI.html">Credential Provider API</a>
</li>
<li class="none">
<a href="../../hadoop-kms/index.html">Hadoop KMS</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/Tracing.html">Tracing</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/UnixShellGuide.html">Unix Shell Guide</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/registry/index.html">Registry</a>
</li>
</ul>
<h5>HDFS</h5>
<ul>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsDesign.html">Architecture</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsUserGuide.html">User Guide</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HDFSCommands.html">Commands Reference</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HDFSHighAvailabilityWithQJM.html">NameNode HA With QJM</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HDFSHighAvailabilityWithNFS.html">NameNode HA With NFS</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ObserverNameNode.html">Observer NameNode</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/Federation.html">Federation</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ViewFs.html">ViewFs</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ViewFsOverloadScheme.html">ViewFsOverloadScheme</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsSnapshots.html">Snapshots</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsEditsViewer.html">Edits Viewer</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsImageViewer.html">Image Viewer</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsPermissionsGuide.html">Permissions and HDFS</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsQuotaAdminGuide.html">Quotas and HDFS</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/LibHdfs.html">libhdfs (C API)</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/WebHDFS.html">WebHDFS (REST API)</a>
</li>
<li class="none">
<a href="../../hadoop-hdfs-httpfs/index.html">HttpFS</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ShortCircuitLocalReads.html">Short Circuit Local Reads</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/CentralizedCacheManagement.html">Centralized Cache Management</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsNfsGateway.html">NFS Gateway</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsRollingUpgrade.html">Rolling Upgrade</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ExtendedAttributes.html">Extended Attributes</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/TransparentEncryption.html">Transparent Encryption</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsMultihoming.html">Multihoming</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/ArchivalStorage.html">Storage Policies</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/MemoryStorage.html">Memory Storage Support</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/SLGUserGuide.html">Synthetic Load Generator</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HDFSErasureCoding.html">Erasure Coding</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HDFSDiskbalancer.html">Disk Balancer</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsUpgradeDomain.html">Upgrade Domain</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsDataNodeAdminGuide.html">DataNode Admin</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs-rbf/HDFSRouterFederation.html">Router Federation</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/HdfsProvidedStorage.html">Provided Storage</a>
</li>
</ul>
<h5>MapReduce</h5>
<ul>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/MapReduceTutorial.html">Tutorial</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/MapredCommands.html">Commands Reference</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/MapReduce_Compatibility_Hadoop1_Hadoop2.html">Compatibility with 1.x</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/EncryptedShuffle.html">Encrypted Shuffle</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/PluggableShuffleAndPluggableSort.html">Pluggable Shuffle/Sort</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/DistributedCacheDeploy.html">Distributed Cache Deploy</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/SharedCacheSupport.html">Support for YARN Shared Cache</a>
</li>
</ul>
<h5>MapReduce REST APIs</h5>
<ul>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/MapredAppMasterRest.html">MR Application Master</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-hs/HistoryServerRest.html">MR History Server</a>
</li>
</ul>
<h5>YARN</h5>
<ul>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/YARN.html">Architecture</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/YarnCommands.html">Commands Reference</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/CapacityScheduler.html">Capacity Scheduler</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/FairScheduler.html">Fair Scheduler</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/ResourceManagerRestart.html">ResourceManager Restart</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/ResourceManagerHA.html">ResourceManager HA</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/ResourceModel.html">Resource Model</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/NodeLabel.html">Node Labels</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/NodeAttributes.html">Node Attributes</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/WebApplicationProxy.html">Web Application Proxy</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/TimelineServer.html">Timeline Server</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/TimelineServiceV2.html">Timeline Service V.2</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/WritingYarnApplications.html">Writing YARN Applications</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/YarnApplicationSecurity.html">YARN Application Security</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/NodeManager.html">NodeManager</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/DockerContainers.html">Running Applications in Docker Containers</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/RuncContainers.html">Running Applications in runC Containers</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/NodeManagerCgroups.html">Using CGroups</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/SecureContainer.html">Secure Containers</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/ReservationSystem.html">Reservation System</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/GracefulDecommission.html">Graceful Decommission</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/OpportunisticContainers.html">Opportunistic Containers</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/Federation.html">YARN Federation</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/SharedCache.html">Shared Cache</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/UsingGpus.html">Using GPU</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/UsingFPGA.html">Using FPGA</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/PlacementConstraints.html">Placement Constraints</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/YarnUI2.html">YARN UI2</a>
</li>
</ul>
<h5>YARN REST APIs</h5>
<ul>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/WebServicesIntro.html">Introduction</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/ResourceManagerRest.html">Resource Manager</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/NodeManagerRest.html">Node Manager</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/TimelineServer.html#Timeline_Server_REST_API_v1">Timeline Server</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/TimelineServiceV2.html#Timeline_Service_v.2_REST_API">Timeline Service V.2</a>
</li>
</ul>
<h5>YARN Service</h5>
<ul>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/Overview.html">Overview</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/QuickStart.html">QuickStart</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/Concepts.html">Concepts</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/YarnServiceAPI.html">Yarn Service API</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/ServiceDiscovery.html">Service Discovery</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-site/yarn-service/SystemServices.html">System Services</a>
</li>
</ul>
<h5>Hadoop Compatible File Systems</h5>
<ul>
<li class="none">
<a href="../../hadoop-aliyun/tools/hadoop-aliyun/index.html">Aliyun OSS</a>
</li>
<li class="none">
<a href="../../hadoop-aws/tools/hadoop-aws/index.html">Amazon S3</a>
</li>
<li class="none">
<a href="../../hadoop-azure/index.html">Azure Blob Storage</a>
</li>
<li class="none">
<a href="../../hadoop-azure-datalake/index.html">Azure Data Lake Storage</a>
</li>
<li class="none">
<a href="../../hadoop-openstack/index.html">OpenStack Swift</a>
</li>
<li class="none">
<a href="../../hadoop-cos/cloud-storage/index.html">Tencent COS</a>
</li>
</ul>
<h5>Auth</h5>
<ul>
<li class="none">
<a href="../../hadoop-auth/index.html">Overview</a>
</li>
<li class="none">
<a href="../../hadoop-auth/Examples.html">Examples</a>
</li>
<li class="none">
<a href="../../hadoop-auth/Configuration.html">Configuration</a>
</li>
<li class="none">
<a href="../../hadoop-auth/BuildingIt.html">Building</a>
</li>
</ul>
<h5>Tools</h5>
<ul>
<li class="none">
<a href="../../hadoop-streaming/HadoopStreaming.html">Hadoop Streaming</a>
</li>
<li class="none">
<a href="../../hadoop-archives/HadoopArchives.html">Hadoop Archives</a>
</li>
<li class="none">
<a href="../../hadoop-archive-logs/HadoopArchiveLogs.html">Hadoop Archive Logs</a>
</li>
<li class="none">
<a href="../../hadoop-distcp/DistCp.html">DistCp</a>
</li>
<li class="none">
<a href="../../hadoop-gridmix/GridMix.html">GridMix</a>
</li>
<li class="none">
<a href="../../hadoop-rumen/Rumen.html">Rumen</a>
</li>
<li class="none">
<a href="../../hadoop-resourceestimator/ResourceEstimator.html">Resource Estimator Service</a>
</li>
<li class="none">
<a href="../../hadoop-sls/SchedulerLoadSimulator.html">Scheduler Load Simulator</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/Benchmarking.html">Hadoop Benchmarking</a>
</li>
<li class="none">
<a href="../../hadoop-dynamometer/Dynamometer.html">Dynamometer</a>
</li>
</ul>
<h5>Reference</h5>
<ul>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/release/">Changelog and Release Notes</a>
</li>
<li class="none">
<a href="../../api/index.html">Java API docs</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/UnixShellAPI.html">Unix Shell API</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/Metrics.html">Metrics</a>
</li>
</ul>
<h5>Configuration</h5>
<ul>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/core-default.xml">core-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs/hdfs-default.xml">hdfs-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-hdfs-rbf/hdfs-rbf-default.xml">hdfs-rbf-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-mapreduce-client/hadoop-mapreduce-client-core/mapred-default.xml">mapred-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-yarn/hadoop-yarn-common/yarn-default.xml">yarn-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-kms/kms-default.html">kms-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-hdfs-httpfs/httpfs-default.html">httpfs-default.xml</a>
</li>
<li class="none">
<a href="../../hadoop-project-dist/hadoop-common/DeprecatedProperties.html">Deprecated Properties</a>
</li>
</ul>
<a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy">
<img alt="Built by Maven" src="./images/logos/maven-feather.png"/>
</a>
</div>
</div>
<div id="bodyColumn">
<div id="contentBox">
<!---
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License. See accompanying LICENSE file.
-->
<ul>
<li><a href="#JvmMetrics">JvmMetrics</a></li>
<li><a href="#rpc">rpc</a></li>
<li><a href="#RetryCache.2FNameNodeRetryCache">RetryCache/NameNodeRetryCache</a></li>
<li><a href="#FairCallQueue">FairCallQueue</a></li>
<li><a href="#DecayRpcSchedulerDetailed">DecayRpcSchedulerDetailed</a></li>
<li><a href="#rpcdetailed">rpcdetailed</a></li>
<li><a href="#namenode">namenode</a></li>
<li><a href="#FSNamesystem">FSNamesystem</a></li>
<li><a href="#JournalNode">JournalNode</a></li>
<li><a href="#datanode">datanode</a></li>
<li><a href="#FsVolume">FsVolume</a></li>
<li><a href="#RBFMetrics">RBFMetrics</a></li>
<li><a href="#RouterRPCMetrics">RouterRPCMetrics</a></li>
<li><a href="#StateStoreMetrics">StateStoreMetrics</a></li>
<li><a href="#ClusterMetrics">ClusterMetrics</a></li>
<li><a href="#QueueMetrics">QueueMetrics</a></li>
<li><a href="#NodeManagerMetrics">NodeManagerMetrics</a></li>
<li><a href="#ContainerMetrics">ContainerMetrics</a></li>
<li><a href="#UgiMetrics">UgiMetrics</a></li>
<li><a href="#MetricsSystem">MetricsSystem</a></li>
<li><a href="#StartupProgress">StartupProgress</a></li></ul>
<h1>Overview</h1>
<p>Metrics are statistical information exposed by Hadoop daemons, used for monitoring, performance tuning and debug. There are many metrics available by default and they are very useful for troubleshooting. This page shows the details of the available metrics.</p>
<p>Each section describes each context into which metrics are grouped.</p>
<p>The documentation of Metrics 2.0 framework is <a href="../../api/org/apache/hadoop/metrics2/package-summary.html">here</a>.</p>
<h1>jvm context</h1>
<div class="section">
<h2><a name="JvmMetrics"></a>JvmMetrics</h2>
<p>Each metrics record contains tags such as ProcessName, SessionID and Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>MemNonHeapUsedM</tt> </td>
<td align="left"> Current non-heap memory used in MB </td></tr>
<tr class="a">
<td align="left"> <tt>MemNonHeapCommittedM</tt> </td>
<td align="left"> Current non-heap memory committed in MB </td></tr>
<tr class="b">
<td align="left"> <tt>MemNonHeapMaxM</tt> </td>
<td align="left"> Max non-heap memory size in MB </td></tr>
<tr class="a">
<td align="left"> <tt>MemHeapUsedM</tt> </td>
<td align="left"> Current heap memory used in MB </td></tr>
<tr class="b">
<td align="left"> <tt>MemHeapCommittedM</tt> </td>
<td align="left"> Current heap memory committed in MB </td></tr>
<tr class="a">
<td align="left"> <tt>MemHeapMaxM</tt> </td>
<td align="left"> Max heap memory size in MB </td></tr>
<tr class="b">
<td align="left"> <tt>MemMaxM</tt> </td>
<td align="left"> Max memory size in MB </td></tr>
<tr class="a">
<td align="left"> <tt>ThreadsNew</tt> </td>
<td align="left"> Current number of NEW threads </td></tr>
<tr class="b">
<td align="left"> <tt>ThreadsRunnable</tt> </td>
<td align="left"> Current number of RUNNABLE threads </td></tr>
<tr class="a">
<td align="left"> <tt>ThreadsBlocked</tt> </td>
<td align="left"> Current number of BLOCKED threads </td></tr>
<tr class="b">
<td align="left"> <tt>ThreadsWaiting</tt> </td>
<td align="left"> Current number of WAITING threads </td></tr>
<tr class="a">
<td align="left"> <tt>ThreadsTimedWaiting</tt> </td>
<td align="left"> Current number of TIMED_WAITING threads </td></tr>
<tr class="b">
<td align="left"> <tt>ThreadsTerminated</tt> </td>
<td align="left"> Current number of TERMINATED threads </td></tr>
<tr class="a">
<td align="left"> <tt>GcInfo</tt> </td>
<td align="left"> Total GC count and GC time in msec, grouped by the kind of GC. &#xa0;ex.) GcCountPS Scavenge=6, GCTimeMillisPS Scavenge=40, GCCountPS MarkSweep=0, GCTimeMillisPS MarkSweep=0 </td></tr>
<tr class="b">
<td align="left"> <tt>GcCount</tt> </td>
<td align="left"> Total GC count </td></tr>
<tr class="a">
<td align="left"> <tt>GcTimeMillis</tt> </td>
<td align="left"> Total GC time in msec </td></tr>
<tr class="b">
<td align="left"> <tt>LogFatal</tt> </td>
<td align="left"> Total number of FATAL logs </td></tr>
<tr class="a">
<td align="left"> <tt>LogError</tt> </td>
<td align="left"> Total number of ERROR logs </td></tr>
<tr class="b">
<td align="left"> <tt>LogWarn</tt> </td>
<td align="left"> Total number of WARN logs </td></tr>
<tr class="a">
<td align="left"> <tt>LogInfo</tt> </td>
<td align="left"> Total number of INFO logs </td></tr>
<tr class="b">
<td align="left"> <tt>GcNumWarnThresholdExceeded</tt> </td>
<td align="left"> Number of times that the GC warn threshold is exceeded </td></tr>
<tr class="a">
<td align="left"> <tt>GcNumInfoThresholdExceeded</tt> </td>
<td align="left"> Number of times that the GC info threshold is exceeded </td></tr>
<tr class="b">
<td align="left"> <tt>GcTotalExtraSleepTime</tt> </td>
<td align="left"> Total GC extra sleep time in msec </td></tr>
<tr class="a">
<td align="left"> <tt>GcTimePercentage</tt> </td>
<td align="left"> The percentage (0..100) of time that the JVM spent in GC pauses within the observation window if <tt>dfs.namenode.gc.time.monitor.enable</tt> is set to true. Use <tt>dfs.namenode.gc.time.monitor.sleep.interval.ms</tt> to specify the sleep interval in msec. Use <tt>dfs.namenode.gc.time.monitor.observation.window.ms</tt> to specify the observation window in msec. </td></tr>
</tbody>
</table>
<h1>rpc context</h1></div>
<div class="section">
<h2><a name="rpc"></a>rpc</h2>
<p>Each metrics record contains tags such as Hostname and port (number to which server is bound) as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>ReceivedBytes</tt> </td>
<td align="left"> Total number of received bytes </td></tr>
<tr class="a">
<td align="left"> <tt>SentBytes</tt> </td>
<td align="left"> Total number of sent bytes </td></tr>
<tr class="b">
<td align="left"> <tt>RpcQueueTimeNumOps</tt> </td>
<td align="left"> Total number of RPC calls </td></tr>
<tr class="a">
<td align="left"> <tt>RpcQueueTimeAvgTime</tt> </td>
<td align="left"> Average queue time in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>RpcLockWaitTimeNumOps</tt> </td>
<td align="left"> Total number of RPC call (same as RpcQueueTimeNumOps) </td></tr>
<tr class="a">
<td align="left"> <tt>RpcLockWaitTimeAvgTime</tt> </td>
<td align="left"> Average time waiting for lock acquisition in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>RpcProcessingTimeNumOps</tt> </td>
<td align="left"> Total number of RPC calls (same to RpcQueueTimeNumOps) </td></tr>
<tr class="a">
<td align="left"> <tt>RpcProcessingAvgTime</tt> </td>
<td align="left"> Average Processing time in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>RpcAuthenticationFailures</tt> </td>
<td align="left"> Total number of authentication failures </td></tr>
<tr class="a">
<td align="left"> <tt>RpcAuthenticationSuccesses</tt> </td>
<td align="left"> Total number of authentication successes </td></tr>
<tr class="b">
<td align="left"> <tt>RpcAuthorizationFailures</tt> </td>
<td align="left"> Total number of authorization failures </td></tr>
<tr class="a">
<td align="left"> <tt>RpcAuthorizationSuccesses</tt> </td>
<td align="left"> Total number of authorization successes </td></tr>
<tr class="b">
<td align="left"> <tt>NumOpenConnections</tt> </td>
<td align="left"> Current number of open connections </td></tr>
<tr class="a">
<td align="left"> <tt>CallQueueLength</tt> </td>
<td align="left"> Current length of the call queue </td></tr>
<tr class="b">
<td align="left"> <tt>numDroppedConnections</tt> </td>
<td align="left"> Total number of dropped connections </td></tr>
<tr class="a">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>sNumOps</tt> </td>
<td align="left"> Shows total number of RPC calls (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>s50thPercentileLatency</tt> </td>
<td align="left"> Shows the 50th percentile of RPC queue time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>s75thPercentileLatency</tt> </td>
<td align="left"> Shows the 75th percentile of RPC queue time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>s90thPercentileLatency</tt> </td>
<td align="left"> Shows the 90th percentile of RPC queue time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>s95thPercentileLatency</tt> </td>
<td align="left"> Shows the 95th percentile of RPC queue time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcQueueTime</tt><i>num</i><tt>s99thPercentileLatency</tt> </td>
<td align="left"> Shows the 99th percentile of RPC queue time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>sNumOps</tt> </td>
<td align="left"> Shows total number of RPC calls (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>s50thPercentileLatency</tt> </td>
<td align="left"> Shows the 50th percentile of RPC processing time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>s75thPercentileLatency</tt> </td>
<td align="left"> Shows the 75th percentile of RPC processing time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>s90thPercentileLatency</tt> </td>
<td align="left"> Shows the 90th percentile of RPC processing time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>s95thPercentileLatency</tt> </td>
<td align="left"> Shows the 95th percentile of RPC processing time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcProcessingTime</tt><i>num</i><tt>s99thPercentileLatency</tt> </td>
<td align="left"> Shows the 99th percentile of RPC processing time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>sNumOps</tt> </td>
<td align="left"> Shows total number of RPC calls (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>s50thPercentileLatency</tt> </td>
<td align="left"> Shows the 50th percentile of RPC lock wait time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>s75thPercentileLatency</tt> </td>
<td align="left"> Shows the 75th percentile of RPC lock wait time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>s90thPercentileLatency</tt> </td>
<td align="left"> Shows the 90th percentile of RPC lock wait time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>s95thPercentileLatency</tt> </td>
<td align="left"> Shows the 95th percentile of RPC lock wait time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>rpcLockWaitTime</tt><i>num</i><tt>s99thPercentileLatency</tt> </td>
<td align="left"> Shows the 99th percentile of RPC lock wait time in milliseconds (<i>num</i> seconds granularity) if <tt>rpc.metrics.quantile.enable</tt> is set to true. <i>num</i> is specified by <tt>rpc.metrics.percentiles.intervals</tt>. </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="RetryCache.2FNameNodeRetryCache"></a>RetryCache/NameNodeRetryCache</h2>
<p>RetryCache metrics is useful to monitor NameNode fail-over. Each metrics record contains Hostname tag.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>CacheHit</tt> </td>
<td align="left"> Total number of RetryCache hit </td></tr>
<tr class="a">
<td align="left"> <tt>CacheCleared</tt> </td>
<td align="left"> Total number of RetryCache cleared </td></tr>
<tr class="b">
<td align="left"> <tt>CacheUpdated</tt> </td>
<td align="left"> Total number of RetryCache updated </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="FairCallQueue"></a>FairCallQueue</h2>
<p>FairCallQueue metrics will only exist if FairCallQueue is enabled. Each metric exists for each level of priority.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>FairCallQueueSize_p</tt><i>Priority</i> </td>
<td align="left"> Current number of calls in priority queue </td></tr>
<tr class="a">
<td align="left"> <tt>FairCallQueueOverflowedCalls_p</tt><i>Priority</i> </td>
<td align="left"> Total number of overflowed calls in priority queue </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="DecayRpcSchedulerDetailed"></a>DecayRpcSchedulerDetailed</h2>
<p>DecayRpcSchedulerDetailed metrics only exist when DecayRpcScheduler is used (FairCallQueue enabled). It is an addition to FairCallQueue metrics. For each level of priority, rpcqueue and rpcprocessing detailed metrics are exposed.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>DecayRPCSchedulerPriority.</tt><i>Priority</i><tt>.RpcQueueTime</tt> </td>
<td align="left"> RpcQueueTime metrics for each priority </td></tr>
<tr class="a">
<td align="left"> <tt>DecayRPCSchedulerPriority.</tt><i>Priority</i><tt>.RpcProcessingTime</tt> </td>
<td align="left"> RpcProcessingTime metrics for each priority </td></tr>
</tbody>
</table>
<h1>rpcdetailed context</h1>
<p>Metrics of rpcdetailed context are exposed in unified manner by RPC layer. Two metrics are exposed for each RPC based on its name. Metrics named &#x201c;(RPC method name)NumOps&#x201d; indicates total number of method calls, and metrics named &#x201c;(RPC method name)AvgTime&#x201d; shows average turn around time for method calls in milliseconds. Please note that the AvgTime metrics do not include time spent waiting to acquire locks on data structures (see RpcLockWaitTimeAvgTime).</p></div>
<div class="section">
<h2><a name="rpcdetailed"></a>rpcdetailed</h2>
<p>Each metrics record contains tags such as Hostname and port (number to which server is bound) as additional information along with metrics.</p>
<p>The Metrics about RPCs which is not called are not included in metrics record.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <i>methodname</i><tt>NumOps</tt> </td>
<td align="left"> Total number of the times the method is called </td></tr>
<tr class="a">
<td align="left"> <i>methodname</i><tt>AvgTime</tt> </td>
<td align="left"> Average turn around time of the method in milliseconds </td></tr>
</tbody>
</table>
<h1>dfs context</h1></div>
<div class="section">
<h2><a name="namenode"></a>namenode</h2>
<p>Each metrics record contains tags such as ProcessName, SessionId, and Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>CreateFileOps</tt> </td>
<td align="left"> Total number of files created </td></tr>
<tr class="a">
<td align="left"> <tt>FilesCreated</tt> </td>
<td align="left"> Total number of files and directories created by create or mkdir operations </td></tr>
<tr class="b">
<td align="left"> <tt>FilesAppended</tt> </td>
<td align="left"> Total number of files appended </td></tr>
<tr class="a">
<td align="left"> <tt>GetBlockLocations</tt> </td>
<td align="left"> Total number of getBlockLocations operations </td></tr>
<tr class="b">
<td align="left"> <tt>FilesRenamed</tt> </td>
<td align="left"> Total number of rename <b>operations</b> (NOT number of files/dirs renamed) </td></tr>
<tr class="a">
<td align="left"> <tt>GetListingOps</tt> </td>
<td align="left"> Total number of directory listing operations </td></tr>
<tr class="b">
<td align="left"> <tt>DeleteFileOps</tt> </td>
<td align="left"> Total number of delete operations </td></tr>
<tr class="a">
<td align="left"> <tt>FilesDeleted</tt> </td>
<td align="left"> Total number of files and directories deleted by delete or rename operations </td></tr>
<tr class="b">
<td align="left"> <tt>FileInfoOps</tt> </td>
<td align="left"> Total number of getFileInfo and getLinkFileInfo operations </td></tr>
<tr class="a">
<td align="left"> <tt>AddBlockOps</tt> </td>
<td align="left"> Total number of addBlock operations succeeded </td></tr>
<tr class="b">
<td align="left"> <tt>GetAdditionalDatanodeOps</tt> </td>
<td align="left"> Total number of getAdditionalDatanode operations </td></tr>
<tr class="a">
<td align="left"> <tt>CreateSymlinkOps</tt> </td>
<td align="left"> Total number of createSymlink operations </td></tr>
<tr class="b">
<td align="left"> <tt>GetLinkTargetOps</tt> </td>
<td align="left"> Total number of getLinkTarget operations </td></tr>
<tr class="a">
<td align="left"> <tt>FilesInGetListingOps</tt> </td>
<td align="left"> Total number of files and directories listed by directory listing operations </td></tr>
<tr class="b">
<td align="left"> <tt>SuccessfulReReplications</tt> </td>
<td align="left"> Total number of successful block re-replications </td></tr>
<tr class="a">
<td align="left"> <tt>NumTimesReReplicationNotScheduled</tt> </td>
<td align="left"> Total number of times that failed to schedule a block re-replication </td></tr>
<tr class="b">
<td align="left"> <tt>TimeoutReReplications</tt> </td>
<td align="left"> Total number of timed out block re-replications </td></tr>
<tr class="a">
<td align="left"> <tt>AllowSnapshotOps</tt> </td>
<td align="left"> Total number of allowSnapshot operations </td></tr>
<tr class="b">
<td align="left"> <tt>DisallowSnapshotOps</tt> </td>
<td align="left"> Total number of disallowSnapshot operations </td></tr>
<tr class="a">
<td align="left"> <tt>CreateSnapshotOps</tt> </td>
<td align="left"> Total number of createSnapshot operations </td></tr>
<tr class="b">
<td align="left"> <tt>DeleteSnapshotOps</tt> </td>
<td align="left"> Total number of deleteSnapshot operations </td></tr>
<tr class="a">
<td align="left"> <tt>RenameSnapshotOps</tt> </td>
<td align="left"> Total number of renameSnapshot operations </td></tr>
<tr class="b">
<td align="left"> <tt>ListSnapshottableDirOps</tt> </td>
<td align="left"> Total number of snapshottableDirectoryStatus operations </td></tr>
<tr class="a">
<td align="left"> <tt>SnapshotDiffReportOps</tt> </td>
<td align="left"> Total number of getSnapshotDiffReport operations </td></tr>
<tr class="b">
<td align="left"> <tt>TransactionsNumOps</tt> </td>
<td align="left"> Total number of Journal transactions </td></tr>
<tr class="a">
<td align="left"> <tt>TransactionsAvgTime</tt> </td>
<td align="left"> Average time of Journal transactions in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>SyncsNumOps</tt> </td>
<td align="left"> Total number of Journal syncs </td></tr>
<tr class="a">
<td align="left"> <tt>SyncsAvgTime</tt> </td>
<td align="left"> Average time of Journal syncs in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>SyncsTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of Journal sync time in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>TransactionsBatchedInSync</tt> </td>
<td align="left"> Total number of Journal transactions batched in sync </td></tr>
<tr class="b">
<td align="left"> <tt>TransactionsBatchedInSync</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileCount</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of number of batched Journal transactions (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>StorageBlockReportNumOps</tt> </td>
<td align="left"> Total number of processing block reports from individual storages in DataNode </td></tr>
<tr class="b">
<td align="left"> <tt>StorageBlockReportAvgTime</tt> </td>
<td align="left"> Average time of processing block reports in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>StorageBlockReport</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of block report processing time in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>CacheReportNumOps</tt> </td>
<td align="left"> Total number of processing cache reports from DataNode </td></tr>
<tr class="a">
<td align="left"> <tt>CacheReportAvgTime</tt> </td>
<td align="left"> Average time of processing cache reports in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>CacheReport</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of cached report processing time in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>SafeModeTime</tt> </td>
<td align="left"> The interval between FSNameSystem starts and the last time safemode leaves in milliseconds. &#xa0;(sometimes not equal to the time in SafeMode, see <a class="externalLink" href="https://issues.apache.org/jira/browse/HDFS-5156">HDFS-5156</a>) </td></tr>
<tr class="b">
<td align="left"> <tt>FsImageLoadTime</tt> </td>
<td align="left"> Time loading FS Image at startup in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>GetEditNumOps</tt> </td>
<td align="left"> Total number of edits downloads from SecondaryNameNode </td></tr>
<tr class="b">
<td align="left"> <tt>GetEditAvgTime</tt> </td>
<td align="left"> Average edits download time in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>GetImageNumOps</tt> </td>
<td align="left"> Total number of fsimage downloads from SecondaryNameNode </td></tr>
<tr class="b">
<td align="left"> <tt>GetImageAvgTime</tt> </td>
<td align="left"> Average fsimage download time in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>PutImageNumOps</tt> </td>
<td align="left"> Total number of fsimage uploads to SecondaryNameNode </td></tr>
<tr class="b">
<td align="left"> <tt>PutImageAvgTime</tt> </td>
<td align="left"> Average fsimage upload time in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>TotalFileOps</tt></td>
<td align="left"> Total number of file operations performed </td></tr>
<tr class="b">
<td align="left"> <tt>NNStartedTimeInMillis</tt></td>
<td align="left"> NameNode start time in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>GenerateEDEKTimeNumOps</tt> </td>
<td align="left"> Total number of generating EDEK </td></tr>
<tr class="b">
<td align="left"> <tt>GenerateEDEKTimeAvgTime</tt> </td>
<td align="left"> Average time of generating EDEK in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>GenerateEDEKTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of time spent in generating EDEK in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>WarmUpEDEKTimeNumOps</tt> </td>
<td align="left"> Total number of warming up EDEK </td></tr>
<tr class="a">
<td align="left"> <tt>WarmUpEDEKTimeAvgTime</tt> </td>
<td align="left"> Average time of warming up EDEK in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>WarmUpEDEKTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of time spent in warming up EDEK in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>ResourceCheckTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of of NameNode resource check latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>EditLogTailTimeNumOps</tt> </td>
<td align="left"> Total number of times the standby NameNode tailed the edit log </td></tr>
<tr class="a">
<td align="left"> <tt>EditLogTailTimeAvgTime</tt> </td>
<td align="left"> Average time (in milliseconds) spent by standby NameNode in tailing edit log </td></tr>
<tr class="b">
<td align="left"> <tt>EditLogTailTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of time spent in tailing edit logs by standby NameNode in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>EditLogFetchTimeNumOps</tt> </td>
<td align="left"> Total number of times the standby NameNode fetched remote edit streams from journal nodes </td></tr>
<tr class="b">
<td align="left"> <tt>EditLogFetchTimeAvgTime</tt> </td>
<td align="left"> Average time (in milliseconds) spent by standby NameNode in fetching remote edit streams from journal nodes </td></tr>
<tr class="a">
<td align="left"> <tt>EditLogFetchTime</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of time spent in fetching edit streams from journal nodes by standby NameNode in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>NumEditLogLoadedNumOps</tt> </td>
<td align="left"> Total number of times edits were loaded by standby NameNode </td></tr>
<tr class="a">
<td align="left"> <tt>NumEditLogLoadedAvgCount</tt> </td>
<td align="left"> Average number of edits loaded by standby NameNode in each edit log tailing </td></tr>
<tr class="b">
<td align="left"> <tt>NumEditLogLoaded</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileCount</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of number of edits loaded by standby NameNode in each edit log tailing (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>EditLogTailIntervalNumOps</tt> </td>
<td align="left"> Total number of intervals between edit log tailings by standby NameNode </td></tr>
<tr class="b">
<td align="left"> <tt>EditLogTailIntervalAvgTime</tt> </td>
<td align="left"> Average time of intervals between edit log tailings by standby NameNode in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>EditLogTailInterval</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of time between edit log tailings by standby NameNode in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>PendingEditsCount</tt> </td>
<td align="left"> Current number of pending edits </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="FSNamesystem"></a>FSNamesystem</h2>
<p>Each metrics record contains tags such as HAState and Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>MissingBlocks</tt> </td>
<td align="left"> Current number of missing blocks </td></tr>
<tr class="a">
<td align="left"> <tt>ExpiredHeartbeats</tt> </td>
<td align="left"> Total number of expired heartbeats </td></tr>
<tr class="b">
<td align="left"> <tt>TransactionsSinceLastCheckpoint</tt> </td>
<td align="left"> Total number of transactions since last checkpoint </td></tr>
<tr class="a">
<td align="left"> <tt>TransactionsSinceLastLogRoll</tt> </td>
<td align="left"> Total number of transactions since last edit log roll </td></tr>
<tr class="b">
<td align="left"> <tt>LastWrittenTransactionId</tt> </td>
<td align="left"> Last transaction ID written to the edit log </td></tr>
<tr class="a">
<td align="left"> <tt>LastCheckpointTime</tt> </td>
<td align="left"> Time in milliseconds since epoch of last checkpoint </td></tr>
<tr class="b">
<td align="left"> <tt>CapacityTotal</tt> </td>
<td align="left"> Current raw capacity of DataNodes in bytes </td></tr>
<tr class="a">
<td align="left"> <tt>CapacityTotalGB</tt> </td>
<td align="left"> Current raw capacity of DataNodes in GB </td></tr>
<tr class="b">
<td align="left"> <tt>CapacityUsed</tt> </td>
<td align="left"> Current used capacity across all DataNodes in bytes </td></tr>
<tr class="a">
<td align="left"> <tt>CapacityUsedGB</tt> </td>
<td align="left"> Current used capacity across all DataNodes in GB </td></tr>
<tr class="b">
<td align="left"> <tt>CapacityRemaining</tt> </td>
<td align="left"> Current remaining capacity in bytes </td></tr>
<tr class="a">
<td align="left"> <tt>CapacityRemainingGB</tt> </td>
<td align="left"> Current remaining capacity in GB </td></tr>
<tr class="b">
<td align="left"> <tt>CapacityUsedNonDFS</tt> </td>
<td align="left"> Current space used by DataNodes for non DFS purposes in bytes </td></tr>
<tr class="a">
<td align="left"> <tt>TotalLoad</tt> </td>
<td align="left"> Current number of connections </td></tr>
<tr class="b">
<td align="left"> <tt>SnapshottableDirectories</tt> </td>
<td align="left"> Current number of snapshottable directories </td></tr>
<tr class="a">
<td align="left"> <tt>Snapshots</tt> </td>
<td align="left"> Current number of snapshots </td></tr>
<tr class="b">
<td align="left"> <tt>NumEncryptionZones</tt> </td>
<td align="left"> Current number of encryption zones </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksTotal</tt> </td>
<td align="left"> Current number of allocated blocks in the system </td></tr>
<tr class="b">
<td align="left"> <tt>FilesTotal</tt> </td>
<td align="left"> Current number of files and directories </td></tr>
<tr class="a">
<td align="left"> <tt>PendingReplicationBlocks</tt> </td>
<td align="left"> Current number of blocks pending to be replicated </td></tr>
<tr class="b">
<td align="left"> <tt>UnderReplicatedBlocks</tt> </td>
<td align="left"> Current number of blocks under replicated </td></tr>
<tr class="a">
<td align="left"> <tt>CorruptBlocks</tt> </td>
<td align="left"> Current number of blocks with corrupt replicas. </td></tr>
<tr class="b">
<td align="left"> <tt>ScheduledReplicationBlocks</tt> </td>
<td align="left"> Current number of blocks scheduled for replications </td></tr>
<tr class="a">
<td align="left"> <tt>PendingDeletionBlocks</tt> </td>
<td align="left"> Current number of blocks pending deletion </td></tr>
<tr class="b">
<td align="left"> <tt>ExcessBlocks</tt> </td>
<td align="left"> Current number of excess blocks </td></tr>
<tr class="a">
<td align="left"> <tt>PostponedMisreplicatedBlocks</tt> </td>
<td align="left"> (HA-only) Current number of blocks postponed to replicate </td></tr>
<tr class="b">
<td align="left"> <tt>PendingDataNodeMessageCount</tt> </td>
<td align="left"> (HA-only) Current number of pending block-related messages for later processing in the standby NameNode </td></tr>
<tr class="a">
<td align="left"> <tt>MillisSinceLastLoadedEdits</tt> </td>
<td align="left"> (HA-only) Time in milliseconds since the last time standby NameNode load edit log. In active NameNode, set to 0 </td></tr>
<tr class="b">
<td align="left"> <tt>BlockCapacity</tt> </td>
<td align="left"> Current number of block capacity </td></tr>
<tr class="a">
<td align="left"> <tt>NumLiveDataNodes</tt> </td>
<td align="left"> Number of datanodes which are currently live </td></tr>
<tr class="b">
<td align="left"> <tt>NumDeadDataNodes</tt> </td>
<td align="left"> Number of datanodes which are currently dead </td></tr>
<tr class="a">
<td align="left"> <tt>NumDecomLiveDataNodes</tt> </td>
<td align="left"> Number of datanodes which have been decommissioned and are now live </td></tr>
<tr class="b">
<td align="left"> <tt>NumDecomDeadDataNodes</tt> </td>
<td align="left"> Number of datanodes which have been decommissioned and are now dead </td></tr>
<tr class="a">
<td align="left"> <tt>NumDecommissioningDataNodes</tt> </td>
<td align="left"> Number of datanodes in decommissioning state </td></tr>
<tr class="b">
<td align="left"> <tt>VolumeFailuresTotal</tt> </td>
<td align="left"> Total number of volume failures across all Datanodes </td></tr>
<tr class="a">
<td align="left"> <tt>EstimatedCapacityLostTotal</tt> </td>
<td align="left"> An estimate of the total capacity lost due to volume failures </td></tr>
<tr class="b">
<td align="left"> <tt>StaleDataNodes</tt> </td>
<td align="left"> Current number of DataNodes marked stale due to delayed heartbeat </td></tr>
<tr class="a">
<td align="left"> <tt>NumStaleStorages</tt> </td>
<td align="left"> Number of storages marked as content stale (after NameNode restart/failover before first block report is received) </td></tr>
<tr class="b">
<td align="left"> <tt>MissingReplOneBlocks</tt> </td>
<td align="left"> Current number of missing blocks with replication factor 1 </td></tr>
<tr class="a">
<td align="left"> <tt>HighestPriorityLowRedundancyReplicatedBlocks</tt> </td>
<td align="left"> Current number of non-corrupt, low redundancy replicated blocks with the highest risk of loss (have 0 or 1 replica). Will be recovered with the highest priority. </td></tr>
<tr class="b">
<td align="left"> <tt>HighestPriorityLowRedundancyECBlocks</tt> </td>
<td align="left"> Current number of non-corrupt, low redundancy EC blocks with the highest risk of loss. Will be recovered with the highest priority. </td></tr>
<tr class="a">
<td align="left"> <tt>NumFilesUnderConstruction</tt> </td>
<td align="left"> Current number of files under construction </td></tr>
<tr class="b">
<td align="left"> <tt>NumActiveClients</tt> </td>
<td align="left"> Current number of active clients holding lease </td></tr>
<tr class="a">
<td align="left"> <tt>HAState</tt> </td>
<td align="left"> (HA-only) Current state of the NameNode: initializing or active or standby or stopping state </td></tr>
<tr class="b">
<td align="left"> <tt>FSState</tt> </td>
<td align="left"> Current state of the file system: Safemode or Operational </td></tr>
<tr class="a">
<td align="left"> <tt>LockQueueLength</tt> </td>
<td align="left"> Number of threads waiting to acquire FSNameSystem lock </td></tr>
<tr class="b">
<td align="left"> <tt>TotalSyncCount</tt> </td>
<td align="left"> Total number of sync operations performed by edit log </td></tr>
<tr class="a">
<td align="left"> <tt>TotalSyncTimes</tt> </td>
<td align="left"> Total number of milliseconds spent by various edit logs in sync operation</td></tr>
<tr class="b">
<td align="left"> <tt>NameDirSize</tt> </td>
<td align="left"> NameNode name directories size in bytes </td></tr>
<tr class="a">
<td align="left"> <tt>NumTimedOutPendingReconstructions</tt> </td>
<td align="left"> The number of timed out reconstructions. Not the number of unique blocks that timed out. </td></tr>
<tr class="b">
<td align="left"> <tt>NumInMaintenanceLiveDataNodes</tt> </td>
<td align="left"> Number of live Datanodes which are in maintenance state </td></tr>
<tr class="a">
<td align="left"> <tt>NumInMaintenanceDeadDataNodes</tt> </td>
<td align="left"> Number of dead Datanodes which are in maintenance state </td></tr>
<tr class="b">
<td align="left"> <tt>NumEnteringMaintenanceDataNodes</tt> </td>
<td align="left"> Number of Datanodes that are entering the maintenance state </td></tr>
<tr class="a">
<td align="left"> <tt>FSN(Read/Write)Lock</tt><i>OperationName</i><tt>NanosNumOps</tt> </td>
<td align="left"> Total number of acquiring lock by operations </td></tr>
<tr class="b">
<td align="left"> <tt>FSN(Read/Write)Lock</tt><i>OperationName</i><tt>NanosAvgTime</tt> </td>
<td align="left"> Average time of holding the lock by operations in nanoseconds </td></tr>
<tr class="a">
<td align="left"> <tt>FSN(Read/Write)LockOverallNanosNumOps</tt> </td>
<td align="left"> Total number of acquiring lock by all operations </td></tr>
<tr class="b">
<td align="left"> <tt>FSN(Read/Write)LockOverallNanosAvgTime</tt> </td>
<td align="left"> Average time of holding the lock by all operations in nanoseconds </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="JournalNode"></a>JournalNode</h2>
<p>The server-side metrics for a journal from the JournalNode&#x2019;s perspective. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>Syncs60sNumOps</tt> </td>
<td align="left"> Number of sync operations (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs60s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of sync latency in microseconds (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs60s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of sync latency in microseconds (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs60s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of sync latency in microseconds (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs60s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of sync latency in microseconds (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs60s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of sync latency in microseconds (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs300sNumOps</tt> </td>
<td align="left"> Number of sync operations (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs300s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of sync latency in microseconds (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs300s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of sync latency in microseconds (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs300s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of sync latency in microseconds (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs300s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of sync latency in microseconds (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs300s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of sync latency in microseconds (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs3600sNumOps</tt> </td>
<td align="left"> Number of sync operations (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs3600s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of sync latency in microseconds (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs3600s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of sync latency in microseconds (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs3600s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of sync latency in microseconds (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>Syncs3600s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of sync latency in microseconds (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>Syncs3600s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of sync latency in microseconds (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync60sNumOps</tt> </td>
<td align="left"> Number of times transactions were batched in sync operation (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync60s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of transactions batched in sync count (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync60s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of transactions batched in sync count (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync60s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of transactions batched in sync count (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync60s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of transactions batched in sync count (1 minute granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync60s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of transactions batched in sync count (1 minute granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync300sNumOps</tt> </td>
<td align="left"> Number of times transactions were batched in sync operation (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync300s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of transactions batched in sync count (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync300s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of transactions batched in sync count (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync300s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of transactions batched in sync count (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync300s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of transactions batched in sync count (5 minutes granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync300s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of transactions batched in sync count (5 minutes granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync3600sNumOps</tt> </td>
<td align="left"> Number of times transactions were batched in sync operation (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync3600s50thPercentileLatencyMicros</tt> </td>
<td align="left"> The 50th percentile of transactions batched in sync count (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync3600s75thPercentileLatencyMicros</tt> </td>
<td align="left"> The 75th percentile of transactions batched in sync count (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync3600s90thPercentileLatencyMicros</tt> </td>
<td align="left"> The 90th percentile of transactions batched in sync count (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>NumTransactionsBatchedInSync3600s95thPercentileLatencyMicros</tt> </td>
<td align="left"> The 95th percentile of transactions batched in sync count (1 hour granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>NumTransactionsBatchedInSync3600s99thPercentileLatencyMicros</tt> </td>
<td align="left"> The 99th percentile of transactions batched in sync count (1 hour granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>BatchesWritten</tt> </td>
<td align="left"> Total number of batches written since startup </td></tr>
<tr class="a">
<td align="left"> <tt>TxnsWritten</tt> </td>
<td align="left"> Total number of transactions written since startup </td></tr>
<tr class="b">
<td align="left"> <tt>BytesWritten</tt> </td>
<td align="left"> Total number of bytes written since startup </td></tr>
<tr class="a">
<td align="left"> <tt>BatchesWrittenWhileLagging</tt> </td>
<td align="left"> Total number of batches written where this node was lagging </td></tr>
<tr class="b">
<td align="left"> <tt>LastWriterEpoch</tt> </td>
<td align="left"> Current writer&#x2019;s epoch number </td></tr>
<tr class="a">
<td align="left"> <tt>CurrentLagTxns</tt> </td>
<td align="left"> The number of transactions that this JournalNode is lagging </td></tr>
<tr class="b">
<td align="left"> <tt>LastWrittenTxId</tt> </td>
<td align="left"> The highest transaction id stored on this JournalNode </td></tr>
<tr class="a">
<td align="left"> <tt>LastPromisedEpoch</tt> </td>
<td align="left"> The last epoch number which this node has promised not to accept any lower epoch, or 0 if no promises have been made </td></tr>
<tr class="b">
<td align="left"> <tt>LastJournalTimestamp</tt> </td>
<td align="left"> The timestamp of last successfully written transaction </td></tr>
<tr class="a">
<td align="left"> <tt>TxnsServedViaRpc</tt> </td>
<td align="left"> Number of transactions served via the RPC mechanism </td></tr>
<tr class="b">
<td align="left"> <tt>BytesServedViaRpc</tt> </td>
<td align="left"> Number of bytes served via the RPC mechanism </td></tr>
<tr class="a">
<td align="left"> <tt>RpcRequestCacheMissAmountNumMisses</tt> </td>
<td align="left"> Number of RPC requests which could not be served due to lack of data in the cache </td></tr>
<tr class="b">
<td align="left"> <tt>RpcRequestCacheMissAmountAvgTxns</tt> </td>
<td align="left"> The average number of transactions by which a request missed the cache; for example if transaction ID 10 is requested and the cache&#x2019;s oldest transaction is ID 15, value 5 will be added to this average </td></tr>
<tr class="a">
<td align="left"> <tt>RpcEmptyResponses</tt> </td>
<td align="left"> Number of RPC requests with zero edits returned </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="datanode"></a>datanode</h2>
<p>Each metrics record contains tags such as SessionId and Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>BytesWritten</tt> </td>
<td align="left"> Total number of bytes written to DataNode </td></tr>
<tr class="a">
<td align="left"> <tt>BytesRead</tt> </td>
<td align="left"> Total number of bytes read from DataNode </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksWritten</tt> </td>
<td align="left"> Total number of blocks written to DataNode </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksRead</tt> </td>
<td align="left"> Total number of blocks read from DataNode </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksReplicated</tt> </td>
<td align="left"> Total number of blocks replicated </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksRemoved</tt> </td>
<td align="left"> Total number of blocks removed </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksVerified</tt> </td>
<td align="left"> Total number of blocks verified </td></tr>
<tr class="a">
<td align="left"> <tt>BlockVerificationFailures</tt> </td>
<td align="left"> Total number of verifications failures </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksCached</tt> </td>
<td align="left"> Total number of blocks cached </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksUncached</tt> </td>
<td align="left"> Total number of blocks uncached </td></tr>
<tr class="b">
<td align="left"> <tt>ReadsFromLocalClient</tt> </td>
<td align="left"> Total number of read operations from local client </td></tr>
<tr class="a">
<td align="left"> <tt>ReadsFromRemoteClient</tt> </td>
<td align="left"> Total number of read operations from remote client </td></tr>
<tr class="b">
<td align="left"> <tt>WritesFromLocalClient</tt> </td>
<td align="left"> Total number of write operations from local client </td></tr>
<tr class="a">
<td align="left"> <tt>WritesFromRemoteClient</tt> </td>
<td align="left"> Total number of write operations from remote client </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksGetLocalPathInfo</tt> </td>
<td align="left"> Total number of operations to get local path names of blocks </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksWrite</tt> </td>
<td align="left"> Total number of blocks written to memory </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksWriteFallback</tt> </td>
<td align="left"> Total number of blocks written to memory but not satisfied (failed-over to disk) </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBytesWrite</tt> </td>
<td align="left"> Total number of bytes written to memory </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksReadHits</tt> </td>
<td align="left"> Total number of times a block in memory was read </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksEvicted</tt> </td>
<td align="left"> Total number of blocks evicted in memory </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksEvictedWithoutRead</tt> </td>
<td align="left"> Total number of blocks evicted in memory without ever being read from memory </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksEvictionWindowMsNumOps</tt> </td>
<td align="left"> Number of blocks evicted in memory</td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksEvictionWindowMsAvgTime</tt> </td>
<td align="left"> Average time of blocks in memory before being evicted in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksEvictionWindows</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of latency between memory write and eviction in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksLazyPersisted</tt> </td>
<td align="left"> Total number of blocks written to disk by lazy writer </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksDeletedBeforeLazyPersisted</tt> </td>
<td align="left"> Total number of blocks deleted by application before being persisted to disk </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBytesLazyPersisted</tt> </td>
<td align="left"> Total number of bytes written to disk by lazy writer </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksLazyPersistWindowMsNumOps</tt> </td>
<td align="left"> Number of blocks written to disk by lazy writer </td></tr>
<tr class="b">
<td align="left"> <tt>RamDiskBlocksLazyPersistWindowMsAvgTime</tt> </td>
<td align="left"> Average time of blocks written to disk by lazy writer in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>RamDiskBlocksLazyPersistWindows</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of latency between memory write and disk persist in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>FsyncCount</tt> </td>
<td align="left"> Total number of fsync </td></tr>
<tr class="a">
<td align="left"> <tt>VolumeFailures</tt> </td>
<td align="left"> Total number of volume failures occurred </td></tr>
<tr class="b">
<td align="left"> <tt>ReadBlockOpNumOps</tt> </td>
<td align="left"> Total number of read operations </td></tr>
<tr class="a">
<td align="left"> <tt>ReadBlockOpAvgTime</tt> </td>
<td align="left"> Average time of read operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>WriteBlockOpNumOps</tt> </td>
<td align="left"> Total number of write operations </td></tr>
<tr class="a">
<td align="left"> <tt>WriteBlockOpAvgTime</tt> </td>
<td align="left"> Average time of write operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>BlockChecksumOpNumOps</tt> </td>
<td align="left"> Total number of blockChecksum operations </td></tr>
<tr class="a">
<td align="left"> <tt>BlockChecksumOpAvgTime</tt> </td>
<td align="left"> Average time of blockChecksum operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>CopyBlockOpNumOps</tt> </td>
<td align="left"> Total number of block copy operations </td></tr>
<tr class="a">
<td align="left"> <tt>CopyBlockOpAvgTime</tt> </td>
<td align="left"> Average time of block copy operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>ReplaceBlockOpNumOps</tt> </td>
<td align="left"> Total number of block replace operations </td></tr>
<tr class="a">
<td align="left"> <tt>ReplaceBlockOpAvgTime</tt> </td>
<td align="left"> Average time of block replace operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>HeartbeatsNumOps</tt> </td>
<td align="left"> Total number of heartbeats </td></tr>
<tr class="a">
<td align="left"> <tt>HeartbeatsAvgTime</tt> </td>
<td align="left"> Average heartbeat time in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>HeartbeatsFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td>
<td align="left"> Total number of heartbeats to specific serviceId and nnId </td></tr>
<tr class="a">
<td align="left"> <tt>HeartbeatsFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>AvgTime</tt> </td>
<td align="left"> Average heartbeat time in milliseconds to specific serviceId and nnId </td></tr>
<tr class="b">
<td align="left"> <tt>HeartbeatsTotalNumOps</tt> </td>
<td align="left"> Total number of heartbeats which is a duplicate of HeartbeatsNumOps </td></tr>
<tr class="a">
<td align="left"> <tt>HeartbeatsTotalAvgTime</tt> </td>
<td align="left"> Average total heartbeat time in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>HeartbeatsTotalFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td>
<td align="left"> Total number of heartbeats to specific serviceId and nnId which is a duplicate of <tt>HeartbeatsFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td></tr>
<tr class="a">
<td align="left"> <tt>HeartbeatsTotalFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>AvgTime</tt> </td>
<td align="left"> Average total heartbeat time in milliseconds to specific serviceId and nnId </td></tr>
<tr class="b">
<td align="left"> <tt>LifelinesNumOps</tt> </td>
<td align="left"> Total number of lifeline messages </td></tr>
<tr class="a">
<td align="left"> <tt>LifelinesAvgTime</tt> </td>
<td align="left"> Average lifeline message processing time in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>LifelinesFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td>
<td align="left"> Total number of lifeline messages to specific serviceId and nnId </td></tr>
<tr class="a">
<td align="left"> <tt>LifelinesFor</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>AvgTime</tt> </td>
<td align="left"> Average lifeline message processing time to specific serviceId and nnId in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>BlockReportsNumOps</tt> </td>
<td align="left"> Total number of block report operations </td></tr>
<tr class="a">
<td align="left"> <tt>BlockReportsAvgTime</tt> </td>
<td align="left"> Average time of block report operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>BlockReports</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td>
<td align="left"> Total number of block report operations to specific serviceId and nnId </td></tr>
<tr class="a">
<td align="left"> <tt>BlockReports</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>AvgTime</tt> </td>
<td align="left"> Average time of block report operations to specific serviceId and nnId in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>IncrementalBlockReportsNumOps</tt> </td>
<td align="left"> Total number of incremental block report operations </td></tr>
<tr class="a">
<td align="left"> <tt>IncrementalBlockReportsAvgTime</tt> </td>
<td align="left"> Average time of incremental block report operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>IncrementalBlockReports</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>NumOps</tt> </td>
<td align="left"> Total number of incremental block report operations to specific serviceId and nnId </td></tr>
<tr class="a">
<td align="left"> <tt>IncrementalBlockReports</tt><i>ServiceId</i><tt>-</tt><i>NNId</i><tt>AvgTime</tt> </td>
<td align="left"> Average time of incremental block report operations to specific serviceId and nnId in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>CacheReportsNumOps</tt> </td>
<td align="left"> Total number of cache report operations </td></tr>
<tr class="a">
<td align="left"> <tt>CacheReportsAvgTime</tt> </td>
<td align="left"> Average time of cache report operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>PacketAckRoundTripTimeNanosNumOps</tt> </td>
<td align="left"> Total number of ack round trip </td></tr>
<tr class="a">
<td align="left"> <tt>PacketAckRoundTripTimeNanosAvgTime</tt> </td>
<td align="left"> Average time from ack send to receive minus the downstream ack time in nanoseconds </td></tr>
<tr class="b">
<td align="left"> <tt>PacketAckRoundTripTimeNanos</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile latency from ack send to receive minus the downstream ack time in nanoseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>FlushNanosNumOps</tt> </td>
<td align="left"> Total number of flushes </td></tr>
<tr class="b">
<td align="left"> <tt>FlushNanosAvgTime</tt> </td>
<td align="left"> Average flush time in nanoseconds </td></tr>
<tr class="a">
<td align="left"> <tt>FlushNanos</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile flush time in nanoseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>FsyncNanosNumOps</tt> </td>
<td align="left"> Total number of fsync </td></tr>
<tr class="a">
<td align="left"> <tt>FsyncNanosAvgTime</tt> </td>
<td align="left"> Average fsync time in nanoseconds </td></tr>
<tr class="b">
<td align="left"> <tt>FsyncNanos</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile fsync time in nanoseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>SendDataPacketBlockedOnNetworkNanosNumOps</tt> </td>
<td align="left"> Total number of sending packets </td></tr>
<tr class="b">
<td align="left"> <tt>SendDataPacketBlockedOnNetworkNanosAvgTime</tt> </td>
<td align="left"> Average waiting time of sending packets in nanoseconds </td></tr>
<tr class="a">
<td align="left"> <tt>SendDataPacketBlockedOnNetworkNanos</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile waiting time of sending packets in nanoseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>SendDataPacketTransferNanosNumOps</tt> </td>
<td align="left"> Total number of sending packets </td></tr>
<tr class="a">
<td align="left"> <tt>SendDataPacketTransferNanosAvgTime</tt> </td>
<td align="left"> Average transfer time of sending packets in nanoseconds </td></tr>
<tr class="b">
<td align="left"> <tt>SendDataPacketTransferNanos</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile transfer time of sending packets in nanoseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>TotalWriteTime</tt></td>
<td align="left"> Total number of milliseconds spent on write operation </td></tr>
<tr class="b">
<td align="left"> <tt>TotalReadTime</tt> </td>
<td align="left"> Total number of milliseconds spent on read operation </td></tr>
<tr class="a">
<td align="left"> <tt>RemoteBytesRead</tt> </td>
<td align="left"> Number of bytes read by remote clients </td></tr>
<tr class="b">
<td align="left"> <tt>RemoteBytesWritten</tt> </td>
<td align="left"> Number of bytes written by remote clients </td></tr>
<tr class="a">
<td align="left"> <tt>BPServiceActorInfo</tt> </td>
<td align="left"> The information about a block pool service actor </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksInPendingIBR</tt> </td>
<td align="left"> Number of blocks in pending incremental block report (IBR) </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksReceivingInPendingIBR</tt> </td>
<td align="left"> Number of blocks at receiving status in pending incremental block report (IBR) </td></tr>
<tr class="b">
<td align="left"> <tt>BlocksReceivedInPendingIBR</tt> </td>
<td align="left"> Number of blocks at received status in pending incremental block report (IBR) </td></tr>
<tr class="a">
<td align="left"> <tt>BlocksDeletedInPendingIBR</tt> </td>
<td align="left"> Number of blocks at deleted status in pending incremental block report (IBR) </td></tr>
<tr class="b">
<td align="left"> <tt>EcReconstructionTasks</tt> </td>
<td align="left"> Total number of erasure coding reconstruction tasks </td></tr>
<tr class="a">
<td align="left"> <tt>EcFailedReconstructionTasks</tt> </td>
<td align="left"> Total number of erasure coding failed reconstruction tasks </td></tr>
<tr class="b">
<td align="left"> <tt>EcInvalidReconstructionTasks</tt> </td>
<td align="left"> Total number of erasure coding invalidated reconstruction tasks </td></tr>
<tr class="a">
<td align="left"> <tt>EcDecodingTimeNanos</tt> </td>
<td align="left"> Total number of nanoseconds spent by decoding tasks </td></tr>
<tr class="b">
<td align="left"> <tt>EcReconstructionBytesRead</tt> </td>
<td align="left"> Total number of bytes read by erasure coding worker </td></tr>
<tr class="a">
<td align="left"> <tt>EcReconstructionBytesWritten</tt> </td>
<td align="left"> Total number of bytes written by erasure coding worker </td></tr>
<tr class="b">
<td align="left"> <tt>EcReconstructionRemoteBytesRead</tt> </td>
<td align="left"> Total number of bytes remote read by erasure coding worker </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="FsVolume"></a>FsVolume</h2>
<p>Per-volume metrics contain Datanode Volume IO related statistics. Per-volume metrics are off by default. They can be enabled by setting <tt>dfs.datanode .fileio.profiling.percentage.fraction</tt> to an integer value between 1 and 100. Setting this value to 0 would mean profiling is not enabled. But enabling per-volume metrics may have a performance impact. Each metrics record contains tags such as Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>TotalMetadataOperations</tt> </td>
<td align="left"> Total number (monotonically increasing) of metadata operations. Metadata operations include stat, list, mkdir, delete, move, open and posix_fadvise. </td></tr>
<tr class="a">
<td align="left"> <tt>MetadataOperationRateNumOps</tt> </td>
<td align="left"> The number of metadata operations within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>MetadataOperationRateAvgTime</tt> </td>
<td align="left"> Mean time of metadata operations in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>MetadataOperationLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of metadata operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>TotalDataFileIos</tt> </td>
<td align="left"> Total number (monotonically increasing) of data file io operations </td></tr>
<tr class="a">
<td align="left"> <tt>DataFileIoRateNumOps</tt> </td>
<td align="left"> The number of data file io operations within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>DataFileIoRateAvgTime</tt> </td>
<td align="left"> Mean time of data file io operations in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>DataFileIoLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of data file io operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>FlushIoRateNumOps</tt> </td>
<td align="left"> The number of file flush io operations within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>FlushIoRateAvgTime</tt> </td>
<td align="left"> Mean time of file flush io operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>FlushIoLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of file flush io operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>SyncIoRateNumOps</tt> </td>
<td align="left"> The number of file sync io operations within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>SyncIoRateAvgTime</tt> </td>
<td align="left"> Mean time of file sync io operations in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>SyncIoLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of file sync io operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>ReadIoRateNumOps</tt> </td>
<td align="left"> The number of file read io operations within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>ReadIoRateAvgTime</tt> </td>
<td align="left"> Mean time of file read io operations in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>ReadIoLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of file read io operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>WriteIoRateNumOps</tt> </td>
<td align="left"> The number of file write io operations within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>WriteIoRateAvgTime</tt> </td>
<td align="left"> Mean time of file write io operations in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>WriteIoLatency</tt><i>num</i><tt>s(50/75/90/95/99)thPercentileLatency</tt> </td>
<td align="left"> The 50/75/90/95/99th percentile of file write io operations latency in milliseconds (<i>num</i> seconds granularity). Percentile measurement is off by default, by watching no intervals. The intervals are specified by <tt>dfs.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>TotalFileIoErrors</tt> </td>
<td align="left"> Total number (monotonically increasing) of file io error operations </td></tr>
<tr class="a">
<td align="left"> <tt>FileIoErrorRateNumOps</tt> </td>
<td align="left"> The number of file io error operations within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>FileIoErrorRateAvgTime</tt> </td>
<td align="left"> It measures the mean time in milliseconds from the start of an operation to hitting a failure </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="RBFMetrics"></a>RBFMetrics</h2>
<p>RBFMetrics shows the metrics which are the aggregated values of sub-clusters&#x2019; information in the Router-based federation.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>NumFiles</tt> </td>
<td align="left"> Current number of files and directories </td></tr>
<tr class="a">
<td align="left"> <tt>NumBlocks</tt> </td>
<td align="left"> Current number of allocated blocks </td></tr>
<tr class="b">
<td align="left"> <tt>NumOfBlocksPendingReplication</tt> </td>
<td align="left"> Current number of blocks pending to be replicated </td></tr>
<tr class="a">
<td align="left"> <tt>NumOfBlocksUnderReplicated</tt> </td>
<td align="left"> Current number of blocks under replicated </td></tr>
<tr class="b">
<td align="left"> <tt>NumOfBlocksPendingDeletion</tt> </td>
<td align="left"> Current number of blocks pending deletion </td></tr>
<tr class="a">
<td align="left"> <tt>ProvidedSpace</tt> </td>
<td align="left"> The total remote storage capacity mounted in the federated cluster </td></tr>
<tr class="b">
<td align="left"> <tt>NumInMaintenanceLiveDataNodes</tt> </td>
<td align="left"> Number of live Datanodes which are in maintenance state </td></tr>
<tr class="a">
<td align="left"> <tt>NumInMaintenanceDeadDataNodes</tt> </td>
<td align="left"> Number of dead Datanodes which are in maintenance state </td></tr>
<tr class="b">
<td align="left"> <tt>NumEnteringMaintenanceDataNodes</tt> </td>
<td align="left"> Number of Datanodes that are entering the maintenance state </td></tr>
<tr class="a">
<td align="left"> <tt>TotalCapacity</tt> </td>
<td align="left"> Current raw capacity of DataNodes in bytes (long primitive, may overflow) </td></tr>
<tr class="b">
<td align="left"> <tt>UsedCapacity</tt> </td>
<td align="left"> Current used capacity across all DataNodes in bytes (long primitive, may overflow) </td></tr>
<tr class="a">
<td align="left"> <tt>RemainingCapacity</tt> </td>
<td align="left"> Current remaining capacity in bytes (long primitive, may overflow) </td></tr>
<tr class="b">
<td align="left"> <tt>TotalCapacityBigInt</tt> </td>
<td align="left"> Current raw capacity of DataNodes in bytes (using BigInteger) </td></tr>
<tr class="a">
<td align="left"> <tt>UsedCapacityBigInt</tt> </td>
<td align="left"> Current used capacity across all DataNodes in bytes (using BigInteger) </td></tr>
<tr class="b">
<td align="left"> <tt>RemainingCapacityBigInt</tt> </td>
<td align="left"> Current remaining capacity in bytes (using BigInteger) </td></tr>
<tr class="a">
<td align="left"> <tt>NumOfMissingBlocks</tt> </td>
<td align="left"> Current number of missing blocks </td></tr>
<tr class="b">
<td align="left"> <tt>NumLiveNodes</tt> </td>
<td align="left"> Number of datanodes which are currently live </td></tr>
<tr class="a">
<td align="left"> <tt>NumDeadNodes</tt> </td>
<td align="left"> Number of datanodes which are currently dead </td></tr>
<tr class="b">
<td align="left"> <tt>NumStaleNodes</tt> </td>
<td align="left"> Current number of DataNodes marked stale due to delayed heartbeat </td></tr>
<tr class="a">
<td align="left"> <tt>NumDecomLiveNodes</tt> </td>
<td align="left"> Number of datanodes which have been decommissioned and are now live </td></tr>
<tr class="b">
<td align="left"> <tt>NumDecomDeadNodes</tt> </td>
<td align="left"> Number of datanodes which have been decommissioned and are now dead </td></tr>
<tr class="a">
<td align="left"> <tt>NumDecommissioningNodes</tt> </td>
<td align="left"> Number of datanodes in decommissioning state </td></tr>
<tr class="b">
<td align="left"> <tt>Namenodes</tt> </td>
<td align="left"> Current information about all the namenodes </td></tr>
<tr class="a">
<td align="left"> <tt>Nameservices</tt> </td>
<td align="left"> Current information for each registered nameservice </td></tr>
<tr class="b">
<td align="left"> <tt>MountTable</tt> </td>
<td align="left"> The mount table for the federated filesystem </td></tr>
<tr class="a">
<td align="left"> <tt>Routers</tt> </td>
<td align="left"> Current information about all routers </td></tr>
<tr class="b">
<td align="left"> <tt>NumNameservices</tt> </td>
<td align="left"> Number of nameservices </td></tr>
<tr class="a">
<td align="left"> <tt>NumNamenodes</tt> </td>
<td align="left"> Number of namenodes </td></tr>
<tr class="b">
<td align="left"> <tt>NumExpiredNamenodes</tt> </td>
<td align="left"> Number of expired namenodes </td></tr>
<tr class="a">
<td align="left"> <tt>NodeUsage</tt> </td>
<td align="left"> Max, Median, Min and Standard Deviation of DataNodes usage </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="RouterRPCMetrics"></a>RouterRPCMetrics</h2>
<p>RouterRPCMetrics shows the statistics of the Router component in Router-based federation.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>ProcessingOp</tt> </td>
<td align="left"> Number of operations the Router processed internally </td></tr>
<tr class="a">
<td align="left"> <tt>ProxyOp</tt> </td>
<td align="left"> Number of operations the Router proxied to a Namenode </td></tr>
<tr class="b">
<td align="left"> <tt>ProxyOpFailureStandby</tt> </td>
<td align="left"> Number of operations to fail to reach NN </td></tr>
<tr class="a">
<td align="left"> <tt>ProxyOpFailureCommunicate</tt> </td>
<td align="left"> Number of operations to hit a standby NN </td></tr>
<tr class="b">
<td align="left"> <tt>ProxyOpNotImplemented</tt> </td>
<td align="left"> Number of operations not implemented </td></tr>
<tr class="a">
<td align="left"> <tt>RouterFailureStateStore</tt> </td>
<td align="left"> Number of failed requests due to State Store unavailable </td></tr>
<tr class="b">
<td align="left"> <tt>RouterFailureReadOnly</tt> </td>
<td align="left"> Number of failed requests due to read only mount point </td></tr>
<tr class="a">
<td align="left"> <tt>RouterFailureLocked</tt> </td>
<td align="left"> Number of failed requests due to locked path </td></tr>
<tr class="b">
<td align="left"> <tt>RouterFailureSafemode</tt> </td>
<td align="left"> Number of failed requests due to safe mode </td></tr>
<tr class="a">
<td align="left"> <tt>ProcessingNumOps</tt> </td>
<td align="left"> Number of operations the Router processed internally within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>ProcessingAvgTime</tt> </td>
<td align="left"> Average time for the Router to process operations in nanoseconds </td></tr>
<tr class="a">
<td align="left"> <tt>ProxyNumOps</tt> </td>
<td align="left"> Number of times of that the Router to proxy operations to the Namenodes within an interval time of metric </td></tr>
<tr class="b">
<td align="left"> <tt>ProxyAvgTime</tt> </td>
<td align="left"> Average time for the Router to proxy operations to the Namenodes in nanoseconds </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="StateStoreMetrics"></a>StateStoreMetrics</h2>
<p>StateStoreMetrics shows the statistics of the State Store component in Router-based federation.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>ReadsNumOps</tt> </td>
<td align="left"> Number of GET transactions for State Store within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>ReadsAvgTime</tt> </td>
<td align="left"> Average time of GET transactions for State Store in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>WritesNumOps</tt> </td>
<td align="left"> Number of PUT transactions for State Store within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>WritesAvgTime</tt> </td>
<td align="left"> Average time of PUT transactions for State Store in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>RemovesNumOps</tt> </td>
<td align="left"> Number of REMOVE transactions for State Store within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>RemovesAvgTime</tt> </td>
<td align="left"> Average time of REMOVE transactions for State Store in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>FailuresNumOps</tt> </td>
<td align="left"> Number of failed transactions for State Store within an interval time of metric </td></tr>
<tr class="a">
<td align="left"> <tt>FailuresAvgTime</tt> </td>
<td align="left"> Average time of failed transactions for State Store in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>Cache</tt><i>BaseRecord</i><tt>Size</tt> </td>
<td align="left"> Number of store records to cache in State Store </td></tr>
</tbody>
</table>
<h1>yarn context</h1></div>
<div class="section">
<h2><a name="ClusterMetrics"></a>ClusterMetrics</h2>
<p>ClusterMetrics shows the metrics of the YARN cluster from the ResourceManager&#x2019;s perspective. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>NumActiveNMs</tt> </td>
<td align="left"> Current number of active NodeManagers </td></tr>
<tr class="a">
<td align="left"> <tt>numDecommissioningNMs</tt> </td>
<td align="left"> Current number of NodeManagers being decommissioned</td></tr>
<tr class="b">
<td align="left"> <tt>NumDecommissionedNMs</tt> </td>
<td align="left"> Current number of decommissioned NodeManagers </td></tr>
<tr class="a">
<td align="left"> <tt>NumShutdownNMs</tt> </td>
<td align="left"> Current number of NodeManagers shut down gracefully. Note that this does not count NodeManagers that are forcefully killed. </td></tr>
<tr class="b">
<td align="left"> <tt>NumLostNMs</tt> </td>
<td align="left"> Current number of lost NodeManagers for not sending heartbeats. </td></tr>
<tr class="a">
<td align="left"> <tt>NumUnhealthyNMs</tt> </td>
<td align="left"> Current number of unhealthy NodeManagers </td></tr>
<tr class="b">
<td align="left"> <tt>NumRebootedNMs</tt> </td>
<td align="left"> Current number of rebooted NodeManagers </td></tr>
<tr class="a">
<td align="left"> <tt>AMLaunchDelayNumOps</tt> </td>
<td align="left"> Total number of AMs launched </td></tr>
<tr class="b">
<td align="left"> <tt>AMLaunchDelayAvgTime</tt> </td>
<td align="left"> Average time in milliseconds RM spends to launch AM containers after the AM container is allocated</td></tr>
<tr class="a">
<td align="left"> <tt>AMRegisterDelayNumOps</tt> </td>
<td align="left"> Total number of AMs registered </td></tr>
<tr class="b">
<td align="left"> <tt>AMRegisterDelayAvgTime</tt> </td>
<td align="left"> Average time in milliseconds AM spends to register with RM after the AM container gets launched </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="QueueMetrics"></a>QueueMetrics</h2>
<p>QueueMetrics shows an application queue from the ResourceManager&#x2019;s perspective. Each metrics record shows the statistics of each queue, and contains tags such as queue name and Hostname as additional information along with metrics.</p>
<p>In <tt>running_</tt><i>num</i> metrics such as <tt>running_0</tt>, you can set the property <tt>yarn.resourcemanager.metrics.runtime.buckets</tt> in yarn-site.xml to change the buckets. The default values is <tt>60,300,1440</tt>.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>running_0</tt> </td>
<td align="left"> Current number of running applications whose elapsed time are less than 60 minutes </td></tr>
<tr class="a">
<td align="left"> <tt>running_60</tt> </td>
<td align="left"> Current number of running applications whose elapsed time are between 60 and 300 minutes </td></tr>
<tr class="b">
<td align="left"> <tt>running_300</tt> </td>
<td align="left"> Current number of running applications whose elapsed time are between 300 and 1440 minutes </td></tr>
<tr class="a">
<td align="left"> <tt>running_1440</tt> </td>
<td align="left"> Current number of running applications elapsed time are more than 1440 minutes </td></tr>
<tr class="b">
<td align="left"> <tt>AppsSubmitted</tt> </td>
<td align="left"> Total number of submitted applications </td></tr>
<tr class="a">
<td align="left"> <tt>AppsRunning</tt> </td>
<td align="left"> Current number of running applications </td></tr>
<tr class="b">
<td align="left"> <tt>AppsPending</tt> </td>
<td align="left"> Current number of applications that have not yet been assigned by any containers </td></tr>
<tr class="a">
<td align="left"> <tt>AppsCompleted</tt> </td>
<td align="left"> Total number of completed applications </td></tr>
<tr class="b">
<td align="left"> <tt>AppsKilled</tt> </td>
<td align="left"> Total number of killed applications </td></tr>
<tr class="a">
<td align="left"> <tt>AppsFailed</tt> </td>
<td align="left"> Total number of failed applications </td></tr>
<tr class="b">
<td align="left"> <tt>AllocatedMB</tt> </td>
<td align="left"> Current allocated memory in MB </td></tr>
<tr class="a">
<td align="left"> <tt>AllocatedVCores</tt> </td>
<td align="left"> Current allocated CPU in virtual cores </td></tr>
<tr class="b">
<td align="left"> <tt>AllocatedContainers</tt> </td>
<td align="left"> Current number of allocated containers </td></tr>
<tr class="a">
<td align="left"> <tt>AggregateContainersAllocated</tt> </td>
<td align="left"> Total number of allocated containers </td></tr>
<tr class="b">
<td align="left"> <tt>aggregateNodeLocalContainersAllocated</tt> </td>
<td align="left"> Total number of node local containers allocated </td></tr>
<tr class="a">
<td align="left"> <tt>aggregateRackLocalContainersAllocated</tt> </td>
<td align="left"> Total number of rack local containers allocated </td></tr>
<tr class="b">
<td align="left"> <tt>aggregateOffSwitchContainersAllocated</tt> </td>
<td align="left"> Total number of off switch containers allocated </td></tr>
<tr class="a">
<td align="left"> <tt>AggregateContainersReleased</tt> </td>
<td align="left"> Total number of released containers </td></tr>
<tr class="b">
<td align="left"> <tt>AvailableMB</tt> </td>
<td align="left"> Current available memory in MB </td></tr>
<tr class="a">
<td align="left"> <tt>AvailableVCores</tt> </td>
<td align="left"> Current available CPU in virtual cores </td></tr>
<tr class="b">
<td align="left"> <tt>PendingMB</tt> </td>
<td align="left"> Current memory requests in MB that are pending to be fulfilled by the scheduler </td></tr>
<tr class="a">
<td align="left"> <tt>PendingVCores</tt> </td>
<td align="left"> Current CPU requests in virtual cores that are pending to be fulfilled by the scheduler </td></tr>
<tr class="b">
<td align="left"> <tt>PendingContainers</tt> </td>
<td align="left"> Current number of containers that are pending to be fulfilled by the scheduler </td></tr>
<tr class="a">
<td align="left"> <tt>ReservedMB</tt> </td>
<td align="left"> Current reserved memory in MB </td></tr>
<tr class="b">
<td align="left"> <tt>ReservedVCores</tt> </td>
<td align="left"> Current reserved CPU in virtual cores </td></tr>
<tr class="a">
<td align="left"> <tt>ReservedContainers</tt> </td>
<td align="left"> Current number of reserved containers </td></tr>
<tr class="b">
<td align="left"> <tt>ActiveUsers</tt> </td>
<td align="left"> Current number of active users </td></tr>
<tr class="a">
<td align="left"> <tt>ActiveApplications</tt> </td>
<td align="left"> Current number of active applications </td></tr>
<tr class="b">
<td align="left"> <tt>AppAttemptFirstContainerAllocationDelayNumOps</tt> </td>
<td align="left"> Total number of first container allocated for all attempts </td></tr>
<tr class="a">
<td align="left"> <tt>AppAttemptFirstContainerAllocationDelayAvgTime</tt> </td>
<td align="left"> Average time RM spends to allocate the first container for all attempts. For managed AM, the first container is AM container. So, this indicates the time duration to allocate AM container. For unmanaged AM, this is the time duration to allocate the first container asked by unmanaged AM. </td></tr>
<tr class="b">
<td align="left"> <tt>FairShareMB</tt> </td>
<td align="left"> (FairScheduler only) Current fair share of memory in MB </td></tr>
<tr class="a">
<td align="left"> <tt>FairShareVCores</tt> </td>
<td align="left"> (FairScheduler only) Current fair share of CPU in virtual cores </td></tr>
<tr class="b">
<td align="left"> <tt>MinShareMB</tt> </td>
<td align="left"> (FairScheduler only) Minimum share of memory in MB </td></tr>
<tr class="a">
<td align="left"> <tt>MinShareVCores</tt> </td>
<td align="left"> (FairScheduler only) Minimum share of CPU in virtual cores </td></tr>
<tr class="b">
<td align="left"> <tt>MaxShareMB</tt> </td>
<td align="left"> (FairScheduler only) Maximum share of memory in MB </td></tr>
<tr class="a">
<td align="left"> <tt>MaxShareVCores</tt> </td>
<td align="left"> (FairScheduler only) Maximum share of CPU in virtual cores </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="NodeManagerMetrics"></a>NodeManagerMetrics</h2>
<p>NodeManagerMetrics shows the statistics of the containers in the node. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>containersLaunched</tt> </td>
<td align="left"> Total number of launched containers </td></tr>
<tr class="a">
<td align="left"> <tt>containersCompleted</tt> </td>
<td align="left"> Total number of successfully completed containers </td></tr>
<tr class="b">
<td align="left"> <tt>containersFailed</tt> </td>
<td align="left"> Total number of failed containers </td></tr>
<tr class="a">
<td align="left"> <tt>containersKilled</tt> </td>
<td align="left"> Total number of killed containers </td></tr>
<tr class="b">
<td align="left"> <tt>containersIniting</tt> </td>
<td align="left"> Current number of initializing containers </td></tr>
<tr class="a">
<td align="left"> <tt>containersRunning</tt> </td>
<td align="left"> Current number of running containers </td></tr>
<tr class="b">
<td align="left"> <tt>allocatedContainers</tt> </td>
<td align="left"> Current number of allocated containers </td></tr>
<tr class="a">
<td align="left"> <tt>allocatedGB</tt> </td>
<td align="left"> Current allocated memory in GB </td></tr>
<tr class="b">
<td align="left"> <tt>availableGB</tt> </td>
<td align="left"> Current available memory in GB </td></tr>
<tr class="a">
<td align="left"> <tt>allocatedVcores</tt> </td>
<td align="left"> Current used vcores</td></tr>
<tr class="b">
<td align="left"> <tt>availableVcores</tt> </td>
<td align="left"> Current available vcores </td></tr>
<tr class="a">
<td align="left"> <tt>containerLaunchDuration</tt> </td>
<td align="left"> Average time duration in milliseconds NM takes to launch a container</td></tr>
<tr class="b">
<td align="left"> <tt>badLocalDirs</tt> </td>
<td align="left"> Current number of bad local directories. Currently, a disk that cannot be read/written/executed by NM process or A disk being full is considered as bad.</td></tr>
<tr class="a">
<td align="left"> <tt>badLogDirs</tt> </td>
<td align="left"> Current number of bad log directories. Currently, a disk that cannot be read/written/executed by NM process or A disk being full is considered as bad. </td></tr>
<tr class="b">
<td align="left"> <tt>goodLocalDirsDiskUtilizationPerc</tt> </td>
<td align="left"> Current disk utilization percentage across all good local directories </td></tr>
<tr class="a">
<td align="left"> <tt>goodLogDirsDiskUtilizationPerc</tt> </td>
<td align="left"> Current disk utilization percentage across all good log directories </td></tr>
</tbody>
</table></div>
<div class="section">
<h2><a name="ContainerMetrics"></a>ContainerMetrics</h2>
<p>ContainerMetrics shows the resource utilization statistics of a container. Each metrics record contains tags such as ContainerPid and Hostname as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>pMemLimitMBs</tt> </td>
<td align="left"> Physical memory limit of the container in MB </td></tr>
<tr class="a">
<td align="left"> <tt>vMemLimitMBs</tt> </td>
<td align="left"> Virtual memory limit of the container in MB </td></tr>
<tr class="b">
<td align="left"> <tt>vCoreLimit</tt> </td>
<td align="left"> CPU limit of the container in number of vcores </td></tr>
<tr class="a">
<td align="left"> <tt>launchDurationMs</tt> </td>
<td align="left"> Container launch duration in msec </td></tr>
<tr class="b">
<td align="left"> <tt>localizationDurationMs</tt> </td>
<td align="left"> Container localization duration in msec </td></tr>
<tr class="a">
<td align="left"> <tt>StartTime</tt> </td>
<td align="left"> Time in msec when container starts </td></tr>
<tr class="b">
<td align="left"> <tt>FinishTime</tt> </td>
<td align="left"> Time in msec when container finishes </td></tr>
<tr class="a">
<td align="left"> <tt>ExitCode</tt> </td>
<td align="left"> Container&#x2019;s exit code </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBsNumUsage</tt> </td>
<td align="left"> Total number of physical memory used metrics </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBsAvgMBs</tt> </td>
<td align="left"> Average physical memory used in MB </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBsStdevMBs</tt> </td>
<td align="left"> Standard deviation of the physical memory used in MB </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBsMinMBs</tt> </td>
<td align="left"> Minimum physical memory used in MB </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBsMaxMBs</tt> </td>
<td align="left"> Maximum physical memory used in MB </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBsIMinMBs</tt> </td>
<td align="left"> Minimum physical memory used in MB of current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBsIMaxMBs</tt> </td>
<td align="left"> Maximum physical memory used in MB of current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBsINumUsage</tt> </td>
<td align="left"> Total number of physical memory used metrics in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentNumUsage</tt> </td>
<td align="left"> Total number of physical CPU cores percent used metrics </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentAvgPercents</tt> </td>
<td align="left"> Average physical CPU cores percent used </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentStdevPercents</tt> </td>
<td align="left"> Standard deviation of physical CPU cores percent used </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentMinPercents</tt> </td>
<td align="left"> Minimum physical CPU cores percent used</td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentMaxPercents</tt> </td>
<td align="left"> Maximum physical CPU cores percent used </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentIMinPercents</tt> </td>
<td align="left"> Minimum physical CPU cores percent used in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentIMaxPercents</tt> </td>
<td align="left"> Maximum physical CPU cores percent used in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentINumUsage</tt> </td>
<td align="left"> Total number of physical CPU cores used metrics in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>MilliVcoreUsageNumUsage</tt> </td>
<td align="left"> Total number of vcores used metrics </td></tr>
<tr class="a">
<td align="left"> <tt>MilliVcoreUsageAvgMilliVcores</tt> </td>
<td align="left"> 1000 times the average vcores used </td></tr>
<tr class="b">
<td align="left"> <tt>MilliVcoreUsageStdevMilliVcores</tt> </td>
<td align="left"> 1000 times the standard deviation of vcores used </td></tr>
<tr class="a">
<td align="left"> <tt>MilliVcoreUsageMinMilliVcores</tt> </td>
<td align="left"> 1000 times the minimum vcores used </td></tr>
<tr class="b">
<td align="left"> <tt>MilliVcoreUsageMaxMilliVcores</tt> </td>
<td align="left"> 1000 times the maximum vcores used </td></tr>
<tr class="a">
<td align="left"> <tt>MilliVcoreUsageIMinMilliVcores</tt> </td>
<td align="left"> 1000 times the average vcores used in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>MilliVcoreUsageIMaxMilliVcores</tt> </td>
<td align="left"> 1000 times the maximum vcores used in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="a">
<td align="left"> <tt>MilliVcoreUsageINumUsage</tt> </td>
<td align="left"> Total number of vcores used metrics in current <i>interval</i> (the time of <i>interval</i> is specified by yarn.nodemanager.container-metrics.period-ms) </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBHistogramNumUsage</tt> </td>
<td align="left"> Total number of physical memory used metrics (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBHistogram50thPercentileMBs</tt> </td>
<td align="left"> The 50th percentile of physical memory used in MB (1 second granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBHistogram75thPercentileMBs</tt> </td>
<td align="left"> The 75th percentile of physical memory used in MB (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBHistogram90thPercentileMBs</tt> </td>
<td align="left"> The 90th percentile of physical memory used in MB (1 second granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>PMemUsageMBHistogram95thPercentileMBs</tt> </td>
<td align="left"> The 95th percentile of physical memory used in MB (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PMemUsageMBHistogram99thPercentileMBs</tt> </td>
<td align="left"> The 99th percentile of physical memory used in MB (1 second granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentHistogramNumUsage</tt> </td>
<td align="left"> Total number of physical CPU cores used metrics (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentHistogram50thPercentilePercents</tt> </td>
<td align="left"> The 50th percentile of physical CPU cores percent used (1 second granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentHistogram75thPercentilePercents</tt> </td>
<td align="left"> The 75th percentile of physical CPU cores percent used (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentHistogram90thPercentilePercents</tt> </td>
<td align="left"> The 90th percentile of physical CPU cores percent used (1 second granularity) </td></tr>
<tr class="b">
<td align="left"> <tt>PCpuUsagePercentHistogram95thPercentilePercents</tt> </td>
<td align="left"> The 95th percentile of physical CPU cores percent used (1 second granularity) </td></tr>
<tr class="a">
<td align="left"> <tt>PCpuUsagePercentHistogram99thPercentilePercents</tt> </td>
<td align="left"> The 99th percentile of physical CPU cores percent used (1 second granularity) </td></tr>
</tbody>
</table>
<h1>ugi context</h1></div>
<div class="section">
<h2><a name="UgiMetrics"></a>UgiMetrics</h2>
<p>UgiMetrics is related to user and group information. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>LoginSuccessNumOps</tt> </td>
<td align="left"> Total number of successful kerberos logins </td></tr>
<tr class="a">
<td align="left"> <tt>LoginSuccessAvgTime</tt> </td>
<td align="left"> Average time for successful kerberos logins in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>LoginFailureNumOps</tt> </td>
<td align="left"> Total number of failed kerberos logins </td></tr>
<tr class="a">
<td align="left"> <tt>LoginFailureAvgTime</tt> </td>
<td align="left"> Average time for failed kerberos logins in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>getGroupsNumOps</tt> </td>
<td align="left"> Total number of group resolutions </td></tr>
<tr class="a">
<td align="left"> <tt>getGroupsAvgTime</tt> </td>
<td align="left"> Average time for group resolution in milliseconds </td></tr>
<tr class="b">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>sNumOps</tt> </td>
<td align="left"> Total number of group resolutions (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>s50thPercentileLatency</tt> </td>
<td align="left"> Shows the 50th percentile of group resolution time in milliseconds (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>s75thPercentileLatency</tt> </td>
<td align="left"> Shows the 75th percentile of group resolution time in milliseconds (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>s90thPercentileLatency</tt> </td>
<td align="left"> Shows the 90th percentile of group resolution time in milliseconds (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="b">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>s95thPercentileLatency</tt> </td>
<td align="left"> Shows the 95th percentile of group resolution time in milliseconds (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
<tr class="a">
<td align="left"> <tt>getGroups</tt><i>num</i><tt>s99thPercentileLatency</tt> </td>
<td align="left"> Shows the 99th percentile of group resolution time in milliseconds (<i>num</i> seconds granularity). <i>num</i> is specified by <tt>hadoop.user.group.metrics.percentiles.intervals</tt>. </td></tr>
</tbody>
</table>
<h1>metricssystem context</h1></div>
<div class="section">
<h2><a name="MetricsSystem"></a>MetricsSystem</h2>
<p>MetricsSystem shows the statistics for metrics snapshots and publishes. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>NumActiveSources</tt> </td>
<td align="left"> Current number of active metrics sources </td></tr>
<tr class="a">
<td align="left"> <tt>NumAllSources</tt> </td>
<td align="left"> Total number of metrics sources </td></tr>
<tr class="b">
<td align="left"> <tt>NumActiveSinks</tt> </td>
<td align="left"> Current number of active sinks </td></tr>
<tr class="a">
<td align="left"> <tt>NumAllSinks</tt> </td>
<td align="left"> Total number of sinks &#xa0;(BUT usually less than <tt>NumActiveSinks</tt>, see <a class="externalLink" href="https://issues.apache.org/jira/browse/HADOOP-9946">HADOOP-9946</a>) </td></tr>
<tr class="b">
<td align="left"> <tt>SnapshotNumOps</tt> </td>
<td align="left"> Total number of operations to snapshot statistics from a metrics source </td></tr>
<tr class="a">
<td align="left"> <tt>SnapshotAvgTime</tt> </td>
<td align="left"> Average time in milliseconds to snapshot statistics from a metrics source </td></tr>
<tr class="b">
<td align="left"> <tt>PublishNumOps</tt> </td>
<td align="left"> Total number of operations to publish statistics to a sink </td></tr>
<tr class="a">
<td align="left"> <tt>PublishAvgTime</tt> </td>
<td align="left"> Average time in milliseconds to publish statistics to a sink </td></tr>
<tr class="b">
<td align="left"> <tt>DroppedPubAll</tt> </td>
<td align="left"> Total number of dropped publishes </td></tr>
<tr class="a">
<td align="left"> <tt>Sink_</tt><i>instance</i><tt>NumOps</tt> </td>
<td align="left"> Total number of sink operations for the <i>instance</i> </td></tr>
<tr class="b">
<td align="left"> <tt>Sink_</tt><i>instance</i><tt>AvgTime</tt> </td>
<td align="left"> Average time in milliseconds of sink operations for the <i>instance</i> </td></tr>
<tr class="a">
<td align="left"> <tt>Sink_</tt><i>instance</i><tt>Dropped</tt> </td>
<td align="left"> Total number of dropped sink operations for the <i>instance</i> </td></tr>
<tr class="b">
<td align="left"> <tt>Sink_</tt><i>instance</i><tt>Qsize</tt> </td>
<td align="left"> Current queue length of sink operations </td></tr>
</tbody>
</table>
<h1>default context</h1></div>
<div class="section">
<h2><a name="StartupProgress"></a>StartupProgress</h2>
<p>StartupProgress metrics shows the statistics of NameNode startup. Four metrics are exposed for each startup phase based on its name. The startup <i>phase</i>s are <tt>LoadingFsImage</tt>, <tt>LoadingEdits</tt>, <tt>SavingCheckpoint</tt>, and <tt>SafeMode</tt>. Each metrics record contains Hostname tag as additional information along with metrics.</p>
<table border="0" class="bodyTable">
<thead>
<tr class="a">
<th align="left"> Name </th>
<th align="left"> Description </th></tr>
</thead><tbody>
<tr class="b">
<td align="left"> <tt>ElapsedTime</tt> </td>
<td align="left"> Total elapsed time in milliseconds </td></tr>
<tr class="a">
<td align="left"> <tt>PercentComplete</tt> </td>
<td align="left"> Current rate completed in NameNode startup progress &#xa0;(The max value is not 100 but 1.0) </td></tr>
<tr class="b">
<td align="left"> <i>phase</i><tt>Count</tt> </td>
<td align="left"> Total number of steps completed in the phase </td></tr>
<tr class="a">
<td align="left"> <i>phase</i><tt>ElapsedTime</tt> </td>
<td align="left"> Total elapsed time in the phase in milliseconds </td></tr>
<tr class="b">
<td align="left"> <i>phase</i><tt>Total</tt> </td>
<td align="left"> Total number of steps in the phase </td></tr>
<tr class="a">
<td align="left"> <i>phase</i><tt>PercentComplete</tt> </td>
<td align="left"> Current rate completed in the phase &#xa0;(The max value is not 100 but 1.0) </td></tr>
</tbody>
</table></div>
</div>
</div>
<div class="clear">
<hr/>
</div>
<div id="footer">
<div class="xright">
&#169; 2008-2021
Apache Software Foundation
- <a href="http://maven.apache.org/privacy-policy.html">Privacy Policy</a>.
Apache Maven, Maven, Apache, the Apache feather logo, and the Apache Maven project logos are trademarks of The Apache Software Foundation.
</div>
<div class="clear">
<hr/>
</div>
</div>
</body>
</html>