You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hbase.apache.org by gi...@apache.org on 2020/12/31 20:17:24 UTC
[hbase-site] branch asf-site updated: Published site at
043da5f5eebd009a14780d12b4e70011b200b5bb.
This is an automated email from the ASF dual-hosted git repository.
git-site-role pushed a commit to branch asf-site
in repository https://gitbox.apache.org/repos/asf/hbase-site.git
The following commit(s) were added to refs/heads/asf-site by this push:
new 08b065b Published site at 043da5f5eebd009a14780d12b4e70011b200b5bb.
08b065b is described below
commit 08b065bd6b5db8d1ecbf245b7f0d6d2adf217e2a
Author: jenkins <bu...@apache.org>
AuthorDate: Thu Dec 31 20:17:10 2020 +0000
Published site at 043da5f5eebd009a14780d12b4e70011b200b5bb.
---
acid-semantics.html | 2 +-
apache_hbase_reference_guide.pdf | 4 +-
.../org/apache/hadoop/hbase/util/RegionMover.html | 4 +-
book.html | 2 +-
bulk-loads.html | 2 +-
checkstyle-aggregate.html | 182 +-
coc.html | 2 +-
dependencies.html | 2 +-
dependency-convergence.html | 2 +-
dependency-info.html | 2 +-
dependency-management.html | 6 +-
devapidocs/constant-values.html | 16 +-
devapidocs/index-all.html | 8 +
.../apache/hadoop/hbase/backup/package-tree.html | 4 +-
.../apache/hadoop/hbase/chaos/package-tree.html | 2 +-
.../hadoop/hbase/client/AsyncConnectionImpl.html | 50 +-
.../apache/hadoop/hbase/client/package-tree.html | 22 +-
.../hadoop/hbase/coprocessor/package-tree.html | 2 +-
.../apache/hadoop/hbase/filter/package-tree.html | 6 +-
.../hadoop/hbase/hbtop/terminal/package-tree.html | 2 +-
.../org/apache/hadoop/hbase/http/package-tree.html | 4 +-
.../org/apache/hadoop/hbase/io/hfile/HFile.html | 20 +-
.../apache/hadoop/hbase/io/hfile/HFileInfo.html | 167 +-
.../apache/hadoop/hbase/io/hfile/package-tree.html | 4 +-
.../org/apache/hadoop/hbase/ipc/package-tree.html | 2 +-
.../hadoop/hbase/mapreduce/package-tree.html | 4 +-
.../hbase/master/assignment/package-tree.html | 2 +-
.../hadoop/hbase/master/balancer/package-tree.html | 2 +-
.../apache/hadoop/hbase/master/package-tree.html | 6 +-
.../hbase/master/procedure/package-tree.html | 2 +-
.../org/apache/hadoop/hbase/package-tree.html | 18 +-
.../hadoop/hbase/procedure2/package-tree.html | 6 +-
.../hbase/procedure2/store/wal/package-tree.html | 2 +-
.../apache/hadoop/hbase/quotas/package-tree.html | 8 +-
.../hbase/regionserver/MetricsRegionServer.html | 149 +-
.../regionserver/ScannerContext.LimitScope.html | 4 +-
.../regionserver/ScannerContext.NextState.html | 4 +-
.../hadoop/hbase/regionserver/package-tree.html | 16 +-
.../regionserver/querymatcher/package-tree.html | 2 +-
.../hbase/regionserver/wal/package-tree.html | 4 +-
.../hadoop/hbase/replication/package-tree.html | 2 +-
.../hadoop/hbase/security/access/package-tree.html | 6 +-
.../apache/hadoop/hbase/security/package-tree.html | 2 +-
.../apache/hadoop/hbase/thrift/package-tree.html | 2 +-
.../HBaseFsck.CheckRegionConsistencyWorkItem.html | 10 +-
.../hbase/util/HBaseFsck.FileLockCallable.html | 16 +-
.../hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html | 6 +-
.../util/HBaseFsck.PrintingErrorReporter.html | 42 +-
.../HBaseFsck.RegionBoundariesInformation.html | 16 +-
.../hbase/util/HBaseFsck.WorkItemHdfsDir.html | 12 +-
.../util/HBaseFsck.WorkItemHdfsRegionInfo.html | 12 +-
.../hbase/util/HBaseFsck.WorkItemOverlapMerge.html | 10 +-
.../hbase/util/HBaseFsck.WorkItemRegion.html | 16 +-
.../org/apache/hadoop/hbase/util/HBaseFsck.html | 414 +-
.../org/apache/hadoop/hbase/util/package-tree.html | 12 +-
.../org/apache/hadoop/hbase/wal/package-tree.html | 2 +-
.../hadoop/hbase/client/AsyncConnectionImpl.html | 435 +-
.../hbase/client/example/AsyncClientExample.html | 2 +-
.../FSDataInputStreamWrapper.ReadStatistics.html | 26 +-
.../hadoop/hbase/io/FSDataInputStreamWrapper.html | 26 +-
.../hbase/io/hfile/HFile.CachingBlockReader.html | 347 +-
.../apache/hadoop/hbase/io/hfile/HFile.Reader.html | 347 +-
.../apache/hadoop/hbase/io/hfile/HFile.Writer.html | 347 +-
.../hadoop/hbase/io/hfile/HFile.WriterFactory.html | 347 +-
.../org/apache/hadoop/hbase/io/hfile/HFile.html | 347 +-
.../apache/hadoop/hbase/io/hfile/HFileInfo.html | 947 +--
.../master/HMaster.TableDescriptorGetter.html | 342 +-
.../org/apache/hadoop/hbase/master/HMaster.html | 342 +-
.../hbase/regionserver/MetricsRegionServer.html | 496 +-
.../HBaseFsck.CheckRegionConsistencyWorkItem.html | 7697 ++++++++++----------
.../hbase/util/HBaseFsck.FileLockCallable.html | 7697 ++++++++++----------
.../hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html | 7697 ++++++++++----------
.../util/HBaseFsck.PrintingErrorReporter.html | 7697 ++++++++++----------
.../HBaseFsck.RegionBoundariesInformation.html | 7697 ++++++++++----------
.../hbase/util/HBaseFsck.WorkItemHdfsDir.html | 7697 ++++++++++----------
.../util/HBaseFsck.WorkItemHdfsRegionInfo.html | 7697 ++++++++++----------
.../hbase/util/HBaseFsck.WorkItemOverlapMerge.html | 7697 ++++++++++----------
.../hbase/util/HBaseFsck.WorkItemRegion.html | 7697 ++++++++++----------
.../org/apache/hadoop/hbase/util/HBaseFsck.html | 7697 ++++++++++----------
.../hbase/util/RegionMover.RegionMoverBuilder.html | 4 +-
.../org/apache/hadoop/hbase/util/RegionMover.html | 4 +-
downloads.html | 2 +-
export_control.html | 2 +-
index.html | 2 +-
issue-tracking.html | 2 +-
mail-lists.html | 2 +-
metrics.html | 2 +-
old_news.html | 2 +-
plugin-management.html | 2 +-
plugins.html | 2 +-
poweredbyhbase.html | 2 +-
project-info.html | 2 +-
project-reports.html | 2 +-
project-summary.html | 2 +-
pseudo-distributed.html | 2 +-
replication.html | 2 +-
resources.html | 2 +-
source-repository.html | 2 +-
sponsors.html | 2 +-
supportingprojects.html | 2 +-
team-list.html | 2 +-
...ncTableRegionReplicasRead.FailPrimaryGetCP.html | 12 +-
.../AbstractTestAsyncTableRegionReplicasRead.html | 54 +-
.../hadoop/hbase/client/TestAsyncAdminBase.html | 50 +-
...syncAdminBuilder.TestMaxRetriesCoprocessor.html | 10 +-
...minBuilder.TestOperationTimeoutCoprocessor.html | 10 +-
...syncAdminBuilder.TestRpcTimeoutCoprocessor.html | 8 +-
.../hadoop/hbase/client/TestAsyncAdminBuilder.html | 36 +-
.../hbase/client/TestAsyncClusterAdminApi2.html | 20 +-
.../hbase/client/TestAsyncMetaRegionLocator.html | 18 +-
.../client/TestAsyncNonMetaRegionLocator.html | 76 +-
...atorConcurrenyLimit.CountingRegionObserver.html | 10 +-
...stAsyncNonMetaRegionLocatorConcurrenyLimit.html | 32 +-
...TestAsyncRegionLocator.SleepRegionObserver.html | 8 +-
.../hbase/client/TestAsyncRegionLocator.html | 28 +-
.../TestAsyncSingleRequestRpcRetryingCaller.html | 34 +-
.../apache/hadoop/hbase/client/TestAsyncTable.html | 108 +-
.../TestAsyncTableLocateRegionForDeletedTable.html | 24 +-
.../TestAsyncTableNoncedRetry.SleepOnceCP.html | 10 +-
.../hbase/client/TestAsyncTableNoncedRetry.html | 40 +-
.../TestAsyncTableScanMetrics.ScanWithMetrics.html | 4 +-
.../hbase/client/TestAsyncTableScanMetrics.html | 40 +-
...estCatalogReplicaLoadBalanceSimpleSelector.html | 26 +-
.../hbase/client/TestMetaRegionLocationCache.html | 26 +-
.../hbase/client/TestZKConnectionRegistry.html | 22 +-
.../TestMasterOperationsForRegionReplicas.html | 26 +-
...TestEndToEndSplitTransaction.RegionChecker.html | 24 +-
...estEndToEndSplitTransaction.RegionSplitter.html | 22 +-
.../regionserver/TestEndToEndSplitTransaction.html | 36 +-
.../hbase/replication/TestReplicationBase.html | 86 +-
.../replication/TestReplicationSyncUpToolBase.html | 54 +-
...TestSerialReplicationEndpoint.TestEndpoint.html | 16 +-
.../TestSerialReplicationEndpoint.html | 24 +-
...ncTableRegionReplicasRead.FailPrimaryGetCP.html | 361 +-
.../AbstractTestAsyncTableRegionReplicasRead.html | 361 +-
.../hadoop/hbase/client/TestAsyncAdminBase.html | 269 +-
...syncAdminBuilder.TestMaxRetriesCoprocessor.html | 409 +-
...minBuilder.TestOperationTimeoutCoprocessor.html | 409 +-
...syncAdminBuilder.TestRpcTimeoutCoprocessor.html | 409 +-
.../hadoop/hbase/client/TestAsyncAdminBuilder.html | 409 +-
.../hbase/client/TestAsyncClusterAdminApi2.html | 191 +-
.../hbase/client/TestAsyncMetaRegionLocator.html | 127 +-
.../client/TestAsyncNonMetaRegionLocator.html | 869 +--
...atorConcurrenyLimit.CountingRegionObserver.html | 277 +-
...stAsyncNonMetaRegionLocatorConcurrenyLimit.html | 277 +-
...TestAsyncRegionLocator.SleepRegionObserver.html | 251 +-
.../hbase/client/TestAsyncRegionLocator.html | 251 +-
.../TestAsyncSingleRequestRpcRetryingCaller.html | 309 +-
.../apache/hadoop/hbase/client/TestAsyncTable.html | 3265 ++++-----
.../TestAsyncTableLocateRegionForDeletedTable.html | 165 +-
.../TestAsyncTableNoncedRetry.SleepOnceCP.html | 291 +-
.../hbase/client/TestAsyncTableNoncedRetry.html | 291 +-
.../TestAsyncTableScanMetrics.ScanWithMetrics.html | 275 +-
.../hbase/client/TestAsyncTableScanMetrics.html | 275 +-
...estCatalogReplicaLoadBalanceSimpleSelector.html | 184 +-
.../hbase/client/TestMetaRegionLocationCache.html | 343 +-
.../hbase/client/TestZKConnectionRegistry.html | 197 +-
.../TestMasterOperationsForRegionReplicas.html | 150 +-
...TestEndToEndSplitTransaction.RegionChecker.html | 994 ++-
...estEndToEndSplitTransaction.RegionSplitter.html | 994 ++-
.../regionserver/TestEndToEndSplitTransaction.html | 994 ++-
...plitTransactionOnCluster.CustomSplitPolicy.html | 158 +-
...actionOnCluster.FailingSplitMasterObserver.html | 158 +-
.../TestSplitTransactionOnCluster.MyMaster.html | 158 +-
...itTransactionOnCluster.MyMasterRpcServices.html | 158 +-
.../TestSplitTransactionOnCluster.html | 158 +-
.../hbase/replication/TestReplicationBase.html | 652 +-
.../replication/TestReplicationSyncUpToolBase.html | 289 +-
...TestSerialReplicationEndpoint.TestEndpoint.html | 309 +-
.../TestSerialReplicationEndpoint.html | 309 +-
170 files changed, 49873 insertions(+), 49764 deletions(-)
diff --git a/acid-semantics.html b/acid-semantics.html
index 83db1d4..b953815 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -467,7 +467,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/apache_hbase_reference_guide.pdf b/apache_hbase_reference_guide.pdf
index e84f593..ed94bde 100644
--- a/apache_hbase_reference_guide.pdf
+++ b/apache_hbase_reference_guide.pdf
@@ -5,8 +5,8 @@
/Author (Apache HBase Team)
/Creator (Asciidoctor PDF 1.5.3, based on Prawn 2.2.2)
/Producer (Apache HBase Team)
-/ModDate (D:20201230200432+00'00')
-/CreationDate (D:20201230201436+00'00')
+/ModDate (D:20201231200440+00'00')
+/CreationDate (D:20201231201444+00'00')
>>
endobj
2 0 obj
diff --git a/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html b/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
index 65b5503..3e9e470 100644
--- a/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
+++ b/apidocs/src-html/org/apache/hadoop/hbase/util/RegionMover.html
@@ -129,8 +129,8 @@
<span class="sourceLineNo">121</span><a name="line.121"></a>
<span class="sourceLineNo">122</span> @Override<a name="line.122"></a>
<span class="sourceLineNo">123</span> public void close() {<a name="line.123"></a>
-<span class="sourceLineNo">124</span> IOUtils.closeQuietly(this.admin);<a name="line.124"></a>
-<span class="sourceLineNo">125</span> IOUtils.closeQuietly(this.conn);<a name="line.125"></a>
+<span class="sourceLineNo">124</span> IOUtils.closeQuietly(this.admin, e -> LOG.warn("failed to close admin", e));<a name="line.124"></a>
+<span class="sourceLineNo">125</span> IOUtils.closeQuietly(this.conn, e -> LOG.warn("failed to close conn", e));<a name="line.125"></a>
<span class="sourceLineNo">126</span> }<a name="line.126"></a>
<span class="sourceLineNo">127</span><a name="line.127"></a>
<span class="sourceLineNo">128</span> /**<a name="line.128"></a>
diff --git a/book.html b/book.html
index d26596c..7c340cf 100644
--- a/book.html
+++ b/book.html
@@ -46207,7 +46207,7 @@ org/apache/hadoop/hbase/security/access/AccessControlClient.revoke:(Lorg/apache/
<div id="footer">
<div id="footer-text">
Version 3.0.0-SNAPSHOT<br>
-Last updated 2020-12-30 20:04:32 UTC
+Last updated 2020-12-31 20:04:40 UTC
</div>
</div>
<link rel="stylesheet" href="./coderay-asciidoctor.css">
diff --git a/bulk-loads.html b/bulk-loads.html
index 617f756..acbf558 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -172,7 +172,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/checkstyle-aggregate.html b/checkstyle-aggregate.html
index 891bfea..32bb283 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -16952,13 +16952,13 @@
<td>coding</td>
<td>InnerAssignment</td>
<td>Inner assignments should be avoided.</td>
-<td>117</td></tr>
+<td>118</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>coding</td>
<td>InnerAssignment</td>
<td>Inner assignments should be avoided.</td>
-<td>135</td></tr></table></div>
+<td>136</td></tr></table></div>
<div class="section">
<h3 id="org.apache.hadoop.hbase.client.TestAsyncTableScanner.java">org/apache/hadoop/hbase/client/TestAsyncTableScanner.java</h3>
<table border="0" class="table table-striped">
@@ -17054,61 +17054,61 @@
<td>whitespace</td>
<td>MethodParamPad</td>
<td>'(' should be on the previous line.</td>
-<td>98</td></tr>
+<td>100</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'block' child has incorrect indentation level 8, expected level should be 10.</td>
-<td>118</td></tr>
+<td>120</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'try' has incorrect indentation level 8, expected level should be 10.</td>
-<td>119</td></tr>
+<td>121</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'try' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>120</td></tr>
+<td>122</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'try' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>122</td></tr>
+<td>124</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'try rcurly' has incorrect indentation level 8, expected level should be 10.</td>
-<td>123</td></tr>
+<td>125</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'catch' child has incorrect indentation level 10, expected level should be 12.</td>
-<td>124</td></tr>
+<td>126</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'catch rcurly' has incorrect indentation level 8, expected level should be 10.</td>
-<td>125</td></tr>
+<td>127</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'block' child has incorrect indentation level 8, expected level should be 10.</td>
-<td>126</td></tr>
+<td>128</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'block rcurly' has incorrect indentation level 6, expected level should be 8.</td>
-<td>127</td></tr></table></div>
+<td>129</td></tr></table></div>
<div class="section">
<h3 id="org.apache.hadoop.hbase.client.TestCheckAndMutate.java">org/apache/hadoop/hbase/client/TestCheckAndMutate.java</h3>
<table border="0" class="table table-striped">
@@ -29783,13 +29783,13 @@
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 118).</td>
-<td>366</td></tr>
+<td>374</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 118).</td>
-<td>368</td></tr></table></div>
+<td>376</td></tr></table></div>
<div class="section">
<h3 id="org.apache.hadoop.hbase.io.hfile.HFilePrettyPrinter.java">org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.java</h3>
<table border="0" class="table table-striped">
@@ -50222,7 +50222,7 @@
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 110).</td>
-<td>243</td></tr></table></div>
+<td>247</td></tr></table></div>
<div class="section">
<h3 id="org.apache.hadoop.hbase.regionserver.MetricsRegionServerSource.java">org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.java</h3>
<table border="0" class="table table-striped">
@@ -70631,451 +70631,451 @@
<td>imports</td>
<td>ImportOrder</td>
<td>Wrong order for 'org.apache.yetus.audience.InterfaceAudience' import.</td>
-<td>142</td></tr>
+<td>143</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>710</td></tr>
+<td>711</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'if' child has incorrect indentation level 11, expected level should be 10.</td>
-<td>768</td></tr>
+<td>769</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>846</td></tr>
+<td>847</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'regionName' must be private and have accessor methods.</td>
-<td>873</td></tr>
+<td>874</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'metaFirstKey' must be private and have accessor methods.</td>
-<td>874</td></tr>
+<td>875</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'metaLastKey' must be private and have accessor methods.</td>
-<td>875</td></tr>
+<td>876</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'storesFirstKey' must be private and have accessor methods.</td>
-<td>876</td></tr>
+<td>877</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'storesLastKey' must be private and have accessor methods.</td>
-<td>877</td></tr>
+<td>878</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>whitespace</td>
<td>MethodParamPad</td>
<td>'(' is preceded with whitespace.</td>
-<td>879</td></tr>
+<td>880</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>933</td></tr>
+<td>934</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>935</td></tr>
+<td>936</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1010</td></tr>
+<td>1011</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>whitespace</td>
<td>ParenPad</td>
<td>')' is preceded with whitespace.</td>
-<td>1045</td></tr>
+<td>1046</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1142</td></tr>
+<td>1143</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1147</td></tr>
+<td>1148</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1197</td></tr>
+<td>1198</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1201</td></tr>
+<td>1202</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 118).</td>
-<td>1207</td></tr>
+<td>1208</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 113).</td>
-<td>1208</td></tr>
+<td>1209</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>1216</td></tr>
+<td>1217</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 113).</td>
-<td>1217</td></tr>
+<td>1218</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 101).</td>
-<td>1219</td></tr>
+<td>1220</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1233</td></tr>
+<td>1234</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1367</td></tr>
+<td>1368</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1368</td></tr>
+<td>1369</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1370</td></tr>
+<td>1371</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 102).</td>
-<td>1388</td></tr>
+<td>1389</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1389</td></tr>
+<td>1390</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>1393</td></tr>
+<td>1394</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1404</td></tr>
+<td>1405</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 109).</td>
-<td>1423</td></tr>
+<td>1424</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1424</td></tr>
+<td>1425</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>1453</td></tr>
+<td>1454</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 123).</td>
-<td>1456</td></tr>
+<td>1457</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 102).</td>
-<td>1467</td></tr>
+<td>1468</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1609</td></tr>
+<td>1610</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>1610</td></tr>
+<td>1611</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1613</td></tr>
+<td>1614</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'if' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1648</td></tr>
+<td>1649</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'if' child has incorrect indentation level 9, expected level should be 8.</td>
-<td>1651</td></tr>
+<td>1652</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'if rcurly' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1652</td></tr>
+<td>1653</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1780</td></tr>
+<td>1781</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>whitespace</td>
<td>ParenPad</td>
<td>')' is preceded with whitespace.</td>
-<td>1970</td></tr>
+<td>1971</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>2098</td></tr>
+<td>2099</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>2140</td></tr>
+<td>2141</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>MethodLength</td>
<td>Method length is 235 lines (max allowed is 150).</td>
-<td>2161</td></tr>
+<td>2162</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>2164</td></tr>
+<td>2165</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>NeedBraces</td>
<td>'if' construct must use '{}'s.</td>
-<td>2236</td></tr>
+<td>2237</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>2402</td></tr>
+<td>2403</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'method def' child has incorrect indentation level 6, expected level should be 4.</td>
-<td>2613</td></tr>
+<td>2614</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>2654</td></tr>
+<td>2655</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>2655</td></tr>
+<td>2656</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>indentation</td>
<td>Indentation</td>
<td>'.' has incorrect indentation level 10, expected level should be 12.</td>
-<td>2681</td></tr>
+<td>2682</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>design</td>
<td>VisibilityModifier</td>
<td>Variable 'errorCount' must be private and have accessor methods.</td>
-<td>2879</td></tr>
+<td>2880</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>2943</td></tr>
+<td>2944</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>3109</td></tr>
+<td>3110</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>3180</td></tr>
+<td>3181</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 115).</td>
-<td>3493</td></tr>
+<td>3494</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 108).</td>
-<td>3536</td></tr>
+<td>3537</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 107).</td>
-<td>3541</td></tr>
+<td>3542</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>3542</td></tr>
+<td>3543</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 111).</td>
-<td>3549</td></tr>
+<td>3550</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 116).</td>
-<td>3554</td></tr>
+<td>3555</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 107).</td>
-<td>3561</td></tr>
+<td>3562</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 106).</td>
-<td>3563</td></tr>
+<td>3564</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 113).</td>
-<td>3566</td></tr>
+<td>3567</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 145).</td>
-<td>3568</td></tr>
+<td>3569</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 104).</td>
-<td>3569</td></tr>
+<td>3570</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 179).</td>
-<td>3570</td></tr>
+<td>3571</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>LineLength</td>
<td>Line is longer than 100 characters (found 113).</td>
-<td>3572</td></tr>
+<td>3573</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>3597</td></tr>
+<td>3598</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>javadoc</td>
<td>NonEmptyAtclauseDescription</td>
<td>At-clause should have a non-empty description.</td>
-<td>3598</td></tr>
+<td>3599</td></tr>
<tr class="b">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>blocks</td>
<td>LeftCurly</td>
<td>'{' at column 39 should have line break after.</td>
-<td>3614</td></tr>
+<td>3615</td></tr>
<tr class="a">
<td><img src="images/icon_error_sml.gif" alt="" /> Error</td>
<td>sizes</td>
<td>MethodLength</td>
<td>Method length is 227 lines (max allowed is 150).</td>
-<td>3624</td></tr></table></div>
+<td>3625</td></tr></table></div>
<div class="section">
<h3 id="org.apache.hadoop.hbase.util.HBaseFsckRepair.java">org/apache/hadoop/hbase/util/HBaseFsckRepair.java</h3>
<table border="0" class="table table-striped">
@@ -75689,7 +75689,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/coc.html b/coc.html
index 897ff59..1c91ecd 100644
--- a/coc.html
+++ b/coc.html
@@ -241,7 +241,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependencies.html b/dependencies.html
index 27b9335..6a870b9 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -313,7 +313,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-convergence.html b/dependency-convergence.html
index 30fa522..4cc1b84 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -824,7 +824,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-info.html b/dependency-info.html
index 0a410eb..4056cb0 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -194,7 +194,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/dependency-management.html b/dependency-management.html
index 6d58643..bc3999d 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -239,8 +239,8 @@
<td><a class="externalLink" href="https://www.apache.org/licenses/LICENSE-2.0.txt">Apache License, Version 2.0</a></td></tr>
<tr class="b">
<td>commons-io</td>
-<td><a class="externalLink" href="http://commons.apache.org/proper/commons-io/">commons-io</a></td>
-<td>2.6</td>
+<td><a class="externalLink" href="https://commons.apache.org/proper/commons-io/">commons-io</a></td>
+<td>2.8.0</td>
<td>-</td>
<td>jar</td>
<td><a class="externalLink" href="https://www.apache.org/licenses/LICENSE-2.0.txt">Apache License, Version 2.0</a></td></tr>
@@ -1019,7 +1019,7 @@
<div class="row">
<p>Copyright ©2007–2020
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-30</li>
+All rights reserved. <li id="publishDate" class="pull-right">Last Published: 2020-12-31</li>
</p>
</div>
<p id="poweredBy" class="pull-right"><a href="http://maven.apache.org/" title="Built by Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" src="./images/logos/maven-feather.png" /></a>
diff --git a/devapidocs/constant-values.html b/devapidocs/constant-values.html
index 065d03a..0f38094 100644
--- a/devapidocs/constant-values.html
+++ b/devapidocs/constant-values.html
@@ -21461,19 +21461,33 @@
</tr>
<tbody>
<tr class="altColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.DEFAULT_SLOW_METRIC_TIME">
+<!-- -->
+</a><code>protected static final int</code></td>
+<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></code></td>
+<td class="colLast"><code>1000</code></td>
+</tr>
+<tr class="rowColor">
<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.RS_ENABLE_TABLE_METRICS_DEFAULT">
<!-- -->
</a><code>public static final boolean</code></td>
<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_DEFAULT">RS_ENABLE_TABLE_METRICS_DEFAULT</a></code></td>
<td class="colLast"><code>true</code></td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.RS_ENABLE_TABLE_METRICS_KEY">
<!-- -->
</a><code>public static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_KEY">RS_ENABLE_TABLE_METRICS_KEY</a></code></td>
<td class="colLast"><code>"hbase.regionserver.enable.table.latencies"</code></td>
</tr>
+<tr class="rowColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.regionserver.MetricsRegionServer.SLOW_METRIC_TIME">
+<!-- -->
+</a><code>public static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td><code><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></code></td>
+<td class="colLast"><code>"hbase.ipc.slow.metric.time"</code></td>
+</tr>
</tbody>
</table>
</li>
diff --git a/devapidocs/index-all.html b/devapidocs/index-all.html
index 0bf6ef4..f2cf643 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -24844,6 +24844,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/HConstants.html#DEFAULT_SLOW_LOG_SYS_TABLE_ENABLED_KEY">DEFAULT_SLOW_LOG_SYS_TABLE_ENABLED_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.<a href="org/apache/hadoop/hbase/HConstants.html" title="class in org.apache.hadoop.hbase">HConstants</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html#DEFAULT_SLOW_RESPONSE_NANO_SEC">DEFAULT_SLOW_RESPONSE_NANO_SEC</a></span> - Static variable in class org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html#DEFAULT_SLOW_SYNC_ROLL_INTERVAL_MS">DEFAULT_SLOW_SYNC_ROLL_INTERVAL_MS</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.wal.<a href="org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a></dt>
@@ -71921,6 +71923,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFileInfo.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFilePreadReader.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFilePreadReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFilePreadReader</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.html#LOG">LOG</a></span> - Static variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/HFilePrettyPrinter.html" title="class in org.apache.hadoop.hbase.io.hfile">HFilePrettyPrinter</a></dt>
@@ -112473,6 +112477,8 @@ service.</div>
<div class="block">hbase:slowlog table name - can be enabled
with config - hbase.regionserver.slowlog.systable.enabled</div>
</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></span> - Static variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html#SLOW_PUT_DESC">SLOW_PUT_DESC</a></span> - Static variable in interface org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html#SLOW_PUT_KEY">SLOW_PUT_KEY</a></span> - Static variable in interface org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></dt>
@@ -112562,6 +112568,8 @@ service.</div>
</dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/HRegionServer.html#slowLogTableOpsChore">slowLogTableOpsChore</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#slowMetricTime">slowMetricTime</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServer</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceImpl.html#slowPut">slowPut</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceImpl.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSourceImpl</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html#slowResponseTime">slowResponseTime</a></span> - Variable in class org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
index 761a9cc..18685bf 100644
--- a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
@@ -166,10 +166,10 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupRestoreConstants.BackupCommand.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupRestoreConstants.BackupCommand</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupState.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
index b17377d..6095a20 100644
--- a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
@@ -103,8 +103,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ExecutorAction.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ExecutorAction</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html b/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
index 3bae02e..38d64a8 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
@@ -761,7 +761,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>logCallStack</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.228">logCallStack</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/StackTraceElement.html?is-external=true" title="class or interface in java.lang">StackTraceElement</a>[] stackTraceElements)</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.229">logCallStack</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/StackTraceElement.html?is-external=true" title="class or interface in java.lang">StackTraceElement</a>[] stackTraceElements)</pre>
</li>
</ul>
<a name="getRegionLocator-org.apache.hadoop.hbase.TableName-">
@@ -770,7 +770,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getRegionLocator</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableRegionLocator.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableRegionLocator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.239">getRegionLocator</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableRegionLocator.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableRegionLocator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.240">getRegionLocator</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getRegionLocator-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
<div class="block">Retrieve a AsyncRegionLocator implementation to inspect region information on a table. The
returned AsyncRegionLocator is not thread-safe, so a new instance should be created for each
@@ -792,7 +792,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>clearRegionLocationCache</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.244">clearRegionLocationCache</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.245">clearRegionLocationCache</a>()</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#clearRegionLocationCache--">AsyncConnection</a></code></span></div>
<div class="block">Clear all the entries in the region location cache, for all the tables.
<p/>
@@ -812,7 +812,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getLocator</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/AsyncRegionLocator.html" title="class in org.apache.hadoop.hbase.client">AsyncRegionLocator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.249">getLocator</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/AsyncRegionLocator.html" title="class in org.apache.hadoop.hbase.client">AsyncRegionLocator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.250">getLocator</a>()</pre>
</li>
</ul>
<a name="getNonceGenerator--">
@@ -821,7 +821,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getNonceGenerator</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/NonceGenerator.html" title="interface in org.apache.hadoop.hbase.client">NonceGenerator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.254">getNonceGenerator</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/NonceGenerator.html" title="interface in org.apache.hadoop.hbase.client">NonceGenerator</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.255">getNonceGenerator</a>()</pre>
</li>
</ul>
<a name="createRegionServerStub-org.apache.hadoop.hbase.ServerName-">
@@ -830,7 +830,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>createRegionServerStub</h4>
-<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.258">createRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
+<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.259">createRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
@@ -844,7 +844,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getRegionServerStub</h4>
-<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.262">getRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
+<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.ClientProtos.ClientService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.263">getRegionServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
@@ -858,7 +858,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>createMasterStub</h4>
-<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.268">createMasterStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
+<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.269">createMasterStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
@@ -872,7 +872,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>createAdminServerStub</h4>
-<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.272">createAdminServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
+<pre>private org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.273">createAdminServerStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
@@ -886,7 +886,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getAdminStub</h4>
-<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.276">getAdminStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
+<pre>org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.AdminService.Interface <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.277">getAdminStub</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> serverName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
@@ -900,7 +900,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getMasterStub</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a><org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.282">getMasterStub</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a><org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.283">getMasterStub</a>()</pre>
</li>
</ul>
<a name="getClusterId--">
@@ -909,7 +909,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getClusterId</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.305">getClusterId</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.306">getClusterId</a>()</pre>
</li>
</ul>
<a name="clearMasterStubCache-org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface-">
@@ -918,7 +918,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>clearMasterStubCache</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.314">clearMasterStubCache</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface stub)</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.315">clearMasterStubCache</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProtos.MasterService.Interface stub)</pre>
</li>
</ul>
<a name="getStatisticsTracker--">
@@ -927,7 +927,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getStatisticsTracker</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a><<a href="../../../../../org/apache/hadoop/hbase/client/ServerStatisticTracker.html" title="class in org.apache.hadoop.hbase.client">ServerStatisticTracker</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.318">getStatisticsTracker</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a><<a href="../../../../../org/apache/hadoop/hbase/client/ServerStatisticTracker.html" title="class in org.apache.hadoop.hbase.client">ServerStatisticTracker</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.319">getStatisticsTracker</a>()</pre>
</li>
</ul>
<a name="getBackoffPolicy--">
@@ -936,7 +936,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getBackoffPolicy</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/backoff/ClientBackoffPolicy.html" title="interface in org.apache.hadoop.hbase.client.backoff">ClientBackoffPolicy</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.322">getBackoffPolicy</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/backoff/ClientBackoffPolicy.html" title="interface in org.apache.hadoop.hbase.client.backoff">ClientBackoffPolicy</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.323">getBackoffPolicy</a>()</pre>
</li>
</ul>
<a name="getTableBuilder-org.apache.hadoop.hbase.TableName-">
@@ -945,7 +945,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getTableBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a><<a href="../../../../../org/apache/hadoop/hbase/client/AdvancedScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">AdvancedScanResultConsumer</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.327">getTableBuilder</a>(<a href="../../../.. [...]
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a><<a href="../../../../../org/apache/hadoop/hbase/client/AdvancedScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">AdvancedScanResultConsumer</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.328">getTableBuilder</a>(<a href="../../../.. [...]
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getTableBuilder-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTableBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTable.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTable</code></a>.
<p>
@@ -965,7 +965,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getTableBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a><<a href="../../../../../org/apache/hadoop/hbase/client/ScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">ScanResultConsumer</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.338">getTableBuilder</a>(<a href="../../../../../org/apache/h [...]
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncTableBuilder</a><<a href="../../../../../org/apache/hadoop/hbase/client/ScanResultConsumer.html" title="interface in org.apache.hadoop.hbase.client">ScanResultConsumer</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.339">getTableBuilder</a>(<a href="../../../../../org/apache/h [...]
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> pool)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getTableBuilder-org.apache.hadoop.hbase.TableName-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTableBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTableBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncTable.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncTable</code></a>.
@@ -987,7 +987,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getAdminBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.352">getAdminBuilder</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.353">getAdminBuilder</a>()</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getAdminBuilder--">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdminBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdmin.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdmin</code></a>.
<p>
@@ -1006,7 +1006,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getAdminBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.362">getAdminBuilder</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> pool)</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncAdminBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.363">getAdminBuilder</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> pool)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getAdminBuilder-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdminBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdminBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncAdmin.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncAdmin</code></a>.</div>
<dl>
@@ -1023,7 +1023,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getBufferedMutatorBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.374">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.375">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getBufferedMutatorBuilder-org.apache.hadoop.hbase.TableName-">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutatorBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutator.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutator</code></a>.</div>
<dl>
@@ -1040,7 +1040,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getBufferedMutatorBuilder</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.379">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client">AsyncBufferedMutatorBuilder</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.380">getBufferedMutatorBuilder</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> pool)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getBufferedMutatorBuilder-org.apache.hadoop.hbase.TableName-java.util.concurrent.ExecutorService-">AsyncConnection</a></code></span></div>
<div class="block">Returns an <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutatorBuilder.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutatorBuilder</code></a> for creating <a href="../../../../../org/apache/hadoop/hbase/client/AsyncBufferedMutator.html" title="interface in org.apache.hadoop.hbase.client"><code>AsyncBufferedMutator</code></a>.</div>
@@ -1059,7 +1059,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>toConnection</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.386">toConnection</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.387">toConnection</a>()</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#toConnection--">AsyncConnection</a></code></span></div>
<div class="block">Convert this connection to a <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client"><code>Connection</code></a>.
<p/>
@@ -1077,7 +1077,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getHbck</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a><<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.403">getHbck</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/CompletableFuture.html?is-external=true" title="class or interface in java.util.concurrent">CompletableFuture</a><<a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.404">getHbck</a>()</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getHbck--">AsyncConnection</a></code></span></div>
<div class="block">Retrieve an Hbck implementation to fix an HBase cluster. The returned Hbck is not guaranteed to
be thread-safe. A new instance should be created by each thread. This is a lightweight
@@ -1100,7 +1100,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockList">
<li class="blockList">
<h4>getHbck</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.420">getHbck</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> masterServer)
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Hbck.html" title="interface in org.apache.hadoop.hbase.client">Hbck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.421">getHbck</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> masterServer)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnection.html#getHbck-org.apache.hadoop.hbase.ServerName-">AsyncConnection</a></code></span></div>
<div class="block">Retrieve an Hbck implementation to fix an HBase cluster. The returned Hbck is not guaranteed to
@@ -1130,7 +1130,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/client/AsyncConnectio
<ul class="blockListLast">
<li class="blockList">
<h4>getConnectionMetrics</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a><<a href="../../../../../org/apache/hadoop/hbase/client/MetricsConnection.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.428">getConnectionMetrics</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a><<a href="../../../../../org/apache/hadoop/hbase/client/MetricsConnection.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html#line.429">getConnectionMetrics</a>()</pre>
</li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
index 67e0bb1..a58c7cb 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -455,23 +455,23 @@
<ul>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/LogQueryFilter.Type.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/LogQueryFilter.FilterByOperator.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.FilterByOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/ServerType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ServerType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CatalogReplicaMode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CatalogReplicaMode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Consistency.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Consistency</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactionState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/ServerType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ServerType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CatalogReplicaMode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CatalogReplicaMode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MobCompactPartitionPolicy.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MobCompactPartitionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Scan.ReadType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Scan.ReadType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
index b99c6c6..6b1ffff 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
@@ -181,8 +181,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">RegionObserver.MutationType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/MetaTableMetrics.MetaTableOps.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">MetaTableMetrics.MetaTableOps</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">RegionObserver.MutationType</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
index c00a7c6..42cd278 100644
--- a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
@@ -190,13 +190,13 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/BitComparator.BitwiseOp.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">BitComparator.BitwiseOp</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/RegexStringComparator.EngineType.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">RegexStringComparator.EngineType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.Order.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.Order</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/Filter.ReturnCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">Filter.ReturnCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
index 007e90f..b8f3866 100644
--- a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
@@ -107,8 +107,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/KeyPress.Type.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">KeyPress.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/Color.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">Color</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/KeyPress.Type.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">KeyPress.Type</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
index f761cc1..085883a 100644
--- a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
@@ -140,9 +140,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Event.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Event</span></a></li>
<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/HttpConfig.Policy.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">HttpConfig.Policy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Event.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Event</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
index be0fd90..e2d86e4 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFile.html
@@ -782,7 +782,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>createReader</h4>
-<pre>public static <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.525">createReader</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>public static <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.526">createReader</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path path,
org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -806,7 +806,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>createReader</h4>
-<pre>public static <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.543">createReader</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>public static <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.544">createReader</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path path,
<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/CacheConfig.html" title="class in org.apache.hadoop.hbase.io.hfile">CacheConfig</a> cacheConf,
boolean primaryReplicaReader,
@@ -834,7 +834,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>isHFileFormat</h4>
-<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.568">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.569">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path path)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Returns true if the specified file has a valid HFile Trailer.</div>
@@ -855,7 +855,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>isHFileFormat</h4>
-<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.579">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.580">isHFileFormat</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.FileStatus fileStatus)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Returns true if the specified file has a valid HFile Trailer.</div>
@@ -876,7 +876,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>getSupportedCompressionAlgorithms</h4>
-<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.605">getSupportedCompressionAlgorithms</a>()</pre>
+<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.606">getSupportedCompressionAlgorithms</a>()</pre>
<div class="block">Get names of supported compression algorithms. The names are acceptable by
HFile.Writer.</div>
<dl>
@@ -897,7 +897,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>longToInt</h4>
-<pre>static int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.614">longToInt</a>(long l)</pre>
+<pre>static int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.615">longToInt</a>(long l)</pre>
</li>
</ul>
<a name="getStoreFiles-org.apache.hadoop.fs.FileSystem-org.apache.hadoop.fs.Path-">
@@ -906,7 +906,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>getStoreFiles</h4>
-<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.fs.Path> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.629">getStoreFiles</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.fs.Path> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.630">getStoreFiles</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path regionDir)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Returns all HFiles belonging to the given region directory. Could return an
@@ -928,7 +928,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>checkFormatVersion</h4>
-<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.656">checkFormatVersion</a>(int version)
+<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.657">checkFormatVersion</a>(int version)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/IllegalArgumentException.html?is-external=true" title="class or interface in java.lang">IllegalArgumentException</a></pre>
<div class="block">Checks the given <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.html" title="class in org.apache.hadoop.hbase.io.hfile"><code>HFile</code></a> format version, and throws an exception if
invalid. Note that if the version number comes from an input file and has
@@ -948,7 +948,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>checkHFileVersion</h4>
-<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.666">checkHFileVersion</a>(org.apache.hadoop.conf.Configuration c)</pre>
+<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.667">checkHFileVersion</a>(org.apache.hadoop.conf.Configuration c)</pre>
</li>
</ul>
<a name="main-java.lang.String:A-">
@@ -957,7 +957,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>main</h4>
-<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.677">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
+<pre>public static void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFile.html#line.678">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<dl>
<dt><span class="throwsLabel">Throws:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
index 94378ad..3024499 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
@@ -114,7 +114,7 @@ var activeTableTab = "activeTableTab";
<hr>
<br>
<pre>@InterfaceAudience.Private
-public class <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.64">HFileInfo</a>
+public class <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.68">HFileInfo</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></pre>
<div class="block">Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and
@@ -227,42 +227,46 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
</td>
</tr>
<tr class="rowColor">
+<td class="colFirst"><code>private static org.slf4j.Logger</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#LOG">LOG</a></span></code> </td>
+</tr>
+<tr class="altColor">
<td class="colFirst"><code>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#map">map</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>(package private) static int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MAX_MINOR_VERSION">MAX_MINOR_VERSION</a></span></code>
<div class="block">Maximum minor version supported by this HFile format</div>
</td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>static byte[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MAX_TAGS_LEN">MAX_TAGS_LEN</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#metaIndexReader">metaIndexReader</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private static int</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#MIN_V2_MINOR_VERSION_WITH_PB">MIN_V2_MINOR_VERSION_WITH_PB</a></span></code>
<div class="block">We can read files whose major version is v2 IFF their minor version is at least 3.</div>
</td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>(package private) static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#RESERVED_PREFIX">RESERVED_PREFIX</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>(package private) static byte[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#RESERVED_PREFIX_BYTES">RESERVED_PREFIX_BYTES</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>(package private) static byte[]</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#TAGS_COMPRESSED">TAGS_COMPRESSED</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html#trailer">trailer</a></span></code> </td>
</tr>
@@ -532,13 +536,22 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<!-- -->
</a>
<h3>Field Detail</h3>
+<a name="LOG">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>LOG</h4>
+<pre>private static final org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.70">LOG</a></pre>
+</li>
+</ul>
<a name="RESERVED_PREFIX">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>RESERVED_PREFIX</h4>
-<pre>static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.65">RESERVED_PREFIX</a></pre>
+<pre>static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.72">RESERVED_PREFIX</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../../constant-values.html#org.apache.hadoop.hbase.io.hfile.HFileInfo.RESERVED_PREFIX">Constant Field Values</a></dd>
@@ -551,7 +564,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>RESERVED_PREFIX_BYTES</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.66">RESERVED_PREFIX_BYTES</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.73">RESERVED_PREFIX_BYTES</a></pre>
</li>
</ul>
<a name="LASTKEY">
@@ -560,7 +573,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>LASTKEY</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.67">LASTKEY</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.74">LASTKEY</a></pre>
</li>
</ul>
<a name="AVG_KEY_LEN">
@@ -569,7 +582,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>AVG_KEY_LEN</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.68">AVG_KEY_LEN</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.75">AVG_KEY_LEN</a></pre>
</li>
</ul>
<a name="AVG_VALUE_LEN">
@@ -578,7 +591,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>AVG_VALUE_LEN</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.69">AVG_VALUE_LEN</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.76">AVG_VALUE_LEN</a></pre>
</li>
</ul>
<a name="CREATE_TIME_TS">
@@ -587,7 +600,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>CREATE_TIME_TS</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.70">CREATE_TIME_TS</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.77">CREATE_TIME_TS</a></pre>
</li>
</ul>
<a name="TAGS_COMPRESSED">
@@ -596,7 +609,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>TAGS_COMPRESSED</h4>
-<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.71">TAGS_COMPRESSED</a></pre>
+<pre>static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.78">TAGS_COMPRESSED</a></pre>
</li>
</ul>
<a name="MAX_TAGS_LEN">
@@ -605,7 +618,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>MAX_TAGS_LEN</h4>
-<pre>public static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.72">MAX_TAGS_LEN</a></pre>
+<pre>public static final byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.79">MAX_TAGS_LEN</a></pre>
</li>
</ul>
<a name="map">
@@ -614,7 +627,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>map</h4>
-<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.73">map</a></pre>
+<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.80">map</a></pre>
</li>
</ul>
<a name="MIN_V2_MINOR_VERSION_WITH_PB">
@@ -623,7 +636,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>MIN_V2_MINOR_VERSION_WITH_PB</h4>
-<pre>private static final int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.78">MIN_V2_MINOR_VERSION_WITH_PB</a></pre>
+<pre>private static final int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.85">MIN_V2_MINOR_VERSION_WITH_PB</a></pre>
<div class="block">We can read files whose major version is v2 IFF their minor version is at least 3.</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -637,7 +650,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>MAX_MINOR_VERSION</h4>
-<pre>static final int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.83">MAX_MINOR_VERSION</a></pre>
+<pre>static final int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.90">MAX_MINOR_VERSION</a></pre>
<div class="block">Maximum minor version supported by this HFile format</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -651,7 +664,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>lastKeyCell</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.86">lastKeyCell</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.93">lastKeyCell</a></pre>
<div class="block">Last key in the file. Filled in when we read in the file info</div>
</li>
</ul>
@@ -661,7 +674,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>avgKeyLen</h4>
-<pre>private int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.88">avgKeyLen</a></pre>
+<pre>private int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.95">avgKeyLen</a></pre>
<div class="block">Average key length read from file info</div>
</li>
</ul>
@@ -671,7 +684,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>avgValueLen</h4>
-<pre>private int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.90">avgValueLen</a></pre>
+<pre>private int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.97">avgValueLen</a></pre>
<div class="block">Average value length read from file info</div>
</li>
</ul>
@@ -681,7 +694,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>includesMemstoreTS</h4>
-<pre>private boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.91">includesMemstoreTS</a></pre>
+<pre>private boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.98">includesMemstoreTS</a></pre>
</li>
</ul>
<a name="decodeMemstoreTS">
@@ -690,7 +703,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>decodeMemstoreTS</h4>
-<pre>private boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.92">decodeMemstoreTS</a></pre>
+<pre>private boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.99">decodeMemstoreTS</a></pre>
</li>
</ul>
<a name="loadOnOpenBlocks">
@@ -699,7 +712,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>loadOnOpenBlocks</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.98">loadOnOpenBlocks</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.105">loadOnOpenBlocks</a></pre>
<div class="block">Blocks read from the load-on-open section, excluding data root index, meta
index, and file info.</div>
</li>
@@ -710,7 +723,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>blockIter</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.105">blockIter</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.112">blockIter</a></pre>
<div class="block">The iterator will track all blocks in load-on-open section, since we use the
<a href="../../../../../../org/apache/hadoop/hbase/io/ByteBuffAllocator.html" title="class in org.apache.hadoop.hbase.io"><code>ByteBuffAllocator</code></a> to manage the ByteBuffers in block now,
so we must ensure that deallocate all ByteBuffers in the end.</div>
@@ -722,7 +735,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>dataIndexReader</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.107">dataIndexReader</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.114">dataIndexReader</a></pre>
</li>
</ul>
<a name="metaIndexReader">
@@ -731,7 +744,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>metaIndexReader</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.108">metaIndexReader</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.115">metaIndexReader</a></pre>
</li>
</ul>
<a name="trailer">
@@ -740,7 +753,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>trailer</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.110">trailer</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.117">trailer</a></pre>
</li>
</ul>
<a name="hfileContext">
@@ -749,7 +762,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockListLast">
<li class="blockList">
<h4>hfileContext</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.111">hfileContext</a></pre>
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.118">hfileContext</a></pre>
</li>
</ul>
</li>
@@ -766,7 +779,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>HFileInfo</h4>
-<pre>public <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.113">HFileInfo</a>()</pre>
+<pre>public <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.120">HFileInfo</a>()</pre>
</li>
</ul>
<a name="HFileInfo-org.apache.hadoop.hbase.io.hfile.ReaderContext-org.apache.hadoop.conf.Configuration-">
@@ -775,7 +788,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockListLast">
<li class="blockList">
<h4>HFileInfo</h4>
-<pre>public <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.117">HFileInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a> context,
+<pre>public <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.124">HFileInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a> context,
org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
@@ -798,7 +811,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>append</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.133">append</a>(byte[] k,
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileInfo.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileInfo</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.140">append</a>(byte[] k,
byte[] v,
boolean checkPrefix)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -824,7 +837,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>isReservedFileInfoKey</h4>
-<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.147">isReservedFileInfoKey</a>(byte[] key)</pre>
+<pre>public static boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.154">isReservedFileInfoKey</a>(byte[] key)</pre>
<div class="block">Return true if the given file info key is reserved for internal use.</div>
</li>
</ul>
@@ -834,7 +847,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>clear</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.152">clear</a>()</pre>
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.159">clear</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#clear--" title="class or interface in java.util">clear</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -847,7 +860,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>comparator</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Comparator.html?is-external=true" title="class or interface in java.util">Comparator</a><? super byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.157">comparator</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Comparator.html?is-external=true" title="class or interface in java.util">Comparator</a><? super byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.164">comparator</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#comparator--" title="class or interface in java.util">comparator</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></dd>
@@ -860,7 +873,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>containsKey</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.162">containsKey</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.169">containsKey</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#containsKey-java.lang.Object-" title="class or interface in java.util">containsKey</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -873,7 +886,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>containsValue</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.167">containsValue</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> value)</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.174">containsValue</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> value)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#containsValue-java.lang.Object-" title="class or interface in java.util">containsValue</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -886,7 +899,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>entrySet</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.Entry.html?is-external=true" title="class or interface in java.util">Map.Entry</a><byte[],byte[]>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.172">entrySet</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.Entry.html?is-external=true" title="class or interface in java.util">Map.Entry</a><byte[],byte[]>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.179">entrySet</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#entrySet--" title="class or interface in java.util">entrySet</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -901,7 +914,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>equals</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.177">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> o)</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.184">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> o)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#equals-java.lang.Object-" title="class or interface in java.util">equals</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -916,7 +929,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>firstKey</h4>
-<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.182">firstKey</a>()</pre>
+<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.189">firstKey</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#firstKey--" title="class or interface in java.util">firstKey</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></dd>
@@ -929,7 +942,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>get</h4>
-<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.187">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
+<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.194">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#get-java.lang.Object-" title="class or interface in java.util">get</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -942,7 +955,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>hashCode</h4>
-<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.192">hashCode</a>()</pre>
+<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.199">hashCode</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#hashCode--" title="class or interface in java.util">hashCode</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -957,7 +970,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>headMap</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.197">headMap</a>(byte[] toKey)</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.204">headMap</a>(byte[] toKey)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#headMap-K-" title="class or interface in java.util">headMap</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></dd>
@@ -970,7 +983,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>isEmpty</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.202">isEmpty</a>()</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.209">isEmpty</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#isEmpty--" title="class or interface in java.util">isEmpty</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -983,7 +996,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>keySet</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.207">keySet</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.214">keySet</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#keySet--" title="class or interface in java.util">keySet</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -998,7 +1011,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>lastKey</h4>
-<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.212">lastKey</a>()</pre>
+<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.219">lastKey</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#lastKey--" title="class or interface in java.util">lastKey</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></dd>
@@ -1011,7 +1024,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>put</h4>
-<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.217">put</a>(byte[] key,
+<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.224">put</a>(byte[] key,
byte[] value)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1025,7 +1038,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>putAll</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.222">putAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><? extends byte[],? extends byte[]> m)</pre>
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.229">putAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><? extends byte[],? extends byte[]> m)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#putAll-java.util.Map-" title="class or interface in java.util">putAll</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -1038,7 +1051,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>remove</h4>
-<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.227">remove</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
+<pre>public byte[] <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.234">remove</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a> key)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#remove-java.lang.Object-" title="class or interface in java.util">remove</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -1051,7 +1064,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>size</h4>
-<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.232">size</a>()</pre>
+<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.239">size</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#size--" title="class or interface in java.util">size</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -1064,7 +1077,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>subMap</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.237">subMap</a>(byte[] fromKey,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.244">subMap</a>(byte[] fromKey,
byte[] toKey)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1078,7 +1091,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>tailMap</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.242">tailMap</a>(byte[] fromKey)</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.249">tailMap</a>(byte[] fromKey)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true#tailMap-K-" title="class or interface in java.util">tailMap</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><byte[],byte[]></code></dd>
@@ -1091,7 +1104,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>values</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.247">values</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><byte[]> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.254">values</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true#values--" title="class or interface in java.util">values</a></code> in interface <code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><byte[],byte[]></code></dd>
@@ -1106,7 +1119,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>write</h4>
-<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.256">write</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataOutputStream.html?is-external=true" title="class or interface in java.io">DataOutputStream</a> out)
+<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.263">write</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataOutputStream.html?is-external=true" title="class or interface in java.io">DataOutputStream</a> out)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Write out this instance on the passed in <code>out</code> stream.
We write it as a protobuf.</div>
@@ -1124,7 +1137,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>read</h4>
-<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.273">read</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a> in)
+<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.280">read</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a> in)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Populate this instance with what we find on the passed in <code>in</code> stream.
Can deserialize protobuf of old Writables format.</div>
@@ -1142,7 +1155,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>parseWritable</h4>
-<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.309">parseWritable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a> in)
+<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.316">parseWritable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/io/DataInputStream.html?is-external=true" title="class or interface in java.io">DataInputStream</a> in)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Now parse the old Writable format. It was a list of Map entries. Each map entry was a
key and a value of a byte []. The old map format had a byte before each entry that held
@@ -1160,7 +1173,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>parsePB</h4>
-<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.330">parsePB</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos.FileInfoProto fip)</pre>
+<pre>void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.337">parsePB</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos.FileInfoProto fip)</pre>
<div class="block">Fill our map with content of the pb we read off disk</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -1174,7 +1187,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>initTrailerAndContext</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.337">initTrailerAndContext</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a> context,
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.344">initTrailerAndContext</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.html" title="class in org.apache.hadoop.hbase.io.hfile">ReaderContext</a> context,
org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
@@ -1189,7 +1202,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>initMetaAndIndex</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.356">initMetaAndIndex</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> reader)
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.364">initMetaAndIndex</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFile.Reader.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFile.Reader</a> reader)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">should be called after initTrailerAndContext</div>
<dl>
@@ -1204,7 +1217,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>createHFileContext</h4>
-<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.391">createHFileContext</a>(org.apache.hadoop.fs.Path path,
+<pre>private <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.400">createHFileContext</a>(org.apache.hadoop.fs.Path path,
<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> trailer,
org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -1220,7 +1233,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>loadMetaInfo</h4>
-<pre>private void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.417">loadMetaInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> blockIter,
+<pre>private void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.426">loadMetaInfo</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.BlockIterator.html" title="interface in org.apache.hadoop.hbase.io.hfile">HFileBlock.BlockIterator</a> blockIter,
<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> hfileContext)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
@@ -1235,7 +1248,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>checkFileVersion</h4>
-<pre>private void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.451">checkFileVersion</a>(org.apache.hadoop.fs.Path path)</pre>
+<pre>private void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.460">checkFileVersion</a>(org.apache.hadoop.fs.Path path)</pre>
<div class="block">File version check is a little sloppy. We read v3 files but can also read v2 files if their
content has been pb'd; files written with 0.98.</div>
</li>
@@ -1246,7 +1259,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>close</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.466">close</a>()</pre>
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.475">close</a>()</pre>
</li>
</ul>
<a name="getMajorVersion--">
@@ -1255,7 +1268,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getMajorVersion</h4>
-<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.472">getMajorVersion</a>()</pre>
+<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.481">getMajorVersion</a>()</pre>
</li>
</ul>
<a name="setTrailer-org.apache.hadoop.hbase.io.hfile.FixedFileTrailer-">
@@ -1264,7 +1277,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>setTrailer</h4>
-<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.476">setTrailer</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> trailer)</pre>
+<pre>public void <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.485">setTrailer</a>(<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> trailer)</pre>
</li>
</ul>
<a name="getTrailer--">
@@ -1273,7 +1286,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getTrailer</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.480">getTrailer</a>()</pre>
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/FixedFileTrailer.html" title="class in org.apache.hadoop.hbase.io.hfile">FixedFileTrailer</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.489">getTrailer</a>()</pre>
</li>
</ul>
<a name="getDataBlockIndexReader--">
@@ -1282,7 +1295,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getDataBlockIndexReader</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.484">getDataBlockIndexReader</a>()</pre>
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.CellBasedKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.CellBasedKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.493">getDataBlockIndexReader</a>()</pre>
</li>
</ul>
<a name="getMetaBlockIndexReader--">
@@ -1291,7 +1304,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getMetaBlockIndexReader</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.488">getMetaBlockIndexReader</a>()</pre>
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlockIndex.ByteArrayKeyBlockIndexReader.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlockIndex.ByteArrayKeyBlockIndexReader</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.497">getMetaBlockIndexReader</a>()</pre>
</li>
</ul>
<a name="getHFileContext--">
@@ -1300,7 +1313,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getHFileContext</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.492">getHFileContext</a>()</pre>
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileContext.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileContext</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.501">getHFileContext</a>()</pre>
</li>
</ul>
<a name="getLoadOnOpenBlocks--">
@@ -1309,7 +1322,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getLoadOnOpenBlocks</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.496">getLoadOnOpenBlocks</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.html" title="class in org.apache.hadoop.hbase.io.hfile">HFileBlock</a>> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.505">getLoadOnOpenBlocks</a>()</pre>
</li>
</ul>
<a name="getLastKeyCell--">
@@ -1318,7 +1331,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getLastKeyCell</h4>
-<pre>public <a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.500">getLastKeyCell</a>()</pre>
+<pre>public <a href="../../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.509">getLastKeyCell</a>()</pre>
</li>
</ul>
<a name="getAvgKeyLen--">
@@ -1327,7 +1340,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getAvgKeyLen</h4>
-<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.504">getAvgKeyLen</a>()</pre>
+<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.513">getAvgKeyLen</a>()</pre>
</li>
</ul>
<a name="getAvgValueLen--">
@@ -1336,7 +1349,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>getAvgValueLen</h4>
-<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.508">getAvgValueLen</a>()</pre>
+<pre>public int <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.517">getAvgValueLen</a>()</pre>
</li>
</ul>
<a name="shouldIncludeMemStoreTS--">
@@ -1345,7 +1358,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockList">
<li class="blockList">
<h4>shouldIncludeMemStoreTS</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.512">shouldIncludeMemStoreTS</a>()</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.521">shouldIncludeMemStoreTS</a>()</pre>
</li>
</ul>
<a name="isDecodeMemstoreTS--">
@@ -1354,7 +1367,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMa
<ul class="blockListLast">
<li class="blockList">
<h4>isDecodeMemstoreTS</h4>
-<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.516">isDecodeMemstoreTS</a>()</pre>
+<pre>public boolean <a href="../../../../../../src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html#line.525">isDecodeMemstoreTS</a>()</pre>
</li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
index f5a5d60..5d4f16c 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
@@ -301,10 +301,10 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockCacheFactory.ExternalBlockCaches.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockCacheFactory.ExternalBlockCaches</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/ReaderContext.ReaderType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">ReaderContext.ReaderType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</span></a></li>
<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.Writer.State.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">HFileBlock.Writer.State</span></a></li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
index 17eaa68..e0d239b 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -356,9 +356,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/CallEvent.Type.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">CallEvent.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/MetricsHBaseServerSourceFactoryImpl.SourceStorage.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">MetricsHBaseServerSourceFactoryImpl.SourceStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
index aeaab0b..4abc8b1 100644
--- a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
@@ -296,10 +296,10 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/CellCounter.CellCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">CellCounter.CellCounterMapper.Counters</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/SyncTable.SyncMapper.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">SyncTable.SyncMapper.Counter</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/TableSplit.Version.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">TableSplit.Version</span></a></li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
index f8add9f..5c89e3f 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
@@ -151,8 +151,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/ServerState.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">ServerState</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/TransitRegionStateProcedure.TransitionType.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">TransitRegionStateProcedure.TransitionType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/ServerState.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">ServerState</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
index 4aadbb8..39196e0 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
@@ -199,8 +199,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.LocalityType.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.LocalityType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
index 2b5a13a..09e1c49 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -339,12 +339,12 @@
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetaRegionLocationCache.ZNodeOpType.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetaRegionLocationCache.ZNodeOpType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMasterSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetricsMasterSourceFactoryImpl.FactoryStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">ServerManager.ServerLiveState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
index 8452d19..eb466df 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
@@ -222,9 +222,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ServerProcedureInterface.ServerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">ServerProcedureInterface.ServerOperationType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MetaProcedureInterface.MetaOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">MetaProcedureInterface.MetaOperationType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/TableProcedureInterface.TableOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">TableProcedureInterface.TableOperationType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ServerProcedureInterface.ServerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">ServerProcedureInterface.ServerOperationType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">PeerProcedureInterface.PeerOperationType</span></a></li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/package-tree.html b/devapidocs/org/apache/hadoop/hbase/package-tree.html
index 2dc5582..5e18d58 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -433,19 +433,19 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClientMetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClientMetaTableAccessor.QueryType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Size.Unit.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Size.Unit</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeyValue.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeyValue.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HConstants.OperationStatusCode.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HConstants.OperationStatusCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Coprocessor.State.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Coprocessor.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Size.Unit.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Size.Unit</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClientMetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClientMetaTableAccessor.QueryType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompatibilitySingletonFactory.SingletonStorage.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompatibilitySingletonFactory.SingletonStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
index 2cc5efe..4debb4e 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -217,10 +217,10 @@
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">StateMachineProcedure.Flow</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
index 2525a0e..7b64815 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
@@ -133,8 +133,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.PushType.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">WALProcedureStore.PushType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/ProcedureStoreTracker.DeleteState.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">ProcedureStoreTracker.DeleteState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.PushType.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">WALProcedureStore.PushType</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
index 9c84a1b..4fc5836 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
@@ -240,12 +240,12 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">SpaceViolationPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html b/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
index f596899..5996c38 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
@@ -142,46 +142,58 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#bulkLoadTimer">bulkLoadTimer</a></span></code> </td>
</tr>
<tr class="rowColor">
+<td class="colFirst"><code>protected static int</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#DEFAULT_SLOW_METRIC_TIME">DEFAULT_SLOW_METRIC_TIME</a></span></code> </td>
+</tr>
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#metricRegistry">metricRegistry</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#metricsTable">metricsTable</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#quotaSource">quotaSource</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#regionServerWrapper">regionServerWrapper</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>static boolean</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_DEFAULT">RS_ENABLE_TABLE_METRICS_DEFAULT</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#RS_ENABLE_TABLE_METRICS_KEY">RS_ENABLE_TABLE_METRICS_KEY</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverReadQueryMeter">serverReadQueryMeter</a></span></code> </td>
</tr>
-<tr class="altColor">
+<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverSource">serverSource</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#serverWriteQueryMeter">serverWriteQueryMeter</a></span></code> </td>
</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#SLOW_METRIC_TIME">SLOW_METRIC_TIME</a></span></code> </td>
+</tr>
<tr class="altColor">
+<td class="colFirst"><code>protected long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#slowMetricTime">slowMetricTime</a></span></code> </td>
+</tr>
+<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#tableMetrics">tableMetrics</a></span></code> </td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#userAggregate">userAggregate</a></span></code> </td>
</tr>
@@ -415,13 +427,26 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</dl>
</li>
</ul>
+<a name="SLOW_METRIC_TIME">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>SLOW_METRIC_TIME</h4>
+<pre>public static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.45">SLOW_METRIC_TIME</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.regionserver.MetricsRegionServer.SLOW_METRIC_TIME">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
<a name="serverSource">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>serverSource</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.45">serverSource</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.46">serverSource</a></pre>
</li>
</ul>
<a name="regionServerWrapper">
@@ -430,7 +455,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>regionServerWrapper</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.46">regionServerWrapper</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.47">regionServerWrapper</a></pre>
</li>
</ul>
<a name="tableMetrics">
@@ -439,7 +464,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>tableMetrics</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.47">tableMetrics</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.48">tableMetrics</a></pre>
</li>
</ul>
<a name="metricsTable">
@@ -448,7 +473,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>metricsTable</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.48">metricsTable</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.49">metricsTable</a></pre>
</li>
</ul>
<a name="quotaSource">
@@ -457,7 +482,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>quotaSource</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.49">quotaSource</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerQuotaSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.50">quotaSource</a></pre>
</li>
</ul>
<a name="userAggregate">
@@ -466,7 +491,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>userAggregate</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.50">userAggregate</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.51">userAggregate</a></pre>
</li>
</ul>
<a name="metricRegistry">
@@ -475,7 +500,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>metricRegistry</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.52">metricRegistry</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/MetricRegistry.html" title="interface in org.apache.hadoop.hbase.metrics">MetricRegistry</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.53">metricRegistry</a></pre>
</li>
</ul>
<a name="bulkLoadTimer">
@@ -484,7 +509,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>bulkLoadTimer</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Timer.html" title="interface in org.apache.hadoop.hbase.metrics">Timer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.53">bulkLoadTimer</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Timer.html" title="interface in org.apache.hadoop.hbase.metrics">Timer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.54">bulkLoadTimer</a></pre>
</li>
</ul>
<a name="serverReadQueryMeter">
@@ -493,16 +518,38 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>serverReadQueryMeter</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.54">serverReadQueryMeter</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.55">serverReadQueryMeter</a></pre>
</li>
</ul>
<a name="serverWriteQueryMeter">
<!-- -->
</a>
-<ul class="blockListLast">
+<ul class="blockList">
<li class="blockList">
<h4>serverWriteQueryMeter</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.55">serverWriteQueryMeter</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/metrics/Meter.html" title="interface in org.apache.hadoop.hbase.metrics">Meter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.56">serverWriteQueryMeter</a></pre>
+</li>
+</ul>
+<a name="slowMetricTime">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>slowMetricTime</h4>
+<pre>protected long <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.57">slowMetricTime</a></pre>
+</li>
+</ul>
+<a name="DEFAULT_SLOW_METRIC_TIME">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>DEFAULT_SLOW_METRIC_TIME</h4>
+<pre>protected static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.58">DEFAULT_SLOW_METRIC_TIME</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.regionserver.MetricsRegionServer.DEFAULT_SLOW_METRIC_TIME">Constant Field Values</a></dd>
+</dl>
</li>
</ul>
</li>
@@ -519,7 +566,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>MetricsRegionServer</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.57">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> regionServerWrapper,
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.60">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> regionServerWrapper,
org.apache.hadoop.conf.Configuration conf,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> metricsTable)</pre>
</li>
@@ -530,7 +577,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>MetricsRegionServer</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.76">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> regionServerWrapper,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.80">MetricsRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> regionServerWrapper,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> serverSource,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> tableMetrics,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsTable.html" title="class in org.apache.hadoop.hbase.regionserver">MetricsTable</a> metricsTable,
@@ -551,7 +598,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>createTableMetrics</h4>
-<pre>static <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.89">createTableMetrics</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>static <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver">RegionServerTableMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.93">createTableMetrics</a>(org.apache.hadoop.conf.Configuration conf)</pre>
<div class="block">Creates an instance of <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerTableMetrics.html" title="class in org.apache.hadoop.hbase.regionserver"><code>RegionServerTableMetrics</code></a> only if the feature is enabled.</div>
</li>
</ul>
@@ -561,7 +608,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>getMetricsSource</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.96">getMetricsSource</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.100">getMetricsSource</a>()</pre>
</li>
</ul>
<a name="getMetricsUserAggregate--">
@@ -570,7 +617,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>getMetricsUserAggregate</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.100">getMetricsUserAggregate</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsUserAggregate.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsUserAggregate</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.104">getMetricsUserAggregate</a>()</pre>
</li>
</ul>
<a name="getRegionServerWrapper--">
@@ -579,7 +626,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>getRegionServerWrapper</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.104">getRegionServerWrapper</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapper.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.108">getRegionServerWrapper</a>()</pre>
</li>
</ul>
<a name="updatePutBatch-org.apache.hadoop.hbase.TableName-long-">
@@ -588,7 +635,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updatePutBatch</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.108">updatePutBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.112">updatePutBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -598,7 +645,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updatePut</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.118">updatePut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.122">updatePut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -608,7 +655,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateDelete</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.126">updateDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.130">updateDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -618,7 +665,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateDeleteBatch</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.134">updateDeleteBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.138">updateDeleteBatch</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -628,7 +675,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateCheckAndDelete</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.144">updateCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.148">updateCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -638,7 +685,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateCheckAndPut</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.151">updateCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.155">updateCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -648,7 +695,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateCheckAndMutate</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.158">updateCheckAndMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.162">updateCheckAndMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -658,7 +705,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateGet</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.165">updateGet</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.169">updateGet</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -668,7 +715,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateIncrement</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.176">updateIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.180">updateIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -678,7 +725,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateAppend</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.187">updateAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.191">updateAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -688,7 +735,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateReplay</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.198">updateReplay</a>(long t)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.202">updateReplay</a>(long t)</pre>
</li>
</ul>
<a name="updateScanSize-org.apache.hadoop.hbase.TableName-long-">
@@ -697,7 +744,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateScanSize</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.203">updateScanSize</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.207">updateScanSize</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long scanSize)</pre>
</li>
</ul>
@@ -707,7 +754,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateScanTime</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.210">updateScanTime</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.214">updateScanTime</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long t)</pre>
</li>
</ul>
@@ -717,7 +764,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateSplitTime</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.218">updateSplitTime</a>(long t)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.222">updateSplitTime</a>(long t)</pre>
</li>
</ul>
<a name="incrSplitRequest--">
@@ -726,7 +773,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>incrSplitRequest</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.222">incrSplitRequest</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.226">incrSplitRequest</a>()</pre>
</li>
</ul>
<a name="incrSplitSuccess--">
@@ -735,7 +782,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>incrSplitSuccess</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.226">incrSplitSuccess</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.230">incrSplitSuccess</a>()</pre>
</li>
</ul>
<a name="updateFlush-java.lang.String-long-long-long-">
@@ -744,7 +791,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateFlush</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.230">updateFlush</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> table,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.234">updateFlush</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> table,
long t,
long memstoreSize,
long fileSize)</pre>
@@ -756,7 +803,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateCompaction</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.243">updateCompaction</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> table,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.247">updateCompaction</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> table,
boolean isMajor,
long t,
int inputFileCount,
@@ -771,7 +818,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateBulkLoad</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.260">updateBulkLoad</a>(long millis)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.264">updateBulkLoad</a>(long millis)</pre>
</li>
</ul>
<a name="incrementNumRegionSizeReportsSent-long-">
@@ -780,7 +827,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>incrementNumRegionSizeReportsSent</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.267">incrementNumRegionSizeReportsSent</a>(long numReportsSent)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.271">incrementNumRegionSizeReportsSent</a>(long numReportsSent)</pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html#incrementNumRegionSizeReportsSent-long-"><code>MetricsRegionServerQuotaSource.incrementNumRegionSizeReportsSent(long)</code></a></dd>
@@ -793,7 +840,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>incrementRegionSizeReportingChoreTime</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.274">incrementRegionSizeReportingChoreTime</a>(long time)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.278">incrementRegionSizeReportingChoreTime</a>(long time)</pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerQuotaSource.html#incrementRegionSizeReportingChoreTime-long-"><code>MetricsRegionServerQuotaSource.incrementRegionSizeReportingChoreTime(long)</code></a></dd>
@@ -806,7 +853,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateReadQueryMeter</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.278">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.282">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long count)</pre>
</li>
</ul>
@@ -816,7 +863,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateReadQueryMeter</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.285">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.289">updateReadQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn)</pre>
</li>
</ul>
<a name="updateWriteQueryMeter-org.apache.hadoop.hbase.TableName-long-">
@@ -825,7 +872,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>updateWriteQueryMeter</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.292">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.296">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn,
long count)</pre>
</li>
</ul>
@@ -835,7 +882,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>updateWriteQueryMeter</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.299">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html#line.303">updateWriteQueryMeter</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tn)</pre>
</li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
index 5ff38e2..ddb0c5f 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html
@@ -300,7 +300,7 @@ the order they are declared.</div>
<ul class="blockList">
<li class="blockList">
<h4>values</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.88">values</a>()</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.89">values</a>()</pre>
<div class="block">Returns an array containing the constants of this enum type, in
the order they are declared. This method may be used to iterate
over the constants as follows:
@@ -320,7 +320,7 @@ for (ScannerContext.LimitScope c : ScannerContext.LimitScope.values())
<ul class="blockList">
<li class="blockList">
<h4>valueOf</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.88">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.LimitScope</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html#line.89">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
<div class="block">Returns the enum constant of this type with the specified name.
The string must match <i>exactly</i> an identifier used to declare an
enum constant in this type. (Extraneous whitespace characters are
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
index 43bd1f4..1fa8a69 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html
@@ -372,7 +372,7 @@ the order they are declared.</div>
<ul class="blockList">
<li class="blockList">
<h4>values</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.88">values</a>()</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.89">values</a>()</pre>
<div class="block">Returns an array containing the constants of this enum type, in
the order they are declared. This method may be used to iterate
over the constants as follows:
@@ -392,7 +392,7 @@ for (ScannerContext.NextState c : ScannerContext.NextState.values())
<ul class="blockList">
<li class="blockList">
<h4>valueOf</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.88">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver">ScannerContext.NextState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html#line.89">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
<div class="block">Returns the enum constant of this type with the specified name.
The string must match <i>exactly</i> an identifier used to declare an
enum constant in this type. (Extraneous whitespace characters are
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
index 5363cef..4454e11 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -732,20 +732,20 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MetricsRegionServerSourceFactoryImpl.FactoryStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MemStoreCompactionStrategy.Action.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MemStoreCompactionStrategy.Action</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TimeRangeTracker.Type.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TimeRangeTracker.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegion.FlushResult.Result.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">HRegion.FlushResult.Result</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">FlushType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
index bd7348f..ba24945 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
@@ -130,9 +130,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.MatchCode.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">ScanQueryMatcher.MatchCode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/DeleteTracker.DeleteResult.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">DeleteTracker.DeleteResult</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
index 2dc717e..e12604b 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
@@ -247,10 +247,10 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/RingBufferTruck.Type.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">RingBufferTruck.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.RollRequestReason.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">WALActionsListener.RollRequestReason</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
index 57a9d42..f3a4541 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
@@ -175,8 +175,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">SyncReplicationState</span></a></li>
<li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeer.PeerState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">ReplicationPeer.PeerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.replication.<a href="../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication"><span class="typeNameLink">SyncReplicationState</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
index 072a22b..5a0ed3b 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
@@ -162,12 +162,12 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Action.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Action</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/SnapshotScannerHDFSAclHelper.HDFSAclOperation.OperationType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">SnapshotScannerHDFSAclHelper.HDFSAclOperation.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/SnapshotScannerHDFSAclHelper.HDFSAclOperation.AclType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">SnapshotScannerHDFSAclHelper.HDFSAclOperation.AclType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
index 76d4bcb..c060011 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
@@ -189,9 +189,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslUtil.QualityOfProtection</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslStatus.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslStatus</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/AuthMethod.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">AuthMethod</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslUtil.QualityOfProtection</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
index 60fa9ee..1cc1670 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
@@ -211,9 +211,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ImplType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ImplType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/MetricsThriftServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">MetricsThriftServerSourceFactoryImpl.FactoryStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
index 0e8f092..cc09fc4 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1850">HBaseFsck.CheckRegionConsistencyWorkItem</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1851">HBaseFsck.CheckRegionConsistencyWorkItem</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>></pre>
</li>
@@ -211,7 +211,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>key</h4>
-<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1851">key</a></pre>
+<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1852">key</a></pre>
</li>
</ul>
<a name="hbi">
@@ -220,7 +220,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>hbi</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1852">hbi</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1853">hbi</a></pre>
</li>
</ul>
</li>
@@ -237,7 +237,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>CheckRegionConsistencyWorkItem</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1854">CheckRegionConsistencyWorkItem</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> key,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1855">CheckRegionConsistencyWorkItem</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> key,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi)</pre>
</li>
</ul>
@@ -255,7 +255,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>call</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1860">call</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1861">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
index b52179f..7995d1c 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.406">HBaseFsck.FileLockCallable</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.407">HBaseFsck.FileLockCallable</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><org.apache.hadoop.fs.FSDataOutputStream></pre>
</li>
@@ -225,7 +225,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>retryCounter</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.407">retryCounter</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.408">retryCounter</a></pre>
</li>
</ul>
<a name="conf">
@@ -234,7 +234,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>conf</h4>
-<pre>private final org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.408">conf</a></pre>
+<pre>private final org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.409">conf</a></pre>
</li>
</ul>
<a name="hbckLockPath">
@@ -243,7 +243,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>hbckLockPath</h4>
-<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.409">hbckLockPath</a></pre>
+<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.410">hbckLockPath</a></pre>
</li>
</ul>
</li>
@@ -260,7 +260,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>FileLockCallable</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.411">FileLockCallable</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.412">FileLockCallable</a>(org.apache.hadoop.conf.Configuration conf,
<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> retryCounter)</pre>
</li>
</ul>
@@ -278,7 +278,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>getHbckLockPath</h4>
-<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.419">getHbckLockPath</a>()</pre>
+<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.420">getHbckLockPath</a>()</pre>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>Will be <code>null</code> unless you call <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#call--"><code>call()</code></a></dd>
@@ -291,7 +291,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>call</h4>
-<pre>public org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.424">call</a>()
+<pre>public org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.425">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -307,7 +307,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>createFileWithRetries</h4>
-<pre>private org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.449">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>private org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.450">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path hbckLockFilePath,
org.apache.hadoop.fs.permission.FsPermission defaultPerms)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
index 5e953c4..bc4b681 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3613">HBaseFsck.HBaseFsckTool</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3614">HBaseFsck.HBaseFsckTool</a>
extends org.apache.hadoop.conf.Configured
implements org.apache.hadoop.util.Tool</pre>
<div class="block">This is a Tool wrapper that gathers -Dxxx=yyy configuration settings from the command line.</div>
@@ -207,7 +207,7 @@ implements org.apache.hadoop.util.Tool</pre>
<ul class="blockListLast">
<li class="blockList">
<h4>HBaseFsckTool</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3614">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3615">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration conf)</pre>
</li>
</ul>
</li>
@@ -224,7 +224,7 @@ implements org.apache.hadoop.util.Tool</pre>
<ul class="blockListLast">
<li class="blockList">
<h4>run</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3616">run</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3617">run</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
index f388e15..2e92ec5 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2878">HBaseFsck.PrintingErrorReporter</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2879">HBaseFsck.PrintingErrorReporter</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></pre>
</li>
@@ -301,7 +301,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>errorCount</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2879">errorCount</a></pre>
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2880">errorCount</a></pre>
</li>
</ul>
<a name="showProgress">
@@ -310,7 +310,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>showProgress</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2880">showProgress</a></pre>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2881">showProgress</a></pre>
</li>
</ul>
<a name="progressThreshold">
@@ -319,7 +319,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>progressThreshold</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2882">progressThreshold</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2883">progressThreshold</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.util.HBaseFsck.PrintingErrorReporter.progressThreshold">Constant Field Values</a></dd>
@@ -332,7 +332,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>errorTables</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2884">errorTables</a></pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2885">errorTables</a></pre>
</li>
</ul>
<a name="errorList">
@@ -341,7 +341,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockListLast">
<li class="blockList">
<h4>errorList</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2887">errorList</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2888">errorList</a></pre>
</li>
</ul>
</li>
@@ -358,7 +358,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockListLast">
<li class="blockList">
<h4>PrintingErrorReporter</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2878">PrintingErrorReporter</a>()</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2879">PrintingErrorReporter</a>()</pre>
</li>
</ul>
</li>
@@ -375,7 +375,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>clear</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2890">clear</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2891">clear</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#clear--">clear</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -388,7 +388,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>reportError</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2897">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2898">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -402,7 +402,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>reportError</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2912">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2913">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a> table)</pre>
<dl>
@@ -417,7 +417,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>reportError</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2919">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2920">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a> table,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> info)</pre>
@@ -433,7 +433,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>reportError</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2927">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2928">reportError</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a> errorCode,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a> table,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> info1,
@@ -450,7 +450,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>reportError</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2936">reportError</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2937">reportError</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#reportError-java.lang.String-">reportError</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -463,7 +463,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>report</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2946">report</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2947">report</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
<div class="block">Report error information, but do not increment the error count. Intended for cases
where the actual error would have been reported previously.</div>
<dl>
@@ -480,7 +480,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>summarize</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2954">summarize</a>()</pre>
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2955">summarize</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#summarize--">summarize</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -493,7 +493,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>getErrorList</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2967">getErrorList</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/ArrayList.html?is-external=true" title="class or interface in java.util">ArrayList</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2968">getErrorList</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#getErrorList--">getErrorList</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -506,7 +506,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>print</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2972">print</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2973">print</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#print-java.lang.String-">print</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -519,7 +519,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>tableHasErrors</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2979">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a> table)</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2980">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a> table)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#tableHasErrors-org.apache.hadoop.hbase.util.HbckTableInfo-">tableHasErrors</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -532,7 +532,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>resetErrors</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2984">resetErrors</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2985">resetErrors</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#resetErrors--">resetErrors</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -545,7 +545,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockList">
<li class="blockList">
<h4>detail</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2989">detail</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2990">detail</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> message)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#detail-java.lang.String-">detail</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
@@ -558,7 +558,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporte
<ul class="blockListLast">
<li class="blockList">
<h4>progress</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2997">progress</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2998">progress</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html#progress--">progress</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a></code></dd>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
index 6fc1a1a..2ecfec2 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html
@@ -113,7 +113,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.872">HBaseFsck.RegionBoundariesInformation</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.873">HBaseFsck.RegionBoundariesInformation</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
</li>
</ul>
@@ -219,7 +219,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>regionName</h4>
-<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">regionName</a></pre>
+<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">regionName</a></pre>
</li>
</ul>
<a name="metaFirstKey">
@@ -228,7 +228,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>metaFirstKey</h4>
-<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">metaFirstKey</a></pre>
+<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">metaFirstKey</a></pre>
</li>
</ul>
<a name="metaLastKey">
@@ -237,7 +237,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>metaLastKey</h4>
-<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">metaLastKey</a></pre>
+<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.876">metaLastKey</a></pre>
</li>
</ul>
<a name="storesFirstKey">
@@ -246,7 +246,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>storesFirstKey</h4>
-<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.876">storesFirstKey</a></pre>
+<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.877">storesFirstKey</a></pre>
</li>
</ul>
<a name="storesLastKey">
@@ -255,7 +255,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>storesLastKey</h4>
-<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.877">storesLastKey</a></pre>
+<pre>public byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.878">storesLastKey</a></pre>
</li>
</ul>
</li>
@@ -272,7 +272,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>RegionBoundariesInformation</h4>
-<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.872">RegionBoundariesInformation</a>()</pre>
+<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">RegionBoundariesInformation</a>()</pre>
</li>
</ul>
</li>
@@ -289,7 +289,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>toString</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.879">toString</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.880">toString</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#toString--" title="class or interface in java.lang">toString</a></code> in class <code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
index 4c5ca4cc..2f9447b 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3072">HBaseFsck.WorkItemHdfsDir</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3073">HBaseFsck.WorkItemHdfsDir</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>></pre>
<div class="block">Contact hdfs and get all information about specified table directory into
@@ -218,7 +218,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>tableDir</h4>
-<pre>private org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3073">tableDir</a></pre>
+<pre>private org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3074">tableDir</a></pre>
</li>
</ul>
<a name="errors">
@@ -227,7 +227,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>errors</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3074">errors</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3075">errors</a></pre>
</li>
</ul>
<a name="fs">
@@ -236,7 +236,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>fs</h4>
-<pre>private org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3075">fs</a></pre>
+<pre>private org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3076">fs</a></pre>
</li>
</ul>
</li>
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>WorkItemHdfsDir</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3077">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3078">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem fs,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> errors,
org.apache.hadoop.fs.FileStatus status)</pre>
</li>
@@ -272,7 +272,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>call</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3084">call</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3085">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutionException.html?is-external=true" title="class or interface in java.util.concurrent">ExecutionException</a></pre>
<dl>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
index 429ad98..1fe8acf 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3191">HBaseFsck.WorkItemHdfsRegionInfo</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3192">HBaseFsck.WorkItemHdfsRegionInfo</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>></pre>
<div class="block">Contact hdfs and get all information about specified table directory into
@@ -218,7 +218,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>hbi</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3192">hbi</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3193">hbi</a></pre>
</li>
</ul>
<a name="hbck">
@@ -227,7 +227,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>hbck</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3193">hbck</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3194">hbck</a></pre>
</li>
</ul>
<a name="errors">
@@ -236,7 +236,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>errors</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3194">errors</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3195">errors</a></pre>
</li>
</ul>
</li>
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>WorkItemHdfsRegionInfo</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3196">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3197">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi,
<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> hbck,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> errors)</pre>
</li>
@@ -272,7 +272,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>call</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3203">call</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3204">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
index 209d18c..19f0cd2 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2565">HBaseFsck.WorkItemOverlapMerge</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2566">HBaseFsck.WorkItemOverlapMerge</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>></pre>
</li>
@@ -211,7 +211,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>handler</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2566">handler</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2567">handler</a></pre>
</li>
</ul>
<a name="overlapgroup">
@@ -220,7 +220,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>overlapgroup</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2567">overlapgroup</a></pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2568">overlapgroup</a></pre>
</li>
</ul>
</li>
@@ -237,7 +237,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>WorkItemOverlapMerge</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2569">WorkItemOverlapMerge</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> overlapgroup,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2570">WorkItemOverlapMerge</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> overlapgroup,
<a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a> handler)</pre>
</li>
</ul>
@@ -255,7 +255,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>call</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2576">call</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2577">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
index ca1bb2d..1fdd1b4 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3010">HBaseFsck.WorkItemRegion</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3011">HBaseFsck.WorkItemRegion</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Callable.html?is-external=true" title="class or interface in java.util.concurrent">Callable</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a>></pre>
<div class="block">Contact a region server and get all information from it</div>
@@ -226,7 +226,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>hbck</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3011">hbck</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3012">hbck</a></pre>
</li>
</ul>
<a name="rsinfo">
@@ -235,7 +235,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>rsinfo</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3012">rsinfo</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3013">rsinfo</a></pre>
</li>
</ul>
<a name="errors">
@@ -244,7 +244,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>errors</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3013">errors</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3014">errors</a></pre>
</li>
</ul>
<a name="connection">
@@ -253,7 +253,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>connection</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3014">connection</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3015">connection</a></pre>
</li>
</ul>
</li>
@@ -270,7 +270,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>WorkItemRegion</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3016">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> hbck,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3017">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> hbck,
<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> info,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> errors,
<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection)</pre>
@@ -290,7 +290,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockList">
<li class="blockList">
<h4>call</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3025">call</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Void.html?is-external=true" title="class or interface in java.lang">Void</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3026">call</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -306,7 +306,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurre
<ul class="blockListLast">
<li class="blockList">
<h4>filterRegions</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3056">filterRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Lis [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3057">filterRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Lis [...]
</li>
</ul>
</li>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
index ef96ea4..8ba46ca 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.html
@@ -124,7 +124,7 @@ var activeTableTab = "activeTableTab";
<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Deprecated.html?is-external=true" title="class or interface in java.lang">@Deprecated</a>
@InterfaceAudience.LimitedPrivate(value="Tools")
@InterfaceStability.Evolving
-public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.202">HBaseFsck</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.203">HBaseFsck</a>
extends org.apache.hadoop.conf.Configured
implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.html?is-external=true" title="class or interface in java.io">Closeable</a></pre>
<div class="block">HBaseFsck (hbck) is a tool for checking and repairing region consistency and
@@ -1675,7 +1675,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_TIME_LAG</h4>
-<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.203">DEFAULT_TIME_LAG</a></pre>
+<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_TIME_LAG</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1689,7 +1689,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_SLEEP_BEFORE_RERUN</h4>
-<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
+<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1703,7 +1703,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>MAX_NUM_THREADS</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">MAX_NUM_THREADS</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">MAX_NUM_THREADS</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1717,7 +1717,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>rsSupportsOffline</h4>
-<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">rsSupportsOffline</a></pre>
+<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">rsSupportsOffline</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1727,7 +1727,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_OVERLAPS_TO_SIDELINE</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1741,7 +1741,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_MAX_MERGE</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_MAX_MERGE</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.209">DEFAULT_MAX_MERGE</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1756,7 +1756,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
<li class="blockList">
<h4>HBCK_LOCK_FILE</h4>
<pre>@InterfaceAudience.Private
-public static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.215">HBCK_LOCK_FILE</a></pre>
+public static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.216">HBCK_LOCK_FILE</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Here is where hbase-1.x used to default the lock for hbck1.
It puts in place a lock when it goes to write/make changes.</div>
@@ -1772,7 +1772,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_MAX_LOCK_FILE_ATTEMPTS</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.216">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1786,7 +1786,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1800,7 +1800,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.219">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1814,7 +1814,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_WAIT_FOR_LOCK_TIMEOUT</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.223">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1828,7 +1828,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1842,7 +1842,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1856,7 +1856,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.227">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -1870,7 +1870,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>LOG</h4>
-<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.231">LOG</a></pre>
+<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.232">LOG</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Internal resources</div>
</li>
@@ -1881,7 +1881,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>status</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.232">status</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.233">status</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1891,7 +1891,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>connection</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.233">connection</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.234">connection</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1901,7 +1901,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>admin</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.234">admin</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.235">admin</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1911,7 +1911,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>meta</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.235">meta</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.236">meta</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1921,7 +1921,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>executor</h4>
-<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.237">executor</a></pre>
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.238">executor</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1931,7 +1931,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>startMillis</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.238">startMillis</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.239">startMillis</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1941,7 +1941,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>hfcc</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.239">hfcc</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.240">hfcc</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1951,7 +1951,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>retcode</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.240">retcode</a></pre>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">retcode</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1961,7 +1961,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>HBCK_LOCK_PATH</h4>
-<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">HBCK_LOCK_PATH</a></pre>
+<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">HBCK_LOCK_PATH</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1971,7 +1971,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>hbckOutFd</h4>
-<pre>private org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">hbckOutFd</a></pre>
+<pre>private org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.243">hbckOutFd</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1981,7 +1981,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>hbckLockCleanup</h4>
-<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.246">hbckLockCleanup</a></pre>
+<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.247">hbckLockCleanup</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -1991,7 +1991,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>unsupportedOptionsInV2</h4>
-<pre>private static final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.249">unsupportedOptionsInV2</a></pre>
+<pre>private static final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.250">unsupportedOptionsInV2</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2001,7 +2001,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>details</h4>
-<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.257">details</a></pre>
+<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">details</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Options</div>
</li>
@@ -2012,7 +2012,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>timelag</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">timelag</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">timelag</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2022,7 +2022,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>forceExclusive</h4>
-<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">forceExclusive</a></pre>
+<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">forceExclusive</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2032,7 +2032,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixAssignments</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">fixAssignments</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixAssignments</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2042,7 +2042,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixMeta</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixMeta</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">fixMeta</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2052,7 +2052,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>checkHdfs</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">checkHdfs</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">checkHdfs</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2062,7 +2062,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixHdfsHoles</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">fixHdfsHoles</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsHoles</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2072,7 +2072,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixHdfsOverlaps</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsOverlaps</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOverlaps</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2082,7 +2082,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixHdfsOrphans</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOrphans</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixHdfsOrphans</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2092,7 +2092,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixTableOrphans</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixTableOrphans</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixTableOrphans</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2102,7 +2102,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixVersionFile</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixVersionFile</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixVersionFile</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2112,7 +2112,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixSplitParents</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixSplitParents</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">fixSplitParents</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2122,7 +2122,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>removeParents</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">removeParents</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">removeParents</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2132,7 +2132,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixReferenceFiles</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">fixReferenceFiles</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixReferenceFiles</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2142,7 +2142,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixHFileLinks</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixHFileLinks</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixHFileLinks</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2152,7 +2152,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixEmptyMetaCells</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixEmptyMetaCells</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixEmptyMetaCells</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2162,7 +2162,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixReplication</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixReplication</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">fixReplication</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2172,7 +2172,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>cleanReplicationBarrier</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">cleanReplicationBarrier</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">cleanReplicationBarrier</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2182,7 +2182,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixAny</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">fixAny</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.276">fixAny</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2192,7 +2192,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>tablesIncluded</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.279">tablesIncluded</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.280">tablesIncluded</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2202,7 +2202,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>cleanReplicationBarrierTable</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.280">cleanReplicationBarrierTable</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.281">cleanReplicationBarrierTable</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2212,7 +2212,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>maxMerge</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.281">maxMerge</a></pre>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.282">maxMerge</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2222,7 +2222,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>maxOverlapsToSideline</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.283">maxOverlapsToSideline</a></pre>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">maxOverlapsToSideline</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2232,7 +2232,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>sidelineBigOverlaps</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">sidelineBigOverlaps</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineBigOverlaps</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2242,7 +2242,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>sidelineDir</h4>
-<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineDir</a></pre>
+<pre>private org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.286">sidelineDir</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2252,7 +2252,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>rerun</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.287">rerun</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">rerun</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2262,7 +2262,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>summary</h4>
-<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">summary</a></pre>
+<pre>private static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">summary</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2272,7 +2272,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>checkMetaOnly</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">checkMetaOnly</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkMetaOnly</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2282,7 +2282,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>checkRegionBoundaries</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkRegionBoundaries</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">checkRegionBoundaries</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2292,7 +2292,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>ignorePreCheckPermission</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">ignorePreCheckPermission</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.292">ignorePreCheckPermission</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2302,7 +2302,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>errors</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.296">errors</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.297">errors</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">State</div>
</li>
@@ -2313,7 +2313,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>fixes</h4>
-<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.297">fixes</a></pre>
+<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.298">fixes</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2323,7 +2323,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>regionInfoMap</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/TreeMap.html?is-external=true" title="class or interface in java.util">TreeMap</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apach [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/TreeMap.html?is-external=true" title="class or interface in java.util">TreeMap</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apach [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">This map contains the state of all hbck items. It maps from encoded region
name to HbckRegionInfo structure. The information contained in HbckRegionInfo is used
@@ -2336,7 +2336,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>emptyRegionInfoQualifiers</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.306">emptyRegionInfoQualifiers</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.307">emptyRegionInfoQualifiers</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2346,7 +2346,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>tablesInfo</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">This map from Tablename -> TableInfo contains the structures necessary to
detect table consistency problems (holes, dupes, overlaps). It is sorted
@@ -2364,7 +2364,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>orphanHdfsDirs</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.323">orphanHdfsDirs</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.324">orphanHdfsDirs</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">When initially looking at HDFS, we attempt to find any orphaned data.</div>
</li>
@@ -2375,7 +2375,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>orphanTableDirs</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2385,7 +2385,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>tableStates</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/client/TableState.html" title="class in org.apache.hadoop.hbase.client">TableState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/client/TableState.html" title="class in org.apache.hadoop.hbase.client">TableState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2395,7 +2395,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>lockFileRetryCounterFactory</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.327">lockFileRetryCounterFactory</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.328">lockFileRetryCounterFactory</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2405,7 +2405,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>createZNodeRetryCounterFactory</h4>
-<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.328">createZNodeRetryCounterFactory</a></pre>
+<pre>private final <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.329">createZNodeRetryCounterFactory</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2415,7 +2415,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>skippedRegions</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2425,7 +2425,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>zkw</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.332">zkw</a></pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.333">zkw</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2435,7 +2435,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>hbckEphemeralNodePath</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.333">hbckEphemeralNodePath</a></pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.334">hbckEphemeralNodePath</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2445,7 +2445,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockListLast">
<li class="blockList">
<h4>hbckZodeCreated</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.334">hbckZodeCreated</a></pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.335">hbckZodeCreated</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2463,7 +2463,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>HBaseFsck</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.343">HBaseFsck</a>(org.apache.hadoop.conf.Configuration conf)
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.344">HBaseFsck</a>(org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/ClassNotFoundException.html?is-external=true" title="class or interface in java.lang">ClassNotFoundException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2485,7 +2485,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockListLast">
<li class="blockList">
<h4>HBaseFsck</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.364">HBaseFsck</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.365">HBaseFsck</a>(org.apache.hadoop.conf.Configuration conf,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> exec)
throws <a href="../../../../../org/apache/hadoop/hbase/MasterNotRunningException.html" title="class in org.apache.hadoop.hbase">MasterNotRunningException</a>,
<a href="../../../../../org/apache/hadoop/hbase/ZooKeeperConnectionException.html" title="class in org.apache.hadoop.hbase">ZooKeeperConnectionException</a>,
@@ -2518,7 +2518,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>createThreadPool</h4>
-<pre>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.347">createThreadPool</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.348">createThreadPool</a>(org.apache.hadoop.conf.Configuration conf)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2528,7 +2528,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>createLockRetryCounterFactory</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.377">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.378">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration conf)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
@@ -2542,7 +2542,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<ul class="blockList">
<li class="blockList">
<h4>createZnodeRetryCounterFactory</h4>
-<pre>private static <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.389">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>private static <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.390">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration conf)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
@@ -2557,7 +2557,7 @@ public static final <a href="https://docs.oracle.com/javase/8/docs/api/java
<li class="blockList">
<h4>getTmpDir</h4>
<pre>@InterfaceAudience.Private
-public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.402">getTmpDir</a>(org.apache.hadoop.conf.Configuration conf)
+public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.403">getTmpDir</a>(org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -2574,7 +2574,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkAndMarkRunningHbck</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a><org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.483">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a><org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.484">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration conf,
<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a> retryCounter)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2593,7 +2593,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>unlockHbck</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.509">unlockHbck</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.510">unlockHbck</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2603,7 +2603,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>connect</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.540">connect</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.541">connect</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">To repair region consistency, one must call connect() in order to repair
@@ -2620,7 +2620,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadDeployedRegions</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.586">loadDeployedRegions</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.587">loadDeployedRegions</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2638,7 +2638,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>clearState</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.636">clearState</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.637">clearState</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Clear the current state of hbck.</div>
</li>
@@ -2649,7 +2649,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>offlineHdfsIntegrityRepair</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.653">offlineHdfsIntegrityRepair</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.654">offlineHdfsIntegrityRepair</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2669,7 +2669,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>onlineConsistencyRepair</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.689">onlineConsistencyRepair</a>()
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.690">onlineConsistencyRepair</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -2694,7 +2694,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setMasterInMaintenanceMode</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.755">setMasterInMaintenanceMode</a>()
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.756">setMasterInMaintenanceMode</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">This method maintains an ephemeral znode. If the creation fails we return false or throw
@@ -2713,7 +2713,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>cleanupHbckZnode</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.786">cleanupHbckZnode</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.787">cleanupHbckZnode</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2723,7 +2723,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>onlineHbck</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.804">onlineHbck</a>()
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.805">onlineHbck</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
@@ -2747,7 +2747,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>keyOnly</h4>
-<pre>public static byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.845">keyOnly</a>(byte[] b)</pre>
+<pre>public static byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.846">keyOnly</a>(byte[] b)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2757,7 +2757,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>close</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.855">close</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.856">close</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -2776,7 +2776,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkRegionBoundaries</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.888">checkRegionBoundaries</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.889">checkRegionBoundaries</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2786,7 +2786,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>adoptHdfsOrphans</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.973">adoptHdfsOrphans</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> orphanHdfsDirs)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.974">adoptHdfsOrphans</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>> orphanHdfsDirs)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Iterates through the list of all orphan/invalid regiondirs.</div>
@@ -2802,7 +2802,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>adoptHdfsOrphan</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.990">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.991">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Orphaned regions are regions without a .regioninfo file in them. We "adopt"
@@ -2824,7 +2824,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>restoreHdfsIntegrity</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1082">restoreHdfsIntegrity</a>()
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1083">restoreHdfsIntegrity</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2847,7 +2847,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>offlineReferenceFileRepair</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1130">offlineReferenceFileRepair</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1131">offlineReferenceFileRepair</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2870,7 +2870,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>offlineHLinkFileRepair</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1184">offlineHLinkFileRepair</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1185">offlineHLinkFileRepair</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2890,7 +2890,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>sidelineFile</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1231">sidelineFile</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1232">sidelineFile</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path hbaseRoot,
org.apache.hadoop.fs.Path path)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -2907,7 +2907,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>reportEmptyMetaCells</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1249">reportEmptyMetaCells</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1250">reportEmptyMetaCells</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">TODO -- need to add tests for this.</div>
</li>
@@ -2918,7 +2918,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>reportTablesInFlux</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1262">reportTablesInFlux</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1263">reportTablesInFlux</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">TODO -- need to add tests for this.</div>
</li>
@@ -2929,7 +2929,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getErrors</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1279">getErrors</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1280">getErrors</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -2939,7 +2939,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadHdfsRegionInfos</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2957,7 +2957,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getColumnFamilyList</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1372">getColumnFamilyList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1373">getColumnFamilyList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is [...]
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -2979,7 +2979,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>fabricateTableInfo</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1391">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a> fstd,
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1392">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a> fstd,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>> columns)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -3000,7 +3000,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>fixEmptyMetaCells</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1406">fixEmptyMetaCells</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1407">fixEmptyMetaCells</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">To fix the empty REGIONINFO_QUALIFIER rows from hbase:meta <br></div>
@@ -3016,7 +3016,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>fixOrphanTables</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1426">fixOrphanTables</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1427">fixOrphanTables</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">To fix orphan table by creating a .tableinfo file under tableDir <br>
@@ -3037,7 +3037,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>logParallelMerge</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1482">logParallelMerge</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1483">logParallelMerge</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Log an appropriate message about whether or not overlapping merges are computed in parallel.</div>
</li>
@@ -3048,7 +3048,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkHdfsIntegrity</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
boolean fixOverlaps)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3064,7 +3064,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getSidelineDir</h4>
-<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1512">getSidelineDir</a>()
+<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1513">getSidelineDir</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -3079,7 +3079,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1525">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1526">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem fs,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3096,7 +3096,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1537">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1538">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem fs,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> parentDir,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -3119,7 +3119,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadTableStates</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1612">loadTableStates</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1613">loadTableStates</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Load the list of disabled tables in ZK into local set.</div>
@@ -3136,7 +3136,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>isTableDisabled</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1626">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1627">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Check if the specified region's table is disabled.</div>
<dl>
@@ -3151,7 +3151,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadHdfsRegionDirs</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1636">loadHdfsRegionDirs</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1637">loadHdfsRegionDirs</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3170,7 +3170,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>recordMetaRegion</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1694">recordMetaRegion</a>()
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1695">recordMetaRegion</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Record the location of the hbase:meta region as found in ZooKeeper.</div>
@@ -3186,7 +3186,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>createZooKeeperWatcher</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1730">createZooKeeperWatcher</a>()
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1731">createZooKeeperWatcher</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -3201,7 +3201,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>processRegionServers</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1751">processRegionServers</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>> regionServerList)
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1752">processRegionServers</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html?is-external=true" title="class or interface in java.util">Collection</a><<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>> regionServerList)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3221,7 +3221,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkAndFixConsistency</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1779">checkAndFixConsistency</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1780">checkAndFixConsistency</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3241,7 +3241,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkRegionConsistencyConcurrently</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1824">checkRegionConsistencyConcurrently</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>>&n [...]
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1825">checkRegionConsistencyConcurrently</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>>&n [...]
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3261,7 +3261,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>addSkippedRegion</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1878">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi)</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1879">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3271,7 +3271,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkAndFixTableStates</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1892">checkAndFixTableStates</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1893">checkAndFixTableStates</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Check and fix table states, assumes full info available:
@@ -3289,7 +3289,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>preCheckPermission</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1934">preCheckPermission</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1935">preCheckPermission</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -3304,7 +3304,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>deleteMetaRegion</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1960">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1961">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Deletes region from meta table</div>
@@ -3320,7 +3320,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>deleteMetaRegion</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1967">deleteMetaRegion</a>(byte[] metaKey)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1968">deleteMetaRegion</a>(byte[] metaKey)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Deletes region from meta table</div>
@@ -3336,7 +3336,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>resetSplitParent</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1976">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1977">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Reset the split parent region info in meta table</div>
@@ -3352,7 +3352,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>offline</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2001">offline</a>(byte[] regionName)
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2002">offline</a>(byte[] regionName)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">This backwards-compatibility wrapper for permanently offlining a region
@@ -3373,7 +3373,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>closeRegion</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2042">closeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2043">closeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3400,7 +3400,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>undeployRegions</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2090">undeployRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2091">undeployRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3417,7 +3417,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>undeployRegionsForHbi</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2111">undeployRegionsForHbi</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2112">undeployRegionsForHbi</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3434,7 +3434,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>tryAssignmentRepair</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2125">tryAssignmentRepair</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2126">tryAssignmentRepair</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> msg)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
@@ -3454,7 +3454,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkRegionConsistency</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2161">checkRegionConsistency</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> key,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2162">checkRegionConsistency</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> key,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hbi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
@@ -3475,7 +3475,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkIntegrity</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck [...]
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck [...]
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Checks tables integrity. Goes over all regions and scans the tables.
@@ -3493,7 +3493,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadTableInfosForTablesWithNoRegion</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2473">loadTableInfosForTablesWithNoRegion</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2474">loadTableInfosForTablesWithNoRegion</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Loads table info's for tables that may not have been included, since there are no
@@ -3510,7 +3510,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>mergeRegionDirs</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2493">mergeRegionDirs</a>(org.apache.hadoop.fs.Path targetRegionDir,
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2494">mergeRegionDirs</a>(org.apache.hadoop.fs.Path targetRegionDir,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> contained)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -3529,7 +3529,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getTables</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2591">getTables</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a> numSkipped)</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2592">getTables</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a> numSkipped)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Return a list of user-space table names whose metadata have not been
modified in the last few milliseconds specified by timelag
@@ -3550,7 +3550,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getTableDescriptors</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2612">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class i [...]
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2613">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class i [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3560,7 +3560,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getOrCreateInfo</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2629">getOrCreateInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2630">getOrCreateInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Gets the entry in regionInfo corresponding to the the given encoded
region name. If the region has not been seen yet, a new entry is added
@@ -3573,7 +3573,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkAndFixReplication</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2638">checkAndFixReplication</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2639">checkAndFixReplication</a>()
throws <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -3588,7 +3588,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>checkMetaRegion</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2657">checkMetaRegion</a>()
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2658">checkMetaRegion</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3611,7 +3611,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>unassignMetaReplica</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2712">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2713">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a> hi)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
org.apache.zookeeper.KeeperException</pre>
@@ -3630,7 +3630,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>assignMetaReplica</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2719">assignMetaReplica</a>(int replicaId)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2720">assignMetaReplica</a>(int replicaId)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
@@ -3649,7 +3649,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>loadMetaEntries</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2738">loadMetaEntries</a>()
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2739">loadMetaEntries</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Scan hbase:meta, adding all regions found to the regionInfo map.</div>
@@ -3665,7 +3665,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>printTableSummary</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2835">printTableSummary</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="clas [...]
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2836">printTableSummary</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/SortedMap.html?is-external=true" title="class or interface in java.util">SortedMap</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="clas [...]
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Prints summary of all tables found on the system.</div>
</li>
@@ -3676,7 +3676,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getErrorReporter</h4>
-<pre>static <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2870">getErrorReporter</a>(org.apache.hadoop.conf.Configuration conf)
+<pre>static <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2871">getErrorReporter</a>(org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/ClassNotFoundException.html?is-external=true" title="class or interface in java.lang">ClassNotFoundException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -3691,7 +3691,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setDisplayFullReport</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3234">setDisplayFullReport</a>()</pre>
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3235">setDisplayFullReport</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Display the full report from fsck. This displays all live and dead region
servers, and all known regions.</div>
@@ -3703,7 +3703,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldDisplayFullReport</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3238">shouldDisplayFullReport</a>()</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3239">shouldDisplayFullReport</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3713,7 +3713,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setForceExclusive</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3245">setForceExclusive</a>()</pre>
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3246">setForceExclusive</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Set exclusive mode.</div>
</li>
@@ -3724,7 +3724,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>isExclusive</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3252">isExclusive</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3253">isExclusive</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Only one instance of hbck can modify HBase at a time.</div>
</li>
@@ -3735,7 +3735,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setSummary</h4>
-<pre>static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3260">setSummary</a>()</pre>
+<pre>static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3261">setSummary</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Set summary mode.
Print only summary of the tables and status (OK or INCONSISTENT)</div>
@@ -3747,7 +3747,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setCheckMetaOnly</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3268">setCheckMetaOnly</a>()</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3269">setCheckMetaOnly</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Set hbase:meta check mode.
Print only info about hbase:meta table deployment/state</div>
@@ -3759,7 +3759,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setRegionBoundariesCheck</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3275">setRegionBoundariesCheck</a>()</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3276">setRegionBoundariesCheck</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Set region boundaries check mode.</div>
</li>
@@ -3770,7 +3770,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixReplication</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3282">setFixReplication</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3283">setFixReplication</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Set replication fix mode.</div>
</li>
@@ -3781,7 +3781,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setCleanReplicationBarrier</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3287">setCleanReplicationBarrier</a>(boolean shouldClean)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3288">setCleanReplicationBarrier</a>(boolean shouldClean)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3791,7 +3791,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setShouldRerun</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3297">setShouldRerun</a>()</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3298">setShouldRerun</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Check if we should rerun fsck again. This checks if we've tried to
fix something and we should rerun fsck tool again.
@@ -3805,7 +3805,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldRerun</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3301">shouldRerun</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3302">shouldRerun</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3815,7 +3815,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixAssignments</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3309">setFixAssignments</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3310">setFixAssignments</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Fix inconsistencies found by fsck. This should try to fix errors (if any)
found by fsck utility.</div>
@@ -3827,7 +3827,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixAssignments</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3314">shouldFixAssignments</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3315">shouldFixAssignments</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3837,7 +3837,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixMeta</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3318">setFixMeta</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3319">setFixMeta</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3847,7 +3847,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixMeta</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3323">shouldFixMeta</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3324">shouldFixMeta</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3857,7 +3857,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixEmptyMetaCells</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3327">setFixEmptyMetaCells</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3328">setFixEmptyMetaCells</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3867,7 +3867,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixEmptyMetaCells</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3332">shouldFixEmptyMetaCells</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3333">shouldFixEmptyMetaCells</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3877,7 +3877,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setCheckHdfs</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3336">setCheckHdfs</a>(boolean checking)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3337">setCheckHdfs</a>(boolean checking)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3887,7 +3887,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldCheckHdfs</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3340">shouldCheckHdfs</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3341">shouldCheckHdfs</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3897,7 +3897,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixHdfsHoles</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3344">setFixHdfsHoles</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3345">setFixHdfsHoles</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3907,7 +3907,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixHdfsHoles</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3349">shouldFixHdfsHoles</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3350">shouldFixHdfsHoles</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3917,7 +3917,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixTableOrphans</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3353">setFixTableOrphans</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3354">setFixTableOrphans</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3927,7 +3927,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixTableOrphans</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3358">shouldFixTableOrphans</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3359">shouldFixTableOrphans</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3937,7 +3937,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixHdfsOverlaps</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3362">setFixHdfsOverlaps</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3363">setFixHdfsOverlaps</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3947,7 +3947,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixHdfsOverlaps</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3367">shouldFixHdfsOverlaps</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3368">shouldFixHdfsOverlaps</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3957,7 +3957,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixHdfsOrphans</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3371">setFixHdfsOrphans</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3372">setFixHdfsOrphans</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3967,7 +3967,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixHdfsOrphans</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3376">shouldFixHdfsOrphans</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3377">shouldFixHdfsOrphans</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3977,7 +3977,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixVersionFile</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3380">setFixVersionFile</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3381">setFixVersionFile</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3987,7 +3987,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixVersionFile</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3385">shouldFixVersionFile</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3386">shouldFixVersionFile</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -3997,7 +3997,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setSidelineBigOverlaps</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3389">setSidelineBigOverlaps</a>(boolean sbo)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3390">setSidelineBigOverlaps</a>(boolean sbo)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4007,7 +4007,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldSidelineBigOverlaps</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3393">shouldSidelineBigOverlaps</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3394">shouldSidelineBigOverlaps</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4017,7 +4017,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixSplitParents</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3397">setFixSplitParents</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3398">setFixSplitParents</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4027,7 +4027,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setRemoveParents</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3402">setRemoveParents</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3403">setRemoveParents</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4037,7 +4037,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixSplitParents</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3407">shouldFixSplitParents</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3408">shouldFixSplitParents</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4047,7 +4047,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldRemoveParents</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3411">shouldRemoveParents</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3412">shouldRemoveParents</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4057,7 +4057,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixReferenceFiles</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3415">setFixReferenceFiles</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3416">setFixReferenceFiles</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4067,7 +4067,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixReferenceFiles</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3420">shouldFixReferenceFiles</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3421">shouldFixReferenceFiles</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4077,7 +4077,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setFixHFileLinks</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3424">setFixHFileLinks</a>(boolean shouldFix)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3425">setFixHFileLinks</a>(boolean shouldFix)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4087,7 +4087,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldFixHFileLinks</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3429">shouldFixHFileLinks</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3430">shouldFixHFileLinks</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4097,7 +4097,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>shouldIgnorePreCheckPermission</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3433">shouldIgnorePreCheckPermission</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3434">shouldIgnorePreCheckPermission</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4107,7 +4107,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setIgnorePreCheckPermission</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3437">setIgnorePreCheckPermission</a>(boolean ignorePreCheckPermission)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3438">setIgnorePreCheckPermission</a>(boolean ignorePreCheckPermission)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4117,7 +4117,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setMaxMerge</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3444">setMaxMerge</a>(int mm)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3445">setMaxMerge</a>(int mm)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -4131,7 +4131,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getMaxMerge</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3448">getMaxMerge</a>()</pre>
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3449">getMaxMerge</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4141,7 +4141,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setMaxOverlapsToSideline</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3452">setMaxOverlapsToSideline</a>(int mo)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3453">setMaxOverlapsToSideline</a>(int mo)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4151,7 +4151,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getMaxOverlapsToSideline</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3456">getMaxOverlapsToSideline</a>()</pre>
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3457">getMaxOverlapsToSideline</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4161,7 +4161,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>isTableIncluded</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3464">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table)</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3465">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Only check/fix tables specified by the list,
Empty list means all tables are included.</div>
@@ -4173,7 +4173,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>includeTable</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3468">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3469">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4183,7 +4183,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getIncludedTables</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3472">getIncludedTables</a>()</pre>
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is-external=true" title="class or interface in java.util">Set</a><<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3473">getIncludedTables</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4193,7 +4193,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setTimeLag</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3481">setTimeLag</a>(long seconds)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3482">setTimeLag</a>(long seconds)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">We are interested in only those tables that have not changed their state in
hbase:meta during the last few seconds specified by hbase.admin.fsck.timelag</div>
@@ -4209,7 +4209,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setSidelineDir</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3489">setSidelineDir</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> sidelineDir)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3490">setSidelineDir</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> sidelineDir)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -4223,7 +4223,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>createHFileCorruptionChecker</h4>
-<pre>protected <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3493">createHFileCorruptionChecker</a>(boolean sidelineCorruptHFiles)
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3494">createHFileCorruptionChecker</a>(boolean sidelineCorruptHFiles)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -4238,7 +4238,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getHFilecorruptionChecker</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3497">getHFilecorruptionChecker</a>()</pre>
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3498">getHFilecorruptionChecker</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4248,7 +4248,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setHFileCorruptionChecker</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3501">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> hfcc)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3502">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a> hfcc)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4258,7 +4258,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setRetCode</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3505">setRetCode</a>(int code)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3506">setRetCode</a>(int code)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4268,7 +4268,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>getRetCode</h4>
-<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3509">getRetCode</a>()</pre>
+<pre>public int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3510">getRetCode</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4278,7 +4278,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>printUsageAndExit</h4>
-<pre>protected <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3513">printUsageAndExit</a>()</pre>
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3514">printUsageAndExit</a>()</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4288,7 +4288,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>main</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3600">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3601">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">Main program</div>
@@ -4306,7 +4306,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>exec</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3624">exec</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> exec,
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3625">exec</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a> exec,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)
throws org.apache.zookeeper.KeeperException,
<a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
@@ -4328,7 +4328,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>isOptionsSupported</h4>
-<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3853">isOptionsSupported</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)</pre>
+<pre>private boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3854">isOptionsSupported</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[] args)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4338,7 +4338,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>setCleanReplicationBarrierTable</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3870">setCleanReplicationBarrierTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> cleanReplicationBarrierTable)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3871">setCleanReplicationBarrierTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> cleanReplicationBarrierTable)</pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
</li>
</ul>
@@ -4348,7 +4348,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>cleanReplicationBarrier</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3874">cleanReplicationBarrier</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3875">cleanReplicationBarrier</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<dl>
@@ -4363,7 +4363,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>debugLsr</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3952">debugLsr</a>(org.apache.hadoop.fs.Path p)
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3953">debugLsr</a>(org.apache.hadoop.fs.Path p)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
<div class="block">ls -r for debugging purposes</div>
@@ -4379,7 +4379,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockList">
<li class="blockList">
<h4>debugLsr</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3959">debugLsr</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3960">debugLsr</a>(org.apache.hadoop.conf.Configuration conf,
org.apache.hadoop.fs.Path p)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="deprecatedLabel">Deprecated.</span> </div>
@@ -4396,7 +4396,7 @@ public static org.apache.hadoop.fs.Path <a href="../../../../../src-ht
<ul class="blockListLast">
<li class="blockList">
<h4>debugLsr</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3967">debugLsr</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3968">debugLsr</a>(org.apache.hadoop.conf.Configuration conf,
org.apache.hadoop.fs.Path p,
<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a> errors)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
index ce1456b..5538cd5 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -534,15 +534,15 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Order.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Order</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HbckErrorReporter.ERROR_CODE</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.UnsafeComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.UnsafeComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a><T>)</li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLockWithObjectPool.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLockWithObjectPool.ReferenceType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PrettyPrinter.Unit.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PrettyPrinter.Unit</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a><T>)</li>
<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/ChecksumType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">ChecksumType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HbckErrorReporter.ERROR_CODE</span></a></li>
<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/DNS.ServerType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">DNS.ServerType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLockWithObjectPool.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLockWithObjectPool.ReferenceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Order.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Order</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.UnsafeComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.UnsafeComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a><T>)</li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a><T>)</li>
</ul>
</li>
</ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
index 188279e..3a77775 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
@@ -198,8 +198,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true [...]
<ul>
-<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/RegionGroupingProvider.Strategies.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">RegionGroupingProvider.Strategies</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.Providers.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">WALFactory.Providers</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/RegionGroupingProvider.Strategies.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">RegionGroupingProvider.Strategies</span></a></li>
</ul>
</li>
</ul>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html b/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
index 84ca66a..864ae8a 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/client/AsyncConnectionImpl.html
@@ -220,223 +220,224 @@
<span class="sourceLineNo">212</span> if(LOG.isDebugEnabled()){<a name="line.212"></a>
<span class="sourceLineNo">213</span> logCallStack(Thread.currentThread().getStackTrace());<a name="line.213"></a>
<span class="sourceLineNo">214</span> }<a name="line.214"></a>
-<span class="sourceLineNo">215</span> IOUtils.closeQuietly(clusterStatusListener);<a name="line.215"></a>
-<span class="sourceLineNo">216</span> IOUtils.closeQuietly(rpcClient);<a name="line.216"></a>
-<span class="sourceLineNo">217</span> IOUtils.closeQuietly(registry);<a name="line.217"></a>
-<span class="sourceLineNo">218</span> if (choreService != null) {<a name="line.218"></a>
-<span class="sourceLineNo">219</span> choreService.shutdown();<a name="line.219"></a>
-<span class="sourceLineNo">220</span> }<a name="line.220"></a>
-<span class="sourceLineNo">221</span> metrics.ifPresent(MetricsConnection::shutdown);<a name="line.221"></a>
-<span class="sourceLineNo">222</span> ConnectionOverAsyncConnection c = this.conn;<a name="line.222"></a>
-<span class="sourceLineNo">223</span> if (c != null) {<a name="line.223"></a>
-<span class="sourceLineNo">224</span> c.closePool();<a name="line.224"></a>
-<span class="sourceLineNo">225</span> }<a name="line.225"></a>
-<span class="sourceLineNo">226</span> }<a name="line.226"></a>
-<span class="sourceLineNo">227</span><a name="line.227"></a>
-<span class="sourceLineNo">228</span> private void logCallStack(StackTraceElement[] stackTraceElements) {<a name="line.228"></a>
-<span class="sourceLineNo">229</span> StringBuilder stackBuilder = new StringBuilder("Call stack:");<a name="line.229"></a>
-<span class="sourceLineNo">230</span> for (StackTraceElement element : stackTraceElements) {<a name="line.230"></a>
-<span class="sourceLineNo">231</span> stackBuilder.append("\n at ");<a name="line.231"></a>
-<span class="sourceLineNo">232</span> stackBuilder.append(element);<a name="line.232"></a>
-<span class="sourceLineNo">233</span> }<a name="line.233"></a>
-<span class="sourceLineNo">234</span> stackBuilder.append("\n");<a name="line.234"></a>
-<span class="sourceLineNo">235</span> LOG.debug(stackBuilder.toString());<a name="line.235"></a>
-<span class="sourceLineNo">236</span> }<a name="line.236"></a>
-<span class="sourceLineNo">237</span><a name="line.237"></a>
-<span class="sourceLineNo">238</span> @Override<a name="line.238"></a>
-<span class="sourceLineNo">239</span> public AsyncTableRegionLocator getRegionLocator(TableName tableName) {<a name="line.239"></a>
-<span class="sourceLineNo">240</span> return new AsyncTableRegionLocatorImpl(tableName, this);<a name="line.240"></a>
-<span class="sourceLineNo">241</span> }<a name="line.241"></a>
-<span class="sourceLineNo">242</span><a name="line.242"></a>
-<span class="sourceLineNo">243</span> @Override<a name="line.243"></a>
-<span class="sourceLineNo">244</span> public void clearRegionLocationCache() {<a name="line.244"></a>
-<span class="sourceLineNo">245</span> locator.clearCache();<a name="line.245"></a>
-<span class="sourceLineNo">246</span> }<a name="line.246"></a>
-<span class="sourceLineNo">247</span><a name="line.247"></a>
-<span class="sourceLineNo">248</span> // we will override this method for testing retry caller, so do not remove this method.<a name="line.248"></a>
-<span class="sourceLineNo">249</span> AsyncRegionLocator getLocator() {<a name="line.249"></a>
-<span class="sourceLineNo">250</span> return locator;<a name="line.250"></a>
-<span class="sourceLineNo">251</span> }<a name="line.251"></a>
-<span class="sourceLineNo">252</span><a name="line.252"></a>
-<span class="sourceLineNo">253</span> // ditto<a name="line.253"></a>
-<span class="sourceLineNo">254</span> NonceGenerator getNonceGenerator() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span> return nonceGenerator;<a name="line.255"></a>
-<span class="sourceLineNo">256</span> }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span> private ClientService.Interface createRegionServerStub(ServerName serverName) throws IOException {<a name="line.258"></a>
-<span class="sourceLineNo">259</span> return ClientService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.259"></a>
-<span class="sourceLineNo">260</span> }<a name="line.260"></a>
-<span class="sourceLineNo">261</span><a name="line.261"></a>
-<span class="sourceLineNo">262</span> ClientService.Interface getRegionServerStub(ServerName serverName) throws IOException {<a name="line.262"></a>
-<span class="sourceLineNo">263</span> return ConcurrentMapUtils.computeIfAbsentEx(rsStubs,<a name="line.263"></a>
-<span class="sourceLineNo">264</span> getStubKey(ClientService.getDescriptor().getName(), serverName),<a name="line.264"></a>
-<span class="sourceLineNo">265</span> () -> createRegionServerStub(serverName));<a name="line.265"></a>
-<span class="sourceLineNo">266</span> }<a name="line.266"></a>
-<span class="sourceLineNo">267</span><a name="line.267"></a>
-<span class="sourceLineNo">268</span> private MasterService.Interface createMasterStub(ServerName serverName) throws IOException {<a name="line.268"></a>
-<span class="sourceLineNo">269</span> return MasterService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.269"></a>
-<span class="sourceLineNo">270</span> }<a name="line.270"></a>
-<span class="sourceLineNo">271</span><a name="line.271"></a>
-<span class="sourceLineNo">272</span> private AdminService.Interface createAdminServerStub(ServerName serverName) throws IOException {<a name="line.272"></a>
-<span class="sourceLineNo">273</span> return AdminService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.273"></a>
-<span class="sourceLineNo">274</span> }<a name="line.274"></a>
-<span class="sourceLineNo">275</span><a name="line.275"></a>
-<span class="sourceLineNo">276</span> AdminService.Interface getAdminStub(ServerName serverName) throws IOException {<a name="line.276"></a>
-<span class="sourceLineNo">277</span> return ConcurrentMapUtils.computeIfAbsentEx(adminSubs,<a name="line.277"></a>
-<span class="sourceLineNo">278</span> getStubKey(AdminService.getDescriptor().getName(), serverName),<a name="line.278"></a>
-<span class="sourceLineNo">279</span> () -> createAdminServerStub(serverName));<a name="line.279"></a>
-<span class="sourceLineNo">280</span> }<a name="line.280"></a>
-<span class="sourceLineNo">281</span><a name="line.281"></a>
-<span class="sourceLineNo">282</span> CompletableFuture<MasterService.Interface> getMasterStub() {<a name="line.282"></a>
-<span class="sourceLineNo">283</span> return ConnectionUtils.getOrFetch(masterStub, masterStubMakeFuture, false, () -> {<a name="line.283"></a>
-<span class="sourceLineNo">284</span> CompletableFuture<MasterService.Interface> future = new CompletableFuture<>();<a name="line.284"></a>
-<span class="sourceLineNo">285</span> addListener(registry.getActiveMaster(), (addr, error) -> {<a name="line.285"></a>
-<span class="sourceLineNo">286</span> if (error != null) {<a name="line.286"></a>
-<span class="sourceLineNo">287</span> future.completeExceptionally(error);<a name="line.287"></a>
-<span class="sourceLineNo">288</span> } else if (addr == null) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span> future.completeExceptionally(new MasterNotRunningException(<a name="line.289"></a>
-<span class="sourceLineNo">290</span> "ZooKeeper available but no active master location found"));<a name="line.290"></a>
-<span class="sourceLineNo">291</span> } else {<a name="line.291"></a>
-<span class="sourceLineNo">292</span> LOG.debug("The fetched master address is {}", addr);<a name="line.292"></a>
-<span class="sourceLineNo">293</span> try {<a name="line.293"></a>
-<span class="sourceLineNo">294</span> future.complete(createMasterStub(addr));<a name="line.294"></a>
-<span class="sourceLineNo">295</span> } catch (IOException e) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span> future.completeExceptionally(e);<a name="line.296"></a>
-<span class="sourceLineNo">297</span> }<a name="line.297"></a>
-<span class="sourceLineNo">298</span> }<a name="line.298"></a>
-<span class="sourceLineNo">299</span><a name="line.299"></a>
-<span class="sourceLineNo">300</span> });<a name="line.300"></a>
-<span class="sourceLineNo">301</span> return future;<a name="line.301"></a>
-<span class="sourceLineNo">302</span> }, stub -> true, "master stub");<a name="line.302"></a>
-<span class="sourceLineNo">303</span> }<a name="line.303"></a>
-<span class="sourceLineNo">304</span><a name="line.304"></a>
-<span class="sourceLineNo">305</span> String getClusterId() {<a name="line.305"></a>
-<span class="sourceLineNo">306</span> try {<a name="line.306"></a>
-<span class="sourceLineNo">307</span> return registry.getClusterId().get();<a name="line.307"></a>
-<span class="sourceLineNo">308</span> } catch (InterruptedException | ExecutionException e) {<a name="line.308"></a>
-<span class="sourceLineNo">309</span> LOG.error("Error fetching cluster ID: ", e);<a name="line.309"></a>
-<span class="sourceLineNo">310</span> }<a name="line.310"></a>
-<span class="sourceLineNo">311</span> return null;<a name="line.311"></a>
-<span class="sourceLineNo">312</span> }<a name="line.312"></a>
-<span class="sourceLineNo">313</span><a name="line.313"></a>
-<span class="sourceLineNo">314</span> void clearMasterStubCache(MasterService.Interface stub) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span> masterStub.compareAndSet(stub, null);<a name="line.315"></a>
-<span class="sourceLineNo">316</span> }<a name="line.316"></a>
-<span class="sourceLineNo">317</span><a name="line.317"></a>
-<span class="sourceLineNo">318</span> Optional<ServerStatisticTracker> getStatisticsTracker() {<a name="line.318"></a>
-<span class="sourceLineNo">319</span> return stats;<a name="line.319"></a>
-<span class="sourceLineNo">320</span> }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span> ClientBackoffPolicy getBackoffPolicy() {<a name="line.322"></a>
-<span class="sourceLineNo">323</span> return backoffPolicy;<a name="line.323"></a>
-<span class="sourceLineNo">324</span> }<a name="line.324"></a>
-<span class="sourceLineNo">325</span><a name="line.325"></a>
-<span class="sourceLineNo">326</span> @Override<a name="line.326"></a>
-<span class="sourceLineNo">327</span> public AsyncTableBuilder<AdvancedScanResultConsumer> getTableBuilder(TableName tableName) {<a name="line.327"></a>
-<span class="sourceLineNo">328</span> return new AsyncTableBuilderBase<AdvancedScanResultConsumer>(tableName, connConf) {<a name="line.328"></a>
-<span class="sourceLineNo">329</span><a name="line.329"></a>
-<span class="sourceLineNo">330</span> @Override<a name="line.330"></a>
-<span class="sourceLineNo">331</span> public AsyncTable<AdvancedScanResultConsumer> build() {<a name="line.331"></a>
-<span class="sourceLineNo">332</span> return new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.332"></a>
-<span class="sourceLineNo">333</span> }<a name="line.333"></a>
-<span class="sourceLineNo">334</span> };<a name="line.334"></a>
-<span class="sourceLineNo">335</span> }<a name="line.335"></a>
-<span class="sourceLineNo">336</span><a name="line.336"></a>
-<span class="sourceLineNo">337</span> @Override<a name="line.337"></a>
-<span class="sourceLineNo">338</span> public AsyncTableBuilder<ScanResultConsumer> getTableBuilder(TableName tableName,<a name="line.338"></a>
-<span class="sourceLineNo">339</span> ExecutorService pool) {<a name="line.339"></a>
-<span class="sourceLineNo">340</span> return new AsyncTableBuilderBase<ScanResultConsumer>(tableName, connConf) {<a name="line.340"></a>
-<span class="sourceLineNo">341</span><a name="line.341"></a>
-<span class="sourceLineNo">342</span> @Override<a name="line.342"></a>
-<span class="sourceLineNo">343</span> public AsyncTable<ScanResultConsumer> build() {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> RawAsyncTableImpl rawTable =<a name="line.344"></a>
-<span class="sourceLineNo">345</span> new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.345"></a>
-<span class="sourceLineNo">346</span> return new AsyncTableImpl(AsyncConnectionImpl.this, rawTable, pool);<a name="line.346"></a>
-<span class="sourceLineNo">347</span> }<a name="line.347"></a>
-<span class="sourceLineNo">348</span> };<a name="line.348"></a>
-<span class="sourceLineNo">349</span> }<a name="line.349"></a>
-<span class="sourceLineNo">350</span><a name="line.350"></a>
-<span class="sourceLineNo">351</span> @Override<a name="line.351"></a>
-<span class="sourceLineNo">352</span> public AsyncAdminBuilder getAdminBuilder() {<a name="line.352"></a>
-<span class="sourceLineNo">353</span> return new AsyncAdminBuilderBase(connConf) {<a name="line.353"></a>
-<span class="sourceLineNo">354</span> @Override<a name="line.354"></a>
-<span class="sourceLineNo">355</span> public AsyncAdmin build() {<a name="line.355"></a>
-<span class="sourceLineNo">356</span> return new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.356"></a>
-<span class="sourceLineNo">357</span> }<a name="line.357"></a>
-<span class="sourceLineNo">358</span> };<a name="line.358"></a>
-<span class="sourceLineNo">359</span> }<a name="line.359"></a>
-<span class="sourceLineNo">360</span><a name="line.360"></a>
-<span class="sourceLineNo">361</span> @Override<a name="line.361"></a>
-<span class="sourceLineNo">362</span> public AsyncAdminBuilder getAdminBuilder(ExecutorService pool) {<a name="line.362"></a>
-<span class="sourceLineNo">363</span> return new AsyncAdminBuilderBase(connConf) {<a name="line.363"></a>
-<span class="sourceLineNo">364</span> @Override<a name="line.364"></a>
-<span class="sourceLineNo">365</span> public AsyncAdmin build() {<a name="line.365"></a>
-<span class="sourceLineNo">366</span> RawAsyncHBaseAdmin rawAdmin =<a name="line.366"></a>
-<span class="sourceLineNo">367</span> new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.367"></a>
-<span class="sourceLineNo">368</span> return new AsyncHBaseAdmin(rawAdmin, pool);<a name="line.368"></a>
-<span class="sourceLineNo">369</span> }<a name="line.369"></a>
-<span class="sourceLineNo">370</span> };<a name="line.370"></a>
-<span class="sourceLineNo">371</span> }<a name="line.371"></a>
-<span class="sourceLineNo">372</span><a name="line.372"></a>
-<span class="sourceLineNo">373</span> @Override<a name="line.373"></a>
-<span class="sourceLineNo">374</span> public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span> return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName), RETRY_TIMER);<a name="line.375"></a>
-<span class="sourceLineNo">376</span> }<a name="line.376"></a>
-<span class="sourceLineNo">377</span><a name="line.377"></a>
-<span class="sourceLineNo">378</span> @Override<a name="line.378"></a>
-<span class="sourceLineNo">379</span> public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName,<a name="line.379"></a>
-<span class="sourceLineNo">380</span> ExecutorService pool) {<a name="line.380"></a>
-<span class="sourceLineNo">381</span> return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName, pool),<a name="line.381"></a>
-<span class="sourceLineNo">382</span> RETRY_TIMER);<a name="line.382"></a>
-<span class="sourceLineNo">383</span> }<a name="line.383"></a>
-<span class="sourceLineNo">384</span><a name="line.384"></a>
-<span class="sourceLineNo">385</span> @Override<a name="line.385"></a>
-<span class="sourceLineNo">386</span> public Connection toConnection() {<a name="line.386"></a>
-<span class="sourceLineNo">387</span> ConnectionOverAsyncConnection c = this.conn;<a name="line.387"></a>
-<span class="sourceLineNo">388</span> if (c != null) {<a name="line.388"></a>
-<span class="sourceLineNo">389</span> return c;<a name="line.389"></a>
-<span class="sourceLineNo">390</span> }<a name="line.390"></a>
-<span class="sourceLineNo">391</span> synchronized (this) {<a name="line.391"></a>
-<span class="sourceLineNo">392</span> c = this.conn;<a name="line.392"></a>
-<span class="sourceLineNo">393</span> if (c != null) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span> return c;<a name="line.394"></a>
-<span class="sourceLineNo">395</span> }<a name="line.395"></a>
-<span class="sourceLineNo">396</span> c = new ConnectionOverAsyncConnection(this);<a name="line.396"></a>
-<span class="sourceLineNo">397</span> this.conn = c;<a name="line.397"></a>
-<span class="sourceLineNo">398</span> }<a name="line.398"></a>
-<span class="sourceLineNo">399</span> return c;<a name="line.399"></a>
-<span class="sourceLineNo">400</span> }<a name="line.400"></a>
-<span class="sourceLineNo">401</span><a name="line.401"></a>
-<span class="sourceLineNo">402</span> @Override<a name="line.402"></a>
-<span class="sourceLineNo">403</span> public CompletableFuture<Hbck> getHbck() {<a name="line.403"></a>
-<span class="sourceLineNo">404</span> CompletableFuture<Hbck> future = new CompletableFuture<>();<a name="line.404"></a>
-<span class="sourceLineNo">405</span> addListener(registry.getActiveMaster(), (sn, error) -> {<a name="line.405"></a>
-<span class="sourceLineNo">406</span> if (error != null) {<a name="line.406"></a>
-<span class="sourceLineNo">407</span> future.completeExceptionally(error);<a name="line.407"></a>
-<span class="sourceLineNo">408</span> } else {<a name="line.408"></a>
-<span class="sourceLineNo">409</span> try {<a name="line.409"></a>
-<span class="sourceLineNo">410</span> future.complete(getHbck(sn));<a name="line.410"></a>
-<span class="sourceLineNo">411</span> } catch (IOException e) {<a name="line.411"></a>
-<span class="sourceLineNo">412</span> future.completeExceptionally(e);<a name="line.412"></a>
-<span class="sourceLineNo">413</span> }<a name="line.413"></a>
-<span class="sourceLineNo">414</span> }<a name="line.414"></a>
-<span class="sourceLineNo">415</span> });<a name="line.415"></a>
-<span class="sourceLineNo">416</span> return future;<a name="line.416"></a>
-<span class="sourceLineNo">417</span> }<a name="line.417"></a>
-<span class="sourceLineNo">418</span><a name="line.418"></a>
-<span class="sourceLineNo">419</span> @Override<a name="line.419"></a>
-<span class="sourceLineNo">420</span> public Hbck getHbck(ServerName masterServer) throws IOException {<a name="line.420"></a>
-<span class="sourceLineNo">421</span> // we will not create a new connection when creating a new protobuf stub, and for hbck there<a name="line.421"></a>
-<span class="sourceLineNo">422</span> // will be no performance consideration, so for simplification we will create a new stub every<a name="line.422"></a>
-<span class="sourceLineNo">423</span> // time instead of caching the stub here.<a name="line.423"></a>
-<span class="sourceLineNo">424</span> return new HBaseHbck(MasterProtos.HbckService.newBlockingStub(<a name="line.424"></a>
-<span class="sourceLineNo">425</span> rpcClient.createBlockingRpcChannel(masterServer, user, rpcTimeout)), rpcControllerFactory);<a name="line.425"></a>
-<span class="sourceLineNo">426</span> }<a name="line.426"></a>
-<span class="sourceLineNo">427</span><a name="line.427"></a>
-<span class="sourceLineNo">428</span> Optional<MetricsConnection> getConnectionMetrics() {<a name="line.428"></a>
-<span class="sourceLineNo">429</span> return metrics;<a name="line.429"></a>
-<span class="sourceLineNo">430</span> }<a name="line.430"></a>
-<span class="sourceLineNo">431</span>}<a name="line.431"></a>
+<span class="sourceLineNo">215</span> IOUtils.closeQuietly(clusterStatusListener,<a name="line.215"></a>
+<span class="sourceLineNo">216</span> e -> LOG.warn("failed to close clusterStatusListener", e));<a name="line.216"></a>
+<span class="sourceLineNo">217</span> IOUtils.closeQuietly(rpcClient, e -> LOG.warn("failed to close rpcClient", e));<a name="line.217"></a>
+<span class="sourceLineNo">218</span> IOUtils.closeQuietly(registry, e -> LOG.warn("failed to close registry", e));<a name="line.218"></a>
+<span class="sourceLineNo">219</span> if (choreService != null) {<a name="line.219"></a>
+<span class="sourceLineNo">220</span> choreService.shutdown();<a name="line.220"></a>
+<span class="sourceLineNo">221</span> }<a name="line.221"></a>
+<span class="sourceLineNo">222</span> metrics.ifPresent(MetricsConnection::shutdown);<a name="line.222"></a>
+<span class="sourceLineNo">223</span> ConnectionOverAsyncConnection c = this.conn;<a name="line.223"></a>
+<span class="sourceLineNo">224</span> if (c != null) {<a name="line.224"></a>
+<span class="sourceLineNo">225</span> c.closePool();<a name="line.225"></a>
+<span class="sourceLineNo">226</span> }<a name="line.226"></a>
+<span class="sourceLineNo">227</span> }<a name="line.227"></a>
+<span class="sourceLineNo">228</span><a name="line.228"></a>
+<span class="sourceLineNo">229</span> private void logCallStack(StackTraceElement[] stackTraceElements) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span> StringBuilder stackBuilder = new StringBuilder("Call stack:");<a name="line.230"></a>
+<span class="sourceLineNo">231</span> for (StackTraceElement element : stackTraceElements) {<a name="line.231"></a>
+<span class="sourceLineNo">232</span> stackBuilder.append("\n at ");<a name="line.232"></a>
+<span class="sourceLineNo">233</span> stackBuilder.append(element);<a name="line.233"></a>
+<span class="sourceLineNo">234</span> }<a name="line.234"></a>
+<span class="sourceLineNo">235</span> stackBuilder.append("\n");<a name="line.235"></a>
+<span class="sourceLineNo">236</span> LOG.debug(stackBuilder.toString());<a name="line.236"></a>
+<span class="sourceLineNo">237</span> }<a name="line.237"></a>
+<span class="sourceLineNo">238</span><a name="line.238"></a>
+<span class="sourceLineNo">239</span> @Override<a name="line.239"></a>
+<span class="sourceLineNo">240</span> public AsyncTableRegionLocator getRegionLocator(TableName tableName) {<a name="line.240"></a>
+<span class="sourceLineNo">241</span> return new AsyncTableRegionLocatorImpl(tableName, this);<a name="line.241"></a>
+<span class="sourceLineNo">242</span> }<a name="line.242"></a>
+<span class="sourceLineNo">243</span><a name="line.243"></a>
+<span class="sourceLineNo">244</span> @Override<a name="line.244"></a>
+<span class="sourceLineNo">245</span> public void clearRegionLocationCache() {<a name="line.245"></a>
+<span class="sourceLineNo">246</span> locator.clearCache();<a name="line.246"></a>
+<span class="sourceLineNo">247</span> }<a name="line.247"></a>
+<span class="sourceLineNo">248</span><a name="line.248"></a>
+<span class="sourceLineNo">249</span> // we will override this method for testing retry caller, so do not remove this method.<a name="line.249"></a>
+<span class="sourceLineNo">250</span> AsyncRegionLocator getLocator() {<a name="line.250"></a>
+<span class="sourceLineNo">251</span> return locator;<a name="line.251"></a>
+<span class="sourceLineNo">252</span> }<a name="line.252"></a>
+<span class="sourceLineNo">253</span><a name="line.253"></a>
+<span class="sourceLineNo">254</span> // ditto<a name="line.254"></a>
+<span class="sourceLineNo">255</span> NonceGenerator getNonceGenerator() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span> return nonceGenerator;<a name="line.256"></a>
+<span class="sourceLineNo">257</span> }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span> private ClientService.Interface createRegionServerStub(ServerName serverName) throws IOException {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> return ClientService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.260"></a>
+<span class="sourceLineNo">261</span> }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span> ClientService.Interface getRegionServerStub(ServerName serverName) throws IOException {<a name="line.263"></a>
+<span class="sourceLineNo">264</span> return ConcurrentMapUtils.computeIfAbsentEx(rsStubs,<a name="line.264"></a>
+<span class="sourceLineNo">265</span> getStubKey(ClientService.getDescriptor().getName(), serverName),<a name="line.265"></a>
+<span class="sourceLineNo">266</span> () -> createRegionServerStub(serverName));<a name="line.266"></a>
+<span class="sourceLineNo">267</span> }<a name="line.267"></a>
+<span class="sourceLineNo">268</span><a name="line.268"></a>
+<span class="sourceLineNo">269</span> private MasterService.Interface createMasterStub(ServerName serverName) throws IOException {<a name="line.269"></a>
+<span class="sourceLineNo">270</span> return MasterService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.270"></a>
+<span class="sourceLineNo">271</span> }<a name="line.271"></a>
+<span class="sourceLineNo">272</span><a name="line.272"></a>
+<span class="sourceLineNo">273</span> private AdminService.Interface createAdminServerStub(ServerName serverName) throws IOException {<a name="line.273"></a>
+<span class="sourceLineNo">274</span> return AdminService.newStub(rpcClient.createRpcChannel(serverName, user, rpcTimeout));<a name="line.274"></a>
+<span class="sourceLineNo">275</span> }<a name="line.275"></a>
+<span class="sourceLineNo">276</span><a name="line.276"></a>
+<span class="sourceLineNo">277</span> AdminService.Interface getAdminStub(ServerName serverName) throws IOException {<a name="line.277"></a>
+<span class="sourceLineNo">278</span> return ConcurrentMapUtils.computeIfAbsentEx(adminSubs,<a name="line.278"></a>
+<span class="sourceLineNo">279</span> getStubKey(AdminService.getDescriptor().getName(), serverName),<a name="line.279"></a>
+<span class="sourceLineNo">280</span> () -> createAdminServerStub(serverName));<a name="line.280"></a>
+<span class="sourceLineNo">281</span> }<a name="line.281"></a>
+<span class="sourceLineNo">282</span><a name="line.282"></a>
+<span class="sourceLineNo">283</span> CompletableFuture<MasterService.Interface> getMasterStub() {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> return ConnectionUtils.getOrFetch(masterStub, masterStubMakeFuture, false, () -> {<a name="line.284"></a>
+<span class="sourceLineNo">285</span> CompletableFuture<MasterService.Interface> future = new CompletableFuture<>();<a name="line.285"></a>
+<span class="sourceLineNo">286</span> addListener(registry.getActiveMaster(), (addr, error) -> {<a name="line.286"></a>
+<span class="sourceLineNo">287</span> if (error != null) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span> future.completeExceptionally(error);<a name="line.288"></a>
+<span class="sourceLineNo">289</span> } else if (addr == null) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span> future.completeExceptionally(new MasterNotRunningException(<a name="line.290"></a>
+<span class="sourceLineNo">291</span> "ZooKeeper available but no active master location found"));<a name="line.291"></a>
+<span class="sourceLineNo">292</span> } else {<a name="line.292"></a>
+<span class="sourceLineNo">293</span> LOG.debug("The fetched master address is {}", addr);<a name="line.293"></a>
+<span class="sourceLineNo">294</span> try {<a name="line.294"></a>
+<span class="sourceLineNo">295</span> future.complete(createMasterStub(addr));<a name="line.295"></a>
+<span class="sourceLineNo">296</span> } catch (IOException e) {<a name="line.296"></a>
+<span class="sourceLineNo">297</span> future.completeExceptionally(e);<a name="line.297"></a>
+<span class="sourceLineNo">298</span> }<a name="line.298"></a>
+<span class="sourceLineNo">299</span> }<a name="line.299"></a>
+<span class="sourceLineNo">300</span><a name="line.300"></a>
+<span class="sourceLineNo">301</span> });<a name="line.301"></a>
+<span class="sourceLineNo">302</span> return future;<a name="line.302"></a>
+<span class="sourceLineNo">303</span> }, stub -> true, "master stub");<a name="line.303"></a>
+<span class="sourceLineNo">304</span> }<a name="line.304"></a>
+<span class="sourceLineNo">305</span><a name="line.305"></a>
+<span class="sourceLineNo">306</span> String getClusterId() {<a name="line.306"></a>
+<span class="sourceLineNo">307</span> try {<a name="line.307"></a>
+<span class="sourceLineNo">308</span> return registry.getClusterId().get();<a name="line.308"></a>
+<span class="sourceLineNo">309</span> } catch (InterruptedException | ExecutionException e) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span> LOG.error("Error fetching cluster ID: ", e);<a name="line.310"></a>
+<span class="sourceLineNo">311</span> }<a name="line.311"></a>
+<span class="sourceLineNo">312</span> return null;<a name="line.312"></a>
+<span class="sourceLineNo">313</span> }<a name="line.313"></a>
+<span class="sourceLineNo">314</span><a name="line.314"></a>
+<span class="sourceLineNo">315</span> void clearMasterStubCache(MasterService.Interface stub) {<a name="line.315"></a>
+<span class="sourceLineNo">316</span> masterStub.compareAndSet(stub, null);<a name="line.316"></a>
+<span class="sourceLineNo">317</span> }<a name="line.317"></a>
+<span class="sourceLineNo">318</span><a name="line.318"></a>
+<span class="sourceLineNo">319</span> Optional<ServerStatisticTracker> getStatisticsTracker() {<a name="line.319"></a>
+<span class="sourceLineNo">320</span> return stats;<a name="line.320"></a>
+<span class="sourceLineNo">321</span> }<a name="line.321"></a>
+<span class="sourceLineNo">322</span><a name="line.322"></a>
+<span class="sourceLineNo">323</span> ClientBackoffPolicy getBackoffPolicy() {<a name="line.323"></a>
+<span class="sourceLineNo">324</span> return backoffPolicy;<a name="line.324"></a>
+<span class="sourceLineNo">325</span> }<a name="line.325"></a>
+<span class="sourceLineNo">326</span><a name="line.326"></a>
+<span class="sourceLineNo">327</span> @Override<a name="line.327"></a>
+<span class="sourceLineNo">328</span> public AsyncTableBuilder<AdvancedScanResultConsumer> getTableBuilder(TableName tableName) {<a name="line.328"></a>
+<span class="sourceLineNo">329</span> return new AsyncTableBuilderBase<AdvancedScanResultConsumer>(tableName, connConf) {<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span> @Override<a name="line.331"></a>
+<span class="sourceLineNo">332</span> public AsyncTable<AdvancedScanResultConsumer> build() {<a name="line.332"></a>
+<span class="sourceLineNo">333</span> return new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.333"></a>
+<span class="sourceLineNo">334</span> }<a name="line.334"></a>
+<span class="sourceLineNo">335</span> };<a name="line.335"></a>
+<span class="sourceLineNo">336</span> }<a name="line.336"></a>
+<span class="sourceLineNo">337</span><a name="line.337"></a>
+<span class="sourceLineNo">338</span> @Override<a name="line.338"></a>
+<span class="sourceLineNo">339</span> public AsyncTableBuilder<ScanResultConsumer> getTableBuilder(TableName tableName,<a name="line.339"></a>
+<span class="sourceLineNo">340</span> ExecutorService pool) {<a name="line.340"></a>
+<span class="sourceLineNo">341</span> return new AsyncTableBuilderBase<ScanResultConsumer>(tableName, connConf) {<a name="line.341"></a>
+<span class="sourceLineNo">342</span><a name="line.342"></a>
+<span class="sourceLineNo">343</span> @Override<a name="line.343"></a>
+<span class="sourceLineNo">344</span> public AsyncTable<ScanResultConsumer> build() {<a name="line.344"></a>
+<span class="sourceLineNo">345</span> RawAsyncTableImpl rawTable =<a name="line.345"></a>
+<span class="sourceLineNo">346</span> new RawAsyncTableImpl(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.346"></a>
+<span class="sourceLineNo">347</span> return new AsyncTableImpl(AsyncConnectionImpl.this, rawTable, pool);<a name="line.347"></a>
+<span class="sourceLineNo">348</span> }<a name="line.348"></a>
+<span class="sourceLineNo">349</span> };<a name="line.349"></a>
+<span class="sourceLineNo">350</span> }<a name="line.350"></a>
+<span class="sourceLineNo">351</span><a name="line.351"></a>
+<span class="sourceLineNo">352</span> @Override<a name="line.352"></a>
+<span class="sourceLineNo">353</span> public AsyncAdminBuilder getAdminBuilder() {<a name="line.353"></a>
+<span class="sourceLineNo">354</span> return new AsyncAdminBuilderBase(connConf) {<a name="line.354"></a>
+<span class="sourceLineNo">355</span> @Override<a name="line.355"></a>
+<span class="sourceLineNo">356</span> public AsyncAdmin build() {<a name="line.356"></a>
+<span class="sourceLineNo">357</span> return new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.357"></a>
+<span class="sourceLineNo">358</span> }<a name="line.358"></a>
+<span class="sourceLineNo">359</span> };<a name="line.359"></a>
+<span class="sourceLineNo">360</span> }<a name="line.360"></a>
+<span class="sourceLineNo">361</span><a name="line.361"></a>
+<span class="sourceLineNo">362</span> @Override<a name="line.362"></a>
+<span class="sourceLineNo">363</span> public AsyncAdminBuilder getAdminBuilder(ExecutorService pool) {<a name="line.363"></a>
+<span class="sourceLineNo">364</span> return new AsyncAdminBuilderBase(connConf) {<a name="line.364"></a>
+<span class="sourceLineNo">365</span> @Override<a name="line.365"></a>
+<span class="sourceLineNo">366</span> public AsyncAdmin build() {<a name="line.366"></a>
+<span class="sourceLineNo">367</span> RawAsyncHBaseAdmin rawAdmin =<a name="line.367"></a>
+<span class="sourceLineNo">368</span> new RawAsyncHBaseAdmin(AsyncConnectionImpl.this, RETRY_TIMER, this);<a name="line.368"></a>
+<span class="sourceLineNo">369</span> return new AsyncHBaseAdmin(rawAdmin, pool);<a name="line.369"></a>
+<span class="sourceLineNo">370</span> }<a name="line.370"></a>
+<span class="sourceLineNo">371</span> };<a name="line.371"></a>
+<span class="sourceLineNo">372</span> }<a name="line.372"></a>
+<span class="sourceLineNo">373</span><a name="line.373"></a>
+<span class="sourceLineNo">374</span> @Override<a name="line.374"></a>
+<span class="sourceLineNo">375</span> public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName) {<a name="line.375"></a>
+<span class="sourceLineNo">376</span> return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName), RETRY_TIMER);<a name="line.376"></a>
+<span class="sourceLineNo">377</span> }<a name="line.377"></a>
+<span class="sourceLineNo">378</span><a name="line.378"></a>
+<span class="sourceLineNo">379</span> @Override<a name="line.379"></a>
+<span class="sourceLineNo">380</span> public AsyncBufferedMutatorBuilder getBufferedMutatorBuilder(TableName tableName,<a name="line.380"></a>
+<span class="sourceLineNo">381</span> ExecutorService pool) {<a name="line.381"></a>
+<span class="sourceLineNo">382</span> return new AsyncBufferedMutatorBuilderImpl(connConf, getTableBuilder(tableName, pool),<a name="line.382"></a>
+<span class="sourceLineNo">383</span> RETRY_TIMER);<a name="line.383"></a>
+<span class="sourceLineNo">384</span> }<a name="line.384"></a>
+<span class="sourceLineNo">385</span><a name="line.385"></a>
+<span class="sourceLineNo">386</span> @Override<a name="line.386"></a>
+<span class="sourceLineNo">387</span> public Connection toConnection() {<a name="line.387"></a>
+<span class="sourceLineNo">388</span> ConnectionOverAsyncConnection c = this.conn;<a name="line.388"></a>
+<span class="sourceLineNo">389</span> if (c != null) {<a name="line.389"></a>
+<span class="sourceLineNo">390</span> return c;<a name="line.390"></a>
+<span class="sourceLineNo">391</span> }<a name="line.391"></a>
+<span class="sourceLineNo">392</span> synchronized (this) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span> c = this.conn;<a name="line.393"></a>
+<span class="sourceLineNo">394</span> if (c != null) {<a name="line.394"></a>
+<span class="sourceLineNo">395</span> return c;<a name="line.395"></a>
+<span class="sourceLineNo">396</span> }<a name="line.396"></a>
+<span class="sourceLineNo">397</span> c = new ConnectionOverAsyncConnection(this);<a name="line.397"></a>
+<span class="sourceLineNo">398</span> this.conn = c;<a name="line.398"></a>
+<span class="sourceLineNo">399</span> }<a name="line.399"></a>
+<span class="sourceLineNo">400</span> return c;<a name="line.400"></a>
+<span class="sourceLineNo">401</span> }<a name="line.401"></a>
+<span class="sourceLineNo">402</span><a name="line.402"></a>
+<span class="sourceLineNo">403</span> @Override<a name="line.403"></a>
+<span class="sourceLineNo">404</span> public CompletableFuture<Hbck> getHbck() {<a name="line.404"></a>
+<span class="sourceLineNo">405</span> CompletableFuture<Hbck> future = new CompletableFuture<>();<a name="line.405"></a>
+<span class="sourceLineNo">406</span> addListener(registry.getActiveMaster(), (sn, error) -> {<a name="line.406"></a>
+<span class="sourceLineNo">407</span> if (error != null) {<a name="line.407"></a>
+<span class="sourceLineNo">408</span> future.completeExceptionally(error);<a name="line.408"></a>
+<span class="sourceLineNo">409</span> } else {<a name="line.409"></a>
+<span class="sourceLineNo">410</span> try {<a name="line.410"></a>
+<span class="sourceLineNo">411</span> future.complete(getHbck(sn));<a name="line.411"></a>
+<span class="sourceLineNo">412</span> } catch (IOException e) {<a name="line.412"></a>
+<span class="sourceLineNo">413</span> future.completeExceptionally(e);<a name="line.413"></a>
+<span class="sourceLineNo">414</span> }<a name="line.414"></a>
+<span class="sourceLineNo">415</span> }<a name="line.415"></a>
+<span class="sourceLineNo">416</span> });<a name="line.416"></a>
+<span class="sourceLineNo">417</span> return future;<a name="line.417"></a>
+<span class="sourceLineNo">418</span> }<a name="line.418"></a>
+<span class="sourceLineNo">419</span><a name="line.419"></a>
+<span class="sourceLineNo">420</span> @Override<a name="line.420"></a>
+<span class="sourceLineNo">421</span> public Hbck getHbck(ServerName masterServer) throws IOException {<a name="line.421"></a>
+<span class="sourceLineNo">422</span> // we will not create a new connection when creating a new protobuf stub, and for hbck there<a name="line.422"></a>
+<span class="sourceLineNo">423</span> // will be no performance consideration, so for simplification we will create a new stub every<a name="line.423"></a>
+<span class="sourceLineNo">424</span> // time instead of caching the stub here.<a name="line.424"></a>
+<span class="sourceLineNo">425</span> return new HBaseHbck(MasterProtos.HbckService.newBlockingStub(<a name="line.425"></a>
+<span class="sourceLineNo">426</span> rpcClient.createBlockingRpcChannel(masterServer, user, rpcTimeout)), rpcControllerFactory);<a name="line.426"></a>
+<span class="sourceLineNo">427</span> }<a name="line.427"></a>
+<span class="sourceLineNo">428</span><a name="line.428"></a>
+<span class="sourceLineNo">429</span> Optional<MetricsConnection> getConnectionMetrics() {<a name="line.429"></a>
+<span class="sourceLineNo">430</span> return metrics;<a name="line.430"></a>
+<span class="sourceLineNo">431</span> }<a name="line.431"></a>
+<span class="sourceLineNo">432</span>}<a name="line.432"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html b/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
index 71fb0fa..4077dec 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/client/example/AsyncClientExample.html
@@ -119,7 +119,7 @@
<span class="sourceLineNo">111</span> CompletableFuture<Void> closeFuture = new CompletableFuture<>();<a name="line.111"></a>
<span class="sourceLineNo">112</span> addListener(f, (conn, error) -> {<a name="line.112"></a>
<span class="sourceLineNo">113</span> if (error == null) {<a name="line.113"></a>
-<span class="sourceLineNo">114</span> IOUtils.closeQuietly(conn);<a name="line.114"></a>
+<span class="sourceLineNo">114</span> IOUtils.closeQuietly(conn, e -> LOG.warn("failed to close conn", e));<a name="line.114"></a>
<span class="sourceLineNo">115</span> }<a name="line.115"></a>
<span class="sourceLineNo">116</span> closeFuture.complete(null);<a name="line.116"></a>
<span class="sourceLineNo">117</span> });<a name="line.117"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
index 029218b..9100a21 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.ReadStatistics.html
@@ -29,17 +29,17 @@
<span class="sourceLineNo">021</span>import java.io.IOException;<a name="line.21"></a>
<span class="sourceLineNo">022</span>import java.io.InputStream;<a name="line.22"></a>
<span class="sourceLineNo">023</span>import java.util.concurrent.atomic.AtomicInteger;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>import org.apache.commons.io.IOUtils;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.slf4j.Logger;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.slf4j.LoggerFactory;<a name="line.34"></a>
+<span class="sourceLineNo">024</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.slf4j.Logger;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.slf4j.LoggerFactory;<a name="line.32"></a>
+<span class="sourceLineNo">033</span><a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.34"></a>
<span class="sourceLineNo">035</span><a name="line.35"></a>
<span class="sourceLineNo">036</span>/**<a name="line.36"></a>
<span class="sourceLineNo">037</span> * Wrapper for input stream(s) that takes care of the interaction of FS and HBase checksums,<a name="line.37"></a>
@@ -297,11 +297,11 @@
<span class="sourceLineNo">289</span> }<a name="line.289"></a>
<span class="sourceLineNo">290</span> updateInputStreamStatistics(this.streamNoFsChecksum);<a name="line.290"></a>
<span class="sourceLineNo">291</span> // we do not care about the close exception as it is for reading, no data loss issue.<a name="line.291"></a>
-<span class="sourceLineNo">292</span> IOUtils.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
+<span class="sourceLineNo">292</span> Closeables.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
<span class="sourceLineNo">293</span><a name="line.293"></a>
<span class="sourceLineNo">294</span><a name="line.294"></a>
<span class="sourceLineNo">295</span> updateInputStreamStatistics(stream);<a name="line.295"></a>
-<span class="sourceLineNo">296</span> IOUtils.closeQuietly(stream);<a name="line.296"></a>
+<span class="sourceLineNo">296</span> Closeables.closeQuietly(stream);<a name="line.296"></a>
<span class="sourceLineNo">297</span> }<a name="line.297"></a>
<span class="sourceLineNo">298</span><a name="line.298"></a>
<span class="sourceLineNo">299</span> public HFileSystem getHfs() {<a name="line.299"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
index 029218b..9100a21 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/FSDataInputStreamWrapper.html
@@ -29,17 +29,17 @@
<span class="sourceLineNo">021</span>import java.io.IOException;<a name="line.21"></a>
<span class="sourceLineNo">022</span>import java.io.InputStream;<a name="line.22"></a>
<span class="sourceLineNo">023</span>import java.util.concurrent.atomic.AtomicInteger;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>import org.apache.commons.io.IOUtils;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.slf4j.Logger;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.slf4j.LoggerFactory;<a name="line.34"></a>
+<span class="sourceLineNo">024</span>import org.apache.hadoop.fs.CanUnbuffer;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.fs.HFileSystem;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hdfs.client.HdfsDataInputStream;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.slf4j.Logger;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.slf4j.LoggerFactory;<a name="line.32"></a>
+<span class="sourceLineNo">033</span><a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.34"></a>
<span class="sourceLineNo">035</span><a name="line.35"></a>
<span class="sourceLineNo">036</span>/**<a name="line.36"></a>
<span class="sourceLineNo">037</span> * Wrapper for input stream(s) that takes care of the interaction of FS and HBase checksums,<a name="line.37"></a>
@@ -297,11 +297,11 @@
<span class="sourceLineNo">289</span> }<a name="line.289"></a>
<span class="sourceLineNo">290</span> updateInputStreamStatistics(this.streamNoFsChecksum);<a name="line.290"></a>
<span class="sourceLineNo">291</span> // we do not care about the close exception as it is for reading, no data loss issue.<a name="line.291"></a>
-<span class="sourceLineNo">292</span> IOUtils.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
+<span class="sourceLineNo">292</span> Closeables.closeQuietly(streamNoFsChecksum);<a name="line.292"></a>
<span class="sourceLineNo">293</span><a name="line.293"></a>
<span class="sourceLineNo">294</span><a name="line.294"></a>
<span class="sourceLineNo">295</span> updateInputStreamStatistics(stream);<a name="line.295"></a>
-<span class="sourceLineNo">296</span> IOUtils.closeQuietly(stream);<a name="line.296"></a>
+<span class="sourceLineNo">296</span> Closeables.closeQuietly(stream);<a name="line.296"></a>
<span class="sourceLineNo">297</span> }<a name="line.297"></a>
<span class="sourceLineNo">298</span><a name="line.298"></a>
<span class="sourceLineNo">299</span> public HFileSystem getHfs() {<a name="line.299"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.CachingBlockReader.html
@@ -513,180 +513,181 @@
<span class="sourceLineNo">505</span> throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
<span class="sourceLineNo">506</span> }<a name="line.506"></a>
<span class="sourceLineNo">507</span> } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span> + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span> } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span> context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span> * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span> * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span> * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span> * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span> * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span> * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span> */<a name="line.524"></a>
-<span class="sourceLineNo">525</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span> throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span> }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span> /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span> * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span> * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span> * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span> * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span> * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span> * is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span> */<a name="line.542"></a>
-<span class="sourceLineNo">543</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span> .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span> .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span> .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span> .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span> fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span> return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span> }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span> /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span> * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span> * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span> * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span> */<a name="line.567"></a>
-<span class="sourceLineNo">568</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span> * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span> * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span> * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span> */<a name="line.578"></a>
-<span class="sourceLineNo">579</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span> throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span> final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span> return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span> } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span> return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> }<a name="line.590"></a>
-<span class="sourceLineNo">591</span> }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span> /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span> * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span> *<a name="line.596"></a>
-<span class="sourceLineNo">597</span> * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span> * algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span> * supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span> * <ul><a name="line.600"></a>
-<span class="sourceLineNo">601</span> * <li>"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span> * <li>"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span> * </ul><a name="line.603"></a>
-<span class="sourceLineNo">604</span> */<a name="line.604"></a>
-<span class="sourceLineNo">605</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span> }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span> // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span> /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span> * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span> * @return <code>l</code> cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span> */<a name="line.613"></a>
-<span class="sourceLineNo">614</span> static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span> return (int)(l & 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span> /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span> * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span> *<a name="line.623"></a>
-<span class="sourceLineNo">624</span> * @param fs The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span> * @param regionDir The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span> * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span> * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span> */<a name="line.628"></a>
-<span class="sourceLineNo">629</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span> throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.631"></a>
-<span class="sourceLineNo">632</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span> for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span> for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span> if (!file.isDirectory() &&<a name="line.637"></a>
-<span class="sourceLineNo">638</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.638"></a>
-<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span> regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span> }<a name="line.641"></a>
-<span class="sourceLineNo">642</span> }<a name="line.642"></a>
-<span class="sourceLineNo">643</span> }<a name="line.643"></a>
-<span class="sourceLineNo">644</span> return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span> }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span> /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span> * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span> * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span> *<a name="line.652"></a>
-<span class="sourceLineNo">653</span> * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span> * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span> */<a name="line.655"></a>
-<span class="sourceLineNo">656</span> public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span> throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span> + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span> }<a name="line.662"></a>
-<span class="sourceLineNo">663</span> }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span> + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span> } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span> context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span> }<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span> * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span> * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span> * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span> * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span> * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span> * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span> */<a name="line.525"></a>
+<span class="sourceLineNo">526</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span> throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span> * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span> * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span> * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span> * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span> * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span> * is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span> */<a name="line.543"></a>
+<span class="sourceLineNo">544</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span> ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span> .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span> .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span> .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span> .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span> .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span> fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span> return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span> }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span> /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span> * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span> * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span> * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span> */<a name="line.568"></a>
+<span class="sourceLineNo">569</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span> }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span> /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span> * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span> * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span> * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span> */<a name="line.579"></a>
+<span class="sourceLineNo">580</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span> throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span> final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span> return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span> }<a name="line.591"></a>
+<span class="sourceLineNo">592</span> }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span> /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span> * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span> *<a name="line.597"></a>
+<span class="sourceLineNo">598</span> * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span> * algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span> * supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span> * <ul><a name="line.601"></a>
+<span class="sourceLineNo">602</span> * <li>"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span> * <li>"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span> * </ul><a name="line.604"></a>
+<span class="sourceLineNo">605</span> */<a name="line.605"></a>
+<span class="sourceLineNo">606</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span> return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span> }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span> // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span> /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span> * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span> * @return <code>l</code> cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span> */<a name="line.614"></a>
+<span class="sourceLineNo">615</span> static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span> return (int)(l & 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span> }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span> /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span> * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span> *<a name="line.624"></a>
+<span class="sourceLineNo">625</span> * @param fs The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span> * @param regionDir The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span> * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span> * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span> */<a name="line.629"></a>
+<span class="sourceLineNo">630</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span> throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.632"></a>
+<span class="sourceLineNo">633</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span> for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span> for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span> if (!file.isDirectory() &&<a name="line.638"></a>
+<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.639"></a>
+<span class="sourceLineNo">640</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> }<a name="line.643"></a>
+<span class="sourceLineNo">644</span> }<a name="line.644"></a>
+<span class="sourceLineNo">645</span> return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span> /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span> * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span> * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span> *<a name="line.653"></a>
+<span class="sourceLineNo">654</span> * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span> * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span> */<a name="line.656"></a>
+<span class="sourceLineNo">657</span> public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span> throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span> + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span> }<a name="line.663"></a>
+<span class="sourceLineNo">664</span> }<a name="line.664"></a>
<span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span> public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span> MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span> }<a name="line.674"></a>
-<span class="sourceLineNo">675</span> }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span> public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span> // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span> HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span> }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span> public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span> MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span> }<a name="line.675"></a>
+<span class="sourceLineNo">676</span> }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span> public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span> // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span> HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span> }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Reader.html
@@ -513,180 +513,181 @@
<span class="sourceLineNo">505</span> throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
<span class="sourceLineNo">506</span> }<a name="line.506"></a>
<span class="sourceLineNo">507</span> } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span> + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span> } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span> context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span> * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span> * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span> * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span> * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span> * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span> * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span> */<a name="line.524"></a>
-<span class="sourceLineNo">525</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span> throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span> }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span> /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span> * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span> * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span> * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span> * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span> * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span> * is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span> */<a name="line.542"></a>
-<span class="sourceLineNo">543</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span> .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span> .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span> .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span> .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span> fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span> return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span> }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span> /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span> * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span> * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span> * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span> */<a name="line.567"></a>
-<span class="sourceLineNo">568</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span> * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span> * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span> * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span> */<a name="line.578"></a>
-<span class="sourceLineNo">579</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span> throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span> final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span> return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span> } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span> return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> }<a name="line.590"></a>
-<span class="sourceLineNo">591</span> }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span> /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span> * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span> *<a name="line.596"></a>
-<span class="sourceLineNo">597</span> * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span> * algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span> * supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span> * <ul><a name="line.600"></a>
-<span class="sourceLineNo">601</span> * <li>"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span> * <li>"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span> * </ul><a name="line.603"></a>
-<span class="sourceLineNo">604</span> */<a name="line.604"></a>
-<span class="sourceLineNo">605</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span> }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span> // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span> /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span> * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span> * @return <code>l</code> cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span> */<a name="line.613"></a>
-<span class="sourceLineNo">614</span> static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span> return (int)(l & 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span> /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span> * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span> *<a name="line.623"></a>
-<span class="sourceLineNo">624</span> * @param fs The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span> * @param regionDir The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span> * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span> * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span> */<a name="line.628"></a>
-<span class="sourceLineNo">629</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span> throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.631"></a>
-<span class="sourceLineNo">632</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span> for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span> for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span> if (!file.isDirectory() &&<a name="line.637"></a>
-<span class="sourceLineNo">638</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.638"></a>
-<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span> regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span> }<a name="line.641"></a>
-<span class="sourceLineNo">642</span> }<a name="line.642"></a>
-<span class="sourceLineNo">643</span> }<a name="line.643"></a>
-<span class="sourceLineNo">644</span> return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span> }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span> /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span> * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span> * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span> *<a name="line.652"></a>
-<span class="sourceLineNo">653</span> * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span> * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span> */<a name="line.655"></a>
-<span class="sourceLineNo">656</span> public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span> throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span> + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span> }<a name="line.662"></a>
-<span class="sourceLineNo">663</span> }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span> + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span> } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span> context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span> }<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span> * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span> * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span> * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span> * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span> * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span> * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span> */<a name="line.525"></a>
+<span class="sourceLineNo">526</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span> throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span> * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span> * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span> * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span> * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span> * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span> * is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span> */<a name="line.543"></a>
+<span class="sourceLineNo">544</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span> ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span> .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span> .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span> .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span> .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span> .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span> fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span> return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span> }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span> /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span> * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span> * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span> * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span> */<a name="line.568"></a>
+<span class="sourceLineNo">569</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span> }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span> /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span> * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span> * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span> * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span> */<a name="line.579"></a>
+<span class="sourceLineNo">580</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span> throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span> final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span> return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span> }<a name="line.591"></a>
+<span class="sourceLineNo">592</span> }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span> /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span> * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span> *<a name="line.597"></a>
+<span class="sourceLineNo">598</span> * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span> * algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span> * supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span> * <ul><a name="line.601"></a>
+<span class="sourceLineNo">602</span> * <li>"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span> * <li>"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span> * </ul><a name="line.604"></a>
+<span class="sourceLineNo">605</span> */<a name="line.605"></a>
+<span class="sourceLineNo">606</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span> return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span> }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span> // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span> /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span> * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span> * @return <code>l</code> cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span> */<a name="line.614"></a>
+<span class="sourceLineNo">615</span> static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span> return (int)(l & 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span> }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span> /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span> * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span> *<a name="line.624"></a>
+<span class="sourceLineNo">625</span> * @param fs The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span> * @param regionDir The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span> * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span> * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span> */<a name="line.629"></a>
+<span class="sourceLineNo">630</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span> throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.632"></a>
+<span class="sourceLineNo">633</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span> for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span> for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span> if (!file.isDirectory() &&<a name="line.638"></a>
+<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.639"></a>
+<span class="sourceLineNo">640</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> }<a name="line.643"></a>
+<span class="sourceLineNo">644</span> }<a name="line.644"></a>
+<span class="sourceLineNo">645</span> return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span> /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span> * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span> * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span> *<a name="line.653"></a>
+<span class="sourceLineNo">654</span> * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span> * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span> */<a name="line.656"></a>
+<span class="sourceLineNo">657</span> public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span> throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span> + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span> }<a name="line.663"></a>
+<span class="sourceLineNo">664</span> }<a name="line.664"></a>
<span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span> public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span> MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span> }<a name="line.674"></a>
-<span class="sourceLineNo">675</span> }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span> public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span> // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span> HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span> }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span> public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span> MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span> }<a name="line.675"></a>
+<span class="sourceLineNo">676</span> }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span> public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span> // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span> HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span> }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.Writer.html
@@ -513,180 +513,181 @@
<span class="sourceLineNo">505</span> throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
<span class="sourceLineNo">506</span> }<a name="line.506"></a>
<span class="sourceLineNo">507</span> } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span> + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span> } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span> context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span> * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span> * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span> * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span> * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span> * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span> * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span> */<a name="line.524"></a>
-<span class="sourceLineNo">525</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span> throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span> }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span> /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span> * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span> * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span> * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span> * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span> * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span> * is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span> */<a name="line.542"></a>
-<span class="sourceLineNo">543</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span> .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span> .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span> .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span> .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span> fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span> return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span> }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span> /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span> * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span> * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span> * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span> */<a name="line.567"></a>
-<span class="sourceLineNo">568</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span> * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span> * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span> * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span> */<a name="line.578"></a>
-<span class="sourceLineNo">579</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span> throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span> final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span> return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span> } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span> return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> }<a name="line.590"></a>
-<span class="sourceLineNo">591</span> }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span> /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span> * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span> *<a name="line.596"></a>
-<span class="sourceLineNo">597</span> * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span> * algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span> * supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span> * <ul><a name="line.600"></a>
-<span class="sourceLineNo">601</span> * <li>"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span> * <li>"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span> * </ul><a name="line.603"></a>
-<span class="sourceLineNo">604</span> */<a name="line.604"></a>
-<span class="sourceLineNo">605</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span> }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span> // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span> /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span> * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span> * @return <code>l</code> cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span> */<a name="line.613"></a>
-<span class="sourceLineNo">614</span> static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span> return (int)(l & 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span> /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span> * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span> *<a name="line.623"></a>
-<span class="sourceLineNo">624</span> * @param fs The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span> * @param regionDir The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span> * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span> * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span> */<a name="line.628"></a>
-<span class="sourceLineNo">629</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span> throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.631"></a>
-<span class="sourceLineNo">632</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span> for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span> for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span> if (!file.isDirectory() &&<a name="line.637"></a>
-<span class="sourceLineNo">638</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.638"></a>
-<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span> regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span> }<a name="line.641"></a>
-<span class="sourceLineNo">642</span> }<a name="line.642"></a>
-<span class="sourceLineNo">643</span> }<a name="line.643"></a>
-<span class="sourceLineNo">644</span> return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span> }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span> /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span> * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span> * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span> *<a name="line.652"></a>
-<span class="sourceLineNo">653</span> * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span> * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span> */<a name="line.655"></a>
-<span class="sourceLineNo">656</span> public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span> throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span> + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span> }<a name="line.662"></a>
-<span class="sourceLineNo">663</span> }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span> + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span> } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span> context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span> }<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span> * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span> * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span> * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span> * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span> * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span> * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span> */<a name="line.525"></a>
+<span class="sourceLineNo">526</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span> throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span> * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span> * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span> * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span> * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span> * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span> * is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span> */<a name="line.543"></a>
+<span class="sourceLineNo">544</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span> ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span> .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span> .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span> .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span> .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span> .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span> fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span> return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span> }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span> /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span> * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span> * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span> * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span> */<a name="line.568"></a>
+<span class="sourceLineNo">569</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span> }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span> /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span> * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span> * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span> * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span> */<a name="line.579"></a>
+<span class="sourceLineNo">580</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span> throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span> final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span> return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span> }<a name="line.591"></a>
+<span class="sourceLineNo">592</span> }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span> /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span> * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span> *<a name="line.597"></a>
+<span class="sourceLineNo">598</span> * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span> * algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span> * supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span> * <ul><a name="line.601"></a>
+<span class="sourceLineNo">602</span> * <li>"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span> * <li>"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span> * </ul><a name="line.604"></a>
+<span class="sourceLineNo">605</span> */<a name="line.605"></a>
+<span class="sourceLineNo">606</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span> return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span> }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span> // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span> /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span> * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span> * @return <code>l</code> cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span> */<a name="line.614"></a>
+<span class="sourceLineNo">615</span> static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span> return (int)(l & 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span> }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span> /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span> * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span> *<a name="line.624"></a>
+<span class="sourceLineNo">625</span> * @param fs The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span> * @param regionDir The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span> * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span> * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span> */<a name="line.629"></a>
+<span class="sourceLineNo">630</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span> throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.632"></a>
+<span class="sourceLineNo">633</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span> for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span> for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span> if (!file.isDirectory() &&<a name="line.638"></a>
+<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.639"></a>
+<span class="sourceLineNo">640</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> }<a name="line.643"></a>
+<span class="sourceLineNo">644</span> }<a name="line.644"></a>
+<span class="sourceLineNo">645</span> return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span> /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span> * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span> * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span> *<a name="line.653"></a>
+<span class="sourceLineNo">654</span> * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span> * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span> */<a name="line.656"></a>
+<span class="sourceLineNo">657</span> public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span> throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span> + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span> }<a name="line.663"></a>
+<span class="sourceLineNo">664</span> }<a name="line.664"></a>
<span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span> public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span> MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span> }<a name="line.674"></a>
-<span class="sourceLineNo">675</span> }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span> public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span> // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span> HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span> }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span> public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span> MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span> }<a name="line.675"></a>
+<span class="sourceLineNo">676</span> }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span> public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span> // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span> HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span> }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.WriterFactory.html
@@ -513,180 +513,181 @@
<span class="sourceLineNo">505</span> throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
<span class="sourceLineNo">506</span> }<a name="line.506"></a>
<span class="sourceLineNo">507</span> } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span> + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span> } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span> context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span> * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span> * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span> * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span> * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span> * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span> * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span> */<a name="line.524"></a>
-<span class="sourceLineNo">525</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span> throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span> }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span> /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span> * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span> * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span> * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span> * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span> * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span> * is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span> */<a name="line.542"></a>
-<span class="sourceLineNo">543</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span> .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span> .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span> .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span> .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span> fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span> return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span> }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span> /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span> * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span> * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span> * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span> */<a name="line.567"></a>
-<span class="sourceLineNo">568</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span> * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span> * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span> * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span> */<a name="line.578"></a>
-<span class="sourceLineNo">579</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span> throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span> final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span> return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span> } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span> return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> }<a name="line.590"></a>
-<span class="sourceLineNo">591</span> }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span> /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span> * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span> *<a name="line.596"></a>
-<span class="sourceLineNo">597</span> * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span> * algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span> * supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span> * <ul><a name="line.600"></a>
-<span class="sourceLineNo">601</span> * <li>"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span> * <li>"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span> * </ul><a name="line.603"></a>
-<span class="sourceLineNo">604</span> */<a name="line.604"></a>
-<span class="sourceLineNo">605</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span> }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span> // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span> /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span> * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span> * @return <code>l</code> cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span> */<a name="line.613"></a>
-<span class="sourceLineNo">614</span> static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span> return (int)(l & 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span> /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span> * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span> *<a name="line.623"></a>
-<span class="sourceLineNo">624</span> * @param fs The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span> * @param regionDir The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span> * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span> * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span> */<a name="line.628"></a>
-<span class="sourceLineNo">629</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span> throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.631"></a>
-<span class="sourceLineNo">632</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span> for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span> for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span> if (!file.isDirectory() &&<a name="line.637"></a>
-<span class="sourceLineNo">638</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.638"></a>
-<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span> regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span> }<a name="line.641"></a>
-<span class="sourceLineNo">642</span> }<a name="line.642"></a>
-<span class="sourceLineNo">643</span> }<a name="line.643"></a>
-<span class="sourceLineNo">644</span> return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span> }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span> /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span> * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span> * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span> *<a name="line.652"></a>
-<span class="sourceLineNo">653</span> * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span> * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span> */<a name="line.655"></a>
-<span class="sourceLineNo">656</span> public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span> throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span> + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span> }<a name="line.662"></a>
-<span class="sourceLineNo">663</span> }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span> + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span> } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span> context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span> }<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span> * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span> * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span> * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span> * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span> * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span> * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span> */<a name="line.525"></a>
+<span class="sourceLineNo">526</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span> throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span> * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span> * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span> * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span> * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span> * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span> * is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span> */<a name="line.543"></a>
+<span class="sourceLineNo">544</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span> ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span> .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span> .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span> .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span> .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span> .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span> fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span> return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span> }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span> /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span> * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span> * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span> * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span> */<a name="line.568"></a>
+<span class="sourceLineNo">569</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span> }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span> /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span> * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span> * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span> * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span> */<a name="line.579"></a>
+<span class="sourceLineNo">580</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span> throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span> final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span> return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span> }<a name="line.591"></a>
+<span class="sourceLineNo">592</span> }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span> /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span> * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span> *<a name="line.597"></a>
+<span class="sourceLineNo">598</span> * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span> * algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span> * supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span> * <ul><a name="line.601"></a>
+<span class="sourceLineNo">602</span> * <li>"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span> * <li>"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span> * </ul><a name="line.604"></a>
+<span class="sourceLineNo">605</span> */<a name="line.605"></a>
+<span class="sourceLineNo">606</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span> return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span> }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span> // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span> /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span> * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span> * @return <code>l</code> cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span> */<a name="line.614"></a>
+<span class="sourceLineNo">615</span> static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span> return (int)(l & 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span> }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span> /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span> * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span> *<a name="line.624"></a>
+<span class="sourceLineNo">625</span> * @param fs The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span> * @param regionDir The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span> * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span> * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span> */<a name="line.629"></a>
+<span class="sourceLineNo">630</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span> throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.632"></a>
+<span class="sourceLineNo">633</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span> for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span> for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span> if (!file.isDirectory() &&<a name="line.638"></a>
+<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.639"></a>
+<span class="sourceLineNo">640</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> }<a name="line.643"></a>
+<span class="sourceLineNo">644</span> }<a name="line.644"></a>
+<span class="sourceLineNo">645</span> return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span> /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span> * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span> * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span> *<a name="line.653"></a>
+<span class="sourceLineNo">654</span> * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span> * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span> */<a name="line.656"></a>
+<span class="sourceLineNo">657</span> public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span> throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span> + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span> }<a name="line.663"></a>
+<span class="sourceLineNo">664</span> }<a name="line.664"></a>
<span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span> public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span> MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span> }<a name="line.674"></a>
-<span class="sourceLineNo">675</span> }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span> public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span> // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span> HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span> }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span> public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span> MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span> }<a name="line.675"></a>
+<span class="sourceLineNo">676</span> }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span> public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span> // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span> HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span> }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
index a82ba7f..2a91d20 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFile.html
@@ -513,180 +513,181 @@
<span class="sourceLineNo">505</span> throw new IllegalArgumentException("Invalid HFile version " + trailer.getMajorVersion());<a name="line.505"></a>
<span class="sourceLineNo">506</span> }<a name="line.506"></a>
<span class="sourceLineNo">507</span> } catch (Throwable t) {<a name="line.507"></a>
-<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.508"></a>
-<span class="sourceLineNo">509</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.509"></a>
-<span class="sourceLineNo">510</span> + context.getFilePath(), t);<a name="line.510"></a>
-<span class="sourceLineNo">511</span> } finally {<a name="line.511"></a>
-<span class="sourceLineNo">512</span> context.getInputStreamWrapper().unbuffer();<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> /**<a name="line.516"></a>
-<span class="sourceLineNo">517</span> * Creates reader with cache configuration disabled<a name="line.517"></a>
-<span class="sourceLineNo">518</span> * @param fs filesystem<a name="line.518"></a>
-<span class="sourceLineNo">519</span> * @param path Path to file to read<a name="line.519"></a>
-<span class="sourceLineNo">520</span> * @param conf Configuration<a name="line.520"></a>
-<span class="sourceLineNo">521</span> * @return an active Reader instance<a name="line.521"></a>
-<span class="sourceLineNo">522</span> * @throws IOException Will throw a CorruptHFileException<a name="line.522"></a>
-<span class="sourceLineNo">523</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.523"></a>
-<span class="sourceLineNo">524</span> */<a name="line.524"></a>
-<span class="sourceLineNo">525</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.525"></a>
-<span class="sourceLineNo">526</span> throws IOException {<a name="line.526"></a>
-<span class="sourceLineNo">527</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.527"></a>
-<span class="sourceLineNo">528</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.528"></a>
-<span class="sourceLineNo">529</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span> }<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span> /**<a name="line.532"></a>
-<span class="sourceLineNo">533</span> * @param fs filesystem<a name="line.533"></a>
-<span class="sourceLineNo">534</span> * @param path Path to file to read<a name="line.534"></a>
-<span class="sourceLineNo">535</span> * @param cacheConf This must not be null. @see<a name="line.535"></a>
-<span class="sourceLineNo">536</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.536"></a>
-<span class="sourceLineNo">537</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.537"></a>
-<span class="sourceLineNo">538</span> * @param conf Configuration<a name="line.538"></a>
-<span class="sourceLineNo">539</span> * @return an active Reader instance<a name="line.539"></a>
-<span class="sourceLineNo">540</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.540"></a>
-<span class="sourceLineNo">541</span> * is corrupt/invalid.<a name="line.541"></a>
-<span class="sourceLineNo">542</span> */<a name="line.542"></a>
-<span class="sourceLineNo">543</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.543"></a>
-<span class="sourceLineNo">544</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.544"></a>
-<span class="sourceLineNo">545</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.545"></a>
-<span class="sourceLineNo">546</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> ReaderContext context = new ReaderContextBuilder()<a name="line.547"></a>
-<span class="sourceLineNo">548</span> .withFilePath(path)<a name="line.548"></a>
-<span class="sourceLineNo">549</span> .withInputStreamWrapper(stream)<a name="line.549"></a>
-<span class="sourceLineNo">550</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.550"></a>
-<span class="sourceLineNo">551</span> .withFileSystem(stream.getHfs())<a name="line.551"></a>
-<span class="sourceLineNo">552</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.552"></a>
-<span class="sourceLineNo">553</span> .withReaderType(ReaderType.PREAD)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> .build();<a name="line.554"></a>
-<span class="sourceLineNo">555</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.555"></a>
-<span class="sourceLineNo">556</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.556"></a>
-<span class="sourceLineNo">557</span> fileInfo.initMetaAndIndex(reader);<a name="line.557"></a>
-<span class="sourceLineNo">558</span> return reader;<a name="line.558"></a>
-<span class="sourceLineNo">559</span> }<a name="line.559"></a>
-<span class="sourceLineNo">560</span><a name="line.560"></a>
-<span class="sourceLineNo">561</span> /**<a name="line.561"></a>
-<span class="sourceLineNo">562</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.562"></a>
-<span class="sourceLineNo">563</span> * @param fs filesystem<a name="line.563"></a>
-<span class="sourceLineNo">564</span> * @param path Path to file to verify<a name="line.564"></a>
-<span class="sourceLineNo">565</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.565"></a>
-<span class="sourceLineNo">566</span> * @throws IOException if failed to read from the underlying stream<a name="line.566"></a>
-<span class="sourceLineNo">567</span> */<a name="line.567"></a>
-<span class="sourceLineNo">568</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> /**<a name="line.572"></a>
-<span class="sourceLineNo">573</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.573"></a>
-<span class="sourceLineNo">574</span> * @param fs filesystem<a name="line.574"></a>
-<span class="sourceLineNo">575</span> * @param fileStatus the file to verify<a name="line.575"></a>
-<span class="sourceLineNo">576</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.576"></a>
-<span class="sourceLineNo">577</span> * @throws IOException if failed to read from the underlying stream<a name="line.577"></a>
-<span class="sourceLineNo">578</span> */<a name="line.578"></a>
-<span class="sourceLineNo">579</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.579"></a>
-<span class="sourceLineNo">580</span> throws IOException {<a name="line.580"></a>
-<span class="sourceLineNo">581</span> final Path path = fileStatus.getPath();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> final long size = fileStatus.getLen();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.583"></a>
-<span class="sourceLineNo">584</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.584"></a>
-<span class="sourceLineNo">585</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.585"></a>
-<span class="sourceLineNo">586</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.586"></a>
-<span class="sourceLineNo">587</span> return true;<a name="line.587"></a>
-<span class="sourceLineNo">588</span> } catch (IllegalArgumentException e) {<a name="line.588"></a>
-<span class="sourceLineNo">589</span> return false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> }<a name="line.590"></a>
-<span class="sourceLineNo">591</span> }<a name="line.591"></a>
-<span class="sourceLineNo">592</span><a name="line.592"></a>
-<span class="sourceLineNo">593</span> /**<a name="line.593"></a>
-<span class="sourceLineNo">594</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.594"></a>
-<span class="sourceLineNo">595</span> * HFile.Writer.<a name="line.595"></a>
-<span class="sourceLineNo">596</span> *<a name="line.596"></a>
-<span class="sourceLineNo">597</span> * @return Array of strings, each represents a supported compression<a name="line.597"></a>
-<span class="sourceLineNo">598</span> * algorithm. Currently, the following compression algorithms are<a name="line.598"></a>
-<span class="sourceLineNo">599</span> * supported.<a name="line.599"></a>
-<span class="sourceLineNo">600</span> * <ul><a name="line.600"></a>
-<span class="sourceLineNo">601</span> * <li>"none" - No compression.<a name="line.601"></a>
-<span class="sourceLineNo">602</span> * <li>"gz" - GZIP compression.<a name="line.602"></a>
-<span class="sourceLineNo">603</span> * </ul><a name="line.603"></a>
-<span class="sourceLineNo">604</span> */<a name="line.604"></a>
-<span class="sourceLineNo">605</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> return Compression.getSupportedAlgorithms();<a name="line.606"></a>
-<span class="sourceLineNo">607</span> }<a name="line.607"></a>
-<span class="sourceLineNo">608</span><a name="line.608"></a>
-<span class="sourceLineNo">609</span> // Utility methods.<a name="line.609"></a>
-<span class="sourceLineNo">610</span> /*<a name="line.610"></a>
-<span class="sourceLineNo">611</span> * @param l Long to convert to an int.<a name="line.611"></a>
-<span class="sourceLineNo">612</span> * @return <code>l</code> cast as an int.<a name="line.612"></a>
-<span class="sourceLineNo">613</span> */<a name="line.613"></a>
-<span class="sourceLineNo">614</span> static int longToInt(final long l) {<a name="line.614"></a>
-<span class="sourceLineNo">615</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.615"></a>
-<span class="sourceLineNo">616</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.616"></a>
-<span class="sourceLineNo">617</span> return (int)(l & 0x00000000ffffffffL);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> }<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span> /**<a name="line.620"></a>
-<span class="sourceLineNo">621</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.621"></a>
-<span class="sourceLineNo">622</span> * empty list.<a name="line.622"></a>
-<span class="sourceLineNo">623</span> *<a name="line.623"></a>
-<span class="sourceLineNo">624</span> * @param fs The file system reference.<a name="line.624"></a>
-<span class="sourceLineNo">625</span> * @param regionDir The region directory to scan.<a name="line.625"></a>
-<span class="sourceLineNo">626</span> * @return The list of files found.<a name="line.626"></a>
-<span class="sourceLineNo">627</span> * @throws IOException When scanning the files fails.<a name="line.627"></a>
-<span class="sourceLineNo">628</span> */<a name="line.628"></a>
-<span class="sourceLineNo">629</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.629"></a>
-<span class="sourceLineNo">630</span> throws IOException {<a name="line.630"></a>
-<span class="sourceLineNo">631</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.631"></a>
-<span class="sourceLineNo">632</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.632"></a>
-<span class="sourceLineNo">633</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.633"></a>
-<span class="sourceLineNo">634</span> for(FileStatus dir : familyDirs) {<a name="line.634"></a>
-<span class="sourceLineNo">635</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.635"></a>
-<span class="sourceLineNo">636</span> for (FileStatus file : files) {<a name="line.636"></a>
-<span class="sourceLineNo">637</span> if (!file.isDirectory() &&<a name="line.637"></a>
-<span class="sourceLineNo">638</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.638"></a>
-<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.639"></a>
-<span class="sourceLineNo">640</span> regionHFiles.add(file.getPath());<a name="line.640"></a>
-<span class="sourceLineNo">641</span> }<a name="line.641"></a>
-<span class="sourceLineNo">642</span> }<a name="line.642"></a>
-<span class="sourceLineNo">643</span> }<a name="line.643"></a>
-<span class="sourceLineNo">644</span> return regionHFiles;<a name="line.644"></a>
-<span class="sourceLineNo">645</span> }<a name="line.645"></a>
-<span class="sourceLineNo">646</span><a name="line.646"></a>
-<span class="sourceLineNo">647</span> /**<a name="line.647"></a>
-<span class="sourceLineNo">648</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.648"></a>
-<span class="sourceLineNo">649</span> * invalid. Note that if the version number comes from an input file and has<a name="line.649"></a>
-<span class="sourceLineNo">650</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.650"></a>
-<span class="sourceLineNo">651</span> * indicate that this is not a software error, but corrupted input.<a name="line.651"></a>
-<span class="sourceLineNo">652</span> *<a name="line.652"></a>
-<span class="sourceLineNo">653</span> * @param version an HFile version<a name="line.653"></a>
-<span class="sourceLineNo">654</span> * @throws IllegalArgumentException if the version is invalid<a name="line.654"></a>
-<span class="sourceLineNo">655</span> */<a name="line.655"></a>
-<span class="sourceLineNo">656</span> public static void checkFormatVersion(int version)<a name="line.656"></a>
-<span class="sourceLineNo">657</span> throws IllegalArgumentException {<a name="line.657"></a>
-<span class="sourceLineNo">658</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.658"></a>
-<span class="sourceLineNo">659</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.659"></a>
-<span class="sourceLineNo">660</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.660"></a>
-<span class="sourceLineNo">661</span> + MAX_FORMAT_VERSION + ")");<a name="line.661"></a>
-<span class="sourceLineNo">662</span> }<a name="line.662"></a>
-<span class="sourceLineNo">663</span> }<a name="line.663"></a>
-<span class="sourceLineNo">664</span><a name="line.664"></a>
+<span class="sourceLineNo">508</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.508"></a>
+<span class="sourceLineNo">509</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.509"></a>
+<span class="sourceLineNo">510</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.510"></a>
+<span class="sourceLineNo">511</span> + context.getFilePath(), t);<a name="line.511"></a>
+<span class="sourceLineNo">512</span> } finally {<a name="line.512"></a>
+<span class="sourceLineNo">513</span> context.getInputStreamWrapper().unbuffer();<a name="line.513"></a>
+<span class="sourceLineNo">514</span> }<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> /**<a name="line.517"></a>
+<span class="sourceLineNo">518</span> * Creates reader with cache configuration disabled<a name="line.518"></a>
+<span class="sourceLineNo">519</span> * @param fs filesystem<a name="line.519"></a>
+<span class="sourceLineNo">520</span> * @param path Path to file to read<a name="line.520"></a>
+<span class="sourceLineNo">521</span> * @param conf Configuration<a name="line.521"></a>
+<span class="sourceLineNo">522</span> * @return an active Reader instance<a name="line.522"></a>
+<span class="sourceLineNo">523</span> * @throws IOException Will throw a CorruptHFileException<a name="line.523"></a>
+<span class="sourceLineNo">524</span> * (DoNotRetryIOException subtype) if hfile is corrupt/invalid.<a name="line.524"></a>
+<span class="sourceLineNo">525</span> */<a name="line.525"></a>
+<span class="sourceLineNo">526</span> public static Reader createReader(FileSystem fs, Path path, Configuration conf)<a name="line.526"></a>
+<span class="sourceLineNo">527</span> throws IOException {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> // The primaryReplicaReader is mainly used for constructing block cache key, so if we do not use<a name="line.528"></a>
+<span class="sourceLineNo">529</span> // block cache then it is OK to set it as any value. We use true here.<a name="line.529"></a>
+<span class="sourceLineNo">530</span> return createReader(fs, path, CacheConfig.DISABLED, true, conf);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> /**<a name="line.533"></a>
+<span class="sourceLineNo">534</span> * @param fs filesystem<a name="line.534"></a>
+<span class="sourceLineNo">535</span> * @param path Path to file to read<a name="line.535"></a>
+<span class="sourceLineNo">536</span> * @param cacheConf This must not be null. @see<a name="line.536"></a>
+<span class="sourceLineNo">537</span> * {@link org.apache.hadoop.hbase.io.hfile.CacheConfig#CacheConfig(Configuration)}<a name="line.537"></a>
+<span class="sourceLineNo">538</span> * @param primaryReplicaReader true if this is a reader for primary replica<a name="line.538"></a>
+<span class="sourceLineNo">539</span> * @param conf Configuration<a name="line.539"></a>
+<span class="sourceLineNo">540</span> * @return an active Reader instance<a name="line.540"></a>
+<span class="sourceLineNo">541</span> * @throws IOException Will throw a CorruptHFileException (DoNotRetryIOException subtype) if hfile<a name="line.541"></a>
+<span class="sourceLineNo">542</span> * is corrupt/invalid.<a name="line.542"></a>
+<span class="sourceLineNo">543</span> */<a name="line.543"></a>
+<span class="sourceLineNo">544</span> public static Reader createReader(FileSystem fs, Path path, CacheConfig cacheConf,<a name="line.544"></a>
+<span class="sourceLineNo">545</span> boolean primaryReplicaReader, Configuration conf) throws IOException {<a name="line.545"></a>
+<span class="sourceLineNo">546</span> Preconditions.checkNotNull(cacheConf, "Cannot create Reader with null CacheConf");<a name="line.546"></a>
+<span class="sourceLineNo">547</span> FSDataInputStreamWrapper stream = new FSDataInputStreamWrapper(fs, path);<a name="line.547"></a>
+<span class="sourceLineNo">548</span> ReaderContext context = new ReaderContextBuilder()<a name="line.548"></a>
+<span class="sourceLineNo">549</span> .withFilePath(path)<a name="line.549"></a>
+<span class="sourceLineNo">550</span> .withInputStreamWrapper(stream)<a name="line.550"></a>
+<span class="sourceLineNo">551</span> .withFileSize(fs.getFileStatus(path).getLen())<a name="line.551"></a>
+<span class="sourceLineNo">552</span> .withFileSystem(stream.getHfs())<a name="line.552"></a>
+<span class="sourceLineNo">553</span> .withPrimaryReplicaReader(primaryReplicaReader)<a name="line.553"></a>
+<span class="sourceLineNo">554</span> .withReaderType(ReaderType.PREAD)<a name="line.554"></a>
+<span class="sourceLineNo">555</span> .build();<a name="line.555"></a>
+<span class="sourceLineNo">556</span> HFileInfo fileInfo = new HFileInfo(context, conf);<a name="line.556"></a>
+<span class="sourceLineNo">557</span> Reader reader = createReader(context, fileInfo, cacheConf, conf);<a name="line.557"></a>
+<span class="sourceLineNo">558</span> fileInfo.initMetaAndIndex(reader);<a name="line.558"></a>
+<span class="sourceLineNo">559</span> return reader;<a name="line.559"></a>
+<span class="sourceLineNo">560</span> }<a name="line.560"></a>
+<span class="sourceLineNo">561</span><a name="line.561"></a>
+<span class="sourceLineNo">562</span> /**<a name="line.562"></a>
+<span class="sourceLineNo">563</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.563"></a>
+<span class="sourceLineNo">564</span> * @param fs filesystem<a name="line.564"></a>
+<span class="sourceLineNo">565</span> * @param path Path to file to verify<a name="line.565"></a>
+<span class="sourceLineNo">566</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.566"></a>
+<span class="sourceLineNo">567</span> * @throws IOException if failed to read from the underlying stream<a name="line.567"></a>
+<span class="sourceLineNo">568</span> */<a name="line.568"></a>
+<span class="sourceLineNo">569</span> public static boolean isHFileFormat(final FileSystem fs, final Path path) throws IOException {<a name="line.569"></a>
+<span class="sourceLineNo">570</span> return isHFileFormat(fs, fs.getFileStatus(path));<a name="line.570"></a>
+<span class="sourceLineNo">571</span> }<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span> /**<a name="line.573"></a>
+<span class="sourceLineNo">574</span> * Returns true if the specified file has a valid HFile Trailer.<a name="line.574"></a>
+<span class="sourceLineNo">575</span> * @param fs filesystem<a name="line.575"></a>
+<span class="sourceLineNo">576</span> * @param fileStatus the file to verify<a name="line.576"></a>
+<span class="sourceLineNo">577</span> * @return true if the file has a valid HFile Trailer, otherwise false<a name="line.577"></a>
+<span class="sourceLineNo">578</span> * @throws IOException if failed to read from the underlying stream<a name="line.578"></a>
+<span class="sourceLineNo">579</span> */<a name="line.579"></a>
+<span class="sourceLineNo">580</span> public static boolean isHFileFormat(final FileSystem fs, final FileStatus fileStatus)<a name="line.580"></a>
+<span class="sourceLineNo">581</span> throws IOException {<a name="line.581"></a>
+<span class="sourceLineNo">582</span> final Path path = fileStatus.getPath();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> final long size = fileStatus.getLen();<a name="line.583"></a>
+<span class="sourceLineNo">584</span> try (FSDataInputStreamWrapper fsdis = new FSDataInputStreamWrapper(fs, path)) {<a name="line.584"></a>
+<span class="sourceLineNo">585</span> boolean isHBaseChecksum = fsdis.shouldUseHBaseChecksum();<a name="line.585"></a>
+<span class="sourceLineNo">586</span> assert !isHBaseChecksum; // Initially we must read with FS checksum.<a name="line.586"></a>
+<span class="sourceLineNo">587</span> FixedFileTrailer.readFromStream(fsdis.getStream(isHBaseChecksum), size);<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return true;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> } catch (IllegalArgumentException e) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span> return false;<a name="line.590"></a>
+<span class="sourceLineNo">591</span> }<a name="line.591"></a>
+<span class="sourceLineNo">592</span> }<a name="line.592"></a>
+<span class="sourceLineNo">593</span><a name="line.593"></a>
+<span class="sourceLineNo">594</span> /**<a name="line.594"></a>
+<span class="sourceLineNo">595</span> * Get names of supported compression algorithms. The names are acceptable by<a name="line.595"></a>
+<span class="sourceLineNo">596</span> * HFile.Writer.<a name="line.596"></a>
+<span class="sourceLineNo">597</span> *<a name="line.597"></a>
+<span class="sourceLineNo">598</span> * @return Array of strings, each represents a supported compression<a name="line.598"></a>
+<span class="sourceLineNo">599</span> * algorithm. Currently, the following compression algorithms are<a name="line.599"></a>
+<span class="sourceLineNo">600</span> * supported.<a name="line.600"></a>
+<span class="sourceLineNo">601</span> * <ul><a name="line.601"></a>
+<span class="sourceLineNo">602</span> * <li>"none" - No compression.<a name="line.602"></a>
+<span class="sourceLineNo">603</span> * <li>"gz" - GZIP compression.<a name="line.603"></a>
+<span class="sourceLineNo">604</span> * </ul><a name="line.604"></a>
+<span class="sourceLineNo">605</span> */<a name="line.605"></a>
+<span class="sourceLineNo">606</span> public static String[] getSupportedCompressionAlgorithms() {<a name="line.606"></a>
+<span class="sourceLineNo">607</span> return Compression.getSupportedAlgorithms();<a name="line.607"></a>
+<span class="sourceLineNo">608</span> }<a name="line.608"></a>
+<span class="sourceLineNo">609</span><a name="line.609"></a>
+<span class="sourceLineNo">610</span> // Utility methods.<a name="line.610"></a>
+<span class="sourceLineNo">611</span> /*<a name="line.611"></a>
+<span class="sourceLineNo">612</span> * @param l Long to convert to an int.<a name="line.612"></a>
+<span class="sourceLineNo">613</span> * @return <code>l</code> cast as an int.<a name="line.613"></a>
+<span class="sourceLineNo">614</span> */<a name="line.614"></a>
+<span class="sourceLineNo">615</span> static int longToInt(final long l) {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> // Expecting the size() of a block not exceeding 4GB. Assuming the<a name="line.616"></a>
+<span class="sourceLineNo">617</span> // size() will wrap to negative integer if it exceeds 2GB (From tfile).<a name="line.617"></a>
+<span class="sourceLineNo">618</span> return (int)(l & 0x00000000ffffffffL);<a name="line.618"></a>
+<span class="sourceLineNo">619</span> }<a name="line.619"></a>
+<span class="sourceLineNo">620</span><a name="line.620"></a>
+<span class="sourceLineNo">621</span> /**<a name="line.621"></a>
+<span class="sourceLineNo">622</span> * Returns all HFiles belonging to the given region directory. Could return an<a name="line.622"></a>
+<span class="sourceLineNo">623</span> * empty list.<a name="line.623"></a>
+<span class="sourceLineNo">624</span> *<a name="line.624"></a>
+<span class="sourceLineNo">625</span> * @param fs The file system reference.<a name="line.625"></a>
+<span class="sourceLineNo">626</span> * @param regionDir The region directory to scan.<a name="line.626"></a>
+<span class="sourceLineNo">627</span> * @return The list of files found.<a name="line.627"></a>
+<span class="sourceLineNo">628</span> * @throws IOException When scanning the files fails.<a name="line.628"></a>
+<span class="sourceLineNo">629</span> */<a name="line.629"></a>
+<span class="sourceLineNo">630</span> public static List<Path> getStoreFiles(FileSystem fs, Path regionDir)<a name="line.630"></a>
+<span class="sourceLineNo">631</span> throws IOException {<a name="line.631"></a>
+<span class="sourceLineNo">632</span> List<Path> regionHFiles = new ArrayList<>();<a name="line.632"></a>
+<span class="sourceLineNo">633</span> PathFilter dirFilter = new FSUtils.DirFilter(fs);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> FileStatus[] familyDirs = fs.listStatus(regionDir, dirFilter);<a name="line.634"></a>
+<span class="sourceLineNo">635</span> for(FileStatus dir : familyDirs) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> FileStatus[] files = fs.listStatus(dir.getPath());<a name="line.636"></a>
+<span class="sourceLineNo">637</span> for (FileStatus file : files) {<a name="line.637"></a>
+<span class="sourceLineNo">638</span> if (!file.isDirectory() &&<a name="line.638"></a>
+<span class="sourceLineNo">639</span> (!file.getPath().toString().contains(HConstants.HREGION_OLDLOGDIR_NAME)) &&<a name="line.639"></a>
+<span class="sourceLineNo">640</span> (!file.getPath().toString().contains(HConstants.RECOVERED_EDITS_DIR))) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> regionHFiles.add(file.getPath());<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> }<a name="line.643"></a>
+<span class="sourceLineNo">644</span> }<a name="line.644"></a>
+<span class="sourceLineNo">645</span> return regionHFiles;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> }<a name="line.646"></a>
+<span class="sourceLineNo">647</span><a name="line.647"></a>
+<span class="sourceLineNo">648</span> /**<a name="line.648"></a>
+<span class="sourceLineNo">649</span> * Checks the given {@link HFile} format version, and throws an exception if<a name="line.649"></a>
+<span class="sourceLineNo">650</span> * invalid. Note that if the version number comes from an input file and has<a name="line.650"></a>
+<span class="sourceLineNo">651</span> * not been verified, the caller needs to re-throw an {@link IOException} to<a name="line.651"></a>
+<span class="sourceLineNo">652</span> * indicate that this is not a software error, but corrupted input.<a name="line.652"></a>
+<span class="sourceLineNo">653</span> *<a name="line.653"></a>
+<span class="sourceLineNo">654</span> * @param version an HFile version<a name="line.654"></a>
+<span class="sourceLineNo">655</span> * @throws IllegalArgumentException if the version is invalid<a name="line.655"></a>
+<span class="sourceLineNo">656</span> */<a name="line.656"></a>
+<span class="sourceLineNo">657</span> public static void checkFormatVersion(int version)<a name="line.657"></a>
+<span class="sourceLineNo">658</span> throws IllegalArgumentException {<a name="line.658"></a>
+<span class="sourceLineNo">659</span> if (version < MIN_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.659"></a>
+<span class="sourceLineNo">660</span> throw new IllegalArgumentException("Invalid HFile version: " + version<a name="line.660"></a>
+<span class="sourceLineNo">661</span> + " (expected to be " + "between " + MIN_FORMAT_VERSION + " and "<a name="line.661"></a>
+<span class="sourceLineNo">662</span> + MAX_FORMAT_VERSION + ")");<a name="line.662"></a>
+<span class="sourceLineNo">663</span> }<a name="line.663"></a>
+<span class="sourceLineNo">664</span> }<a name="line.664"></a>
<span class="sourceLineNo">665</span><a name="line.665"></a>
-<span class="sourceLineNo">666</span> public static void checkHFileVersion(final Configuration c) {<a name="line.666"></a>
-<span class="sourceLineNo">667</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.667"></a>
-<span class="sourceLineNo">668</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.668"></a>
-<span class="sourceLineNo">669</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.669"></a>
-<span class="sourceLineNo">670</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.670"></a>
-<span class="sourceLineNo">671</span> MAX_FORMAT_VERSION +<a name="line.671"></a>
-<span class="sourceLineNo">672</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.672"></a>
-<span class="sourceLineNo">673</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.673"></a>
-<span class="sourceLineNo">674</span> }<a name="line.674"></a>
-<span class="sourceLineNo">675</span> }<a name="line.675"></a>
-<span class="sourceLineNo">676</span><a name="line.676"></a>
-<span class="sourceLineNo">677</span> public static void main(String[] args) throws Exception {<a name="line.677"></a>
-<span class="sourceLineNo">678</span> // delegate to preserve old behavior<a name="line.678"></a>
-<span class="sourceLineNo">679</span> HFilePrettyPrinter.main(args);<a name="line.679"></a>
-<span class="sourceLineNo">680</span> }<a name="line.680"></a>
-<span class="sourceLineNo">681</span>}<a name="line.681"></a>
+<span class="sourceLineNo">666</span><a name="line.666"></a>
+<span class="sourceLineNo">667</span> public static void checkHFileVersion(final Configuration c) {<a name="line.667"></a>
+<span class="sourceLineNo">668</span> int version = c.getInt(FORMAT_VERSION_KEY, MAX_FORMAT_VERSION);<a name="line.668"></a>
+<span class="sourceLineNo">669</span> if (version < MAX_FORMAT_VERSION || version > MAX_FORMAT_VERSION) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span> throw new IllegalArgumentException("The setting for " + FORMAT_VERSION_KEY +<a name="line.670"></a>
+<span class="sourceLineNo">671</span> " (in your hbase-*.xml files) is " + version + " which does not match " +<a name="line.671"></a>
+<span class="sourceLineNo">672</span> MAX_FORMAT_VERSION +<a name="line.672"></a>
+<span class="sourceLineNo">673</span> "; are you running with a configuration from an older or newer hbase install (an " +<a name="line.673"></a>
+<span class="sourceLineNo">674</span> "incompatible hbase-default.xml or hbase-site.xml on your CLASSPATH)?");<a name="line.674"></a>
+<span class="sourceLineNo">675</span> }<a name="line.675"></a>
+<span class="sourceLineNo">676</span> }<a name="line.676"></a>
+<span class="sourceLineNo">677</span><a name="line.677"></a>
+<span class="sourceLineNo">678</span> public static void main(String[] args) throws Exception {<a name="line.678"></a>
+<span class="sourceLineNo">679</span> // delegate to preserve old behavior<a name="line.679"></a>
+<span class="sourceLineNo">680</span> HFilePrettyPrinter.main(args);<a name="line.680"></a>
+<span class="sourceLineNo">681</span> }<a name="line.681"></a>
+<span class="sourceLineNo">682</span>}<a name="line.682"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
index 2bc1603..28cda78 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/io/hfile/HFileInfo.html
@@ -52,479 +52,488 @@
<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.security.EncryptionUtil;<a name="line.44"></a>
<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.45"></a>
<span class="sourceLineNo">046</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.46"></a>
-<span class="sourceLineNo">047</span>import org.apache.hbase.thirdparty.com.google.protobuf.UnsafeByteOperations;<a name="line.47"></a>
-<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.shaded.protobuf.ProtobufUtil;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos;<a name="line.49"></a>
-<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos.BytesBytesPair;<a name="line.50"></a>
-<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos;<a name="line.51"></a>
-<span class="sourceLineNo">052</span><a name="line.52"></a>
-<span class="sourceLineNo">053</span>/**<a name="line.53"></a>
-<span class="sourceLineNo">054</span> * Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and<a name="line.54"></a>
-<span class="sourceLineNo">055</span> * added to the tail of the file just before close. Metadata includes core attributes such as last<a name="line.55"></a>
-<span class="sourceLineNo">056</span> * key seen, comparator used writing the file, etc. Clients can add their own attributes via<a name="line.56"></a>
-<span class="sourceLineNo">057</span> * {@link #append(byte[], byte[], boolean)} and they'll be persisted and available at read time.<a name="line.57"></a>
-<span class="sourceLineNo">058</span> * Reader creates the HFileInfo on open by reading the tail of the HFile. The parse of the HFile<a name="line.58"></a>
-<span class="sourceLineNo">059</span> * trailer also creates a {@link HFileContext}, a read-only data structure that includes bulk of<a name="line.59"></a>
-<span class="sourceLineNo">060</span> * the HFileInfo and extras that is safe to pass around when working on HFiles.<a name="line.60"></a>
-<span class="sourceLineNo">061</span> * @see HFileContext<a name="line.61"></a>
-<span class="sourceLineNo">062</span> */<a name="line.62"></a>
-<span class="sourceLineNo">063</span>@InterfaceAudience.Private<a name="line.63"></a>
-<span class="sourceLineNo">064</span>public class HFileInfo implements SortedMap<byte[], byte[]> {<a name="line.64"></a>
-<span class="sourceLineNo">065</span> static final String RESERVED_PREFIX = "hfile.";<a name="line.65"></a>
-<span class="sourceLineNo">066</span> static final byte[] RESERVED_PREFIX_BYTES = Bytes.toBytes(RESERVED_PREFIX);<a name="line.66"></a>
-<span class="sourceLineNo">067</span> static final byte [] LASTKEY = Bytes.toBytes(RESERVED_PREFIX + "LASTKEY");<a name="line.67"></a>
-<span class="sourceLineNo">068</span> static final byte [] AVG_KEY_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_KEY_LEN");<a name="line.68"></a>
-<span class="sourceLineNo">069</span> static final byte [] AVG_VALUE_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_VALUE_LEN");<a name="line.69"></a>
-<span class="sourceLineNo">070</span> static final byte [] CREATE_TIME_TS = Bytes.toBytes(RESERVED_PREFIX + "CREATE_TIME_TS");<a name="line.70"></a>
-<span class="sourceLineNo">071</span> static final byte [] TAGS_COMPRESSED = Bytes.toBytes(RESERVED_PREFIX + "TAGS_COMPRESSED");<a name="line.71"></a>
-<span class="sourceLineNo">072</span> public static final byte [] MAX_TAGS_LEN = Bytes.toBytes(RESERVED_PREFIX + "MAX_TAGS_LEN");<a name="line.72"></a>
-<span class="sourceLineNo">073</span> private final SortedMap<byte [], byte []> map = new TreeMap<>(Bytes.BYTES_COMPARATOR);<a name="line.73"></a>
-<span class="sourceLineNo">074</span><a name="line.74"></a>
-<span class="sourceLineNo">075</span> /**<a name="line.75"></a>
-<span class="sourceLineNo">076</span> * We can read files whose major version is v2 IFF their minor version is at least 3.<a name="line.76"></a>
-<span class="sourceLineNo">077</span> */<a name="line.77"></a>
-<span class="sourceLineNo">078</span> private static final int MIN_V2_MINOR_VERSION_WITH_PB = 3;<a name="line.78"></a>
-<span class="sourceLineNo">079</span><a name="line.79"></a>
-<span class="sourceLineNo">080</span> /** Maximum minor version supported by this HFile format */<a name="line.80"></a>
-<span class="sourceLineNo">081</span> // We went to version 2 when we moved to pb'ing fileinfo and the trailer on<a name="line.81"></a>
-<span class="sourceLineNo">082</span> // the file. This version can read Writables version 1.<a name="line.82"></a>
-<span class="sourceLineNo">083</span> static final int MAX_MINOR_VERSION = 3;<a name="line.83"></a>
-<span class="sourceLineNo">084</span><a name="line.84"></a>
-<span class="sourceLineNo">085</span> /** Last key in the file. Filled in when we read in the file info */<a name="line.85"></a>
-<span class="sourceLineNo">086</span> private Cell lastKeyCell = null;<a name="line.86"></a>
-<span class="sourceLineNo">087</span> /** Average key length read from file info */<a name="line.87"></a>
-<span class="sourceLineNo">088</span> private int avgKeyLen = -1;<a name="line.88"></a>
-<span class="sourceLineNo">089</span> /** Average value length read from file info */<a name="line.89"></a>
-<span class="sourceLineNo">090</span> private int avgValueLen = -1;<a name="line.90"></a>
-<span class="sourceLineNo">091</span> private boolean includesMemstoreTS = false;<a name="line.91"></a>
-<span class="sourceLineNo">092</span> private boolean decodeMemstoreTS = false;<a name="line.92"></a>
-<span class="sourceLineNo">093</span><a name="line.93"></a>
-<span class="sourceLineNo">094</span> /**<a name="line.94"></a>
-<span class="sourceLineNo">095</span> * Blocks read from the load-on-open section, excluding data root index, meta<a name="line.95"></a>
-<span class="sourceLineNo">096</span> * index, and file info.<a name="line.96"></a>
-<span class="sourceLineNo">097</span> */<a name="line.97"></a>
-<span class="sourceLineNo">098</span> private List<HFileBlock> loadOnOpenBlocks = new ArrayList<>();<a name="line.98"></a>
-<span class="sourceLineNo">099</span><a name="line.99"></a>
-<span class="sourceLineNo">100</span> /**<a name="line.100"></a>
-<span class="sourceLineNo">101</span> * The iterator will track all blocks in load-on-open section, since we use the<a name="line.101"></a>
-<span class="sourceLineNo">102</span> * {@link org.apache.hadoop.hbase.io.ByteBuffAllocator} to manage the ByteBuffers in block now,<a name="line.102"></a>
-<span class="sourceLineNo">103</span> * so we must ensure that deallocate all ByteBuffers in the end.<a name="line.103"></a>
+<span class="sourceLineNo">047</span>import org.slf4j.Logger;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.slf4j.LoggerFactory;<a name="line.48"></a>
+<span class="sourceLineNo">049</span><a name="line.49"></a>
+<span class="sourceLineNo">050</span>import org.apache.hbase.thirdparty.com.google.protobuf.UnsafeByteOperations;<a name="line.50"></a>
+<span class="sourceLineNo">051</span><a name="line.51"></a>
+<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.shaded.protobuf.ProtobufUtil;<a name="line.52"></a>
+<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos;<a name="line.53"></a>
+<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HBaseProtos.BytesBytesPair;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.HFileProtos;<a name="line.55"></a>
+<span class="sourceLineNo">056</span><a name="line.56"></a>
+<span class="sourceLineNo">057</span>/**<a name="line.57"></a>
+<span class="sourceLineNo">058</span> * Metadata Map of attributes for HFile written out as HFile Trailer. Created by the Writer and<a name="line.58"></a>
+<span class="sourceLineNo">059</span> * added to the tail of the file just before close. Metadata includes core attributes such as last<a name="line.59"></a>
+<span class="sourceLineNo">060</span> * key seen, comparator used writing the file, etc. Clients can add their own attributes via<a name="line.60"></a>
+<span class="sourceLineNo">061</span> * {@link #append(byte[], byte[], boolean)} and they'll be persisted and available at read time.<a name="line.61"></a>
+<span class="sourceLineNo">062</span> * Reader creates the HFileInfo on open by reading the tail of the HFile. The parse of the HFile<a name="line.62"></a>
+<span class="sourceLineNo">063</span> * trailer also creates a {@link HFileContext}, a read-only data structure that includes bulk of<a name="line.63"></a>
+<span class="sourceLineNo">064</span> * the HFileInfo and extras that is safe to pass around when working on HFiles.<a name="line.64"></a>
+<span class="sourceLineNo">065</span> * @see HFileContext<a name="line.65"></a>
+<span class="sourceLineNo">066</span> */<a name="line.66"></a>
+<span class="sourceLineNo">067</span>@InterfaceAudience.Private<a name="line.67"></a>
+<span class="sourceLineNo">068</span>public class HFileInfo implements SortedMap<byte[], byte[]> {<a name="line.68"></a>
+<span class="sourceLineNo">069</span><a name="line.69"></a>
+<span class="sourceLineNo">070</span> private static final Logger LOG = LoggerFactory.getLogger(HFileInfo.class);<a name="line.70"></a>
+<span class="sourceLineNo">071</span><a name="line.71"></a>
+<span class="sourceLineNo">072</span> static final String RESERVED_PREFIX = "hfile.";<a name="line.72"></a>
+<span class="sourceLineNo">073</span> static final byte[] RESERVED_PREFIX_BYTES = Bytes.toBytes(RESERVED_PREFIX);<a name="line.73"></a>
+<span class="sourceLineNo">074</span> static final byte [] LASTKEY = Bytes.toBytes(RESERVED_PREFIX + "LASTKEY");<a name="line.74"></a>
+<span class="sourceLineNo">075</span> static final byte [] AVG_KEY_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_KEY_LEN");<a name="line.75"></a>
+<span class="sourceLineNo">076</span> static final byte [] AVG_VALUE_LEN = Bytes.toBytes(RESERVED_PREFIX + "AVG_VALUE_LEN");<a name="line.76"></a>
+<span class="sourceLineNo">077</span> static final byte [] CREATE_TIME_TS = Bytes.toBytes(RESERVED_PREFIX + "CREATE_TIME_TS");<a name="line.77"></a>
+<span class="sourceLineNo">078</span> static final byte [] TAGS_COMPRESSED = Bytes.toBytes(RESERVED_PREFIX + "TAGS_COMPRESSED");<a name="line.78"></a>
+<span class="sourceLineNo">079</span> public static final byte [] MAX_TAGS_LEN = Bytes.toBytes(RESERVED_PREFIX + "MAX_TAGS_LEN");<a name="line.79"></a>
+<span class="sourceLineNo">080</span> private final SortedMap<byte [], byte []> map = new TreeMap<>(Bytes.BYTES_COMPARATOR);<a name="line.80"></a>
+<span class="sourceLineNo">081</span><a name="line.81"></a>
+<span class="sourceLineNo">082</span> /**<a name="line.82"></a>
+<span class="sourceLineNo">083</span> * We can read files whose major version is v2 IFF their minor version is at least 3.<a name="line.83"></a>
+<span class="sourceLineNo">084</span> */<a name="line.84"></a>
+<span class="sourceLineNo">085</span> private static final int MIN_V2_MINOR_VERSION_WITH_PB = 3;<a name="line.85"></a>
+<span class="sourceLineNo">086</span><a name="line.86"></a>
+<span class="sourceLineNo">087</span> /** Maximum minor version supported by this HFile format */<a name="line.87"></a>
+<span class="sourceLineNo">088</span> // We went to version 2 when we moved to pb'ing fileinfo and the trailer on<a name="line.88"></a>
+<span class="sourceLineNo">089</span> // the file. This version can read Writables version 1.<a name="line.89"></a>
+<span class="sourceLineNo">090</span> static final int MAX_MINOR_VERSION = 3;<a name="line.90"></a>
+<span class="sourceLineNo">091</span><a name="line.91"></a>
+<span class="sourceLineNo">092</span> /** Last key in the file. Filled in when we read in the file info */<a name="line.92"></a>
+<span class="sourceLineNo">093</span> private Cell lastKeyCell = null;<a name="line.93"></a>
+<span class="sourceLineNo">094</span> /** Average key length read from file info */<a name="line.94"></a>
+<span class="sourceLineNo">095</span> private int avgKeyLen = -1;<a name="line.95"></a>
+<span class="sourceLineNo">096</span> /** Average value length read from file info */<a name="line.96"></a>
+<span class="sourceLineNo">097</span> private int avgValueLen = -1;<a name="line.97"></a>
+<span class="sourceLineNo">098</span> private boolean includesMemstoreTS = false;<a name="line.98"></a>
+<span class="sourceLineNo">099</span> private boolean decodeMemstoreTS = false;<a name="line.99"></a>
+<span class="sourceLineNo">100</span><a name="line.100"></a>
+<span class="sourceLineNo">101</span> /**<a name="line.101"></a>
+<span class="sourceLineNo">102</span> * Blocks read from the load-on-open section, excluding data root index, meta<a name="line.102"></a>
+<span class="sourceLineNo">103</span> * index, and file info.<a name="line.103"></a>
<span class="sourceLineNo">104</span> */<a name="line.104"></a>
-<span class="sourceLineNo">105</span> private HFileBlock.BlockIterator blockIter;<a name="line.105"></a>
+<span class="sourceLineNo">105</span> private List<HFileBlock> loadOnOpenBlocks = new ArrayList<>();<a name="line.105"></a>
<span class="sourceLineNo">106</span><a name="line.106"></a>
-<span class="sourceLineNo">107</span> private HFileBlockIndex.CellBasedKeyBlockIndexReader dataIndexReader;<a name="line.107"></a>
-<span class="sourceLineNo">108</span> private HFileBlockIndex.ByteArrayKeyBlockIndexReader metaIndexReader;<a name="line.108"></a>
-<span class="sourceLineNo">109</span><a name="line.109"></a>
-<span class="sourceLineNo">110</span> private FixedFileTrailer trailer;<a name="line.110"></a>
-<span class="sourceLineNo">111</span> private HFileContext hfileContext;<a name="line.111"></a>
-<span class="sourceLineNo">112</span><a name="line.112"></a>
-<span class="sourceLineNo">113</span> public HFileInfo() {<a name="line.113"></a>
-<span class="sourceLineNo">114</span> super();<a name="line.114"></a>
-<span class="sourceLineNo">115</span> }<a name="line.115"></a>
+<span class="sourceLineNo">107</span> /**<a name="line.107"></a>
+<span class="sourceLineNo">108</span> * The iterator will track all blocks in load-on-open section, since we use the<a name="line.108"></a>
+<span class="sourceLineNo">109</span> * {@link org.apache.hadoop.hbase.io.ByteBuffAllocator} to manage the ByteBuffers in block now,<a name="line.109"></a>
+<span class="sourceLineNo">110</span> * so we must ensure that deallocate all ByteBuffers in the end.<a name="line.110"></a>
+<span class="sourceLineNo">111</span> */<a name="line.111"></a>
+<span class="sourceLineNo">112</span> private HFileBlock.BlockIterator blockIter;<a name="line.112"></a>
+<span class="sourceLineNo">113</span><a name="line.113"></a>
+<span class="sourceLineNo">114</span> private HFileBlockIndex.CellBasedKeyBlockIndexReader dataIndexReader;<a name="line.114"></a>
+<span class="sourceLineNo">115</span> private HFileBlockIndex.ByteArrayKeyBlockIndexReader metaIndexReader;<a name="line.115"></a>
<span class="sourceLineNo">116</span><a name="line.116"></a>
-<span class="sourceLineNo">117</span> public HFileInfo(ReaderContext context, Configuration conf) throws IOException {<a name="line.117"></a>
-<span class="sourceLineNo">118</span> this.initTrailerAndContext(context, conf);<a name="line.118"></a>
-<span class="sourceLineNo">119</span> }<a name="line.119"></a>
-<span class="sourceLineNo">120</span><a name="line.120"></a>
-<span class="sourceLineNo">121</span> /**<a name="line.121"></a>
-<span class="sourceLineNo">122</span> * Append the given key/value pair to the file info, optionally checking the<a name="line.122"></a>
-<span class="sourceLineNo">123</span> * key prefix.<a name="line.123"></a>
-<span class="sourceLineNo">124</span> *<a name="line.124"></a>
-<span class="sourceLineNo">125</span> * @param k key to add<a name="line.125"></a>
-<span class="sourceLineNo">126</span> * @param v value to add<a name="line.126"></a>
-<span class="sourceLineNo">127</span> * @param checkPrefix whether to check that the provided key does not start<a name="line.127"></a>
-<span class="sourceLineNo">128</span> * with the reserved prefix<a name="line.128"></a>
-<span class="sourceLineNo">129</span> * @return this file info object<a name="line.129"></a>
-<span class="sourceLineNo">130</span> * @throws IOException if the key or value is invalid<a name="line.130"></a>
-<span class="sourceLineNo">131</span> * @throws NullPointerException if {@code key} or {@code value} is {@code null}<a name="line.131"></a>
-<span class="sourceLineNo">132</span> */<a name="line.132"></a>
-<span class="sourceLineNo">133</span> public HFileInfo append(final byte[] k, final byte[] v,<a name="line.133"></a>
-<span class="sourceLineNo">134</span> final boolean checkPrefix) throws IOException {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> Objects.requireNonNull(k, "key cannot be null");<a name="line.135"></a>
-<span class="sourceLineNo">136</span> Objects.requireNonNull(v, "value cannot be null");<a name="line.136"></a>
-<span class="sourceLineNo">137</span><a name="line.137"></a>
-<span class="sourceLineNo">138</span> if (checkPrefix && isReservedFileInfoKey(k)) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span> throw new IOException("Keys with a " + HFileInfo.RESERVED_PREFIX<a name="line.139"></a>
-<span class="sourceLineNo">140</span> + " are reserved");<a name="line.140"></a>
-<span class="sourceLineNo">141</span> }<a name="line.141"></a>
-<span class="sourceLineNo">142</span> put(k, v);<a name="line.142"></a>
-<span class="sourceLineNo">143</span> return this;<a name="line.143"></a>
-<span class="sourceLineNo">144</span> }<a name="line.144"></a>
-<span class="sourceLineNo">145</span><a name="line.145"></a>
-<span class="sourceLineNo">146</span> /** Return true if the given file info key is reserved for internal use. */<a name="line.146"></a>
-<span class="sourceLineNo">147</span> public static boolean isReservedFileInfoKey(byte[] key) {<a name="line.147"></a>
-<span class="sourceLineNo">148</span> return Bytes.startsWith(key, HFileInfo.RESERVED_PREFIX_BYTES);<a name="line.148"></a>
-<span class="sourceLineNo">149</span> }<a name="line.149"></a>
-<span class="sourceLineNo">150</span><a name="line.150"></a>
-<span class="sourceLineNo">151</span> @Override<a name="line.151"></a>
-<span class="sourceLineNo">152</span> public void clear() {<a name="line.152"></a>
-<span class="sourceLineNo">153</span> this.map.clear();<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> @Override<a name="line.156"></a>
-<span class="sourceLineNo">157</span> public Comparator<? super byte[]> comparator() {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> return map.comparator();<a name="line.158"></a>
-<span class="sourceLineNo">159</span> }<a name="line.159"></a>
-<span class="sourceLineNo">160</span><a name="line.160"></a>
-<span class="sourceLineNo">161</span> @Override<a name="line.161"></a>
-<span class="sourceLineNo">162</span> public boolean containsKey(Object key) {<a name="line.162"></a>
-<span class="sourceLineNo">163</span> return map.containsKey(key);<a name="line.163"></a>
-<span class="sourceLineNo">164</span> }<a name="line.164"></a>
-<span class="sourceLineNo">165</span><a name="line.165"></a>
-<span class="sourceLineNo">166</span> @Override<a name="line.166"></a>
-<span class="sourceLineNo">167</span> public boolean containsValue(Object value) {<a name="line.167"></a>
-<span class="sourceLineNo">168</span> return map.containsValue(value);<a name="line.168"></a>
-<span class="sourceLineNo">169</span> }<a name="line.169"></a>
-<span class="sourceLineNo">170</span><a name="line.170"></a>
-<span class="sourceLineNo">171</span> @Override<a name="line.171"></a>
-<span class="sourceLineNo">172</span> public Set<java.util.Map.Entry<byte[], byte[]>> entrySet() {<a name="line.172"></a>
-<span class="sourceLineNo">173</span> return map.entrySet();<a name="line.173"></a>
-<span class="sourceLineNo">174</span> }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> @Override<a name="line.176"></a>
-<span class="sourceLineNo">177</span> public boolean equals(Object o) {<a name="line.177"></a>
-<span class="sourceLineNo">178</span> return map.equals(o);<a name="line.178"></a>
-<span class="sourceLineNo">179</span> }<a name="line.179"></a>
-<span class="sourceLineNo">180</span><a name="line.180"></a>
-<span class="sourceLineNo">181</span> @Override<a name="line.181"></a>
-<span class="sourceLineNo">182</span> public byte[] firstKey() {<a name="line.182"></a>
-<span class="sourceLineNo">183</span> return map.firstKey();<a name="line.183"></a>
-<span class="sourceLineNo">184</span> }<a name="line.184"></a>
-<span class="sourceLineNo">185</span><a name="line.185"></a>
-<span class="sourceLineNo">186</span> @Override<a name="line.186"></a>
-<span class="sourceLineNo">187</span> public byte[] get(Object key) {<a name="line.187"></a>
-<span class="sourceLineNo">188</span> return map.get(key);<a name="line.188"></a>
-<span class="sourceLineNo">189</span> }<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
-<span class="sourceLineNo">191</span> @Override<a name="line.191"></a>
-<span class="sourceLineNo">192</span> public int hashCode() {<a name="line.192"></a>
-<span class="sourceLineNo">193</span> return map.hashCode();<a name="line.193"></a>
-<span class="sourceLineNo">194</span> }<a name="line.194"></a>
-<span class="sourceLineNo">195</span><a name="line.195"></a>
-<span class="sourceLineNo">196</span> @Override<a name="line.196"></a>
-<span class="sourceLineNo">197</span> public SortedMap<byte[], byte[]> headMap(byte[] toKey) {<a name="line.197"></a>
-<span class="sourceLineNo">198</span> return this.map.headMap(toKey);<a name="line.198"></a>
-<span class="sourceLineNo">199</span> }<a name="line.199"></a>
-<span class="sourceLineNo">200</span><a name="line.200"></a>
-<span class="sourceLineNo">201</span> @Override<a name="line.201"></a>
-<span class="sourceLineNo">202</span> public boolean isEmpty() {<a name="line.202"></a>
-<span class="sourceLineNo">203</span> return map.isEmpty();<a name="line.203"></a>
-<span class="sourceLineNo">204</span> }<a name="line.204"></a>
-<span class="sourceLineNo">205</span><a name="line.205"></a>
-<span class="sourceLineNo">206</span> @Override<a name="line.206"></a>
-<span class="sourceLineNo">207</span> public Set<byte[]> keySet() {<a name="line.207"></a>
-<span class="sourceLineNo">208</span> return map.keySet();<a name="line.208"></a>
-<span class="sourceLineNo">209</span> }<a name="line.209"></a>
-<span class="sourceLineNo">210</span><a name="line.210"></a>
-<span class="sourceLineNo">211</span> @Override<a name="line.211"></a>
-<span class="sourceLineNo">212</span> public byte[] lastKey() {<a name="line.212"></a>
-<span class="sourceLineNo">213</span> return map.lastKey();<a name="line.213"></a>
-<span class="sourceLineNo">214</span> }<a name="line.214"></a>
-<span class="sourceLineNo">215</span><a name="line.215"></a>
-<span class="sourceLineNo">216</span> @Override<a name="line.216"></a>
-<span class="sourceLineNo">217</span> public byte[] put(byte[] key, byte[] value) {<a name="line.217"></a>
-<span class="sourceLineNo">218</span> return this.map.put(key, value);<a name="line.218"></a>
-<span class="sourceLineNo">219</span> }<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span> @Override<a name="line.221"></a>
-<span class="sourceLineNo">222</span> public void putAll(Map<? extends byte[], ? extends byte[]> m) {<a name="line.222"></a>
-<span class="sourceLineNo">223</span> this.map.putAll(m);<a name="line.223"></a>
-<span class="sourceLineNo">224</span> }<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span> @Override<a name="line.226"></a>
-<span class="sourceLineNo">227</span> public byte[] remove(Object key) {<a name="line.227"></a>
-<span class="sourceLineNo">228</span> return this.map.remove(key);<a name="line.228"></a>
-<span class="sourceLineNo">229</span> }<a name="line.229"></a>
-<span class="sourceLineNo">230</span><a name="line.230"></a>
-<span class="sourceLineNo">231</span> @Override<a name="line.231"></a>
-<span class="sourceLineNo">232</span> public int size() {<a name="line.232"></a>
-<span class="sourceLineNo">233</span> return map.size();<a name="line.233"></a>
-<span class="sourceLineNo">234</span> }<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span> @Override<a name="line.236"></a>
-<span class="sourceLineNo">237</span> public SortedMap<byte[], byte[]> subMap(byte[] fromKey, byte[] toKey) {<a name="line.237"></a>
-<span class="sourceLineNo">238</span> return this.map.subMap(fromKey, toKey);<a name="line.238"></a>
-<span class="sourceLineNo">239</span> }<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span> @Override<a name="line.241"></a>
-<span class="sourceLineNo">242</span> public SortedMap<byte[], byte[]> tailMap(byte[] fromKey) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span> return this.map.tailMap(fromKey);<a name="line.243"></a>
-<span class="sourceLineNo">244</span> }<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span> @Override<a name="line.246"></a>
-<span class="sourceLineNo">247</span> public Collection<byte[]> values() {<a name="line.247"></a>
-<span class="sourceLineNo">248</span> return map.values();<a name="line.248"></a>
-<span class="sourceLineNo">249</span> }<a name="line.249"></a>
-<span class="sourceLineNo">250</span><a name="line.250"></a>
-<span class="sourceLineNo">251</span> /**<a name="line.251"></a>
-<span class="sourceLineNo">252</span> * Write out this instance on the passed in <code>out</code> stream.<a name="line.252"></a>
-<span class="sourceLineNo">253</span> * We write it as a protobuf.<a name="line.253"></a>
-<span class="sourceLineNo">254</span> * @see #read(DataInputStream)<a name="line.254"></a>
-<span class="sourceLineNo">255</span> */<a name="line.255"></a>
-<span class="sourceLineNo">256</span> void write(final DataOutputStream out) throws IOException {<a name="line.256"></a>
-<span class="sourceLineNo">257</span> HFileProtos.FileInfoProto.Builder builder = HFileProtos.FileInfoProto.newBuilder();<a name="line.257"></a>
-<span class="sourceLineNo">258</span> for (Map.Entry<byte [], byte[]> e: this.map.entrySet()) {<a name="line.258"></a>
-<span class="sourceLineNo">259</span> HBaseProtos.BytesBytesPair.Builder bbpBuilder = HBaseProtos.BytesBytesPair.newBuilder();<a name="line.259"></a>
-<span class="sourceLineNo">260</span> bbpBuilder.setFirst(UnsafeByteOperations.unsafeWrap(e.getKey()));<a name="line.260"></a>
-<span class="sourceLineNo">261</span> bbpBuilder.setSecond(UnsafeByteOperations.unsafeWrap(e.getValue()));<a name="line.261"></a>
-<span class="sourceLineNo">262</span> builder.addMapEntry(bbpBuilder.build());<a name="line.262"></a>
-<span class="sourceLineNo">263</span> }<a name="line.263"></a>
-<span class="sourceLineNo">264</span> out.write(ProtobufMagic.PB_MAGIC);<a name="line.264"></a>
-<span class="sourceLineNo">265</span> builder.build().writeDelimitedTo(out);<a name="line.265"></a>
-<span class="sourceLineNo">266</span> }<a name="line.266"></a>
-<span class="sourceLineNo">267</span><a name="line.267"></a>
-<span class="sourceLineNo">268</span> /**<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * Populate this instance with what we find on the passed in <code>in</code> stream.<a name="line.269"></a>
-<span class="sourceLineNo">270</span> * Can deserialize protobuf of old Writables format.<a name="line.270"></a>
-<span class="sourceLineNo">271</span> * @see #write(DataOutputStream)<a name="line.271"></a>
-<span class="sourceLineNo">272</span> */<a name="line.272"></a>
-<span class="sourceLineNo">273</span> void read(final DataInputStream in) throws IOException {<a name="line.273"></a>
-<span class="sourceLineNo">274</span> // This code is tested over in TestHFileReaderV1 where we read an old hfile w/ this new code.<a name="line.274"></a>
-<span class="sourceLineNo">275</span> int pblen = ProtobufUtil.lengthOfPBMagic();<a name="line.275"></a>
-<span class="sourceLineNo">276</span> byte [] pbuf = new byte[pblen];<a name="line.276"></a>
-<span class="sourceLineNo">277</span> if (in.markSupported()) {<a name="line.277"></a>
-<span class="sourceLineNo">278</span> in.mark(pblen);<a name="line.278"></a>
-<span class="sourceLineNo">279</span> }<a name="line.279"></a>
-<span class="sourceLineNo">280</span> int read = in.read(pbuf);<a name="line.280"></a>
-<span class="sourceLineNo">281</span> if (read != pblen) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span> throw new IOException("read=" + read + ", wanted=" + pblen);<a name="line.282"></a>
-<span class="sourceLineNo">283</span> }<a name="line.283"></a>
-<span class="sourceLineNo">284</span> if (ProtobufUtil.isPBMagicPrefix(pbuf)) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span> parsePB(HFileProtos.FileInfoProto.parseDelimitedFrom(in));<a name="line.285"></a>
-<span class="sourceLineNo">286</span> } else {<a name="line.286"></a>
-<span class="sourceLineNo">287</span> if (in.markSupported()) {<a name="line.287"></a>
-<span class="sourceLineNo">288</span> in.reset();<a name="line.288"></a>
-<span class="sourceLineNo">289</span> parseWritable(in);<a name="line.289"></a>
-<span class="sourceLineNo">290</span> } else {<a name="line.290"></a>
-<span class="sourceLineNo">291</span> // We cannot use BufferedInputStream, it consumes more than we read from the underlying IS<a name="line.291"></a>
-<span class="sourceLineNo">292</span> ByteArrayInputStream bais = new ByteArrayInputStream(pbuf);<a name="line.292"></a>
-<span class="sourceLineNo">293</span> SequenceInputStream sis = new SequenceInputStream(bais, in); // Concatenate input streams<a name="line.293"></a>
-<span class="sourceLineNo">294</span> // TODO: Am I leaking anything here wrapping the passed in stream? We are not calling<a name="line.294"></a>
-<span class="sourceLineNo">295</span> // close on the wrapped streams but they should be let go after we leave this context?<a name="line.295"></a>
-<span class="sourceLineNo">296</span> // I see that we keep a reference to the passed in inputstream but since we no longer<a name="line.296"></a>
-<span class="sourceLineNo">297</span> // have a reference to this after we leave, we should be ok.<a name="line.297"></a>
-<span class="sourceLineNo">298</span> parseWritable(new DataInputStream(sis));<a name="line.298"></a>
-<span class="sourceLineNo">299</span> }<a name="line.299"></a>
-<span class="sourceLineNo">300</span> }<a name="line.300"></a>
-<span class="sourceLineNo">301</span> }<a name="line.301"></a>
-<span class="sourceLineNo">302</span><a name="line.302"></a>
-<span class="sourceLineNo">303</span> /**<a name="line.303"></a>
-<span class="sourceLineNo">304</span> * Now parse the old Writable format. It was a list of Map entries. Each map entry was a<a name="line.304"></a>
-<span class="sourceLineNo">305</span> * key and a value of a byte []. The old map format had a byte before each entry that held<a name="line.305"></a>
-<span class="sourceLineNo">306</span> * a code which was short for the key or value type. We know it was a byte [] so in below<a name="line.306"></a>
-<span class="sourceLineNo">307</span> * we just read and dump it.<a name="line.307"></a>
-<span class="sourceLineNo">308</span> */<a name="line.308"></a>
-<span class="sourceLineNo">309</span> void parseWritable(final DataInputStream in) throws IOException {<a name="line.309"></a>
-<span class="sourceLineNo">310</span> // First clear the map.<a name="line.310"></a>
-<span class="sourceLineNo">311</span> // Otherwise we will just accumulate entries every time this method is called.<a name="line.311"></a>
-<span class="sourceLineNo">312</span> this.map.clear();<a name="line.312"></a>
-<span class="sourceLineNo">313</span> // Read the number of entries in the map<a name="line.313"></a>
-<span class="sourceLineNo">314</span> int entries = in.readInt();<a name="line.314"></a>
-<span class="sourceLineNo">315</span> // Then read each key/value pair<a name="line.315"></a>
-<span class="sourceLineNo">316</span> for (int i = 0; i < entries; i++) {<a name="line.316"></a>
-<span class="sourceLineNo">317</span> byte [] key = Bytes.readByteArray(in);<a name="line.317"></a>
-<span class="sourceLineNo">318</span> // We used to read a byte that encoded the class type.<a name="line.318"></a>
-<span class="sourceLineNo">319</span> // Read and ignore it because it is always byte [] in hfile<a name="line.319"></a>
-<span class="sourceLineNo">320</span> in.readByte();<a name="line.320"></a>
-<span class="sourceLineNo">321</span> byte [] value = Bytes.readByteArray(in);<a name="line.321"></a>
-<span class="sourceLineNo">322</span> this.map.put(key, value);<a name="line.322"></a>
-<span class="sourceLineNo">323</span> }<a name="line.323"></a>
-<span class="sourceLineNo">324</span> }<a name="line.324"></a>
-<span class="sourceLineNo">325</span><a name="line.325"></a>
-<span class="sourceLineNo">326</span> /**<a name="line.326"></a>
-<span class="sourceLineNo">327</span> * Fill our map with content of the pb we read off disk<a name="line.327"></a>
-<span class="sourceLineNo">328</span> * @param fip protobuf message to read<a name="line.328"></a>
-<span class="sourceLineNo">329</span> */<a name="line.329"></a>
-<span class="sourceLineNo">330</span> void parsePB(final HFileProtos.FileInfoProto fip) {<a name="line.330"></a>
-<span class="sourceLineNo">331</span> this.map.clear();<a name="line.331"></a>
-<span class="sourceLineNo">332</span> for (BytesBytesPair pair: fip.getMapEntryList()) {<a name="line.332"></a>
-<span class="sourceLineNo">333</span> this.map.put(pair.getFirst().toByteArray(), pair.getSecond().toByteArray());<a name="line.333"></a>
-<span class="sourceLineNo">334</span> }<a name="line.334"></a>
-<span class="sourceLineNo">335</span> }<a name="line.335"></a>
-<span class="sourceLineNo">336</span><a name="line.336"></a>
-<span class="sourceLineNo">337</span> public void initTrailerAndContext(ReaderContext context, Configuration conf) throws IOException {<a name="line.337"></a>
-<span class="sourceLineNo">338</span> try {<a name="line.338"></a>
-<span class="sourceLineNo">339</span> boolean isHBaseChecksum = context.getInputStreamWrapper().shouldUseHBaseChecksum();<a name="line.339"></a>
-<span class="sourceLineNo">340</span> trailer = FixedFileTrailer.readFromStream(context.getInputStreamWrapper()<a name="line.340"></a>
-<span class="sourceLineNo">341</span> .getStream(isHBaseChecksum), context.getFileSize());<a name="line.341"></a>
-<span class="sourceLineNo">342</span> Path path = context.getFilePath();<a name="line.342"></a>
-<span class="sourceLineNo">343</span> checkFileVersion(path);<a name="line.343"></a>
-<span class="sourceLineNo">344</span> this.hfileContext = createHFileContext(path, trailer, conf);<a name="line.344"></a>
-<span class="sourceLineNo">345</span> context.getInputStreamWrapper().unbuffer();<a name="line.345"></a>
-<span class="sourceLineNo">346</span> } catch (Throwable t) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.347"></a>
-<span class="sourceLineNo">348</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.348"></a>
-<span class="sourceLineNo">349</span> + context.getFilePath(), t);<a name="line.349"></a>
-<span class="sourceLineNo">350</span> }<a name="line.350"></a>
-<span class="sourceLineNo">351</span> }<a name="line.351"></a>
-<span class="sourceLineNo">352</span><a name="line.352"></a>
-<span class="sourceLineNo">353</span> /**<a name="line.353"></a>
-<span class="sourceLineNo">354</span> * should be called after initTrailerAndContext<a name="line.354"></a>
-<span class="sourceLineNo">355</span> */<a name="line.355"></a>
-<span class="sourceLineNo">356</span> public void initMetaAndIndex(HFile.Reader reader) throws IOException {<a name="line.356"></a>
-<span class="sourceLineNo">357</span> ReaderContext context = reader.getContext();<a name="line.357"></a>
-<span class="sourceLineNo">358</span> try {<a name="line.358"></a>
-<span class="sourceLineNo">359</span> HFileBlock.FSReader blockReader = reader.getUncachedBlockReader();<a name="line.359"></a>
-<span class="sourceLineNo">360</span> // Initialize an block iterator, and parse load-on-open blocks in the following.<a name="line.360"></a>
-<span class="sourceLineNo">361</span> blockIter = blockReader.blockRange(trailer.getLoadOnOpenDataOffset(),<a name="line.361"></a>
-<span class="sourceLineNo">362</span> context.getFileSize() - trailer.getTrailerSize());<a name="line.362"></a>
-<span class="sourceLineNo">363</span> // Data index. We also read statistics about the block index written after<a name="line.363"></a>
-<span class="sourceLineNo">364</span> // the root level.<a name="line.364"></a>
-<span class="sourceLineNo">365</span> this.dataIndexReader =<a name="line.365"></a>
-<span class="sourceLineNo">366</span> new HFileBlockIndex.CellBasedKeyBlockIndexReader(trailer.createComparator(), trailer.getNumDataIndexLevels());<a name="line.366"></a>
-<span class="sourceLineNo">367</span> dataIndexReader<a name="line.367"></a>
-<span class="sourceLineNo">368</span> .readMultiLevelIndexRoot(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX), trailer.getDataIndexCount());<a name="line.368"></a>
-<span class="sourceLineNo">369</span> reader.setDataBlockIndexReader(dataIndexReader);<a name="line.369"></a>
-<span class="sourceLineNo">370</span> // Meta index.<a name="line.370"></a>
-<span class="sourceLineNo">371</span> this.metaIndexReader = new HFileBlockIndex.ByteArrayKeyBlockIndexReader(1);<a name="line.371"></a>
-<span class="sourceLineNo">372</span> metaIndexReader.readRootIndex(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX),<a name="line.372"></a>
-<span class="sourceLineNo">373</span> trailer.getMetaIndexCount());<a name="line.373"></a>
-<span class="sourceLineNo">374</span> reader.setMetaBlockIndexReader(metaIndexReader);<a name="line.374"></a>
-<span class="sourceLineNo">375</span> loadMetaInfo(blockIter, hfileContext);<a name="line.375"></a>
-<span class="sourceLineNo">376</span> reader.setDataBlockEncoder(HFileDataBlockEncoderImpl.createFromFileInfo(this));<a name="line.376"></a>
-<span class="sourceLineNo">377</span> // Load-On-Open info<a name="line.377"></a>
-<span class="sourceLineNo">378</span> HFileBlock b;<a name="line.378"></a>
-<span class="sourceLineNo">379</span> while ((b = blockIter.nextBlock()) != null) {<a name="line.379"></a>
-<span class="sourceLineNo">380</span> loadOnOpenBlocks.add(b);<a name="line.380"></a>
-<span class="sourceLineNo">381</span> }<a name="line.381"></a>
-<span class="sourceLineNo">382</span> // close the block reader<a name="line.382"></a>
-<span class="sourceLineNo">383</span> context.getInputStreamWrapper().unbuffer();<a name="line.383"></a>
-<span class="sourceLineNo">384</span> } catch (Throwable t) {<a name="line.384"></a>
-<span class="sourceLineNo">385</span> IOUtils.closeQuietly(context.getInputStreamWrapper());<a name="line.385"></a>
-<span class="sourceLineNo">386</span> throw new CorruptHFileException("Problem reading data index and meta index from file "<a name="line.386"></a>
-<span class="sourceLineNo">387</span> + context.getFilePath(), t);<a name="line.387"></a>
-<span class="sourceLineNo">388</span> }<a name="line.388"></a>
-<span class="sourceLineNo">389</span> }<a name="line.389"></a>
-<span class="sourceLineNo">390</span><a name="line.390"></a>
-<span class="sourceLineNo">391</span> private HFileContext createHFileContext(Path path,<a name="line.391"></a>
-<span class="sourceLineNo">392</span> FixedFileTrailer trailer, Configuration conf) throws IOException {<a name="line.392"></a>
-<span class="sourceLineNo">393</span> HFileContextBuilder builder = new HFileContextBuilder()<a name="line.393"></a>
-<span class="sourceLineNo">394</span> .withHBaseCheckSum(true)<a name="line.394"></a>
-<span class="sourceLineNo">395</span> .withHFileName(path.getName())<a name="line.395"></a>
-<span class="sourceLineNo">396</span> .withCompression(trailer.getCompressionCodec())<a name="line.396"></a>
-<span class="sourceLineNo">397</span> .withCellComparator(FixedFileTrailer.createComparator(trailer.getComparatorClassName()));<a name="line.397"></a>
-<span class="sourceLineNo">398</span> // Check for any key material available<a name="line.398"></a>
-<span class="sourceLineNo">399</span> byte[] keyBytes = trailer.getEncryptionKey();<a name="line.399"></a>
-<span class="sourceLineNo">400</span> if (keyBytes != null) {<a name="line.400"></a>
-<span class="sourceLineNo">401</span> Encryption.Context cryptoContext = Encryption.newContext(conf);<a name="line.401"></a>
-<span class="sourceLineNo">402</span> Key key = EncryptionUtil.unwrapKey(conf, keyBytes);<a name="line.402"></a>
-<span class="sourceLineNo">403</span> // Use the algorithm the key wants<a name="line.403"></a>
-<span class="sourceLineNo">404</span> Cipher cipher = Encryption.getCipher(conf, key.getAlgorithm());<a name="line.404"></a>
-<span class="sourceLineNo">405</span> if (cipher == null) {<a name="line.405"></a>
-<span class="sourceLineNo">406</span> throw new IOException("Cipher '" + key.getAlgorithm() + "' is not available"<a name="line.406"></a>
-<span class="sourceLineNo">407</span> + ", path=" + path);<a name="line.407"></a>
-<span class="sourceLineNo">408</span> }<a name="line.408"></a>
-<span class="sourceLineNo">409</span> cryptoContext.setCipher(cipher);<a name="line.409"></a>
-<span class="sourceLineNo">410</span> cryptoContext.setKey(key);<a name="line.410"></a>
-<span class="sourceLineNo">411</span> builder.withEncryptionContext(cryptoContext);<a name="line.411"></a>
-<span class="sourceLineNo">412</span> }<a name="line.412"></a>
-<span class="sourceLineNo">413</span> HFileContext context = builder.build();<a name="line.413"></a>
-<span class="sourceLineNo">414</span> return context;<a name="line.414"></a>
-<span class="sourceLineNo">415</span> }<a name="line.415"></a>
-<span class="sourceLineNo">416</span><a name="line.416"></a>
-<span class="sourceLineNo">417</span> private void loadMetaInfo(HFileBlock.BlockIterator blockIter, HFileContext hfileContext)<a name="line.417"></a>
-<span class="sourceLineNo">418</span> throws IOException {<a name="line.418"></a>
-<span class="sourceLineNo">419</span> read(blockIter.nextBlockWithBlockType(BlockType.FILE_INFO).getByteStream());<a name="line.419"></a>
-<span class="sourceLineNo">420</span> byte[] creationTimeBytes = get(HFileInfo.CREATE_TIME_TS);<a name="line.420"></a>
-<span class="sourceLineNo">421</span> hfileContext.setFileCreateTime(creationTimeBytes == null ?<a name="line.421"></a>
-<span class="sourceLineNo">422</span> 0 : Bytes.toLong(creationTimeBytes));<a name="line.422"></a>
-<span class="sourceLineNo">423</span> byte[] tmp = get(HFileInfo.MAX_TAGS_LEN);<a name="line.423"></a>
-<span class="sourceLineNo">424</span> // max tag length is not present in the HFile means tags were not at all written to file.<a name="line.424"></a>
-<span class="sourceLineNo">425</span> if (tmp != null) {<a name="line.425"></a>
-<span class="sourceLineNo">426</span> hfileContext.setIncludesTags(true);<a name="line.426"></a>
-<span class="sourceLineNo">427</span> tmp = get(HFileInfo.TAGS_COMPRESSED);<a name="line.427"></a>
-<span class="sourceLineNo">428</span> if (tmp != null && Bytes.toBoolean(tmp)) {<a name="line.428"></a>
-<span class="sourceLineNo">429</span> hfileContext.setCompressTags(true);<a name="line.429"></a>
-<span class="sourceLineNo">430</span> }<a name="line.430"></a>
-<span class="sourceLineNo">431</span> }<a name="line.431"></a>
-<span class="sourceLineNo">432</span> // parse meta info<a name="line.432"></a>
-<span class="sourceLineNo">433</span> if (get(HFileInfo.LASTKEY) != null) {<a name="line.433"></a>
-<span class="sourceLineNo">434</span> lastKeyCell = new KeyValue.KeyOnlyKeyValue(get(HFileInfo.LASTKEY));<a name="line.434"></a>
-<span class="sourceLineNo">435</span> }<a name="line.435"></a>
-<span class="sourceLineNo">436</span> avgKeyLen = Bytes.toInt(get(HFileInfo.AVG_KEY_LEN));<a name="line.436"></a>
-<span class="sourceLineNo">437</span> avgValueLen = Bytes.toInt(get(HFileInfo.AVG_VALUE_LEN));<a name="line.437"></a>
-<span class="sourceLineNo">438</span> byte [] keyValueFormatVersion = get(HFileWriterImpl.KEY_VALUE_VERSION);<a name="line.438"></a>
-<span class="sourceLineNo">439</span> includesMemstoreTS = keyValueFormatVersion != null &&<a name="line.439"></a>
-<span class="sourceLineNo">440</span> Bytes.toInt(keyValueFormatVersion) == HFileWriterImpl.KEY_VALUE_VER_WITH_MEMSTORE;<a name="line.440"></a>
-<span class="sourceLineNo">441</span> hfileContext.setIncludesMvcc(includesMemstoreTS);<a name="line.441"></a>
-<span class="sourceLineNo">442</span> if (includesMemstoreTS) {<a name="line.442"></a>
-<span class="sourceLineNo">443</span> decodeMemstoreTS = Bytes.toLong(get(HFileWriterImpl.MAX_MEMSTORE_TS_KEY)) > 0;<a name="line.443"></a>
+<span class="sourceLineNo">117</span> private FixedFileTrailer trailer;<a name="line.117"></a>
+<span class="sourceLineNo">118</span> private HFileContext hfileContext;<a name="line.118"></a>
+<span class="sourceLineNo">119</span><a name="line.119"></a>
+<span class="sourceLineNo">120</span> public HFileInfo() {<a name="line.120"></a>
+<span class="sourceLineNo">121</span> super();<a name="line.121"></a>
+<span class="sourceLineNo">122</span> }<a name="line.122"></a>
+<span class="sourceLineNo">123</span><a name="line.123"></a>
+<span class="sourceLineNo">124</span> public HFileInfo(ReaderContext context, Configuration conf) throws IOException {<a name="line.124"></a>
+<span class="sourceLineNo">125</span> this.initTrailerAndContext(context, conf);<a name="line.125"></a>
+<span class="sourceLineNo">126</span> }<a name="line.126"></a>
+<span class="sourceLineNo">127</span><a name="line.127"></a>
+<span class="sourceLineNo">128</span> /**<a name="line.128"></a>
+<span class="sourceLineNo">129</span> * Append the given key/value pair to the file info, optionally checking the<a name="line.129"></a>
+<span class="sourceLineNo">130</span> * key prefix.<a name="line.130"></a>
+<span class="sourceLineNo">131</span> *<a name="line.131"></a>
+<span class="sourceLineNo">132</span> * @param k key to add<a name="line.132"></a>
+<span class="sourceLineNo">133</span> * @param v value to add<a name="line.133"></a>
+<span class="sourceLineNo">134</span> * @param checkPrefix whether to check that the provided key does not start<a name="line.134"></a>
+<span class="sourceLineNo">135</span> * with the reserved prefix<a name="line.135"></a>
+<span class="sourceLineNo">136</span> * @return this file info object<a name="line.136"></a>
+<span class="sourceLineNo">137</span> * @throws IOException if the key or value is invalid<a name="line.137"></a>
+<span class="sourceLineNo">138</span> * @throws NullPointerException if {@code key} or {@code value} is {@code null}<a name="line.138"></a>
+<span class="sourceLineNo">139</span> */<a name="line.139"></a>
+<span class="sourceLineNo">140</span> public HFileInfo append(final byte[] k, final byte[] v,<a name="line.140"></a>
+<span class="sourceLineNo">141</span> final boolean checkPrefix) throws IOException {<a name="line.141"></a>
+<span class="sourceLineNo">142</span> Objects.requireNonNull(k, "key cannot be null");<a name="line.142"></a>
+<span class="sourceLineNo">143</span> Objects.requireNonNull(v, "value cannot be null");<a name="line.143"></a>
+<span class="sourceLineNo">144</span><a name="line.144"></a>
+<span class="sourceLineNo">145</span> if (checkPrefix && isReservedFileInfoKey(k)) {<a name="line.145"></a>
+<span class="sourceLineNo">146</span> throw new IOException("Keys with a " + HFileInfo.RESERVED_PREFIX<a name="line.146"></a>
+<span class="sourceLineNo">147</span> + " are reserved");<a name="line.147"></a>
+<span class="sourceLineNo">148</span> }<a name="line.148"></a>
+<span class="sourceLineNo">149</span> put(k, v);<a name="line.149"></a>
+<span class="sourceLineNo">150</span> return this;<a name="line.150"></a>
+<span class="sourceLineNo">151</span> }<a name="line.151"></a>
+<span class="sourceLineNo">152</span><a name="line.152"></a>
+<span class="sourceLineNo">153</span> /** Return true if the given file info key is reserved for internal use. */<a name="line.153"></a>
+<span class="sourceLineNo">154</span> public static boolean isReservedFileInfoKey(byte[] key) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span> return Bytes.startsWith(key, HFileInfo.RESERVED_PREFIX_BYTES);<a name="line.155"></a>
+<span class="sourceLineNo">156</span> }<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span> @Override<a name="line.158"></a>
+<span class="sourceLineNo">159</span> public void clear() {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> this.map.clear();<a name="line.160"></a>
+<span class="sourceLineNo">161</span> }<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span> @Override<a name="line.163"></a>
+<span class="sourceLineNo">164</span> public Comparator<? super byte[]> comparator() {<a name="line.164"></a>
+<span class="sourceLineNo">165</span> return map.comparator();<a name="line.165"></a>
+<span class="sourceLineNo">166</span> }<a name="line.166"></a>
+<span class="sourceLineNo">167</span><a name="line.167"></a>
+<span class="sourceLineNo">168</span> @Override<a name="line.168"></a>
+<span class="sourceLineNo">169</span> public boolean containsKey(Object key) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> return map.containsKey(key);<a name="line.170"></a>
+<span class="sourceLineNo">171</span> }<a name="line.171"></a>
+<span class="sourceLineNo">172</span><a name="line.172"></a>
+<span class="sourceLineNo">173</span> @Override<a name="line.173"></a>
+<span class="sourceLineNo">174</span> public boolean containsValue(Object value) {<a name="line.174"></a>
+<span class="sourceLineNo">175</span> return map.containsValue(value);<a name="line.175"></a>
+<span class="sourceLineNo">176</span> }<a name="line.176"></a>
+<span class="sourceLineNo">177</span><a name="line.177"></a>
+<span class="sourceLineNo">178</span> @Override<a name="line.178"></a>
+<span class="sourceLineNo">179</span> public Set<java.util.Map.Entry<byte[], byte[]>> entrySet() {<a name="line.179"></a>
+<span class="sourceLineNo">180</span> return map.entrySet();<a name="line.180"></a>
+<span class="sourceLineNo">181</span> }<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> @Override<a name="line.183"></a>
+<span class="sourceLineNo">184</span> public boolean equals(Object o) {<a name="line.184"></a>
+<span class="sourceLineNo">185</span> return map.equals(o);<a name="line.185"></a>
+<span class="sourceLineNo">186</span> }<a name="line.186"></a>
+<span class="sourceLineNo">187</span><a name="line.187"></a>
+<span class="sourceLineNo">188</span> @Override<a name="line.188"></a>
+<span class="sourceLineNo">189</span> public byte[] firstKey() {<a name="line.189"></a>
+<span class="sourceLineNo">190</span> return map.firstKey();<a name="line.190"></a>
+<span class="sourceLineNo">191</span> }<a name="line.191"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span> @Override<a name="line.193"></a>
+<span class="sourceLineNo">194</span> public byte[] get(Object key) {<a name="line.194"></a>
+<span class="sourceLineNo">195</span> return map.get(key);<a name="line.195"></a>
+<span class="sourceLineNo">196</span> }<a name="line.196"></a>
+<span class="sourceLineNo">197</span><a name="line.197"></a>
+<span class="sourceLineNo">198</span> @Override<a name="line.198"></a>
+<span class="sourceLineNo">199</span> public int hashCode() {<a name="line.199"></a>
+<span class="sourceLineNo">200</span> return map.hashCode();<a name="line.200"></a>
+<span class="sourceLineNo">201</span> }<a name="line.201"></a>
+<span class="sourceLineNo">202</span><a name="line.202"></a>
+<span class="sourceLineNo">203</span> @Override<a name="line.203"></a>
+<span class="sourceLineNo">204</span> public SortedMap<byte[], byte[]> headMap(byte[] toKey) {<a name="line.204"></a>
+<span class="sourceLineNo">205</span> return this.map.headMap(toKey);<a name="line.205"></a>
+<span class="sourceLineNo">206</span> }<a name="line.206"></a>
+<span class="sourceLineNo">207</span><a name="line.207"></a>
+<span class="sourceLineNo">208</span> @Override<a name="line.208"></a>
+<span class="sourceLineNo">209</span> public boolean isEmpty() {<a name="line.209"></a>
+<span class="sourceLineNo">210</span> return map.isEmpty();<a name="line.210"></a>
+<span class="sourceLineNo">211</span> }<a name="line.211"></a>
+<span class="sourceLineNo">212</span><a name="line.212"></a>
+<span class="sourceLineNo">213</span> @Override<a name="line.213"></a>
+<span class="sourceLineNo">214</span> public Set<byte[]> keySet() {<a name="line.214"></a>
+<span class="sourceLineNo">215</span> return map.keySet();<a name="line.215"></a>
+<span class="sourceLineNo">216</span> }<a name="line.216"></a>
+<span class="sourceLineNo">217</span><a name="line.217"></a>
+<span class="sourceLineNo">218</span> @Override<a name="line.218"></a>
+<span class="sourceLineNo">219</span> public byte[] lastKey() {<a name="line.219"></a>
+<span class="sourceLineNo">220</span> return map.lastKey();<a name="line.220"></a>
+<span class="sourceLineNo">221</span> }<a name="line.221"></a>
+<span class="sourceLineNo">222</span><a name="line.222"></a>
+<span class="sourceLineNo">223</span> @Override<a name="line.223"></a>
+<span class="sourceLineNo">224</span> public byte[] put(byte[] key, byte[] value) {<a name="line.224"></a>
+<span class="sourceLineNo">225</span> return this.map.put(key, value);<a name="line.225"></a>
+<span class="sourceLineNo">226</span> }<a name="line.226"></a>
+<span class="sourceLineNo">227</span><a name="line.227"></a>
+<span class="sourceLineNo">228</span> @Override<a name="line.228"></a>
+<span class="sourceLineNo">229</span> public void putAll(Map<? extends byte[], ? extends byte[]> m) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span> this.map.putAll(m);<a name="line.230"></a>
+<span class="sourceLineNo">231</span> }<a name="line.231"></a>
+<span class="sourceLineNo">232</span><a name="line.232"></a>
+<span class="sourceLineNo">233</span> @Override<a name="line.233"></a>
+<span class="sourceLineNo">234</span> public byte[] remove(Object key) {<a name="line.234"></a>
+<span class="sourceLineNo">235</span> return this.map.remove(key);<a name="line.235"></a>
+<span class="sourceLineNo">236</span> }<a name="line.236"></a>
+<span class="sourceLineNo">237</span><a name="line.237"></a>
+<span class="sourceLineNo">238</span> @Override<a name="line.238"></a>
+<span class="sourceLineNo">239</span> public int size() {<a name="line.239"></a>
+<span class="sourceLineNo">240</span> return map.size();<a name="line.240"></a>
+<span class="sourceLineNo">241</span> }<a name="line.241"></a>
+<span class="sourceLineNo">242</span><a name="line.242"></a>
+<span class="sourceLineNo">243</span> @Override<a name="line.243"></a>
+<span class="sourceLineNo">244</span> public SortedMap<byte[], byte[]> subMap(byte[] fromKey, byte[] toKey) {<a name="line.244"></a>
+<span class="sourceLineNo">245</span> return this.map.subMap(fromKey, toKey);<a name="line.245"></a>
+<span class="sourceLineNo">246</span> }<a name="line.246"></a>
+<span class="sourceLineNo">247</span><a name="line.247"></a>
+<span class="sourceLineNo">248</span> @Override<a name="line.248"></a>
+<span class="sourceLineNo">249</span> public SortedMap<byte[], byte[]> tailMap(byte[] fromKey) {<a name="line.249"></a>
+<span class="sourceLineNo">250</span> return this.map.tailMap(fromKey);<a name="line.250"></a>
+<span class="sourceLineNo">251</span> }<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span> @Override<a name="line.253"></a>
+<span class="sourceLineNo">254</span> public Collection<byte[]> values() {<a name="line.254"></a>
+<span class="sourceLineNo">255</span> return map.values();<a name="line.255"></a>
+<span class="sourceLineNo">256</span> }<a name="line.256"></a>
+<span class="sourceLineNo">257</span><a name="line.257"></a>
+<span class="sourceLineNo">258</span> /**<a name="line.258"></a>
+<span class="sourceLineNo">259</span> * Write out this instance on the passed in <code>out</code> stream.<a name="line.259"></a>
+<span class="sourceLineNo">260</span> * We write it as a protobuf.<a name="line.260"></a>
+<span class="sourceLineNo">261</span> * @see #read(DataInputStream)<a name="line.261"></a>
+<span class="sourceLineNo">262</span> */<a name="line.262"></a>
+<span class="sourceLineNo">263</span> void write(final DataOutputStream out) throws IOException {<a name="line.263"></a>
+<span class="sourceLineNo">264</span> HFileProtos.FileInfoProto.Builder builder = HFileProtos.FileInfoProto.newBuilder();<a name="line.264"></a>
+<span class="sourceLineNo">265</span> for (Map.Entry<byte [], byte[]> e: this.map.entrySet()) {<a name="line.265"></a>
+<span class="sourceLineNo">266</span> HBaseProtos.BytesBytesPair.Builder bbpBuilder = HBaseProtos.BytesBytesPair.newBuilder();<a name="line.266"></a>
+<span class="sourceLineNo">267</span> bbpBuilder.setFirst(UnsafeByteOperations.unsafeWrap(e.getKey()));<a name="line.267"></a>
+<span class="sourceLineNo">268</span> bbpBuilder.setSecond(UnsafeByteOperations.unsafeWrap(e.getValue()));<a name="line.268"></a>
+<span class="sourceLineNo">269</span> builder.addMapEntry(bbpBuilder.build());<a name="line.269"></a>
+<span class="sourceLineNo">270</span> }<a name="line.270"></a>
+<span class="sourceLineNo">271</span> out.write(ProtobufMagic.PB_MAGIC);<a name="line.271"></a>
+<span class="sourceLineNo">272</span> builder.build().writeDelimitedTo(out);<a name="line.272"></a>
+<span class="sourceLineNo">273</span> }<a name="line.273"></a>
+<span class="sourceLineNo">274</span><a name="line.274"></a>
+<span class="sourceLineNo">275</span> /**<a name="line.275"></a>
+<span class="sourceLineNo">276</span> * Populate this instance with what we find on the passed in <code>in</code> stream.<a name="line.276"></a>
+<span class="sourceLineNo">277</span> * Can deserialize protobuf of old Writables format.<a name="line.277"></a>
+<span class="sourceLineNo">278</span> * @see #write(DataOutputStream)<a name="line.278"></a>
+<span class="sourceLineNo">279</span> */<a name="line.279"></a>
+<span class="sourceLineNo">280</span> void read(final DataInputStream in) throws IOException {<a name="line.280"></a>
+<span class="sourceLineNo">281</span> // This code is tested over in TestHFileReaderV1 where we read an old hfile w/ this new code.<a name="line.281"></a>
+<span class="sourceLineNo">282</span> int pblen = ProtobufUtil.lengthOfPBMagic();<a name="line.282"></a>
+<span class="sourceLineNo">283</span> byte [] pbuf = new byte[pblen];<a name="line.283"></a>
+<span class="sourceLineNo">284</span> if (in.markSupported()) {<a name="line.284"></a>
+<span class="sourceLineNo">285</span> in.mark(pblen);<a name="line.285"></a>
+<span class="sourceLineNo">286</span> }<a name="line.286"></a>
+<span class="sourceLineNo">287</span> int read = in.read(pbuf);<a name="line.287"></a>
+<span class="sourceLineNo">288</span> if (read != pblen) {<a name="line.288"></a>
+<span class="sourceLineNo">289</span> throw new IOException("read=" + read + ", wanted=" + pblen);<a name="line.289"></a>
+<span class="sourceLineNo">290</span> }<a name="line.290"></a>
+<span class="sourceLineNo">291</span> if (ProtobufUtil.isPBMagicPrefix(pbuf)) {<a name="line.291"></a>
+<span class="sourceLineNo">292</span> parsePB(HFileProtos.FileInfoProto.parseDelimitedFrom(in));<a name="line.292"></a>
+<span class="sourceLineNo">293</span> } else {<a name="line.293"></a>
+<span class="sourceLineNo">294</span> if (in.markSupported()) {<a name="line.294"></a>
+<span class="sourceLineNo">295</span> in.reset();<a name="line.295"></a>
+<span class="sourceLineNo">296</span> parseWritable(in);<a name="line.296"></a>
+<span class="sourceLineNo">297</span> } else {<a name="line.297"></a>
+<span class="sourceLineNo">298</span> // We cannot use BufferedInputStream, it consumes more than we read from the underlying IS<a name="line.298"></a>
+<span class="sourceLineNo">299</span> ByteArrayInputStream bais = new ByteArrayInputStream(pbuf);<a name="line.299"></a>
+<span class="sourceLineNo">300</span> SequenceInputStream sis = new SequenceInputStream(bais, in); // Concatenate input streams<a name="line.300"></a>
+<span class="sourceLineNo">301</span> // TODO: Am I leaking anything here wrapping the passed in stream? We are not calling<a name="line.301"></a>
+<span class="sourceLineNo">302</span> // close on the wrapped streams but they should be let go after we leave this context?<a name="line.302"></a>
+<span class="sourceLineNo">303</span> // I see that we keep a reference to the passed in inputstream but since we no longer<a name="line.303"></a>
+<span class="sourceLineNo">304</span> // have a reference to this after we leave, we should be ok.<a name="line.304"></a>
+<span class="sourceLineNo">305</span> parseWritable(new DataInputStream(sis));<a name="line.305"></a>
+<span class="sourceLineNo">306</span> }<a name="line.306"></a>
+<span class="sourceLineNo">307</span> }<a name="line.307"></a>
+<span class="sourceLineNo">308</span> }<a name="line.308"></a>
+<span class="sourceLineNo">309</span><a name="line.309"></a>
+<span class="sourceLineNo">310</span> /**<a name="line.310"></a>
+<span class="sourceLineNo">311</span> * Now parse the old Writable format. It was a list of Map entries. Each map entry was a<a name="line.311"></a>
+<span class="sourceLineNo">312</span> * key and a value of a byte []. The old map format had a byte before each entry that held<a name="line.312"></a>
+<span class="sourceLineNo">313</span> * a code which was short for the key or value type. We know it was a byte [] so in below<a name="line.313"></a>
+<span class="sourceLineNo">314</span> * we just read and dump it.<a name="line.314"></a>
+<span class="sourceLineNo">315</span> */<a name="line.315"></a>
+<span class="sourceLineNo">316</span> void parseWritable(final DataInputStream in) throws IOException {<a name="line.316"></a>
+<span class="sourceLineNo">317</span> // First clear the map.<a name="line.317"></a>
+<span class="sourceLineNo">318</span> // Otherwise we will just accumulate entries every time this method is called.<a name="line.318"></a>
+<span class="sourceLineNo">319</span> this.map.clear();<a name="line.319"></a>
+<span class="sourceLineNo">320</span> // Read the number of entries in the map<a name="line.320"></a>
+<span class="sourceLineNo">321</span> int entries = in.readInt();<a name="line.321"></a>
+<span class="sourceLineNo">322</span> // Then read each key/value pair<a name="line.322"></a>
+<span class="sourceLineNo">323</span> for (int i = 0; i < entries; i++) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span> byte [] key = Bytes.readByteArray(in);<a name="line.324"></a>
+<span class="sourceLineNo">325</span> // We used to read a byte that encoded the class type.<a name="line.325"></a>
+<span class="sourceLineNo">326</span> // Read and ignore it because it is always byte [] in hfile<a name="line.326"></a>
+<span class="sourceLineNo">327</span> in.readByte();<a name="line.327"></a>
+<span class="sourceLineNo">328</span> byte [] value = Bytes.readByteArray(in);<a name="line.328"></a>
+<span class="sourceLineNo">329</span> this.map.put(key, value);<a name="line.329"></a>
+<span class="sourceLineNo">330</span> }<a name="line.330"></a>
+<span class="sourceLineNo">331</span> }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span> /**<a name="line.333"></a>
+<span class="sourceLineNo">334</span> * Fill our map with content of the pb we read off disk<a name="line.334"></a>
+<span class="sourceLineNo">335</span> * @param fip protobuf message to read<a name="line.335"></a>
+<span class="sourceLineNo">336</span> */<a name="line.336"></a>
+<span class="sourceLineNo">337</span> void parsePB(final HFileProtos.FileInfoProto fip) {<a name="line.337"></a>
+<span class="sourceLineNo">338</span> this.map.clear();<a name="line.338"></a>
+<span class="sourceLineNo">339</span> for (BytesBytesPair pair: fip.getMapEntryList()) {<a name="line.339"></a>
+<span class="sourceLineNo">340</span> this.map.put(pair.getFirst().toByteArray(), pair.getSecond().toByteArray());<a name="line.340"></a>
+<span class="sourceLineNo">341</span> }<a name="line.341"></a>
+<span class="sourceLineNo">342</span> }<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span> public void initTrailerAndContext(ReaderContext context, Configuration conf) throws IOException {<a name="line.344"></a>
+<span class="sourceLineNo">345</span> try {<a name="line.345"></a>
+<span class="sourceLineNo">346</span> boolean isHBaseChecksum = context.getInputStreamWrapper().shouldUseHBaseChecksum();<a name="line.346"></a>
+<span class="sourceLineNo">347</span> trailer = FixedFileTrailer.readFromStream(context.getInputStreamWrapper()<a name="line.347"></a>
+<span class="sourceLineNo">348</span> .getStream(isHBaseChecksum), context.getFileSize());<a name="line.348"></a>
+<span class="sourceLineNo">349</span> Path path = context.getFilePath();<a name="line.349"></a>
+<span class="sourceLineNo">350</span> checkFileVersion(path);<a name="line.350"></a>
+<span class="sourceLineNo">351</span> this.hfileContext = createHFileContext(path, trailer, conf);<a name="line.351"></a>
+<span class="sourceLineNo">352</span> context.getInputStreamWrapper().unbuffer();<a name="line.352"></a>
+<span class="sourceLineNo">353</span> } catch (Throwable t) {<a name="line.353"></a>
+<span class="sourceLineNo">354</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.354"></a>
+<span class="sourceLineNo">355</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.355"></a>
+<span class="sourceLineNo">356</span> throw new CorruptHFileException("Problem reading HFile Trailer from file "<a name="line.356"></a>
+<span class="sourceLineNo">357</span> + context.getFilePath(), t);<a name="line.357"></a>
+<span class="sourceLineNo">358</span> }<a name="line.358"></a>
+<span class="sourceLineNo">359</span> }<a name="line.359"></a>
+<span class="sourceLineNo">360</span><a name="line.360"></a>
+<span class="sourceLineNo">361</span> /**<a name="line.361"></a>
+<span class="sourceLineNo">362</span> * should be called after initTrailerAndContext<a name="line.362"></a>
+<span class="sourceLineNo">363</span> */<a name="line.363"></a>
+<span class="sourceLineNo">364</span> public void initMetaAndIndex(HFile.Reader reader) throws IOException {<a name="line.364"></a>
+<span class="sourceLineNo">365</span> ReaderContext context = reader.getContext();<a name="line.365"></a>
+<span class="sourceLineNo">366</span> try {<a name="line.366"></a>
+<span class="sourceLineNo">367</span> HFileBlock.FSReader blockReader = reader.getUncachedBlockReader();<a name="line.367"></a>
+<span class="sourceLineNo">368</span> // Initialize an block iterator, and parse load-on-open blocks in the following.<a name="line.368"></a>
+<span class="sourceLineNo">369</span> blockIter = blockReader.blockRange(trailer.getLoadOnOpenDataOffset(),<a name="line.369"></a>
+<span class="sourceLineNo">370</span> context.getFileSize() - trailer.getTrailerSize());<a name="line.370"></a>
+<span class="sourceLineNo">371</span> // Data index. We also read statistics about the block index written after<a name="line.371"></a>
+<span class="sourceLineNo">372</span> // the root level.<a name="line.372"></a>
+<span class="sourceLineNo">373</span> this.dataIndexReader =<a name="line.373"></a>
+<span class="sourceLineNo">374</span> new HFileBlockIndex.CellBasedKeyBlockIndexReader(trailer.createComparator(), trailer.getNumDataIndexLevels());<a name="line.374"></a>
+<span class="sourceLineNo">375</span> dataIndexReader<a name="line.375"></a>
+<span class="sourceLineNo">376</span> .readMultiLevelIndexRoot(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX), trailer.getDataIndexCount());<a name="line.376"></a>
+<span class="sourceLineNo">377</span> reader.setDataBlockIndexReader(dataIndexReader);<a name="line.377"></a>
+<span class="sourceLineNo">378</span> // Meta index.<a name="line.378"></a>
+<span class="sourceLineNo">379</span> this.metaIndexReader = new HFileBlockIndex.ByteArrayKeyBlockIndexReader(1);<a name="line.379"></a>
+<span class="sourceLineNo">380</span> metaIndexReader.readRootIndex(blockIter.nextBlockWithBlockType(BlockType.ROOT_INDEX),<a name="line.380"></a>
+<span class="sourceLineNo">381</span> trailer.getMetaIndexCount());<a name="line.381"></a>
+<span class="sourceLineNo">382</span> reader.setMetaBlockIndexReader(metaIndexReader);<a name="line.382"></a>
+<span class="sourceLineNo">383</span> loadMetaInfo(blockIter, hfileContext);<a name="line.383"></a>
+<span class="sourceLineNo">384</span> reader.setDataBlockEncoder(HFileDataBlockEncoderImpl.createFromFileInfo(this));<a name="line.384"></a>
+<span class="sourceLineNo">385</span> // Load-On-Open info<a name="line.385"></a>
+<span class="sourceLineNo">386</span> HFileBlock b;<a name="line.386"></a>
+<span class="sourceLineNo">387</span> while ((b = blockIter.nextBlock()) != null) {<a name="line.387"></a>
+<span class="sourceLineNo">388</span> loadOnOpenBlocks.add(b);<a name="line.388"></a>
+<span class="sourceLineNo">389</span> }<a name="line.389"></a>
+<span class="sourceLineNo">390</span> // close the block reader<a name="line.390"></a>
+<span class="sourceLineNo">391</span> context.getInputStreamWrapper().unbuffer();<a name="line.391"></a>
+<span class="sourceLineNo">392</span> } catch (Throwable t) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span> IOUtils.closeQuietly(context.getInputStreamWrapper(),<a name="line.393"></a>
+<span class="sourceLineNo">394</span> e -> LOG.warn("failed to close input stream wrapper", e));<a name="line.394"></a>
+<span class="sourceLineNo">395</span> throw new CorruptHFileException(<a name="line.395"></a>
+<span class="sourceLineNo">396</span> "Problem reading data index and meta index from file " + context.getFilePath(), t);<a name="line.396"></a>
+<span class="sourceLineNo">397</span> }<a name="line.397"></a>
+<span class="sourceLineNo">398</span> }<a name="line.398"></a>
+<span class="sourceLineNo">399</span><a name="line.399"></a>
+<span class="sourceLineNo">400</span> private HFileContext createHFileContext(Path path,<a name="line.400"></a>
+<span class="sourceLineNo">401</span> FixedFileTrailer trailer, Configuration conf) throws IOException {<a name="line.401"></a>
+<span class="sourceLineNo">402</span> HFileContextBuilder builder = new HFileContextBuilder()<a name="line.402"></a>
+<span class="sourceLineNo">403</span> .withHBaseCheckSum(true)<a name="line.403"></a>
+<span class="sourceLineNo">404</span> .withHFileName(path.getName())<a name="line.404"></a>
+<span class="sourceLineNo">405</span> .withCompression(trailer.getCompressionCodec())<a name="line.405"></a>
+<span class="sourceLineNo">406</span> .withCellComparator(FixedFileTrailer.createComparator(trailer.getComparatorClassName()));<a name="line.406"></a>
+<span class="sourceLineNo">407</span> // Check for any key material available<a name="line.407"></a>
+<span class="sourceLineNo">408</span> byte[] keyBytes = trailer.getEncryptionKey();<a name="line.408"></a>
+<span class="sourceLineNo">409</span> if (keyBytes != null) {<a name="line.409"></a>
+<span class="sourceLineNo">410</span> Encryption.Context cryptoContext = Encryption.newContext(conf);<a name="line.410"></a>
+<span class="sourceLineNo">411</span> Key key = EncryptionUtil.unwrapKey(conf, keyBytes);<a name="line.411"></a>
+<span class="sourceLineNo">412</span> // Use the algorithm the key wants<a name="line.412"></a>
+<span class="sourceLineNo">413</span> Cipher cipher = Encryption.getCipher(conf, key.getAlgorithm());<a name="line.413"></a>
+<span class="sourceLineNo">414</span> if (cipher == null) {<a name="line.414"></a>
+<span class="sourceLineNo">415</span> throw new IOException("Cipher '" + key.getAlgorithm() + "' is not available"<a name="line.415"></a>
+<span class="sourceLineNo">416</span> + ", path=" + path);<a name="line.416"></a>
+<span class="sourceLineNo">417</span> }<a name="line.417"></a>
+<span class="sourceLineNo">418</span> cryptoContext.setCipher(cipher);<a name="line.418"></a>
+<span class="sourceLineNo">419</span> cryptoContext.setKey(key);<a name="line.419"></a>
+<span class="sourceLineNo">420</span> builder.withEncryptionContext(cryptoContext);<a name="line.420"></a>
+<span class="sourceLineNo">421</span> }<a name="line.421"></a>
+<span class="sourceLineNo">422</span> HFileContext context = builder.build();<a name="line.422"></a>
+<span class="sourceLineNo">423</span> return context;<a name="line.423"></a>
+<span class="sourceLineNo">424</span> }<a name="line.424"></a>
+<span class="sourceLineNo">425</span><a name="line.425"></a>
+<span class="sourceLineNo">426</span> private void loadMetaInfo(HFileBlock.BlockIterator blockIter, HFileContext hfileContext)<a name="line.426"></a>
+<span class="sourceLineNo">427</span> throws IOException {<a name="line.427"></a>
+<span class="sourceLineNo">428</span> read(blockIter.nextBlockWithBlockType(BlockType.FILE_INFO).getByteStream());<a name="line.428"></a>
+<span class="sourceLineNo">429</span> byte[] creationTimeBytes = get(HFileInfo.CREATE_TIME_TS);<a name="line.429"></a>
+<span class="sourceLineNo">430</span> hfileContext.setFileCreateTime(creationTimeBytes == null ?<a name="line.430"></a>
+<span class="sourceLineNo">431</span> 0 : Bytes.toLong(creationTimeBytes));<a name="line.431"></a>
+<span class="sourceLineNo">432</span> byte[] tmp = get(HFileInfo.MAX_TAGS_LEN);<a name="line.432"></a>
+<span class="sourceLineNo">433</span> // max tag length is not present in the HFile means tags were not at all written to file.<a name="line.433"></a>
+<span class="sourceLineNo">434</span> if (tmp != null) {<a name="line.434"></a>
+<span class="sourceLineNo">435</span> hfileContext.setIncludesTags(true);<a name="line.435"></a>
+<span class="sourceLineNo">436</span> tmp = get(HFileInfo.TAGS_COMPRESSED);<a name="line.436"></a>
+<span class="sourceLineNo">437</span> if (tmp != null && Bytes.toBoolean(tmp)) {<a name="line.437"></a>
+<span class="sourceLineNo">438</span> hfileContext.setCompressTags(true);<a name="line.438"></a>
+<span class="sourceLineNo">439</span> }<a name="line.439"></a>
+<span class="sourceLineNo">440</span> }<a name="line.440"></a>
+<span class="sourceLineNo">441</span> // parse meta info<a name="line.441"></a>
+<span class="sourceLineNo">442</span> if (get(HFileInfo.LASTKEY) != null) {<a name="line.442"></a>
+<span class="sourceLineNo">443</span> lastKeyCell = new KeyValue.KeyOnlyKeyValue(get(HFileInfo.LASTKEY));<a name="line.443"></a>
<span class="sourceLineNo">444</span> }<a name="line.444"></a>
-<span class="sourceLineNo">445</span> }<a name="line.445"></a>
-<span class="sourceLineNo">446</span><a name="line.446"></a>
-<span class="sourceLineNo">447</span> /**<a name="line.447"></a>
-<span class="sourceLineNo">448</span> * File version check is a little sloppy. We read v3 files but can also read v2 files if their<a name="line.448"></a>
-<span class="sourceLineNo">449</span> * content has been pb'd; files written with 0.98.<a name="line.449"></a>
-<span class="sourceLineNo">450</span> */<a name="line.450"></a>
-<span class="sourceLineNo">451</span> private void checkFileVersion(Path path) {<a name="line.451"></a>
-<span class="sourceLineNo">452</span> int majorVersion = trailer.getMajorVersion();<a name="line.452"></a>
-<span class="sourceLineNo">453</span> if (majorVersion == getMajorVersion()) {<a name="line.453"></a>
-<span class="sourceLineNo">454</span> return;<a name="line.454"></a>
-<span class="sourceLineNo">455</span> }<a name="line.455"></a>
-<span class="sourceLineNo">456</span> int minorVersion = trailer.getMinorVersion();<a name="line.456"></a>
-<span class="sourceLineNo">457</span> if (majorVersion == 2 && minorVersion >= MIN_V2_MINOR_VERSION_WITH_PB) {<a name="line.457"></a>
-<span class="sourceLineNo">458</span> return;<a name="line.458"></a>
-<span class="sourceLineNo">459</span> }<a name="line.459"></a>
-<span class="sourceLineNo">460</span> // We can read v3 or v2 versions of hfile.<a name="line.460"></a>
-<span class="sourceLineNo">461</span> throw new IllegalArgumentException("Invalid HFile version: major=" +<a name="line.461"></a>
-<span class="sourceLineNo">462</span> trailer.getMajorVersion() + ", minor=" + trailer.getMinorVersion() + ": expected at least " +<a name="line.462"></a>
-<span class="sourceLineNo">463</span> "major=2 and minor=" + MAX_MINOR_VERSION + ", path=" + path);<a name="line.463"></a>
-<span class="sourceLineNo">464</span> }<a name="line.464"></a>
-<span class="sourceLineNo">465</span><a name="line.465"></a>
-<span class="sourceLineNo">466</span> public void close() {<a name="line.466"></a>
-<span class="sourceLineNo">467</span> if (blockIter != null) {<a name="line.467"></a>
-<span class="sourceLineNo">468</span> blockIter.freeBlocks();<a name="line.468"></a>
-<span class="sourceLineNo">469</span> }<a name="line.469"></a>
-<span class="sourceLineNo">470</span> }<a name="line.470"></a>
-<span class="sourceLineNo">471</span><a name="line.471"></a>
-<span class="sourceLineNo">472</span> public int getMajorVersion() {<a name="line.472"></a>
-<span class="sourceLineNo">473</span> return 3;<a name="line.473"></a>
-<span class="sourceLineNo">474</span> }<a name="line.474"></a>
-<span class="sourceLineNo">475</span><a name="line.475"></a>
-<span class="sourceLineNo">476</span> public void setTrailer(FixedFileTrailer trailer) {<a name="line.476"></a>
-<span class="sourceLineNo">477</span> this.trailer = trailer;<a name="line.477"></a>
-<span class="sourceLineNo">478</span> }<a name="line.478"></a>
-<span class="sourceLineNo">479</span><a name="line.479"></a>
-<span class="sourceLineNo">480</span> public FixedFileTrailer getTrailer() {<a name="line.480"></a>
-<span class="sourceLineNo">481</span> return this.trailer;<a name="line.481"></a>
-<span class="sourceLineNo">482</span> }<a name="line.482"></a>
-<span class="sourceLineNo">483</span><a name="line.483"></a>
-<span class="sourceLineNo">484</span> public HFileBlockIndex.CellBasedKeyBlockIndexReader getDataBlockIndexReader() {<a name="line.484"></a>
-<span class="sourceLineNo">485</span> return this.dataIndexReader;<a name="line.485"></a>
-<span class="sourceLineNo">486</span> }<a name="line.486"></a>
-<span class="sourceLineNo">487</span><a name="line.487"></a>
-<span class="sourceLineNo">488</span> public HFileBlockIndex.ByteArrayKeyBlockIndexReader getMetaBlockIndexReader() {<a name="line.488"></a>
-<span class="sourceLineNo">489</span> return this.metaIndexReader;<a name="line.489"></a>
-<span class="sourceLineNo">490</span> }<a name="line.490"></a>
-<span class="sourceLineNo">491</span><a name="line.491"></a>
-<span class="sourceLineNo">492</span> public HFileContext getHFileContext() {<a name="line.492"></a>
-<span class="sourceLineNo">493</span> return this.hfileContext;<a name="line.493"></a>
-<span class="sourceLineNo">494</span> }<a name="line.494"></a>
-<span class="sourceLineNo">495</span><a name="line.495"></a>
-<span class="sourceLineNo">496</span> public List<HFileBlock> getLoadOnOpenBlocks() {<a name="line.496"></a>
-<span class="sourceLineNo">497</span> return loadOnOpenBlocks;<a name="line.497"></a>
-<span class="sourceLineNo">498</span> }<a name="line.498"></a>
-<span class="sourceLineNo">499</span><a name="line.499"></a>
-<span class="sourceLineNo">500</span> public Cell getLastKeyCell() {<a name="line.500"></a>
-<span class="sourceLineNo">501</span> return lastKeyCell;<a name="line.501"></a>
-<span class="sourceLineNo">502</span> }<a name="line.502"></a>
-<span class="sourceLineNo">503</span><a name="line.503"></a>
-<span class="sourceLineNo">504</span> public int getAvgKeyLen() {<a name="line.504"></a>
-<span class="sourceLineNo">505</span> return avgKeyLen;<a name="line.505"></a>
-<span class="sourceLineNo">506</span> }<a name="line.506"></a>
-<span class="sourceLineNo">507</span><a name="line.507"></a>
-<span class="sourceLineNo">508</span> public int getAvgValueLen() {<a name="line.508"></a>
-<span class="sourceLineNo">509</span> return avgValueLen;<a name="line.509"></a>
-<span class="sourceLineNo">510</span> }<a name="line.510"></a>
-<span class="sourceLineNo">511</span><a name="line.511"></a>
-<span class="sourceLineNo">512</span> public boolean shouldIncludeMemStoreTS() {<a name="line.512"></a>
-<span class="sourceLineNo">513</span> return includesMemstoreTS;<a name="line.513"></a>
-<span class="sourceLineNo">514</span> }<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> public boolean isDecodeMemstoreTS() {<a name="line.516"></a>
-<span class="sourceLineNo">517</span> return decodeMemstoreTS;<a name="line.517"></a>
-<span class="sourceLineNo">518</span> }<a name="line.518"></a>
-<span class="sourceLineNo">519</span>}<a name="line.519"></a>
+<span class="sourceLineNo">445</span> avgKeyLen = Bytes.toInt(get(HFileInfo.AVG_KEY_LEN));<a name="line.445"></a>
+<span class="sourceLineNo">446</span> avgValueLen = Bytes.toInt(get(HFileInfo.AVG_VALUE_LEN));<a name="line.446"></a>
+<span class="sourceLineNo">447</span> byte [] keyValueFormatVersion = get(HFileWriterImpl.KEY_VALUE_VERSION);<a name="line.447"></a>
+<span class="sourceLineNo">448</span> includesMemstoreTS = keyValueFormatVersion != null &&<a name="line.448"></a>
+<span class="sourceLineNo">449</span> Bytes.toInt(keyValueFormatVersion) == HFileWriterImpl.KEY_VALUE_VER_WITH_MEMSTORE;<a name="line.449"></a>
+<span class="sourceLineNo">450</span> hfileContext.setIncludesMvcc(includesMemstoreTS);<a name="line.450"></a>
+<span class="sourceLineNo">451</span> if (includesMemstoreTS) {<a name="line.451"></a>
+<span class="sourceLineNo">452</span> decodeMemstoreTS = Bytes.toLong(get(HFileWriterImpl.MAX_MEMSTORE_TS_KEY)) > 0;<a name="line.452"></a>
+<span class="sourceLineNo">453</span> }<a name="line.453"></a>
+<span class="sourceLineNo">454</span> }<a name="line.454"></a>
+<span class="sourceLineNo">455</span><a name="line.455"></a>
+<span class="sourceLineNo">456</span> /**<a name="line.456"></a>
+<span class="sourceLineNo">457</span> * File version check is a little sloppy. We read v3 files but can also read v2 files if their<a name="line.457"></a>
+<span class="sourceLineNo">458</span> * content has been pb'd; files written with 0.98.<a name="line.458"></a>
+<span class="sourceLineNo">459</span> */<a name="line.459"></a>
+<span class="sourceLineNo">460</span> private void checkFileVersion(Path path) {<a name="line.460"></a>
+<span class="sourceLineNo">461</span> int majorVersion = trailer.getMajorVersion();<a name="line.461"></a>
+<span class="sourceLineNo">462</span> if (majorVersion == getMajorVersion()) {<a name="line.462"></a>
+<span class="sourceLineNo">463</span> return;<a name="line.463"></a>
+<span class="sourceLineNo">464</span> }<a name="line.464"></a>
+<span class="sourceLineNo">465</span> int minorVersion = trailer.getMinorVersion();<a name="line.465"></a>
+<span class="sourceLineNo">466</span> if (majorVersion == 2 && minorVersion >= MIN_V2_MINOR_VERSION_WITH_PB) {<a name="line.466"></a>
+<span class="sourceLineNo">467</span> return;<a name="line.467"></a>
+<span class="sourceLineNo">468</span> }<a name="line.468"></a>
+<span class="sourceLineNo">469</span> // We can read v3 or v2 versions of hfile.<a name="line.469"></a>
+<span class="sourceLineNo">470</span> throw new IllegalArgumentException("Invalid HFile version: major=" +<a name="line.470"></a>
+<span class="sourceLineNo">471</span> trailer.getMajorVersion() + ", minor=" + trailer.getMinorVersion() + ": expected at least " +<a name="line.471"></a>
+<span class="sourceLineNo">472</span> "major=2 and minor=" + MAX_MINOR_VERSION + ", path=" + path);<a name="line.472"></a>
+<span class="sourceLineNo">473</span> }<a name="line.473"></a>
+<span class="sourceLineNo">474</span><a name="line.474"></a>
+<span class="sourceLineNo">475</span> public void close() {<a name="line.475"></a>
+<span class="sourceLineNo">476</span> if (blockIter != null) {<a name="line.476"></a>
+<span class="sourceLineNo">477</span> blockIter.freeBlocks();<a name="line.477"></a>
+<span class="sourceLineNo">478</span> }<a name="line.478"></a>
+<span class="sourceLineNo">479</span> }<a name="line.479"></a>
+<span class="sourceLineNo">480</span><a name="line.480"></a>
+<span class="sourceLineNo">481</span> public int getMajorVersion() {<a name="line.481"></a>
+<span class="sourceLineNo">482</span> return 3;<a name="line.482"></a>
+<span class="sourceLineNo">483</span> }<a name="line.483"></a>
+<span class="sourceLineNo">484</span><a name="line.484"></a>
+<span class="sourceLineNo">485</span> public void setTrailer(FixedFileTrailer trailer) {<a name="line.485"></a>
+<span class="sourceLineNo">486</span> this.trailer = trailer;<a name="line.486"></a>
+<span class="sourceLineNo">487</span> }<a name="line.487"></a>
+<span class="sourceLineNo">488</span><a name="line.488"></a>
+<span class="sourceLineNo">489</span> public FixedFileTrailer getTrailer() {<a name="line.489"></a>
+<span class="sourceLineNo">490</span> return this.trailer;<a name="line.490"></a>
+<span class="sourceLineNo">491</span> }<a name="line.491"></a>
+<span class="sourceLineNo">492</span><a name="line.492"></a>
+<span class="sourceLineNo">493</span> public HFileBlockIndex.CellBasedKeyBlockIndexReader getDataBlockIndexReader() {<a name="line.493"></a>
+<span class="sourceLineNo">494</span> return this.dataIndexReader;<a name="line.494"></a>
+<span class="sourceLineNo">495</span> }<a name="line.495"></a>
+<span class="sourceLineNo">496</span><a name="line.496"></a>
+<span class="sourceLineNo">497</span> public HFileBlockIndex.ByteArrayKeyBlockIndexReader getMetaBlockIndexReader() {<a name="line.497"></a>
+<span class="sourceLineNo">498</span> return this.metaIndexReader;<a name="line.498"></a>
+<span class="sourceLineNo">499</span> }<a name="line.499"></a>
+<span class="sourceLineNo">500</span><a name="line.500"></a>
+<span class="sourceLineNo">501</span> public HFileContext getHFileContext() {<a name="line.501"></a>
+<span class="sourceLineNo">502</span> return this.hfileContext;<a name="line.502"></a>
+<span class="sourceLineNo">503</span> }<a name="line.503"></a>
+<span class="sourceLineNo">504</span><a name="line.504"></a>
+<span class="sourceLineNo">505</span> public List<HFileBlock> getLoadOnOpenBlocks() {<a name="line.505"></a>
+<span class="sourceLineNo">506</span> return loadOnOpenBlocks;<a name="line.506"></a>
+<span class="sourceLineNo">507</span> }<a name="line.507"></a>
+<span class="sourceLineNo">508</span><a name="line.508"></a>
+<span class="sourceLineNo">509</span> public Cell getLastKeyCell() {<a name="line.509"></a>
+<span class="sourceLineNo">510</span> return lastKeyCell;<a name="line.510"></a>
+<span class="sourceLineNo">511</span> }<a name="line.511"></a>
+<span class="sourceLineNo">512</span><a name="line.512"></a>
+<span class="sourceLineNo">513</span> public int getAvgKeyLen() {<a name="line.513"></a>
+<span class="sourceLineNo">514</span> return avgKeyLen;<a name="line.514"></a>
+<span class="sourceLineNo">515</span> }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span> public int getAvgValueLen() {<a name="line.517"></a>
+<span class="sourceLineNo">518</span> return avgValueLen;<a name="line.518"></a>
+<span class="sourceLineNo">519</span> }<a name="line.519"></a>
+<span class="sourceLineNo">520</span><a name="line.520"></a>
+<span class="sourceLineNo">521</span> public boolean shouldIncludeMemStoreTS() {<a name="line.521"></a>
+<span class="sourceLineNo">522</span> return includesMemstoreTS;<a name="line.522"></a>
+<span class="sourceLineNo">523</span> }<a name="line.523"></a>
+<span class="sourceLineNo">524</span><a name="line.524"></a>
+<span class="sourceLineNo">525</span> public boolean isDecodeMemstoreTS() {<a name="line.525"></a>
+<span class="sourceLineNo">526</span> return decodeMemstoreTS;<a name="line.526"></a>
+<span class="sourceLineNo">527</span> }<a name="line.527"></a>
+<span class="sourceLineNo">528</span>}<a name="line.528"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
index 9554da3..749ea2c 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
@@ -59,176 +59,176 @@
<span class="sourceLineNo">051</span>import java.util.regex.Pattern;<a name="line.51"></a>
<span class="sourceLineNo">052</span>import java.util.stream.Collectors;<a name="line.52"></a>
<span class="sourceLineNo">053</span>import javax.servlet.http.HttpServlet;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.commons.io.IOUtils;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.commons.lang3.StringUtils;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.conf.Configuration;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.fs.Path;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.66"></a>
-<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.HConstants;<a name="line.67"></a>
-<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.68"></a>
-<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.69"></a>
-<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.70"></a>
-<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.71"></a>
-<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.72"></a>
-<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.73"></a>
-<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.74"></a>
-<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.75"></a>
-<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.ServerName;<a name="line.76"></a>
-<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableName;<a name="line.77"></a>
-<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.78"></a>
-<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.79"></a>
-<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.80"></a>
-<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.81"></a>
-<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.82"></a>
-<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.83"></a>
-<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.84"></a>
-<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.85"></a>
-<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.86"></a>
-<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.87"></a>
-<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.88"></a>
-<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.89"></a>
-<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.90"></a>
-<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.92"></a>
-<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.93"></a>
-<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.94"></a>
-<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.95"></a>
-<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.96"></a>
-<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.97"></a>
-<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.98"></a>
-<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.99"></a>
-<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.100"></a>
-<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.102"></a>
-<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.103"></a>
-<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.104"></a>
-<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.105"></a>
-<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.106"></a>
-<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.107"></a>
-<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.108"></a>
-<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.109"></a>
-<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.111"></a>
-<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.112"></a>
-<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.113"></a>
-<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.114"></a>
-<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.115"></a>
-<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.116"></a>
-<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.117"></a>
-<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.120"></a>
-<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.121"></a>
-<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.123"></a>
-<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.124"></a>
-<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.126"></a>
-<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.127"></a>
-<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.128"></a>
-<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.130"></a>
-<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.131"></a>
-<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.132"></a>
-<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.133"></a>
-<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.134"></a>
-<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.135"></a>
-<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.136"></a>
-<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.137"></a>
-<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.138"></a>
-<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.139"></a>
-<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.146"></a>
-<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.147"></a>
-<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.148"></a>
-<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.149"></a>
-<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.151"></a>
-<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.152"></a>
-<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.153"></a>
-<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.154"></a>
-<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.155"></a>
-<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.156"></a>
-<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.157"></a>
-<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.158"></a>
-<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.159"></a>
-<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.160"></a>
-<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.161"></a>
-<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.162"></a>
-<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.163"></a>
-<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.164"></a>
-<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.165"></a>
-<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.166"></a>
-<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.167"></a>
-<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.168"></a>
-<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.169"></a>
-<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.170"></a>
-<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.171"></a>
-<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.172"></a>
-<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.173"></a>
-<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.174"></a>
-<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.175"></a>
-<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.176"></a>
-<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.177"></a>
-<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.178"></a>
-<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.179"></a>
-<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.180"></a>
-<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.181"></a>
-<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.182"></a>
-<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.183"></a>
-<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.184"></a>
-<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.185"></a>
-<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.186"></a>
-<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.187"></a>
-<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.188"></a>
-<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.189"></a>
-<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.190"></a>
-<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.191"></a>
-<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.192"></a>
-<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.193"></a>
-<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.194"></a>
-<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.195"></a>
-<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.196"></a>
-<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.197"></a>
-<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.198"></a>
-<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.199"></a>
-<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.200"></a>
-<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.201"></a>
-<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.202"></a>
-<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.203"></a>
-<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.204"></a>
-<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.207"></a>
-<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.208"></a>
-<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.209"></a>
-<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.216"></a>
-<span class="sourceLineNo">217</span>import org.apache.zookeeper.KeeperException;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>import org.slf4j.Logger;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>import org.slf4j.LoggerFactory;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.223"></a>
+<span class="sourceLineNo">054</span>import org.apache.commons.lang3.StringUtils;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.conf.Configuration;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.Path;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.64"></a>
+<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.65"></a>
+<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HConstants;<a name="line.66"></a>
+<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.67"></a>
+<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.68"></a>
+<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.69"></a>
+<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.70"></a>
+<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.71"></a>
+<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.72"></a>
+<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.73"></a>
+<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.74"></a>
+<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerName;<a name="line.75"></a>
+<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.TableName;<a name="line.76"></a>
+<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.77"></a>
+<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.78"></a>
+<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.80"></a>
+<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.81"></a>
+<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.82"></a>
+<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.83"></a>
+<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.84"></a>
+<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.85"></a>
+<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.86"></a>
+<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.87"></a>
+<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.88"></a>
+<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.89"></a>
+<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.90"></a>
+<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.91"></a>
+<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.92"></a>
+<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.93"></a>
+<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.94"></a>
+<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.95"></a>
+<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.96"></a>
+<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.97"></a>
+<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.98"></a>
+<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.100"></a>
+<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.101"></a>
+<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.103"></a>
+<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.104"></a>
+<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.105"></a>
+<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.106"></a>
+<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.107"></a>
+<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.108"></a>
+<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.109"></a>
+<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.110"></a>
+<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.111"></a>
+<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.112"></a>
+<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.113"></a>
+<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.115"></a>
+<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.116"></a>
+<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.118"></a>
+<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.119"></a>
+<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.120"></a>
+<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.123"></a>
+<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.125"></a>
+<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.126"></a>
+<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.127"></a>
+<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.129"></a>
+<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.130"></a>
+<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.131"></a>
+<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.132"></a>
+<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.133"></a>
+<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.134"></a>
+<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.135"></a>
+<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.136"></a>
+<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.137"></a>
+<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.138"></a>
+<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.140"></a>
+<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.141"></a>
+<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.147"></a>
+<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.149"></a>
+<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.150"></a>
+<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.151"></a>
+<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.152"></a>
+<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.153"></a>
+<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.154"></a>
+<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.155"></a>
+<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.156"></a>
+<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.157"></a>
+<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.158"></a>
+<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.159"></a>
+<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.160"></a>
+<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.161"></a>
+<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.162"></a>
+<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.163"></a>
+<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.164"></a>
+<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.165"></a>
+<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.166"></a>
+<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.167"></a>
+<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.168"></a>
+<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.169"></a>
+<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.170"></a>
+<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.171"></a>
+<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.172"></a>
+<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.173"></a>
+<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.174"></a>
+<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.175"></a>
+<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.176"></a>
+<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.177"></a>
+<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.178"></a>
+<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.179"></a>
+<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.180"></a>
+<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.181"></a>
+<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.182"></a>
+<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.183"></a>
+<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.184"></a>
+<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.185"></a>
+<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.186"></a>
+<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.187"></a>
+<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.188"></a>
+<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.189"></a>
+<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.190"></a>
+<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.191"></a>
+<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.192"></a>
+<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.193"></a>
+<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.194"></a>
+<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.195"></a>
+<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.196"></a>
+<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.197"></a>
+<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.198"></a>
+<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.199"></a>
+<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.200"></a>
+<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.201"></a>
+<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.202"></a>
+<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.204"></a>
+<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.205"></a>
+<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.208"></a>
+<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.209"></a>
+<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.210"></a>
+<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>import org.apache.zookeeper.KeeperException;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>import org.slf4j.Logger;<a name="line.217"></a>
+<span class="sourceLineNo">218</span>import org.slf4j.LoggerFactory;<a name="line.218"></a>
+<span class="sourceLineNo">219</span><a name="line.219"></a>
+<span class="sourceLineNo">220</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.220"></a>
+<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.221"></a>
+<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.223"></a>
<span class="sourceLineNo">224</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.224"></a>
<span class="sourceLineNo">225</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.225"></a>
<span class="sourceLineNo">226</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.226"></a>
@@ -840,7 +840,7 @@
<span class="sourceLineNo">832</span> HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.832"></a>
<span class="sourceLineNo">833</span> } finally {<a name="line.833"></a>
<span class="sourceLineNo">834</span> if (result != null) {<a name="line.834"></a>
-<span class="sourceLineNo">835</span> IOUtils.closeQuietly(result.getSecond());<a name="line.835"></a>
+<span class="sourceLineNo">835</span> Closeables.close(result.getSecond(), true);<a name="line.835"></a>
<span class="sourceLineNo">836</span> }<a name="line.836"></a>
<span class="sourceLineNo">837</span> }<a name="line.837"></a>
<span class="sourceLineNo">838</span> }<a name="line.838"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
index 9554da3..749ea2c 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.html
@@ -59,176 +59,176 @@
<span class="sourceLineNo">051</span>import java.util.regex.Pattern;<a name="line.51"></a>
<span class="sourceLineNo">052</span>import java.util.stream.Collectors;<a name="line.52"></a>
<span class="sourceLineNo">053</span>import javax.servlet.http.HttpServlet;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.commons.io.IOUtils;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.commons.lang3.StringUtils;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.conf.Configuration;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.fs.Path;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.66"></a>
-<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.HConstants;<a name="line.67"></a>
-<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.68"></a>
-<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.69"></a>
-<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.70"></a>
-<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.71"></a>
-<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.72"></a>
-<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.73"></a>
-<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.74"></a>
-<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.75"></a>
-<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.ServerName;<a name="line.76"></a>
-<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableName;<a name="line.77"></a>
-<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.78"></a>
-<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.79"></a>
-<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.80"></a>
-<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.81"></a>
-<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.82"></a>
-<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.83"></a>
-<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.84"></a>
-<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.85"></a>
-<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.86"></a>
-<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.87"></a>
-<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.88"></a>
-<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.89"></a>
-<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.90"></a>
-<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.92"></a>
-<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.93"></a>
-<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.94"></a>
-<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.95"></a>
-<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.96"></a>
-<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.97"></a>
-<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.98"></a>
-<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.99"></a>
-<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.100"></a>
-<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.102"></a>
-<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.103"></a>
-<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.104"></a>
-<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.105"></a>
-<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.106"></a>
-<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.107"></a>
-<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.108"></a>
-<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.109"></a>
-<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.111"></a>
-<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.112"></a>
-<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.113"></a>
-<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.114"></a>
-<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.115"></a>
-<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.116"></a>
-<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.117"></a>
-<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.120"></a>
-<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.121"></a>
-<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.123"></a>
-<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.124"></a>
-<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.126"></a>
-<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.127"></a>
-<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.128"></a>
-<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.130"></a>
-<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.131"></a>
-<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.132"></a>
-<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.133"></a>
-<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.134"></a>
-<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.135"></a>
-<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.136"></a>
-<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.137"></a>
-<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.138"></a>
-<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.139"></a>
-<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.146"></a>
-<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.147"></a>
-<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.148"></a>
-<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.149"></a>
-<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.151"></a>
-<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.152"></a>
-<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.153"></a>
-<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.154"></a>
-<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.155"></a>
-<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.156"></a>
-<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.157"></a>
-<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.158"></a>
-<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.159"></a>
-<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.160"></a>
-<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.161"></a>
-<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.162"></a>
-<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.163"></a>
-<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.164"></a>
-<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.165"></a>
-<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.166"></a>
-<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.167"></a>
-<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.168"></a>
-<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.169"></a>
-<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.170"></a>
-<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.171"></a>
-<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.172"></a>
-<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.173"></a>
-<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.174"></a>
-<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.175"></a>
-<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.176"></a>
-<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.177"></a>
-<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.178"></a>
-<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.179"></a>
-<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.180"></a>
-<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.181"></a>
-<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.182"></a>
-<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.183"></a>
-<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.184"></a>
-<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.185"></a>
-<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.186"></a>
-<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.187"></a>
-<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.188"></a>
-<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.189"></a>
-<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.190"></a>
-<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.191"></a>
-<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.192"></a>
-<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.193"></a>
-<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.194"></a>
-<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.195"></a>
-<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.196"></a>
-<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.197"></a>
-<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.198"></a>
-<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.199"></a>
-<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.200"></a>
-<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.201"></a>
-<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.202"></a>
-<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.203"></a>
-<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.204"></a>
-<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.207"></a>
-<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.208"></a>
-<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.209"></a>
-<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.216"></a>
-<span class="sourceLineNo">217</span>import org.apache.zookeeper.KeeperException;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>import org.slf4j.Logger;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>import org.slf4j.LoggerFactory;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.223"></a>
+<span class="sourceLineNo">054</span>import org.apache.commons.lang3.StringUtils;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.conf.Configuration;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.fs.FSDataOutputStream;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.fs.Path;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.ChoreService;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.ClusterId;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.ClusterMetrics;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.ClusterMetrics.Option;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.ClusterMetricsBuilder;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.DoNotRetryIOException;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.HBaseIOException;<a name="line.64"></a>
+<span class="sourceLineNo">065</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.65"></a>
+<span class="sourceLineNo">066</span>import org.apache.hadoop.hbase.HConstants;<a name="line.66"></a>
+<span class="sourceLineNo">067</span>import org.apache.hadoop.hbase.InvalidFamilyOperationException;<a name="line.67"></a>
+<span class="sourceLineNo">068</span>import org.apache.hadoop.hbase.MasterNotRunningException;<a name="line.68"></a>
+<span class="sourceLineNo">069</span>import org.apache.hadoop.hbase.MetaTableAccessor;<a name="line.69"></a>
+<span class="sourceLineNo">070</span>import org.apache.hadoop.hbase.NamespaceDescriptor;<a name="line.70"></a>
+<span class="sourceLineNo">071</span>import org.apache.hadoop.hbase.PleaseHoldException;<a name="line.71"></a>
+<span class="sourceLineNo">072</span>import org.apache.hadoop.hbase.RegionMetrics;<a name="line.72"></a>
+<span class="sourceLineNo">073</span>import org.apache.hadoop.hbase.ReplicationPeerNotFoundException;<a name="line.73"></a>
+<span class="sourceLineNo">074</span>import org.apache.hadoop.hbase.ServerMetrics;<a name="line.74"></a>
+<span class="sourceLineNo">075</span>import org.apache.hadoop.hbase.ServerName;<a name="line.75"></a>
+<span class="sourceLineNo">076</span>import org.apache.hadoop.hbase.TableName;<a name="line.76"></a>
+<span class="sourceLineNo">077</span>import org.apache.hadoop.hbase.TableNotDisabledException;<a name="line.77"></a>
+<span class="sourceLineNo">078</span>import org.apache.hadoop.hbase.TableNotFoundException;<a name="line.78"></a>
+<span class="sourceLineNo">079</span>import org.apache.hadoop.hbase.UnknownRegionException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span>import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;<a name="line.80"></a>
+<span class="sourceLineNo">081</span>import org.apache.hadoop.hbase.client.CompactionState;<a name="line.81"></a>
+<span class="sourceLineNo">082</span>import org.apache.hadoop.hbase.client.MasterSwitchType;<a name="line.82"></a>
+<span class="sourceLineNo">083</span>import org.apache.hadoop.hbase.client.NormalizeTableFilterParams;<a name="line.83"></a>
+<span class="sourceLineNo">084</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.84"></a>
+<span class="sourceLineNo">085</span>import org.apache.hadoop.hbase.client.RegionInfoBuilder;<a name="line.85"></a>
+<span class="sourceLineNo">086</span>import org.apache.hadoop.hbase.client.RegionStatesCount;<a name="line.86"></a>
+<span class="sourceLineNo">087</span>import org.apache.hadoop.hbase.client.TableDescriptor;<a name="line.87"></a>
+<span class="sourceLineNo">088</span>import org.apache.hadoop.hbase.client.TableDescriptorBuilder;<a name="line.88"></a>
+<span class="sourceLineNo">089</span>import org.apache.hadoop.hbase.client.TableState;<a name="line.89"></a>
+<span class="sourceLineNo">090</span>import org.apache.hadoop.hbase.coprocessor.CoprocessorHost;<a name="line.90"></a>
+<span class="sourceLineNo">091</span>import org.apache.hadoop.hbase.exceptions.MasterStoppedException;<a name="line.91"></a>
+<span class="sourceLineNo">092</span>import org.apache.hadoop.hbase.executor.ExecutorType;<a name="line.92"></a>
+<span class="sourceLineNo">093</span>import org.apache.hadoop.hbase.favored.FavoredNodesManager;<a name="line.93"></a>
+<span class="sourceLineNo">094</span>import org.apache.hadoop.hbase.ipc.CoprocessorRpcUtils;<a name="line.94"></a>
+<span class="sourceLineNo">095</span>import org.apache.hadoop.hbase.ipc.RpcServer;<a name="line.95"></a>
+<span class="sourceLineNo">096</span>import org.apache.hadoop.hbase.ipc.ServerNotRunningYetException;<a name="line.96"></a>
+<span class="sourceLineNo">097</span>import org.apache.hadoop.hbase.log.HBaseMarkers;<a name="line.97"></a>
+<span class="sourceLineNo">098</span>import org.apache.hadoop.hbase.master.MasterRpcServices.BalanceSwitchMode;<a name="line.98"></a>
+<span class="sourceLineNo">099</span>import org.apache.hadoop.hbase.master.assignment.AssignmentManager;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>import org.apache.hadoop.hbase.master.assignment.MergeTableRegionsProcedure;<a name="line.100"></a>
+<span class="sourceLineNo">101</span>import org.apache.hadoop.hbase.master.assignment.RegionStateNode;<a name="line.101"></a>
+<span class="sourceLineNo">102</span>import org.apache.hadoop.hbase.master.assignment.RegionStates;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>import org.apache.hadoop.hbase.master.assignment.TransitRegionStateProcedure;<a name="line.103"></a>
+<span class="sourceLineNo">104</span>import org.apache.hadoop.hbase.master.balancer.BalancerChore;<a name="line.104"></a>
+<span class="sourceLineNo">105</span>import org.apache.hadoop.hbase.master.balancer.ClusterStatusChore;<a name="line.105"></a>
+<span class="sourceLineNo">106</span>import org.apache.hadoop.hbase.master.balancer.LoadBalancerFactory;<a name="line.106"></a>
+<span class="sourceLineNo">107</span>import org.apache.hadoop.hbase.master.cleaner.DirScanPool;<a name="line.107"></a>
+<span class="sourceLineNo">108</span>import org.apache.hadoop.hbase.master.cleaner.HFileCleaner;<a name="line.108"></a>
+<span class="sourceLineNo">109</span>import org.apache.hadoop.hbase.master.cleaner.LogCleaner;<a name="line.109"></a>
+<span class="sourceLineNo">110</span>import org.apache.hadoop.hbase.master.cleaner.ReplicationBarrierCleaner;<a name="line.110"></a>
+<span class="sourceLineNo">111</span>import org.apache.hadoop.hbase.master.cleaner.SnapshotCleanerChore;<a name="line.111"></a>
+<span class="sourceLineNo">112</span>import org.apache.hadoop.hbase.master.janitor.CatalogJanitor;<a name="line.112"></a>
+<span class="sourceLineNo">113</span>import org.apache.hadoop.hbase.master.locking.LockManager;<a name="line.113"></a>
+<span class="sourceLineNo">114</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerFactory;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>import org.apache.hadoop.hbase.master.normalizer.RegionNormalizerManager;<a name="line.115"></a>
+<span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.master.procedure.CreateTableProcedure;<a name="line.116"></a>
+<span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.master.procedure.DeleteNamespaceProcedure;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.master.procedure.DeleteTableProcedure;<a name="line.118"></a>
+<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.master.procedure.DisableTableProcedure;<a name="line.119"></a>
+<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.master.procedure.EnableTableProcedure;<a name="line.120"></a>
+<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.master.procedure.InitMetaProcedure;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureConstants;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;<a name="line.123"></a>
+<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureScheduler;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil;<a name="line.125"></a>
+<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.master.procedure.MasterProcedureUtil.NonceProcedureRunnable;<a name="line.126"></a>
+<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.master.procedure.ModifyTableProcedure;<a name="line.127"></a>
+<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.master.procedure.ProcedurePrepareLatch;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.master.procedure.ProcedureSyncWait;<a name="line.129"></a>
+<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.master.procedure.ReopenTableRegionsProcedure;<a name="line.130"></a>
+<span class="sourceLineNo">131</span>import org.apache.hadoop.hbase.master.procedure.ServerCrashProcedure;<a name="line.131"></a>
+<span class="sourceLineNo">132</span>import org.apache.hadoop.hbase.master.procedure.TruncateTableProcedure;<a name="line.132"></a>
+<span class="sourceLineNo">133</span>import org.apache.hadoop.hbase.master.region.MasterRegion;<a name="line.133"></a>
+<span class="sourceLineNo">134</span>import org.apache.hadoop.hbase.master.region.MasterRegionFactory;<a name="line.134"></a>
+<span class="sourceLineNo">135</span>import org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure;<a name="line.135"></a>
+<span class="sourceLineNo">136</span>import org.apache.hadoop.hbase.master.replication.AddPeerProcedure;<a name="line.136"></a>
+<span class="sourceLineNo">137</span>import org.apache.hadoop.hbase.master.replication.DisablePeerProcedure;<a name="line.137"></a>
+<span class="sourceLineNo">138</span>import org.apache.hadoop.hbase.master.replication.EnablePeerProcedure;<a name="line.138"></a>
+<span class="sourceLineNo">139</span>import org.apache.hadoop.hbase.master.replication.RemovePeerProcedure;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>import org.apache.hadoop.hbase.master.replication.ReplicationPeerManager;<a name="line.140"></a>
+<span class="sourceLineNo">141</span>import org.apache.hadoop.hbase.master.replication.SyncReplicationReplayWALManager;<a name="line.141"></a>
+<span class="sourceLineNo">142</span>import org.apache.hadoop.hbase.master.replication.TransitPeerSyncReplicationStateProcedure;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hadoop.hbase.master.replication.UpdatePeerConfigProcedure;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hadoop.hbase.master.slowlog.SlowLogMasterService;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hadoop.hbase.master.snapshot.SnapshotManager;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hadoop.hbase.master.zksyncer.MasterAddressSyncer;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hadoop.hbase.master.zksyncer.MetaLocationSyncer;<a name="line.147"></a>
+<span class="sourceLineNo">148</span>import org.apache.hadoop.hbase.mob.MobFileCleanerChore;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>import org.apache.hadoop.hbase.mob.MobFileCompactionChore;<a name="line.149"></a>
+<span class="sourceLineNo">150</span>import org.apache.hadoop.hbase.monitoring.MemoryBoundedLogMessageBuffer;<a name="line.150"></a>
+<span class="sourceLineNo">151</span>import org.apache.hadoop.hbase.monitoring.MonitoredTask;<a name="line.151"></a>
+<span class="sourceLineNo">152</span>import org.apache.hadoop.hbase.monitoring.TaskMonitor;<a name="line.152"></a>
+<span class="sourceLineNo">153</span>import org.apache.hadoop.hbase.procedure.MasterProcedureManagerHost;<a name="line.153"></a>
+<span class="sourceLineNo">154</span>import org.apache.hadoop.hbase.procedure.flush.MasterFlushTableProcedureManager;<a name="line.154"></a>
+<span class="sourceLineNo">155</span>import org.apache.hadoop.hbase.procedure2.LockedResource;<a name="line.155"></a>
+<span class="sourceLineNo">156</span>import org.apache.hadoop.hbase.procedure2.Procedure;<a name="line.156"></a>
+<span class="sourceLineNo">157</span>import org.apache.hadoop.hbase.procedure2.ProcedureEvent;<a name="line.157"></a>
+<span class="sourceLineNo">158</span>import org.apache.hadoop.hbase.procedure2.ProcedureExecutor;<a name="line.158"></a>
+<span class="sourceLineNo">159</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureDispatcher.RemoteProcedure;<a name="line.159"></a>
+<span class="sourceLineNo">160</span>import org.apache.hadoop.hbase.procedure2.RemoteProcedureException;<a name="line.160"></a>
+<span class="sourceLineNo">161</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore;<a name="line.161"></a>
+<span class="sourceLineNo">162</span>import org.apache.hadoop.hbase.procedure2.store.ProcedureStore.ProcedureStoreListener;<a name="line.162"></a>
+<span class="sourceLineNo">163</span>import org.apache.hadoop.hbase.procedure2.store.region.RegionProcedureStore;<a name="line.163"></a>
+<span class="sourceLineNo">164</span>import org.apache.hadoop.hbase.quotas.MasterQuotaManager;<a name="line.164"></a>
+<span class="sourceLineNo">165</span>import org.apache.hadoop.hbase.quotas.MasterQuotasObserver;<a name="line.165"></a>
+<span class="sourceLineNo">166</span>import org.apache.hadoop.hbase.quotas.QuotaObserverChore;<a name="line.166"></a>
+<span class="sourceLineNo">167</span>import org.apache.hadoop.hbase.quotas.QuotaTableUtil;<a name="line.167"></a>
+<span class="sourceLineNo">168</span>import org.apache.hadoop.hbase.quotas.QuotaUtil;<a name="line.168"></a>
+<span class="sourceLineNo">169</span>import org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore;<a name="line.169"></a>
+<span class="sourceLineNo">170</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot;<a name="line.170"></a>
+<span class="sourceLineNo">171</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.SpaceQuotaStatus;<a name="line.171"></a>
+<span class="sourceLineNo">172</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier;<a name="line.172"></a>
+<span class="sourceLineNo">173</span>import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory;<a name="line.173"></a>
+<span class="sourceLineNo">174</span>import org.apache.hadoop.hbase.quotas.SpaceViolationPolicy;<a name="line.174"></a>
+<span class="sourceLineNo">175</span>import org.apache.hadoop.hbase.regionserver.HRegionServer;<a name="line.175"></a>
+<span class="sourceLineNo">176</span>import org.apache.hadoop.hbase.regionserver.RSRpcServices;<a name="line.176"></a>
+<span class="sourceLineNo">177</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.177"></a>
+<span class="sourceLineNo">178</span>import org.apache.hadoop.hbase.replication.ReplicationLoadSource;<a name="line.178"></a>
+<span class="sourceLineNo">179</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.179"></a>
+<span class="sourceLineNo">180</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.180"></a>
+<span class="sourceLineNo">181</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.181"></a>
+<span class="sourceLineNo">182</span>import org.apache.hadoop.hbase.replication.SyncReplicationState;<a name="line.182"></a>
+<span class="sourceLineNo">183</span>import org.apache.hadoop.hbase.replication.master.ReplicationHFileCleaner;<a name="line.183"></a>
+<span class="sourceLineNo">184</span>import org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner;<a name="line.184"></a>
+<span class="sourceLineNo">185</span>import org.apache.hadoop.hbase.replication.regionserver.ReplicationStatus;<a name="line.185"></a>
+<span class="sourceLineNo">186</span>import org.apache.hadoop.hbase.rsgroup.RSGroupAdminEndpoint;<a name="line.186"></a>
+<span class="sourceLineNo">187</span>import org.apache.hadoop.hbase.rsgroup.RSGroupBasedLoadBalancer;<a name="line.187"></a>
+<span class="sourceLineNo">188</span>import org.apache.hadoop.hbase.rsgroup.RSGroupInfoManager;<a name="line.188"></a>
+<span class="sourceLineNo">189</span>import org.apache.hadoop.hbase.rsgroup.RSGroupUtil;<a name="line.189"></a>
+<span class="sourceLineNo">190</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.190"></a>
+<span class="sourceLineNo">191</span>import org.apache.hadoop.hbase.security.SecurityConstants;<a name="line.191"></a>
+<span class="sourceLineNo">192</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.192"></a>
+<span class="sourceLineNo">193</span>import org.apache.hadoop.hbase.trace.TraceUtil;<a name="line.193"></a>
+<span class="sourceLineNo">194</span>import org.apache.hadoop.hbase.util.Addressing;<a name="line.194"></a>
+<span class="sourceLineNo">195</span>import org.apache.hadoop.hbase.util.Bytes;<a name="line.195"></a>
+<span class="sourceLineNo">196</span>import org.apache.hadoop.hbase.util.FutureUtils;<a name="line.196"></a>
+<span class="sourceLineNo">197</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.197"></a>
+<span class="sourceLineNo">198</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.198"></a>
+<span class="sourceLineNo">199</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.199"></a>
+<span class="sourceLineNo">200</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.200"></a>
+<span class="sourceLineNo">201</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.201"></a>
+<span class="sourceLineNo">202</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.202"></a>
+<span class="sourceLineNo">203</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.204"></a>
+<span class="sourceLineNo">205</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.205"></a>
+<span class="sourceLineNo">206</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.208"></a>
+<span class="sourceLineNo">209</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.209"></a>
+<span class="sourceLineNo">210</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.210"></a>
+<span class="sourceLineNo">211</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>import org.apache.zookeeper.KeeperException;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>import org.slf4j.Logger;<a name="line.217"></a>
+<span class="sourceLineNo">218</span>import org.slf4j.LoggerFactory;<a name="line.218"></a>
+<span class="sourceLineNo">219</span><a name="line.219"></a>
+<span class="sourceLineNo">220</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.220"></a>
+<span class="sourceLineNo">221</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.221"></a>
+<span class="sourceLineNo">222</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.223"></a>
<span class="sourceLineNo">224</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.224"></a>
<span class="sourceLineNo">225</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.225"></a>
<span class="sourceLineNo">226</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.226"></a>
@@ -840,7 +840,7 @@
<span class="sourceLineNo">832</span> HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.832"></a>
<span class="sourceLineNo">833</span> } finally {<a name="line.833"></a>
<span class="sourceLineNo">834</span> if (result != null) {<a name="line.834"></a>
-<span class="sourceLineNo">835</span> IOUtils.closeQuietly(result.getSecond());<a name="line.835"></a>
+<span class="sourceLineNo">835</span> Closeables.close(result.getSecond(), true);<a name="line.835"></a>
<span class="sourceLineNo">836</span> }<a name="line.836"></a>
<span class="sourceLineNo">837</span> }<a name="line.837"></a>
<span class="sourceLineNo">838</span> }<a name="line.838"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
index b056718..d880d89 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MetricsRegionServer.html
@@ -50,267 +50,271 @@
<span class="sourceLineNo">042</span> "hbase.regionserver.enable.table.latencies";<a name="line.42"></a>
<span class="sourceLineNo">043</span> public static final boolean RS_ENABLE_TABLE_METRICS_DEFAULT = true;<a name="line.43"></a>
<span class="sourceLineNo">044</span><a name="line.44"></a>
-<span class="sourceLineNo">045</span> private final MetricsRegionServerSource serverSource;<a name="line.45"></a>
-<span class="sourceLineNo">046</span> private final MetricsRegionServerWrapper regionServerWrapper;<a name="line.46"></a>
-<span class="sourceLineNo">047</span> private RegionServerTableMetrics tableMetrics;<a name="line.47"></a>
-<span class="sourceLineNo">048</span> private final MetricsTable metricsTable;<a name="line.48"></a>
-<span class="sourceLineNo">049</span> private MetricsRegionServerQuotaSource quotaSource;<a name="line.49"></a>
-<span class="sourceLineNo">050</span> private final MetricsUserAggregate userAggregate;<a name="line.50"></a>
-<span class="sourceLineNo">051</span><a name="line.51"></a>
-<span class="sourceLineNo">052</span> private MetricRegistry metricRegistry;<a name="line.52"></a>
-<span class="sourceLineNo">053</span> private Timer bulkLoadTimer;<a name="line.53"></a>
-<span class="sourceLineNo">054</span> private Meter serverReadQueryMeter;<a name="line.54"></a>
-<span class="sourceLineNo">055</span> private Meter serverWriteQueryMeter;<a name="line.55"></a>
-<span class="sourceLineNo">056</span><a name="line.56"></a>
-<span class="sourceLineNo">057</span> public MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper, Configuration conf,<a name="line.57"></a>
-<span class="sourceLineNo">058</span> MetricsTable metricsTable) {<a name="line.58"></a>
-<span class="sourceLineNo">059</span> this(regionServerWrapper,<a name="line.59"></a>
-<span class="sourceLineNo">060</span> CompatibilitySingletonFactory.getInstance(MetricsRegionServerSourceFactory.class)<a name="line.60"></a>
-<span class="sourceLineNo">061</span> .createServer(regionServerWrapper), createTableMetrics(conf), metricsTable,<a name="line.61"></a>
-<span class="sourceLineNo">062</span> MetricsUserAggregateFactory.getMetricsUserAggregate(conf));<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span> // Create hbase-metrics module based metrics. The registry should already be registered by the<a name="line.64"></a>
-<span class="sourceLineNo">065</span> // MetricsRegionServerSource<a name="line.65"></a>
-<span class="sourceLineNo">066</span> metricRegistry = MetricRegistries.global().get(serverSource.getMetricRegistryInfo()).get();<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span> // create and use metrics from the new hbase-metrics based registry.<a name="line.68"></a>
-<span class="sourceLineNo">069</span> bulkLoadTimer = metricRegistry.timer("Bulkload");<a name="line.69"></a>
+<span class="sourceLineNo">045</span> public static final String SLOW_METRIC_TIME = "hbase.ipc.slow.metric.time";<a name="line.45"></a>
+<span class="sourceLineNo">046</span> private final MetricsRegionServerSource serverSource;<a name="line.46"></a>
+<span class="sourceLineNo">047</span> private final MetricsRegionServerWrapper regionServerWrapper;<a name="line.47"></a>
+<span class="sourceLineNo">048</span> private RegionServerTableMetrics tableMetrics;<a name="line.48"></a>
+<span class="sourceLineNo">049</span> private final MetricsTable metricsTable;<a name="line.49"></a>
+<span class="sourceLineNo">050</span> private MetricsRegionServerQuotaSource quotaSource;<a name="line.50"></a>
+<span class="sourceLineNo">051</span> private final MetricsUserAggregate userAggregate;<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span> private MetricRegistry metricRegistry;<a name="line.53"></a>
+<span class="sourceLineNo">054</span> private Timer bulkLoadTimer;<a name="line.54"></a>
+<span class="sourceLineNo">055</span> private Meter serverReadQueryMeter;<a name="line.55"></a>
+<span class="sourceLineNo">056</span> private Meter serverWriteQueryMeter;<a name="line.56"></a>
+<span class="sourceLineNo">057</span> protected long slowMetricTime;<a name="line.57"></a>
+<span class="sourceLineNo">058</span> protected static final int DEFAULT_SLOW_METRIC_TIME = 1000; // milliseconds<a name="line.58"></a>
+<span class="sourceLineNo">059</span><a name="line.59"></a>
+<span class="sourceLineNo">060</span> public MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper, Configuration conf,<a name="line.60"></a>
+<span class="sourceLineNo">061</span> MetricsTable metricsTable) {<a name="line.61"></a>
+<span class="sourceLineNo">062</span> this(regionServerWrapper,<a name="line.62"></a>
+<span class="sourceLineNo">063</span> CompatibilitySingletonFactory.getInstance(MetricsRegionServerSourceFactory.class)<a name="line.63"></a>
+<span class="sourceLineNo">064</span> .createServer(regionServerWrapper), createTableMetrics(conf), metricsTable,<a name="line.64"></a>
+<span class="sourceLineNo">065</span> MetricsUserAggregateFactory.getMetricsUserAggregate(conf));<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span> // Create hbase-metrics module based metrics. The registry should already be registered by the<a name="line.67"></a>
+<span class="sourceLineNo">068</span> // MetricsRegionServerSource<a name="line.68"></a>
+<span class="sourceLineNo">069</span> metricRegistry = MetricRegistries.global().get(serverSource.getMetricRegistryInfo()).get();<a name="line.69"></a>
<span class="sourceLineNo">070</span><a name="line.70"></a>
-<span class="sourceLineNo">071</span> quotaSource = CompatibilitySingletonFactory.getInstance(MetricsRegionServerQuotaSource.class);<a name="line.71"></a>
-<span class="sourceLineNo">072</span> serverReadQueryMeter = metricRegistry.meter("ServerReadQueryPerSecond");<a name="line.72"></a>
-<span class="sourceLineNo">073</span> serverWriteQueryMeter = metricRegistry.meter("ServerWriteQueryPerSecond");<a name="line.73"></a>
-<span class="sourceLineNo">074</span> }<a name="line.74"></a>
-<span class="sourceLineNo">075</span><a name="line.75"></a>
-<span class="sourceLineNo">076</span> MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper,<a name="line.76"></a>
-<span class="sourceLineNo">077</span> MetricsRegionServerSource serverSource, RegionServerTableMetrics tableMetrics,<a name="line.77"></a>
-<span class="sourceLineNo">078</span> MetricsTable metricsTable, MetricsUserAggregate userAggregate) {<a name="line.78"></a>
-<span class="sourceLineNo">079</span> this.regionServerWrapper = regionServerWrapper;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> this.serverSource = serverSource;<a name="line.80"></a>
-<span class="sourceLineNo">081</span> this.tableMetrics = tableMetrics;<a name="line.81"></a>
-<span class="sourceLineNo">082</span> this.metricsTable = metricsTable;<a name="line.82"></a>
-<span class="sourceLineNo">083</span> this.userAggregate = userAggregate;<a name="line.83"></a>
-<span class="sourceLineNo">084</span> }<a name="line.84"></a>
-<span class="sourceLineNo">085</span><a name="line.85"></a>
-<span class="sourceLineNo">086</span> /**<a name="line.86"></a>
-<span class="sourceLineNo">087</span> * Creates an instance of {@link RegionServerTableMetrics} only if the feature is enabled.<a name="line.87"></a>
-<span class="sourceLineNo">088</span> */<a name="line.88"></a>
-<span class="sourceLineNo">089</span> static RegionServerTableMetrics createTableMetrics(Configuration conf) {<a name="line.89"></a>
-<span class="sourceLineNo">090</span> if (conf.getBoolean(RS_ENABLE_TABLE_METRICS_KEY, RS_ENABLE_TABLE_METRICS_DEFAULT)) {<a name="line.90"></a>
-<span class="sourceLineNo">091</span> return new RegionServerTableMetrics();<a name="line.91"></a>
-<span class="sourceLineNo">092</span> }<a name="line.92"></a>
-<span class="sourceLineNo">093</span> return null;<a name="line.93"></a>
-<span class="sourceLineNo">094</span> }<a name="line.94"></a>
-<span class="sourceLineNo">095</span><a name="line.95"></a>
-<span class="sourceLineNo">096</span> public MetricsRegionServerSource getMetricsSource() {<a name="line.96"></a>
-<span class="sourceLineNo">097</span> return serverSource;<a name="line.97"></a>
+<span class="sourceLineNo">071</span> // create and use metrics from the new hbase-metrics based registry.<a name="line.71"></a>
+<span class="sourceLineNo">072</span> bulkLoadTimer = metricRegistry.timer("Bulkload");<a name="line.72"></a>
+<span class="sourceLineNo">073</span><a name="line.73"></a>
+<span class="sourceLineNo">074</span> slowMetricTime = conf.getLong(SLOW_METRIC_TIME, DEFAULT_SLOW_METRIC_TIME);<a name="line.74"></a>
+<span class="sourceLineNo">075</span> quotaSource = CompatibilitySingletonFactory.getInstance(MetricsRegionServerQuotaSource.class);<a name="line.75"></a>
+<span class="sourceLineNo">076</span> serverReadQueryMeter = metricRegistry.meter("ServerReadQueryPerSecond");<a name="line.76"></a>
+<span class="sourceLineNo">077</span> serverWriteQueryMeter = metricRegistry.meter("ServerWriteQueryPerSecond");<a name="line.77"></a>
+<span class="sourceLineNo">078</span> }<a name="line.78"></a>
+<span class="sourceLineNo">079</span><a name="line.79"></a>
+<span class="sourceLineNo">080</span> MetricsRegionServer(MetricsRegionServerWrapper regionServerWrapper,<a name="line.80"></a>
+<span class="sourceLineNo">081</span> MetricsRegionServerSource serverSource, RegionServerTableMetrics tableMetrics,<a name="line.81"></a>
+<span class="sourceLineNo">082</span> MetricsTable metricsTable, MetricsUserAggregate userAggregate) {<a name="line.82"></a>
+<span class="sourceLineNo">083</span> this.regionServerWrapper = regionServerWrapper;<a name="line.83"></a>
+<span class="sourceLineNo">084</span> this.serverSource = serverSource;<a name="line.84"></a>
+<span class="sourceLineNo">085</span> this.tableMetrics = tableMetrics;<a name="line.85"></a>
+<span class="sourceLineNo">086</span> this.metricsTable = metricsTable;<a name="line.86"></a>
+<span class="sourceLineNo">087</span> this.userAggregate = userAggregate;<a name="line.87"></a>
+<span class="sourceLineNo">088</span> }<a name="line.88"></a>
+<span class="sourceLineNo">089</span><a name="line.89"></a>
+<span class="sourceLineNo">090</span> /**<a name="line.90"></a>
+<span class="sourceLineNo">091</span> * Creates an instance of {@link RegionServerTableMetrics} only if the feature is enabled.<a name="line.91"></a>
+<span class="sourceLineNo">092</span> */<a name="line.92"></a>
+<span class="sourceLineNo">093</span> static RegionServerTableMetrics createTableMetrics(Configuration conf) {<a name="line.93"></a>
+<span class="sourceLineNo">094</span> if (conf.getBoolean(RS_ENABLE_TABLE_METRICS_KEY, RS_ENABLE_TABLE_METRICS_DEFAULT)) {<a name="line.94"></a>
+<span class="sourceLineNo">095</span> return new RegionServerTableMetrics();<a name="line.95"></a>
+<span class="sourceLineNo">096</span> }<a name="line.96"></a>
+<span class="sourceLineNo">097</span> return null;<a name="line.97"></a>
<span class="sourceLineNo">098</span> }<a name="line.98"></a>
<span class="sourceLineNo">099</span><a name="line.99"></a>
-<span class="sourceLineNo">100</span> public MetricsUserAggregate getMetricsUserAggregate() {<a name="line.100"></a>
-<span class="sourceLineNo">101</span> return userAggregate;<a name="line.101"></a>
+<span class="sourceLineNo">100</span> public MetricsRegionServerSource getMetricsSource() {<a name="line.100"></a>
+<span class="sourceLineNo">101</span> return serverSource;<a name="line.101"></a>
<span class="sourceLineNo">102</span> }<a name="line.102"></a>
<span class="sourceLineNo">103</span><a name="line.103"></a>
-<span class="sourceLineNo">104</span> public MetricsRegionServerWrapper getRegionServerWrapper() {<a name="line.104"></a>
-<span class="sourceLineNo">105</span> return regionServerWrapper;<a name="line.105"></a>
+<span class="sourceLineNo">104</span> public MetricsUserAggregate getMetricsUserAggregate() {<a name="line.104"></a>
+<span class="sourceLineNo">105</span> return userAggregate;<a name="line.105"></a>
<span class="sourceLineNo">106</span> }<a name="line.106"></a>
<span class="sourceLineNo">107</span><a name="line.107"></a>
-<span class="sourceLineNo">108</span> public void updatePutBatch(TableName tn, long t) {<a name="line.108"></a>
-<span class="sourceLineNo">109</span> if (tableMetrics != null && tn != null) {<a name="line.109"></a>
-<span class="sourceLineNo">110</span> tableMetrics.updatePutBatch(tn, t);<a name="line.110"></a>
-<span class="sourceLineNo">111</span> }<a name="line.111"></a>
-<span class="sourceLineNo">112</span> if (t > 1000) {<a name="line.112"></a>
-<span class="sourceLineNo">113</span> serverSource.incrSlowPut();<a name="line.113"></a>
-<span class="sourceLineNo">114</span> }<a name="line.114"></a>
-<span class="sourceLineNo">115</span> serverSource.updatePutBatch(t);<a name="line.115"></a>
-<span class="sourceLineNo">116</span> }<a name="line.116"></a>
-<span class="sourceLineNo">117</span><a name="line.117"></a>
-<span class="sourceLineNo">118</span> public void updatePut(TableName tn, long t) {<a name="line.118"></a>
-<span class="sourceLineNo">119</span> if (tableMetrics != null && tn != null) {<a name="line.119"></a>
-<span class="sourceLineNo">120</span> tableMetrics.updatePut(tn, t);<a name="line.120"></a>
-<span class="sourceLineNo">121</span> }<a name="line.121"></a>
-<span class="sourceLineNo">122</span> serverSource.updatePut(t);<a name="line.122"></a>
-<span class="sourceLineNo">123</span> userAggregate.updatePut(t);<a name="line.123"></a>
-<span class="sourceLineNo">124</span> }<a name="line.124"></a>
-<span class="sourceLineNo">125</span><a name="line.125"></a>
-<span class="sourceLineNo">126</span> public void updateDelete(TableName tn, long t) {<a name="line.126"></a>
-<span class="sourceLineNo">127</span> if (tableMetrics != null && tn != null) {<a name="line.127"></a>
-<span class="sourceLineNo">128</span> tableMetrics.updateDelete(tn, t);<a name="line.128"></a>
-<span class="sourceLineNo">129</span> }<a name="line.129"></a>
-<span class="sourceLineNo">130</span> serverSource.updateDelete(t);<a name="line.130"></a>
-<span class="sourceLineNo">131</span> userAggregate.updateDelete(t);<a name="line.131"></a>
-<span class="sourceLineNo">132</span> }<a name="line.132"></a>
-<span class="sourceLineNo">133</span><a name="line.133"></a>
-<span class="sourceLineNo">134</span> public void updateDeleteBatch(TableName tn, long t) {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> if (tableMetrics != null && tn != null) {<a name="line.135"></a>
-<span class="sourceLineNo">136</span> tableMetrics.updateDeleteBatch(tn, t);<a name="line.136"></a>
-<span class="sourceLineNo">137</span> }<a name="line.137"></a>
-<span class="sourceLineNo">138</span> if (t > 1000) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span> serverSource.incrSlowDelete();<a name="line.139"></a>
-<span class="sourceLineNo">140</span> }<a name="line.140"></a>
-<span class="sourceLineNo">141</span> serverSource.updateDeleteBatch(t);<a name="line.141"></a>
-<span class="sourceLineNo">142</span> }<a name="line.142"></a>
-<span class="sourceLineNo">143</span><a name="line.143"></a>
-<span class="sourceLineNo">144</span> public void updateCheckAndDelete(TableName tn, long t) {<a name="line.144"></a>
-<span class="sourceLineNo">145</span> if (tableMetrics != null && tn != null) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> tableMetrics.updateCheckAndDelete(tn, t);<a name="line.146"></a>
-<span class="sourceLineNo">147</span> }<a name="line.147"></a>
-<span class="sourceLineNo">148</span> serverSource.updateCheckAndDelete(t);<a name="line.148"></a>
-<span class="sourceLineNo">149</span> }<a name="line.149"></a>
-<span class="sourceLineNo">150</span><a name="line.150"></a>
-<span class="sourceLineNo">151</span> public void updateCheckAndPut(TableName tn, long t) {<a name="line.151"></a>
-<span class="sourceLineNo">152</span> if (tableMetrics != null && tn != null) {<a name="line.152"></a>
-<span class="sourceLineNo">153</span> tableMetrics.updateCheckAndPut(tn, t);<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span> serverSource.updateCheckAndPut(t);<a name="line.155"></a>
-<span class="sourceLineNo">156</span> }<a name="line.156"></a>
-<span class="sourceLineNo">157</span><a name="line.157"></a>
-<span class="sourceLineNo">158</span> public void updateCheckAndMutate(TableName tn, long t) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> if (tableMetrics != null && tn != null) {<a name="line.159"></a>
-<span class="sourceLineNo">160</span> tableMetrics.updateCheckAndMutate(tn, t);<a name="line.160"></a>
-<span class="sourceLineNo">161</span> }<a name="line.161"></a>
-<span class="sourceLineNo">162</span> serverSource.updateCheckAndMutate(t);<a name="line.162"></a>
-<span class="sourceLineNo">163</span> }<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span> public void updateGet(TableName tn, long t) {<a name="line.165"></a>
-<span class="sourceLineNo">166</span> if (tableMetrics != null && tn != null) {<a name="line.166"></a>
-<span class="sourceLineNo">167</span> tableMetrics.updateGet(tn, t);<a name="line.167"></a>
-<span class="sourceLineNo">168</span> }<a name="line.168"></a>
-<span class="sourceLineNo">169</span> if (t > 1000) {<a name="line.169"></a>
-<span class="sourceLineNo">170</span> serverSource.incrSlowGet();<a name="line.170"></a>
-<span class="sourceLineNo">171</span> }<a name="line.171"></a>
-<span class="sourceLineNo">172</span> serverSource.updateGet(t);<a name="line.172"></a>
-<span class="sourceLineNo">173</span> userAggregate.updateGet(t);<a name="line.173"></a>
-<span class="sourceLineNo">174</span> }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> public void updateIncrement(TableName tn, long t) {<a name="line.176"></a>
-<span class="sourceLineNo">177</span> if (tableMetrics != null && tn != null) {<a name="line.177"></a>
-<span class="sourceLineNo">178</span> tableMetrics.updateIncrement(tn, t);<a name="line.178"></a>
-<span class="sourceLineNo">179</span> }<a name="line.179"></a>
-<span class="sourceLineNo">180</span> if (t > 1000) {<a name="line.180"></a>
-<span class="sourceLineNo">181</span> serverSource.incrSlowIncrement();<a name="line.181"></a>
-<span class="sourceLineNo">182</span> }<a name="line.182"></a>
-<span class="sourceLineNo">183</span> serverSource.updateIncrement(t);<a name="line.183"></a>
-<span class="sourceLineNo">184</span> userAggregate.updateIncrement(t);<a name="line.184"></a>
-<span class="sourceLineNo">185</span> }<a name="line.185"></a>
-<span class="sourceLineNo">186</span><a name="line.186"></a>
-<span class="sourceLineNo">187</span> public void updateAppend(TableName tn, long t) {<a name="line.187"></a>
-<span class="sourceLineNo">188</span> if (tableMetrics != null && tn != null) {<a name="line.188"></a>
-<span class="sourceLineNo">189</span> tableMetrics.updateAppend(tn, t);<a name="line.189"></a>
-<span class="sourceLineNo">190</span> }<a name="line.190"></a>
-<span class="sourceLineNo">191</span> if (t > 1000) {<a name="line.191"></a>
-<span class="sourceLineNo">192</span> serverSource.incrSlowAppend();<a name="line.192"></a>
-<span class="sourceLineNo">193</span> }<a name="line.193"></a>
-<span class="sourceLineNo">194</span> serverSource.updateAppend(t);<a name="line.194"></a>
-<span class="sourceLineNo">195</span> userAggregate.updateAppend(t);<a name="line.195"></a>
-<span class="sourceLineNo">196</span> }<a name="line.196"></a>
-<span class="sourceLineNo">197</span><a name="line.197"></a>
-<span class="sourceLineNo">198</span> public void updateReplay(long t){<a name="line.198"></a>
-<span class="sourceLineNo">199</span> serverSource.updateReplay(t);<a name="line.199"></a>
-<span class="sourceLineNo">200</span> userAggregate.updateReplay(t);<a name="line.200"></a>
-<span class="sourceLineNo">201</span> }<a name="line.201"></a>
-<span class="sourceLineNo">202</span><a name="line.202"></a>
-<span class="sourceLineNo">203</span> public void updateScanSize(TableName tn, long scanSize){<a name="line.203"></a>
-<span class="sourceLineNo">204</span> if (tableMetrics != null && tn != null) {<a name="line.204"></a>
-<span class="sourceLineNo">205</span> tableMetrics.updateScanSize(tn, scanSize);<a name="line.205"></a>
-<span class="sourceLineNo">206</span> }<a name="line.206"></a>
-<span class="sourceLineNo">207</span> serverSource.updateScanSize(scanSize);<a name="line.207"></a>
-<span class="sourceLineNo">208</span> }<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span> public void updateScanTime(TableName tn, long t) {<a name="line.210"></a>
-<span class="sourceLineNo">211</span> if (tableMetrics != null && tn != null) {<a name="line.211"></a>
-<span class="sourceLineNo">212</span> tableMetrics.updateScanTime(tn, t);<a name="line.212"></a>
-<span class="sourceLineNo">213</span> }<a name="line.213"></a>
-<span class="sourceLineNo">214</span> serverSource.updateScanTime(t);<a name="line.214"></a>
-<span class="sourceLineNo">215</span> userAggregate.updateScanTime(t);<a name="line.215"></a>
-<span class="sourceLineNo">216</span> }<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span> public void updateSplitTime(long t) {<a name="line.218"></a>
-<span class="sourceLineNo">219</span> serverSource.updateSplitTime(t);<a name="line.219"></a>
+<span class="sourceLineNo">108</span> public MetricsRegionServerWrapper getRegionServerWrapper() {<a name="line.108"></a>
+<span class="sourceLineNo">109</span> return regionServerWrapper;<a name="line.109"></a>
+<span class="sourceLineNo">110</span> }<a name="line.110"></a>
+<span class="sourceLineNo">111</span><a name="line.111"></a>
+<span class="sourceLineNo">112</span> public void updatePutBatch(TableName tn, long t) {<a name="line.112"></a>
+<span class="sourceLineNo">113</span> if (tableMetrics != null && tn != null) {<a name="line.113"></a>
+<span class="sourceLineNo">114</span> tableMetrics.updatePutBatch(tn, t);<a name="line.114"></a>
+<span class="sourceLineNo">115</span> }<a name="line.115"></a>
+<span class="sourceLineNo">116</span> if (t > slowMetricTime) {<a name="line.116"></a>
+<span class="sourceLineNo">117</span> serverSource.incrSlowPut();<a name="line.117"></a>
+<span class="sourceLineNo">118</span> }<a name="line.118"></a>
+<span class="sourceLineNo">119</span> serverSource.updatePutBatch(t);<a name="line.119"></a>
+<span class="sourceLineNo">120</span> }<a name="line.120"></a>
+<span class="sourceLineNo">121</span><a name="line.121"></a>
+<span class="sourceLineNo">122</span> public void updatePut(TableName tn, long t) {<a name="line.122"></a>
+<span class="sourceLineNo">123</span> if (tableMetrics != null && tn != null) {<a name="line.123"></a>
+<span class="sourceLineNo">124</span> tableMetrics.updatePut(tn, t);<a name="line.124"></a>
+<span class="sourceLineNo">125</span> }<a name="line.125"></a>
+<span class="sourceLineNo">126</span> serverSource.updatePut(t);<a name="line.126"></a>
+<span class="sourceLineNo">127</span> userAggregate.updatePut(t);<a name="line.127"></a>
+<span class="sourceLineNo">128</span> }<a name="line.128"></a>
+<span class="sourceLineNo">129</span><a name="line.129"></a>
+<span class="sourceLineNo">130</span> public void updateDelete(TableName tn, long t) {<a name="line.130"></a>
+<span class="sourceLineNo">131</span> if (tableMetrics != null && tn != null) {<a name="line.131"></a>
+<span class="sourceLineNo">132</span> tableMetrics.updateDelete(tn, t);<a name="line.132"></a>
+<span class="sourceLineNo">133</span> }<a name="line.133"></a>
+<span class="sourceLineNo">134</span> serverSource.updateDelete(t);<a name="line.134"></a>
+<span class="sourceLineNo">135</span> userAggregate.updateDelete(t);<a name="line.135"></a>
+<span class="sourceLineNo">136</span> }<a name="line.136"></a>
+<span class="sourceLineNo">137</span><a name="line.137"></a>
+<span class="sourceLineNo">138</span> public void updateDeleteBatch(TableName tn, long t) {<a name="line.138"></a>
+<span class="sourceLineNo">139</span> if (tableMetrics != null && tn != null) {<a name="line.139"></a>
+<span class="sourceLineNo">140</span> tableMetrics.updateDeleteBatch(tn, t);<a name="line.140"></a>
+<span class="sourceLineNo">141</span> }<a name="line.141"></a>
+<span class="sourceLineNo">142</span> if (t > slowMetricTime) {<a name="line.142"></a>
+<span class="sourceLineNo">143</span> serverSource.incrSlowDelete();<a name="line.143"></a>
+<span class="sourceLineNo">144</span> }<a name="line.144"></a>
+<span class="sourceLineNo">145</span> serverSource.updateDeleteBatch(t);<a name="line.145"></a>
+<span class="sourceLineNo">146</span> }<a name="line.146"></a>
+<span class="sourceLineNo">147</span><a name="line.147"></a>
+<span class="sourceLineNo">148</span> public void updateCheckAndDelete(TableName tn, long t) {<a name="line.148"></a>
+<span class="sourceLineNo">149</span> if (tableMetrics != null && tn != null) {<a name="line.149"></a>
+<span class="sourceLineNo">150</span> tableMetrics.updateCheckAndDelete(tn, t);<a name="line.150"></a>
+<span class="sourceLineNo">151</span> }<a name="line.151"></a>
+<span class="sourceLineNo">152</span> serverSource.updateCheckAndDelete(t);<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span><a name="line.154"></a>
+<span class="sourceLineNo">155</span> public void updateCheckAndPut(TableName tn, long t) {<a name="line.155"></a>
+<span class="sourceLineNo">156</span> if (tableMetrics != null && tn != null) {<a name="line.156"></a>
+<span class="sourceLineNo">157</span> tableMetrics.updateCheckAndPut(tn, t);<a name="line.157"></a>
+<span class="sourceLineNo">158</span> }<a name="line.158"></a>
+<span class="sourceLineNo">159</span> serverSource.updateCheckAndPut(t);<a name="line.159"></a>
+<span class="sourceLineNo">160</span> }<a name="line.160"></a>
+<span class="sourceLineNo">161</span><a name="line.161"></a>
+<span class="sourceLineNo">162</span> public void updateCheckAndMutate(TableName tn, long t) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span> if (tableMetrics != null && tn != null) {<a name="line.163"></a>
+<span class="sourceLineNo">164</span> tableMetrics.updateCheckAndMutate(tn, t);<a name="line.164"></a>
+<span class="sourceLineNo">165</span> }<a name="line.165"></a>
+<span class="sourceLineNo">166</span> serverSource.updateCheckAndMutate(t);<a name="line.166"></a>
+<span class="sourceLineNo">167</span> }<a name="line.167"></a>
+<span class="sourceLineNo">168</span><a name="line.168"></a>
+<span class="sourceLineNo">169</span> public void updateGet(TableName tn, long t) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (tableMetrics != null && tn != null) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> tableMetrics.updateGet(tn, t);<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> if (t > slowMetricTime) {<a name="line.173"></a>
+<span class="sourceLineNo">174</span> serverSource.incrSlowGet();<a name="line.174"></a>
+<span class="sourceLineNo">175</span> }<a name="line.175"></a>
+<span class="sourceLineNo">176</span> serverSource.updateGet(t);<a name="line.176"></a>
+<span class="sourceLineNo">177</span> userAggregate.updateGet(t);<a name="line.177"></a>
+<span class="sourceLineNo">178</span> }<a name="line.178"></a>
+<span class="sourceLineNo">179</span><a name="line.179"></a>
+<span class="sourceLineNo">180</span> public void updateIncrement(TableName tn, long t) {<a name="line.180"></a>
+<span class="sourceLineNo">181</span> if (tableMetrics != null && tn != null) {<a name="line.181"></a>
+<span class="sourceLineNo">182</span> tableMetrics.updateIncrement(tn, t);<a name="line.182"></a>
+<span class="sourceLineNo">183</span> }<a name="line.183"></a>
+<span class="sourceLineNo">184</span> if (t > slowMetricTime) {<a name="line.184"></a>
+<span class="sourceLineNo">185</span> serverSource.incrSlowIncrement();<a name="line.185"></a>
+<span class="sourceLineNo">186</span> }<a name="line.186"></a>
+<span class="sourceLineNo">187</span> serverSource.updateIncrement(t);<a name="line.187"></a>
+<span class="sourceLineNo">188</span> userAggregate.updateIncrement(t);<a name="line.188"></a>
+<span class="sourceLineNo">189</span> }<a name="line.189"></a>
+<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">191</span> public void updateAppend(TableName tn, long t) {<a name="line.191"></a>
+<span class="sourceLineNo">192</span> if (tableMetrics != null && tn != null) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span> tableMetrics.updateAppend(tn, t);<a name="line.193"></a>
+<span class="sourceLineNo">194</span> }<a name="line.194"></a>
+<span class="sourceLineNo">195</span> if (t > slowMetricTime) {<a name="line.195"></a>
+<span class="sourceLineNo">196</span> serverSource.incrSlowAppend();<a name="line.196"></a>
+<span class="sourceLineNo">197</span> }<a name="line.197"></a>
+<span class="sourceLineNo">198</span> serverSource.updateAppend(t);<a name="line.198"></a>
... 98626 lines suppressed ...