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 2019/12/03 14:43:01 UTC

[hbase-site] branch asf-site updated: Published site at 0f166edc3da303b6b9746db2dc02f2a30c1de4e0.

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 c64d328  Published site at 0f166edc3da303b6b9746db2dc02f2a30c1de4e0.
c64d328 is described below

commit c64d3287bd7cb365f60f1163e26ee45c17e62140
Author: jenkins <bu...@apache.org>
AuthorDate: Tue Dec 3 14:42:47 2019 +0000

    Published site at 0f166edc3da303b6b9746db2dc02f2a30c1de4e0.
---
 acid-semantics.html                                |    2 +-
 apache_hbase_reference_guide.pdf                   |    4 +-
 .../hbase/replication/ReplicationPeerConfig.html   |   47 +-
 book.html                                          |    2 +-
 bulk-loads.html                                    |    2 +-
 checkstyle-aggregate.html                          |  152 +-
 checkstyle.rss                                     |   16 +-
 coc.html                                           |    2 +-
 dependencies.html                                  |    2 +-
 dependency-convergence.html                        |    2 +-
 dependency-info.html                               |    2 +-
 dependency-management.html                         |    2 +-
 devapidocs/constant-values.html                    |    4 +-
 devapidocs/index-all.html                          |    4 -
 .../apache/hadoop/hbase/backup/package-tree.html   |    2 +-
 .../apache/hadoop/hbase/class-use/TableName.html   |   11 +-
 .../apache/hadoop/hbase/client/package-tree.html   |   20 +-
 .../hadoop/hbase/coprocessor/package-tree.html     |    2 +-
 .../apache/hadoop/hbase/executor/package-tree.html |    2 +-
 .../apache/hadoop/hbase/filter/package-tree.html   |    8 +-
 .../hadoop/hbase/hbtop/field/package-tree.html     |    2 +-
 .../apache/hadoop/hbase/io/hfile/package-tree.html |    6 +-
 .../org/apache/hadoop/hbase/ipc/package-tree.html  |    2 +-
 .../hadoop/hbase/mapreduce/package-tree.html       |    4 +-
 .../hadoop/hbase/master/balancer/package-tree.html |    2 +-
 .../apache/hadoop/hbase/master/package-tree.html   |    6 +-
 .../hbase/master/procedure/package-tree.html       |    4 +-
 .../master/replication/AbstractPeerProcedure.html  |   34 +-
 .../master/replication/ModifyPeerProcedure.html    |   38 +-
 .../hadoop/hbase/monitoring/package-tree.html      |    2 +-
 .../org/apache/hadoop/hbase/package-tree.html      |   18 +-
 .../hadoop/hbase/procedure2/package-tree.html      |    6 +-
 .../apache/hadoop/hbase/quotas/package-tree.html   |    4 +-
 .../hadoop/hbase/regionserver/package-tree.html    |   20 +-
 .../regionserver/querymatcher/package-tree.html    |    2 +-
 .../hbase/regionserver/wal/package-tree.html       |    4 +-
 .../hadoop/hbase/replication/ReplicationUtils.html |   64 +-
 .../class-use/ReplicationPeerConfig.html           |   21 +-
 .../hadoop/hbase/replication/package-tree.html     |    2 +-
 .../replication/regionserver/package-tree.html     |    2 +-
 .../hadoop/hbase/rest/model/package-tree.html      |    2 +-
 .../hadoop/hbase/security/access/package-tree.html |    6 +-
 .../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 |    8 +-
 .../src-html/org/apache/hadoop/hbase/Version.html  |    4 +-
 .../master/replication/AbstractPeerProcedure.html  |  271 +-
 .../master/replication/ModifyPeerProcedure.html    |  469 +-
 .../master/replication/ReplicationPeerManager.html |    2 +-
 .../replication/UpdatePeerConfigProcedure.html     |    6 +-
 .../NamespaceTableCfWALEntryFilter.html            |    2 +-
 ...eerConfig.ReplicationPeerConfigBuilderImpl.html |   47 +-
 .../hbase/replication/ReplicationPeerConfig.html   |   47 +-
 .../hadoop/hbase/replication/ReplicationUtils.html |  152 +-
 .../HBaseFsck.CheckRegionConsistencyWorkItem.html  | 7735 ++++++++++----------
 .../hbase/util/HBaseFsck.FileLockCallable.html     | 7735 ++++++++++----------
 .../hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html | 7735 ++++++++++----------
 .../util/HBaseFsck.PrintingErrorReporter.html      | 7735 ++++++++++----------
 .../HBaseFsck.RegionBoundariesInformation.html     | 7735 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemHdfsDir.html      | 7735 ++++++++++----------
 .../util/HBaseFsck.WorkItemHdfsRegionInfo.html     | 7735 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemOverlapMerge.html | 7735 ++++++++++----------
 .../hbase/util/HBaseFsck.WorkItemRegion.html       | 7735 ++++++++++----------
 .../org/apache/hadoop/hbase/util/HBaseFsck.html    | 7735 ++++++++++----------
 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 +-
 testdevapidocs/allclasses-frame.html               |    1 -
 testdevapidocs/allclasses-noframe.html             |    1 -
 testdevapidocs/index-all.html                      |   18 +-
 .../apache/hadoop/hbase/backup/package-tree.html   |    2 +-
 .../hadoop/hbase/chaos/actions/package-tree.html   |    2 +-
 .../hadoop/hbase/class-use/HBaseClassTestRule.html |   94 +-
 .../org/apache/hadoop/hbase/package-tree.html      |   10 +-
 .../hadoop/hbase/procedure/package-tree.html       |    8 +-
 .../hadoop/hbase/procedure2/package-tree.html      |    6 +-
 .../hadoop/hbase/regionserver/package-tree.html    |    6 +-
 .../replication/TestReplicationPeerConfig.html     |   66 +-
 .../TestReplicationTrackerZKImpl.DummyServer.html  |    4 +-
 .../hbase/replication/TestReplicationUtil.html     |  347 -
 .../TestReplicationWALEntryFilters.html            |   10 +-
 .../replication/class-use/TestReplicationUtil.html |  125 -
 .../hadoop/hbase/replication/package-frame.html    |    1 -
 .../hadoop/hbase/replication/package-summary.html  |   46 +-
 .../hadoop/hbase/replication/package-tree.html     |    1 -
 .../org/apache/hadoop/hbase/test/package-tree.html |    2 +-
 .../org/apache/hadoop/hbase/wal/package-tree.html  |    2 +-
 testdevapidocs/overview-tree.html                  |    1 -
 .../replication/TestReplicationPeerConfig.html     |  264 +-
 .../hbase/replication/TestReplicationUtil.html     |  307 -
 .../TestReplicationWALEntryFilters.html            |  482 +-
 116 files changed, 40330 insertions(+), 40967 deletions(-)

diff --git a/acid-semantics.html b/acid-semantics.html
index 871e182..6fc90e7 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -443,7 +443,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 6d01e28..1a03560 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.0.alpha.15, based on Prawn 2.2.2)
 /Producer (Apache HBase Team)
-/ModDate (D:20191202144045+00'00')
-/CreationDate (D:20191202144045+00'00')
+/ModDate (D:20191203143947+00'00')
+/CreationDate (D:20191203143947+00'00')
 >>
 endobj
 2 0 obj
diff --git a/apidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html b/apidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
index 722424c..60884f8 100644
--- a/apidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
+++ b/apidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
@@ -400,25 +400,34 @@
 <span class="sourceLineNo">392</span>   * @return true if the table need replicate to the peer cluster<a name="line.392"></a>
 <span class="sourceLineNo">393</span>   */<a name="line.393"></a>
 <span class="sourceLineNo">394</span>  public boolean needToReplicate(TableName table) {<a name="line.394"></a>
-<span class="sourceLineNo">395</span>    if (replicateAllUserTables) {<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(table.getNamespaceAsString())) {<a name="line.396"></a>
-<span class="sourceLineNo">397</span>        return false;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>      }<a name="line.398"></a>
-<span class="sourceLineNo">399</span>      if (excludeTableCFsMap != null &amp;&amp; excludeTableCFsMap.containsKey(table)) {<a name="line.399"></a>
-<span class="sourceLineNo">400</span>        return false;<a name="line.400"></a>
-<span class="sourceLineNo">401</span>      }<a name="line.401"></a>
-<span class="sourceLineNo">402</span>      return true;<a name="line.402"></a>
-<span class="sourceLineNo">403</span>    } else {<a name="line.403"></a>
-<span class="sourceLineNo">404</span>      if (namespaces != null &amp;&amp; namespaces.contains(table.getNamespaceAsString())) {<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        return true;<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      }<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      if (tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table)) {<a name="line.407"></a>
-<span class="sourceLineNo">408</span>        return true;<a name="line.408"></a>
-<span class="sourceLineNo">409</span>      }<a name="line.409"></a>
-<span class="sourceLineNo">410</span>      return false;<a name="line.410"></a>
-<span class="sourceLineNo">411</span>    }<a name="line.411"></a>
-<span class="sourceLineNo">412</span>  }<a name="line.412"></a>
-<span class="sourceLineNo">413</span>}<a name="line.413"></a>
+<span class="sourceLineNo">395</span>    String namespace = table.getNamespaceAsString();<a name="line.395"></a>
+<span class="sourceLineNo">396</span>    if (replicateAllUserTables) {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>      // replicate all user tables, but filter by exclude namespaces and table-cfs config<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(namespace)) {<a name="line.398"></a>
+<span class="sourceLineNo">399</span>        return false;<a name="line.399"></a>
+<span class="sourceLineNo">400</span>      }<a name="line.400"></a>
+<span class="sourceLineNo">401</span>      // trap here, must check existence first since HashMap allows null value.<a name="line.401"></a>
+<span class="sourceLineNo">402</span>      if (excludeTableCFsMap == null || !excludeTableCFsMap.containsKey(table)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>        return true;<a name="line.403"></a>
+<span class="sourceLineNo">404</span>      }<a name="line.404"></a>
+<span class="sourceLineNo">405</span>      Collection&lt;String&gt; cfs = excludeTableCFsMap.get(table);<a name="line.405"></a>
+<span class="sourceLineNo">406</span>      // if cfs is null or empty then we can make sure that we do not need to replicate this table,<a name="line.406"></a>
+<span class="sourceLineNo">407</span>      // otherwise, we may still need to replicate the table but filter out some families.<a name="line.407"></a>
+<span class="sourceLineNo">408</span>      return cfs != null &amp;&amp; !cfs.isEmpty();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>    } else {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>      // Not replicate all user tables, so filter by namespaces and table-cfs config<a name="line.410"></a>
+<span class="sourceLineNo">411</span>      if (namespaces == null &amp;&amp; tableCFsMap == null) {<a name="line.411"></a>
+<span class="sourceLineNo">412</span>        return false;<a name="line.412"></a>
+<span class="sourceLineNo">413</span>      }<a name="line.413"></a>
+<span class="sourceLineNo">414</span>      // First filter by namespaces config<a name="line.414"></a>
+<span class="sourceLineNo">415</span>      // If table's namespace in peer config, all the tables data are applicable for replication<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      if (namespaces != null &amp;&amp; namespaces.contains(namespace)) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span>        return true;<a name="line.417"></a>
+<span class="sourceLineNo">418</span>      }<a name="line.418"></a>
+<span class="sourceLineNo">419</span>      return tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table);<a name="line.419"></a>
+<span class="sourceLineNo">420</span>    }<a name="line.420"></a>
+<span class="sourceLineNo">421</span>  }<a name="line.421"></a>
+<span class="sourceLineNo">422</span>}<a name="line.422"></a>
 
 
 
diff --git a/book.html b/book.html
index 037b8df..53ad608 100644
--- a/book.html
+++ b/book.html
@@ -43869,7 +43869,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 2019-12-02 14:30:12 UTC
+Last updated 2019-12-03 14:30:06 UTC
 </div>
 </div>
 </body>
diff --git a/bulk-loads.html b/bulk-loads.html
index 2d05631..c85eefe 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -148,7 +148,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 70fd872..57e6155 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -142,7 +142,7 @@
 <th><img src="images/icon_warning_sml.gif" alt="" />&#160;Warnings</th>
 <th><img src="images/icon_error_sml.gif" alt="" />&#160;Errors</th></tr>
 <tr class="b">
-<td>4096</td>
+<td>4095</td>
 <td>0</td>
 <td>0</td>
 <td>11478</td></tr></table></div>
@@ -85733,445 +85733,445 @@
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>709</td></tr>
+<td>708</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' child has incorrect indentation level 11, expected level should be 10.</td>
-<td>767</td></tr>
+<td>766</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>845</td></tr>
+<td>844</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'regionName' must be private and have accessor methods.</td>
-<td>872</td></tr>
+<td>871</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'metaFirstKey' must be private and have accessor methods.</td>
-<td>873</td></tr>
+<td>872</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'metaLastKey' must be private and have accessor methods.</td>
-<td>874</td></tr>
+<td>873</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'storesFirstKey' must be private and have accessor methods.</td>
-<td>875</td></tr>
+<td>874</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'storesLastKey' must be private and have accessor methods.</td>
-<td>876</td></tr>
+<td>875</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>MethodParamPad</td>
 <td>'(' is preceded with whitespace.</td>
-<td>878</td></tr>
+<td>877</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>932</td></tr>
+<td>931</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>934</td></tr>
+<td>933</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1009</td></tr>
+<td>1008</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>ParenPad</td>
 <td>')' is preceded with whitespace.</td>
-<td>1044</td></tr>
+<td>1043</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1141</td></tr>
+<td>1140</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1146</td></tr>
+<td>1145</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1196</td></tr>
+<td>1195</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1200</td></tr>
+<td>1199</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 118).</td>
-<td>1206</td></tr>
+<td>1205</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>1207</td></tr>
+<td>1206</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>1215</td></tr>
+<td>1214</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>1216</td></tr>
+<td>1215</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 101).</td>
-<td>1218</td></tr>
+<td>1217</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1232</td></tr>
+<td>1231</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1366</td></tr>
+<td>1365</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1367</td></tr>
+<td>1366</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1369</td></tr>
+<td>1368</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 102).</td>
-<td>1387</td></tr>
+<td>1386</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1388</td></tr>
+<td>1387</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>1392</td></tr>
+<td>1391</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1403</td></tr>
+<td>1402</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 109).</td>
-<td>1422</td></tr>
+<td>1421</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1423</td></tr>
+<td>1422</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>1452</td></tr>
+<td>1451</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 123).</td>
-<td>1455</td></tr>
+<td>1454</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 102).</td>
-<td>1466</td></tr>
+<td>1465</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1608</td></tr>
+<td>1607</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1609</td></tr>
+<td>1608</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1612</td></tr>
+<td>1611</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1647</td></tr>
+<td>1646</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if' child has incorrect indentation level 9, expected level should be 8.</td>
-<td>1650</td></tr>
+<td>1649</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'if rcurly' has incorrect indentation level 7, expected level should be 6.</td>
-<td>1651</td></tr>
+<td>1650</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'throws' has incorrect indentation level 2, expected level should be 4.</td>
-<td>1779</td></tr>
+<td>1778</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>whitespace</td>
 <td>ParenPad</td>
 <td>')' is preceded with whitespace.</td>
-<td>1969</td></tr>
+<td>1968</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2098</td></tr>
+<td>2097</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2140</td></tr>
+<td>2139</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
 <td>Method length is 232 lines (max allowed is 150).</td>
-<td>2161</td></tr>
+<td>2160</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2164</td></tr>
+<td>2163</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'if' construct must use '{}'s.</td>
-<td>2236</td></tr>
+<td>2235</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2399</td></tr>
+<td>2398</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def' child has incorrect indentation level 6, expected level should be 4.</td>
-<td>2609</td></tr>
+<td>2608</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2650</td></tr>
+<td>2649</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2651</td></tr>
+<td>2650</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'.' has incorrect indentation level 10, expected level should be 12.</td>
-<td>2677</td></tr>
+<td>2676</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>design</td>
 <td>VisibilityModifier</td>
 <td>Variable 'errorCount' must be private and have accessor methods.</td>
-<td>2875</td></tr>
+<td>2874</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2939</td></tr>
+<td>2938</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3105</td></tr>
+<td>3104</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3176</td></tr>
+<td>3175</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 115).</td>
-<td>3489</td></tr>
+<td>3488</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 108).</td>
-<td>3532</td></tr>
+<td>3531</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 107).</td>
-<td>3537</td></tr>
+<td>3536</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3538</td></tr>
+<td>3537</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 111).</td>
-<td>3545</td></tr>
+<td>3544</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 116).</td>
-<td>3550</td></tr>
+<td>3549</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 107).</td>
-<td>3557</td></tr>
+<td>3556</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 106).</td>
-<td>3559</td></tr>
+<td>3558</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>3562</td></tr>
+<td>3561</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 145).</td>
-<td>3564</td></tr>
+<td>3563</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 104).</td>
-<td>3565</td></tr>
+<td>3564</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 179).</td>
-<td>3566</td></tr>
+<td>3565</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 113).</td>
-<td>3568</td></tr>
+<td>3567</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>3593</td></tr>
+<td>3592</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>3594</td></tr>
+<td>3593</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>LeftCurly</td>
 <td>'{' at column 39 should have line break after.</td>
-<td>3610</td></tr>
+<td>3609</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
 <td>Method length is 229 lines (max allowed is 150).</td>
-<td>3620</td></tr></table></div>
+<td>3619</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">
@@ -91340,7 +91340,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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.rss b/checkstyle.rss
index 877f72a..a20ca0a 100644
--- a/checkstyle.rss
+++ b/checkstyle.rss
@@ -25,7 +25,7 @@ under the License.
     <language>en-us</language>
     <copyright>&#169;2007 - 2019 The Apache Software Foundation</copyright>
     <item>
-      <title>File: 4096,
+      <title>File: 4095,
              Errors: 11478,
              Warnings: 0,
              Infos: 0
@@ -16776,20 +16776,6 @@ under the License.
               </tr>
                           <tr>
                 <td>
-                  <a href="https://hbase.apache.org/checkstyle.html#org.apache.hadoop.hbase.replication.TestReplicationUtil.java">org/apache/hadoop/hbase/replication/TestReplicationUtil.java</a>
-                </td>
-                <td>
-                  0
-                </td>
-                <td>
-                  0
-                </td>
-                <td>
-                  0
-                </td>
-              </tr>
-                          <tr>
-                <td>
                   <a href="https://hbase.apache.org/checkstyle.html#org.apache.hadoop.hbase.regionserver.wal.MetricsWAL.java">org/apache/hadoop/hbase/regionserver/wal/MetricsWAL.java</a>
                 </td>
                 <td>
diff --git a/coc.html b/coc.html
index ef6a271..099116f 100644
--- a/coc.html
+++ b/coc.html
@@ -217,7 +217,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 1c038bd..866894e 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -289,7 +289,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 074c753..c224a59 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -534,7 +534,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 c138de1..5f66bed 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -170,7 +170,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 bbe6c73..9bf2c49 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -898,7 +898,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2019
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2019-12-03</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 7a27bbf..31b0f71 100644
--- a/devapidocs/constant-values.html
+++ b/devapidocs/constant-values.html
@@ -4095,14 +4095,14 @@
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<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/Version.html#date">date</a></code></td>
-<td class="colLast"><code>"Mon Dec  2 14:36:41 UTC 2019"</code></td>
+<td class="colLast"><code>"Tue Dec  3 14:36:00 UTC 2019"</code></td>
 </tr>
 <tr class="rowColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.Version.revision">
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<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/Version.html#revision">revision</a></code></td>
-<td class="colLast"><code>"97e01070001ef81558b4dae3a3610d0c73651cb9"</code></td>
+<td class="colLast"><code>"0f166edc3da303b6b9746db2dc02f2a30c1de4e0"</code></td>
 </tr>
 <tr class="altColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.Version.srcChecksum">
diff --git a/devapidocs/index-all.html b/devapidocs/index-all.html
index fd4ea74..8c90bfe 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -17656,10 +17656,6 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/CellSet.html#contains-java.lang.Object-">contains(Object)</a></span> - Method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/CellSet.html" title="class in org.apache.hadoop.hbase.regionserver">CellSet</a></dt>
 <dd>&nbsp;</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/replication/ReplicationUtils.html#contains-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.TableName-">contains(ReplicationPeerConfig, TableName)</a></span> - Static method in class org.apache.hadoop.hbase.replication.<a href="org/apache/hadoop/hbase/replication/ReplicationUtils.html" title="class in org.apache.hadoop.hbase.replication">ReplicationUtils</a></dt>
-<dd>
-<div class="block">Returns whether we should replicate the given table.</div>
-</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/CallQueue.html#contains-java.lang.Object-">contains(Object)</a></span> - Method in class org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/CallQueue.html" title="class in org.apache.hadoop.hbase.thrift">CallQueue</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/types/CopyOnWriteArrayMap.ArrayEntrySet.html#contains-java.lang.Object-">contains(Object)</a></span> - Method in class org.apache.hadoop.hbase.types.<a href="org/apache/hadoop/hbase/types/CopyOnWriteArrayMap.ArrayEntrySet.html" title="class in org.apache.hadoop.hbase.types">CopyOnWriteArrayMap.ArrayEntrySet</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 a4c979f..0010d9e 100644
--- a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
@@ -167,8 +167,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/class-use/TableName.html b/devapidocs/org/apache/hadoop/hbase/class-use/TableName.html
index 8c19f4e..cb8ae0c 100644
--- a/devapidocs/org/apache/hadoop/hbase/class-use/TableName.html
+++ b/devapidocs/org/apache/hadoop/hbase/class-use/TableName.html
@@ -8899,25 +8899,18 @@ service.</div>
 </tr>
 <tbody>
 <tr class="altColor">
-<td class="colFirst"><code>static boolean</code></td>
-<td class="colLast"><span class="typeNameLabel">ReplicationUtils.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#contains-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.TableName-">contains</a></span>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig,
-        <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</code>
-<div class="block">Returns whether we should replicate the given table.</div>
-</td>
-</tr>
-<tr class="rowColor">
 <td class="colFirst"><code>private boolean</code></td>
 <td class="colLast"><span class="typeNameLabel">NamespaceTableCfWALEntryFilter.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html#filterByExcludeTableCfs-org.apache.hadoop.hbase.TableName-java.lang.String-java.util.Map-">filterByExcludeTableCfs</a></span>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                        <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>&nbsp;family,
                        <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>&lt;<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/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.ht [...]
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private boolean</code></td>
 <td class="colLast"><span class="typeNameLabel">NamespaceTableCfWALEntryFilter.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html#filterByTableCfs-org.apache.hadoop.hbase.TableName-java.lang.String-java.util.Map-">filterByTableCfs</a></span>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                 <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>&nbsp;family,
                 <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>&lt;<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/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>boolean</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationPeerConfig.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html#needToReplicate-org.apache.hadoop.hbase.TableName-">needToReplicate</a></span>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</code>
 <div class="block">Decide whether the table need replicate to the peer cluster</div>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
index 078aef9..495769f 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -427,20 +427,20 @@
 <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>&lt;E&gt; (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>&lt;T&gt;, 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.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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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>
+<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/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/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/MobCompactPartitionPolicy.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MobCompactPartitionPolicy</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 c51f7b2..dc618a4 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
@@ -201,8 +201,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>&lt;E&gt; (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>&lt;T&gt;, 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/executor/package-tree.html b/devapidocs/org/apache/hadoop/hbase/executor/package-tree.html
index 127caa7..531254c 100644
--- a/devapidocs/org/apache/hadoop/hbase/executor/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/executor/package-tree.html
@@ -104,8 +104,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>&lt;E&gt; (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>&lt;T&gt;, 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.executor.<a href="../../../../../org/apache/hadoop/hbase/executor/EventType.html" title="enum in org.apache.hadoop.hbase.executor"><span class="typeNameLink">EventType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.executor.<a href="../../../../../org/apache/hadoop/hbase/executor/ExecutorType.html" title="enum in org.apache.hadoop.hbase.executor"><span class="typeNameLink">ExecutorType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.executor.<a href="../../../../../org/apache/hadoop/hbase/executor/EventType.html" title="enum in org.apache.hadoop.hbase.executor"><span class="typeNameLink">EventType</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 1e1d42e..7fb706a 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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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/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/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/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/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.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/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/hbtop/field/package-tree.html b/devapidocs/org/apache/hadoop/hbase/hbtop/field/package-tree.html
index abc40ba..9eebaf0 100644
--- a/devapidocs/org/apache/hadoop/hbase/hbtop/field/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/hbtop/field/package-tree.html
@@ -92,8 +92,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>&lt;E&gt; (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>&lt;T&gt;, 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.field.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/field/FieldValueType.html" title="enum in org.apache.hadoop.hbase.hbtop.field"><span class="typeNameLink">FieldValueType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.hbtop.field.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/field/Field.html" title="enum in org.apache.hadoop.hbase.hbtop.field"><span class="typeNameLink">Field</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.hbtop.field.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/field/FieldValueType.html" title="enum in org.apache.hadoop.hbase.hbtop.field"><span class="typeNameLink">FieldValueType</span></a></li>
 </ul>
 </li>
 </ul>
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 afafe95..507e040 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
@@ -305,12 +305,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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>
-<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/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
 </ul>
 </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 53b29e4..05f6fbe 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -353,8 +353,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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>
diff --git a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
index 58ece33..9bd5736 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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/TableSplit.Version.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">TableSplit.Version</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/SyncTable.SyncMapper.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">SyncTable.SyncMapper.Counter</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 60d69b9..54b8a68 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>&lt;E&gt; (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>&lt;T&gt;, 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 23e5e09..cade9c7 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -362,12 +362,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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>
 <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/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/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/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/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</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 8fd1308..53f2cba 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
@@ -220,10 +220,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>&lt;E&gt; (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>&lt;T&gt;, 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/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>
 <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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html b/devapidocs/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
index 6ec4a1d..1231845 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
@@ -133,7 +133,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public abstract class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.48">AbstractPeerProcedure</a>&lt;TState&gt;
+public abstract class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.47">AbstractPeerProcedure</a>&lt;TState&gt;
 extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/AbstractPeerNoLockProcedure.html" title="class in org.apache.hadoop.hbase.master.replication">AbstractPeerNoLockProcedure</a>&lt;TState&gt;
 implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.html" title="interface in org.apache.hadoop.hbase.master.procedure">PeerProcedureInterface</a></pre>
 <div class="block">The base class for all replication peer related procedure.</div>
@@ -369,7 +369,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.51">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.50">LOG</a></pre>
 </li>
 </ul>
 <a name="UPDATE_LAST_SEQ_ID_BATCH_SIZE">
@@ -378,7 +378,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>UPDATE_LAST_SEQ_ID_BATCH_SIZE</h4>
-<pre>protected static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.53">UPDATE_LAST_SEQ_ID_BATCH_SIZE</a></pre>
+<pre>protected static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.52">UPDATE_LAST_SEQ_ID_BATCH_SIZE</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../../constant-values.html#org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure.UPDATE_LAST_SEQ_ID_BATCH_SIZE">Constant Field Values</a></dd>
@@ -391,7 +391,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>SLEEP_INTERVAL_MS</h4>
-<pre>protected static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.56">SLEEP_INTERVAL_MS</a></pre>
+<pre>protected static final&nbsp;int <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.55">SLEEP_INTERVAL_MS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../../constant-values.html#org.apache.hadoop.hbase.master.replication.AbstractPeerProcedure.SLEEP_INTERVAL_MS">Constant Field Values</a></dd>
@@ -404,7 +404,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockListLast">
 <li class="blockList">
 <h4>latch</h4>
-<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ProcedurePrepareLatch.html" title="class in org.apache.hadoop.hbase.master.procedure">ProcedurePrepareLatch</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.59">latch</a></pre>
+<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ProcedurePrepareLatch.html" title="class in org.apache.hadoop.hbase.master.procedure">ProcedurePrepareLatch</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.58">latch</a></pre>
 </li>
 </ul>
 </li>
@@ -421,7 +421,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>AbstractPeerProcedure</h4>
-<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.61">AbstractPeerProcedure</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.60">AbstractPeerProcedure</a>()</pre>
 </li>
 </ul>
 <a name="AbstractPeerProcedure-java.lang.String-">
@@ -430,7 +430,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockListLast">
 <li class="blockList">
 <h4>AbstractPeerProcedure</h4>
-<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.64">AbstractPeerProcedure</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>&nbsp;peerId)</pre>
+<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.63">AbstractPeerProcedure</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>&nbsp;peerId)</pre>
 </li>
 </ul>
 </li>
@@ -447,7 +447,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>getLatch</h4>
-<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ProcedurePrepareLatch.html" title="class in org.apache.hadoop.hbase.master.procedure">ProcedurePrepareLatch</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.69">getLatch</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ProcedurePrepareLatch.html" title="class in org.apache.hadoop.hbase.master.procedure">ProcedurePrepareLatch</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.68">getLatch</a>()</pre>
 </li>
 </ul>
 <a name="acquireLock-org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv-">
@@ -456,7 +456,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>acquireLock</h4>
-<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2">Procedure.LockState</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.74">acquireLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a> [...]
+<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2">Procedure.LockState</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.73">acquireLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a> [...]
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/Procedure.html#acquireLock-TEnvironment-">Procedure</a></code></span></div>
 <div class="block">The user should override this method if they need a lock on an Entity. A lock can be anything,
  and it is up to the implementor. The Procedure Framework will call this method just before it
@@ -493,7 +493,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>releaseLock</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.82">releaseLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.81">releaseLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/Procedure.html#releaseLock-TEnvironment-">Procedure</a></code></span></div>
 <div class="block">The user should override this method, and release lock if necessary.</div>
 <dl>
@@ -508,7 +508,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>holdLock</h4>
-<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.87">holdLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
+<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.86">holdLock</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/Procedure.html#holdLock-TEnvironment-">Procedure</a></code></span></div>
 <div class="block">Used to keep the procedure lock even when the procedure is yielding or suspended.</div>
 <dl>
@@ -525,7 +525,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>refreshPeer</h4>
-<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.91">refreshPeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
+<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.90">refreshPeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
                                  <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure">PeerProcedureInterface.PeerOperationType</a>&nbsp;type)</pre>
 </li>
 </ul>
@@ -535,7 +535,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>enablePeer</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.98">enablePeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.97">enablePeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                    throws <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -549,7 +549,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>addToMap</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.102">addToMap</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>&lt;<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="https://docs.oracle.com/javase/8/docs/api/jav [...]
+<pre>private&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.101">addToMap</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>&lt;<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="https://docs.oracle.com/javase/8/docs/api/jav [...]
                       <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>&nbsp;encodedRegionName,
                       long&nbsp;barrier,
                       <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationQueueStorage.html" title="interface in org.apache.hadoop.hbase.replication">ReplicationQueueStorage</a>&nbsp;queueStorage)
@@ -566,7 +566,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>setLastPushedSequenceId</h4>
-<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.113">setLastPushedSequenceId</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
+<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.112">setLastPushedSequenceId</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
                                              <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)
                                       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="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
@@ -583,7 +583,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockList">
 <li class="blockList">
 <h4>needSetLastPushedSequenceId</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.135">needSetLastPushedSequenceId</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;tsm,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.134">needSetLastPushedSequenceId</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;tsm,
                                             <a href="../../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)
                                      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>
@@ -598,7 +598,7 @@ implements <a href="../../../../../../org/apache/hadoop/hbase/master/procedure/P
 <ul class="blockListLast">
 <li class="blockList">
 <h4>setLastPushedSequenceIdForTable</h4>
-<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.155">setLastPushedSequenceIdForTable</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
+<pre>protected final&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html#line.154">setLastPushedSequenceIdForTable</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env,
                                                      <a href="../../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                                                      <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>&lt;<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="https://docs.oracle.com/javase/8/docs/api/java/lang/Long.html?is-external=true" title="class or interface in java.lang">Long</a>&gt;&nbsp;lastSeqIds)
                                               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>,
diff --git a/devapidocs/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html b/devapidocs/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
index 5561b40..cb443e4 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
@@ -138,7 +138,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public abstract class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.47">ModifyPeerProcedure</a>
+public abstract class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.46">ModifyPeerProcedure</a>
 extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html" title="class in org.apache.hadoop.hbase.master.replication">AbstractPeerProcedure</a>&lt;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&gt;</pre>
 <div class="block">The base class for all replication peer related procedure except sync replication state
  transition.</div>
@@ -401,7 +401,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockListLast">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.49">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.48">LOG</a></pre>
 </li>
 </ul>
 </li>
@@ -418,7 +418,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>ModifyPeerProcedure</h4>
-<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.51">ModifyPeerProcedure</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.50">ModifyPeerProcedure</a>()</pre>
 </li>
 </ul>
 <a name="ModifyPeerProcedure-java.lang.String-">
@@ -427,7 +427,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockListLast">
 <li class="blockList">
 <h4>ModifyPeerProcedure</h4>
-<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.54">ModifyPeerProcedure</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>&nbsp;peerId)</pre>
+<pre>protected&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.53">ModifyPeerProcedure</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>&nbsp;peerId)</pre>
 </li>
 </ul>
 </li>
@@ -444,7 +444,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>prePeerModification</h4>
-<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.65">prePeerModification</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.64">prePeerModification</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                                      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="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</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>
@@ -467,7 +467,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>updatePeerStorage</h4>
-<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.68">updatePeerStorage</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.67">updatePeerStorage</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                                    throws <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -481,7 +481,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>postPeerModification</h4>
-<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.79">postPeerModification</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.78">postPeerModification</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                                       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="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
 <div class="block">Called before we finish the procedure. The implementation can do some logging work, and also
@@ -504,7 +504,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>releaseLatch</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.82">releaseLatch</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.81">releaseLatch</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)</pre>
 </li>
 </ul>
 <a name="nextStateAfterRefresh--">
@@ -513,7 +513,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>nextStateAfterRefresh</h4>
-<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.90">nextStateAfterRefresh</a>()</pre>
+<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.89">nextStateAfterRefresh</a>()</pre>
 <div class="block">Implementation class can override this method. By default we will jump to
  POST_PEER_MODIFICATION and finish the procedure.</div>
 </li>
@@ -524,7 +524,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>enablePeerBeforeFinish</h4>
-<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.98">enablePeerBeforeFinish</a>()</pre>
+<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.97">enablePeerBeforeFinish</a>()</pre>
 <div class="block">The implementation class should override this method if the procedure may enter the serial
  related states.</div>
 </li>
@@ -535,7 +535,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>getOldPeerConfig</h4>
-<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.102">getOldPeerConfig</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.101">getOldPeerConfig</a>()</pre>
 </li>
 </ul>
 <a name="getNewPeerConfig--">
@@ -544,7 +544,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>getNewPeerConfig</h4>
-<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.106">getNewPeerConfig</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.105">getNewPeerConfig</a>()</pre>
 </li>
 </ul>
 <a name="updateLastPushedSequenceIdForSerialPeer-org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv-">
@@ -553,7 +553,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>updateLastPushedSequenceIdForSerialPeer</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.110">updateLastPushedSequenceIdForSerialPeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.109">updateLastPushedSequenceIdForSerialPeer</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                                                 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="../../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
 <dl>
@@ -569,7 +569,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>needReopen</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.117">needReopen</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;tsm,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.116">needReopen</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;tsm,
                            <a href="../../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tn)
                     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>
@@ -584,7 +584,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>reopenRegions</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.138">reopenRegions</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.137">reopenRegions</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&nbsp;env)
                       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>
@@ -598,7 +598,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>executeFromState</h4>
-<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2">StateMachineProcedure.Flow</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.161">executeFromState</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">Mast [...]
+<pre>protected&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2">StateMachineProcedure.Flow</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.160">executeFromState</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">Mast [...]
                                                       org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;state)
                                                throws <a href="../../../../../../org/apache/hadoop/hbase/procedure2/ProcedureSuspendedException.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureSuspendedException</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>
@@ -623,7 +623,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>getState</h4>
-<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.254">getState</a>(int&nbsp;stateId)</pre>
+<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.253">getState</a>(int&nbsp;stateId)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.html#getState-int-">StateMachineProcedure</a></code></span></div>
 <div class="block">Convert an ordinal (or state id) to an Enum (or more descriptive) state object.</div>
 <dl>
@@ -642,7 +642,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockList">
 <li class="blockList">
 <h4>getStateId</h4>
-<pre>protected&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.259">getStateId</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;state)</pre>
+<pre>protected&nbsp;int&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.258">getStateId</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;state)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.html#getStateId-TState-">StateMachineProcedure</a></code></span></div>
 <div class="block">Convert the Enum (or more descriptive) state object to an ordinal (or state id).</div>
 <dl>
@@ -661,7 +661,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/master/replication/Ab
 <ul class="blockListLast">
 <li class="blockList">
 <h4>getInitialState</h4>
-<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.264">getInitialState</a>()</pre>
+<pre>protected&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html#line.263">getInitialState</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.html#getInitialState--">StateMachineProcedure</a></code></span></div>
 <div class="block">Return the initial state object that will be used for the first call to executeFromState().</div>
 <dl>
diff --git a/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html b/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
index 452eaee..7524d90 100644
--- a/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
@@ -127,8 +127,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>&lt;E&gt; (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>&lt;T&gt;, 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.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/TaskMonitor.TaskFilter.TaskType.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">TaskMonitor.TaskFilter.TaskType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.State.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">MonitoredTask.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/TaskMonitor.TaskFilter.TaskType.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">TaskMonitor.TaskFilter.TaskType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/package-tree.html b/devapidocs/org/apache/hadoop/hbase/package-tree.html
index ebd75bc..0e0e264 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -425,19 +425,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/MetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaTableAccessor.QueryType</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/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/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/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/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/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/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/MetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaTableAccessor.QueryType</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/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/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/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/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/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/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/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/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</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 ebdb6a6..1fce2ac 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -216,11 +216,11 @@
 <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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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>
 </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 daaf2d5..df497ef 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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
index 3913543..6f1444c 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -729,20 +729,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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.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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</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 74ae4b0..b195b74 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>&lt;E&gt; (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>&lt;T&gt;, 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/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>
 <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>
 </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 050f445..7291aff 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
@@ -247,9 +247,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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/ReplicationUtils.html b/devapidocs/org/apache/hadoop/hbase/replication/ReplicationUtils.html
index f26c7b9..2fd57f4 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/ReplicationUtils.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/ReplicationUtils.html
@@ -18,7 +18,7 @@
     catch(err) {
     }
 //-->
-var methods = {"i0":9,"i1":9,"i2":9,"i3":9,"i4":9,"i5":9,"i6":9,"i7":9,"i8":9,"i9":9,"i10":9,"i11":9,"i12":9,"i13":9,"i14":9,"i15":9};
+var methods = {"i0":9,"i1":9,"i2":9,"i3":9,"i4":9,"i5":9,"i6":9,"i7":9,"i8":9,"i9":9,"i10":9,"i11":9,"i12":9,"i13":9,"i14":9};
 var tabs = {65535:["t0","All Methods"],1:["t1","Static Methods"],8:["t4","Concrete Methods"]};
 var altColor = "altColor";
 var rowColor = "rowColor";
@@ -194,84 +194,77 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <th class="colLast" scope="col">Method and Description</th>
 </tr>
 <tr id="i0" class="altColor">
-<td class="colFirst"><code>static boolean</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#contains-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.TableName-">contains</a></span>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig,
-        <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</code>
-<div class="block">Returns whether we should replicate the given table.</div>
-</td>
-</tr>
-<tr id="i1" class="rowColor">
 <td class="colFirst"><code>static int</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getAdaptiveTimeout-int-int-">getAdaptiveTimeout</a></span>(int&nbsp;initialValue,
                   int&nbsp;retries)</code>
 <div class="block">Get the adaptive timeout value when performing a retry</div>
 </td>
 </tr>
-<tr id="i2" class="altColor">
+<tr id="i1" class="rowColor">
 <td class="colFirst"><code>static org.apache.hadoop.conf.Configuration</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerClusterConfiguration-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.conf.Configuration-">getPeerClusterConfiguration</a></span>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig,
                            org.apache.hadoop.conf.Configuration&nbsp;baseConf)</code>&nbsp;</td>
 </tr>
-<tr id="i3" class="rowColor">
+<tr id="i2" class="altColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerRemoteWALDir-org.apache.hadoop.fs.Path-java.lang.String-">getPeerRemoteWALDir</a></span>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                    <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i4" class="altColor">
+<tr id="i3" class="rowColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerRemoteWALDir-java.lang.String-java.lang.String-">getPeerRemoteWALDir</a></span>(<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>&nbsp;remoteWALDir,
                    <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i5" class="rowColor">
+<tr id="i4" class="altColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerReplayWALDir-org.apache.hadoop.fs.Path-java.lang.String-">getPeerReplayWALDir</a></span>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                    <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i6" class="altColor">
+<tr id="i5" class="rowColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerSnapshotWALDir-org.apache.hadoop.fs.Path-java.lang.String-">getPeerSnapshotWALDir</a></span>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                      <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i7" class="rowColor">
+<tr id="i6" class="altColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerSnapshotWALDir-java.lang.String-java.lang.String-">getPeerSnapshotWALDir</a></span>(<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>&nbsp;remoteWALDir,
                      <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i8" class="altColor">
+<tr id="i7" class="rowColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.FileSystem</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getRemoteWALFileSystem-org.apache.hadoop.conf.Configuration-java.lang.String-">getRemoteWALFileSystem</a></span>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                       <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>&nbsp;remoteWALDir)</code>&nbsp;</td>
 </tr>
-<tr id="i9" class="rowColor">
+<tr id="i8" class="altColor">
 <td class="colFirst"><code>private static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isCollectionEqual-java.util.Collection-java.util.Collection-">isCollectionEqual</a></span>(<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>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or inte [...]
                  <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>&lt;<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>&gt;&nbsp;c2)</code>&nbsp;</td>
 </tr>
-<tr id="i10" class="altColor">
+<tr id="i9" class="rowColor">
 <td class="colFirst"><code>static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isNamespacesAndTableCFsEqual-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">isNamespacesAndTableCFsEqual</a></span>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&n [...]
                             <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;rpc2)</code>&nbsp;</td>
 </tr>
-<tr id="i11" class="rowColor">
+<tr id="i10" class="altColor">
 <td class="colFirst"><code>private static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isNamespacesEqual-java.util.Set-java.util.Set-">isNamespacesEqual</a></span>(<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>&lt;<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 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>&lt;<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>&gt;&nbsp;ns2)</code>&nbsp;</td>
 </tr>
-<tr id="i12" class="altColor">
+<tr id="i11" class="rowColor">
 <td class="colFirst"><code>static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isReplicationForBulkLoadDataEnabled-org.apache.hadoop.conf.Configuration-">isReplicationForBulkLoadDataEnabled</a></span>(org.apache.hadoop.conf.Configuration&nbsp;c)</code>&nbsp;</td>
 </tr>
-<tr id="i13" class="rowColor">
+<tr id="i12" class="altColor">
 <td class="colFirst"><code>private static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isTableCFsEqual-java.util.Map-java.util.Map-">isTableCFsEqual</a></span>(<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="https://docs.or [...]
                <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>&lt;<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/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-ex [...]
 </tr>
-<tr id="i14" class="altColor">
+<tr id="i13" class="rowColor">
 <td class="colFirst"><code>static void</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#removeAllQueues-org.apache.hadoop.hbase.replication.ReplicationQueueStorage-java.lang.String-">removeAllQueues</a></span>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationQueueStorage.html" title="interface in org.apache.hadoop.hbase.replication">ReplicationQueueStorage</a>&nbsp;queueStorage,
                <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>&nbsp;peerId)</code>&nbsp;</td>
 </tr>
-<tr id="i15" class="rowColor">
+<tr id="i14" class="altColor">
 <td class="colFirst"><code>static boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#sleepForRetries-java.lang.String-long-int-int-">sleepForRetries</a></span>(<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>&nbsp;msg,
                long&nbsp;sleepForRetries,
@@ -499,24 +492,13 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 </dl>
 </li>
 </ul>
-<a name="contains-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.TableName-">
-<!--   -->
-</a>
-<ul class="blockList">
-<li class="blockList">
-<h4>contains</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.160">contains</a>(<a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig,
-                               <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
-<div class="block">Returns whether we should replicate the given table.</div>
-</li>
-</ul>
 <a name="getRemoteWALFileSystem-org.apache.hadoop.conf.Configuration-java.lang.String-">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRemoteWALFileSystem</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.FileSystem&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.195">getRemoteWALFileSystem</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;org.apache.hadoop.fs.FileSystem&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.157">getRemoteWALFileSystem</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                                                                      <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>&nbsp;remoteWALDir)
                                                               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>
@@ -531,7 +513,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getPeerRemoteWALDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.200">getPeerRemoteWALDir</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>&nbsp;remoteWALDir,
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.162">getPeerRemoteWALDir</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>&nbsp;remoteWALDir,
                                                             <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>&nbsp;peerId)</pre>
 </li>
 </ul>
@@ -541,7 +523,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getPeerRemoteWALDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.204">getPeerRemoteWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.166">getPeerRemoteWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                                                             <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>&nbsp;peerId)</pre>
 </li>
 </ul>
@@ -551,7 +533,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getPeerReplayWALDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.208">getPeerReplayWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.170">getPeerReplayWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                                                             <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>&nbsp;peerId)</pre>
 </li>
 </ul>
@@ -561,7 +543,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getPeerSnapshotWALDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.212">getPeerSnapshotWALDir</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>&nbsp;remoteWALDir,
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.174">getPeerSnapshotWALDir</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>&nbsp;remoteWALDir,
                                                               <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>&nbsp;peerId)</pre>
 </li>
 </ul>
@@ -571,7 +553,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getPeerSnapshotWALDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.216">getPeerSnapshotWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.178">getPeerSnapshotWALDir</a>(org.apache.hadoop.fs.Path&nbsp;remoteWALDir,
                                                               <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>&nbsp;peerId)</pre>
 </li>
 </ul>
@@ -581,7 +563,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>sleepForRetries</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.228">sleepForRetries</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>&nbsp;msg,
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.190">sleepForRetries</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>&nbsp;msg,
                                       long&nbsp;sleepForRetries,
                                       int&nbsp;sleepMultiplier,
                                       int&nbsp;maxRetriesMultiplier)</pre>
@@ -603,7 +585,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>getAdaptiveTimeout</h4>
-<pre>public static&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.243">getAdaptiveTimeout</a>(int&nbsp;initialValue,
+<pre>public static&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html#line.205">getAdaptiveTimeout</a>(int&nbsp;initialValue,
                                      int&nbsp;retries)</pre>
 <div class="block">Get the adaptive timeout value when performing a retry</div>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/class-use/ReplicationPeerConfig.html b/devapidocs/org/apache/hadoop/hbase/replication/class-use/ReplicationPeerConfig.html
index f0c6706..ecbbb1f 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/class-use/ReplicationPeerConfig.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/class-use/ReplicationPeerConfig.html
@@ -833,48 +833,41 @@
        <a href="../../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication">SyncReplicationState</a>&nbsp;syncReplicationState)</code>&nbsp;</td>
 </tr>
 <tr class="altColor">
-<td class="colFirst"><code>static boolean</code></td>
-<td class="colLast"><span class="typeNameLabel">ReplicationUtils.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#contains-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.TableName-">contains</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;pe [...]
-        <a href="../../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</code>
-<div class="block">Returns whether we should replicate the given table.</div>
-</td>
-</tr>
-<tr class="rowColor">
 <td class="colFirst"><code>static org.apache.hadoop.conf.Configuration</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationUtils.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#getPeerClusterConfiguration-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.conf.Configuration-">getPeerClusterConfiguration</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.repli [...]
                            org.apache.hadoop.conf.Configuration&nbsp;baseConf)</code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>static boolean</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationUtils.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationUtils.html#isNamespacesAndTableCFsEqual-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">isNamespacesAndTableCFsEqual</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.ap [...]
                             <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;rpc2)</code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>static <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfigBuilder.html" title="interface in org.apache.hadoop.hbase.replication">ReplicationPeerConfigBuilder</a></code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationPeerConfig.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html#newBuilder-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">newBuilder</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)</code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>void</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationPeerConfigListener.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfigListener.html#peerConfigUpdated-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">peerConfigUpdated</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</ [...]
 <div class="block">Callback method for when users update the ReplicationPeerConfig for this peer</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>void</code></td>
 <td class="colLast"><span class="typeNameLabel">BaseReplicationEndpoint.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/BaseReplicationEndpoint.html#peerConfigUpdated-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">peerConfigUpdated</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;rpc) [...]
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>void</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationPeerImpl.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerImpl.html#setPeerConfig-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">setPeerConfig</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)</code>&n [...]
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>void</code></td>
 <td class="colLast"><span class="typeNameLabel">ReplicationPeerStorage.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerStorage.html#updatePeerConfig-java.lang.String-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">updatePeerConfig</a></span>(<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>&nbsp;peerId,
                 <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)</code>
 <div class="block">Update the config a replication peer.</div>
 </td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>void</code></td>
 <td class="colLast"><span class="typeNameLabel">ZKReplicationPeerStorage.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/replication/ZKReplicationPeerStorage.html#updatePeerConfig-java.lang.String-org.apache.hadoop.hbase.replication.ReplicationPeerConfig-">updatePeerConfig</a></span>(<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>&nbsp;peerId,
                 <a href="../../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)</code>&nbsp;</td>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
index 02505ac..818a04c 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/package-tree.html
@@ -162,8 +162,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>&lt;E&gt; (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>&lt;T&gt;, 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/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>
+<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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html b/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
index c9ac434..800a66a 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
@@ -192,8 +192,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>&lt;E&gt; (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>&lt;T&gt;, 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.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/MetricsReplicationSourceFactoryImpl.SourceHolder.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">MetricsReplicationSourceFactoryImpl.SourceHolder</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.replication.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceShipper.WorkerState.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">ReplicationSourceShipper.WorkerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.replication.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/MetricsReplicationSourceFactoryImpl.SourceHolder.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">MetricsReplicationSourceFactoryImpl.SourceHolder</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html b/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
index 7d70035..3aa879d 100644
--- a/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
@@ -110,8 +110,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>&lt;E&gt; (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>&lt;T&gt;, 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.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.FilterType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.FilterType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType</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 83679f3..2d0dcbe 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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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/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/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/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/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/util/HBaseFsck.CheckRegionConsistencyWorkItem.html b/devapidocs/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
index ce00c7f..17ed745 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.1849">HBaseFsck.CheckRegionConsistencyWorkItem</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1848">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>&lt;<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>&gt;</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&nbsp;<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.1850">key</a></pre>
+<pre>private final&nbsp;<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.1849">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&nbsp;<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.1851">hbi</a></pre>
+<pre>private final&nbsp;<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.1850">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.1853">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>&nbsp;key,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1852">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>&nbsp;key,
                                <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1859">call</a>()
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html#line.1858">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 06a2daf..0b0c77f 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.405">HBaseFsck.FileLockCallable</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.404">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>&lt;org.apache.hadoop.fs.FSDataOutputStream&gt;</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.406">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.405">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&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.407">conf</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.406">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&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.408">hbckLockPath</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.407">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&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.410">FileLockCallable</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.409">FileLockCallable</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                         <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a>&nbsp;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&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.418">getHbckLockPath</a>()</pre>
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.417">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&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.423">call</a>()
+<pre>public&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.422">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&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.448">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.FileLockCallable.html#line.447">createFileWithRetries</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                                                       org.apache.hadoop.fs.Path&nbsp;hbckLockFilePath,
                                                                       org.apache.hadoop.fs.permission.FsPermission&nbsp;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 16ae7a1..bf6ccd9 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.3609">HBaseFsck.HBaseFsckTool</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3608">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.3610">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3609">HBaseFsckTool</a>(org.apache.hadoop.conf.Configuration&nbsp;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&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3612">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>[]&nbsp;args)
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.HBaseFsckTool.html#line.3611">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>[]&nbsp;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 9f8ae4e..1e5562c 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.2874">HBaseFsck.PrintingErrorReporter</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2873">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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2875">errorCount</a></pre>
+<pre>public&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2874">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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2876">showProgress</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2875">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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2878">progressThreshold</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2877">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2880">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2879">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&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2883">errorList</a></pre>
+<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2882">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.2874">PrintingErrorReporter</a>()</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2873">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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2886">clear</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2885">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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2893">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>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2892">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>&nbsp;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>&nbsp;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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2908">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>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2907">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>&nbsp;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>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2915">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>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2914">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>&nbsp;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>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2923">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>&nbsp;errorCode,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2922">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>&nbsp;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>&nbsp;message,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table,
                         <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2932">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>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2931">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>&nbsp;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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2942">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>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2941">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>&nbsp;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&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2950">summarize</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2949">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>&nbsp;in interface&nbsp;<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&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2963">getErrorList</a>()</pre>
+<pre>public&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util">HbckErrorReporter.ERROR_CODE</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2962">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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2968">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>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2967">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>&nbsp;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>&nbsp;in interface&nbsp;<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&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2975">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;table)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2974">tableHasErrors</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckTableInfo.html" title="class in org.apache.hadoop.hbase.util">HbckTableInfo</a>&nbsp;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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2980">resetErrors</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2979">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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2985">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>&nbsp;message)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2984">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>&nbsp;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>&nbsp;in interface&nbsp;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2993">progress</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.PrintingErrorReporter.html#line.2992">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>&nbsp;in interface&nbsp;<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 b1e3f6d..ce9e0b6 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.871">HBaseFsck.RegionBoundariesInformation</a>
+<pre>private static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.870">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&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.872">regionName</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.871">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&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">metaFirstKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.872">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&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">metaLastKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.873">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&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">storesFirstKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.874">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&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.876">storesLastKey</a></pre>
+<pre>public&nbsp;byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.875">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&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.871">RegionBoundariesInformation</a>()</pre>
+<pre>private&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.870">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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.878">toString</a>()</pre>
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.RegionBoundariesInformation.html#line.877">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>&nbsp;in class&nbsp;<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 0929fda..2beedcc 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.3068">HBaseFsck.WorkItemHdfsDir</a>
+<pre>class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3067">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>&lt;<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>&gt;</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&nbsp;org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3069">tableDir</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FileStatus <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3068">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&nbsp;<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.3070">errors</a></pre>
+<pre>private&nbsp;<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.3069">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&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3071">fs</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3070">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.3073">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3072">WorkItemHdfsDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                 <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors,
                 org.apache.hadoop.fs.FileStatus&nbsp;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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3080">call</a>()
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsDir.html#line.3079">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 cf34573..061be88 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.3187">HBaseFsck.WorkItemHdfsRegionInfo</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3186">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>&lt;<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>&gt;</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&nbsp;<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.3188">hbi</a></pre>
+<pre>private&nbsp;<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.3187">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&nbsp;<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.3189">hbck</a></pre>
+<pre>private&nbsp;<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.3188">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&nbsp;<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.3190">errors</a></pre>
+<pre>private&nbsp;<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.3189">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.3192">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3191">WorkItemHdfsRegionInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi,
                        <a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
                        <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3199">call</a>()
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemHdfsRegionInfo.html#line.3198">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 6157678..f0d75ef 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.2562">HBaseFsck.WorkItemOverlapMerge</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2561">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>&lt;<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>&gt;</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&nbsp;<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.2563">handler</a></pre>
+<pre>private&nbsp;<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.2562">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2564">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2563">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.2566">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;overlapgroup,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2565">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;overlapgroup,
                      <a href="../../../../../org/apache/hadoop/hbase/util/hbck/TableIntegrityErrorHandler.html" title="interface in org.apache.hadoop.hbase.util.hbck">TableIntegrityErrorHandler</a>&nbsp;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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2573">call</a>()
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemOverlapMerge.html#line.2572">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 68b50ab..9c5ceeb 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.3006">HBaseFsck.WorkItemRegion</a>
+<pre>static class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3005">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>&lt;<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>&gt;</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&nbsp;<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.3007">hbck</a></pre>
+<pre>private final&nbsp;<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.3006">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&nbsp;<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.3008">rsinfo</a></pre>
+<pre>private final&nbsp;<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.3007">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&nbsp;<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.3009">errors</a></pre>
+<pre>private final&nbsp;<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.3008">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&nbsp;<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.3010">connection</a></pre>
+<pre>private final&nbsp;<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.3009">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.3012">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3011">WorkItemRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;hbck,
                <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;info,
                <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;errors,
                <a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a>&nbsp;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&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3021">call</a>()
+<pre>public&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3020">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&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3052">filterRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Lis [...]
+<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.WorkItemRegion.html#line.3051">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 a75e772..11fa96b 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.203">HBaseFsck</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.202">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&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_TIME_LAG</a></pre>
+<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.203">DEFAULT_TIME_LAG</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
+<pre>public static final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.204">DEFAULT_SLEEP_BEFORE_RERUN</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">MAX_NUM_THREADS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.205">MAX_NUM_THREADS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">rsSupportsOffline</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.206">rsSupportsOffline</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.207">DEFAULT_OVERLAPS_TO_SIDELINE</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.209">DEFAULT_MAX_MERGE</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.208">DEFAULT_MAX_MERGE</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1755,7 +1755,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>HBCK_LOCK_FILE</h4>
-<pre>public static final&nbsp;<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>
+<pre>public static final&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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>
@@ -1771,7 +1771,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_MAX_LOCK_FILE_ATTEMPTS</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.216">DEFAULT_MAX_LOCK_FILE_ATTEMPTS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1785,7 +1785,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.217">DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1799,7 +1799,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.219">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.218">DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1813,7 +1813,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_WAIT_FOR_LOCK_TIMEOUT</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.223">DEFAULT_WAIT_FOR_LOCK_TIMEOUT</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1827,7 +1827,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.224">DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1841,7 +1841,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.225">DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1855,7 +1855,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.227">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.226">DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -1869,7 +1869,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.232">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.231">LOG</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Internal resources</div>
 </li>
@@ -1880,7 +1880,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>status</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1890,7 +1890,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>connection</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1900,7 +1900,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>admin</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1910,7 +1910,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>meta</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1920,7 +1920,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>executor</h4>
-<pre>protected&nbsp;<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>
+<pre>protected&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1930,7 +1930,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>startMillis</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.239">startMillis</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.238">startMillis</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1940,7 +1940,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>hfcc</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1950,7 +1950,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>retcode</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">retcode</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.240">retcode</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1960,7 +1960,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>HBCK_LOCK_PATH</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">HBCK_LOCK_PATH</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.241">HBCK_LOCK_PATH</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1970,7 +1970,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckOutFd</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.243">hbckOutFd</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.FSDataOutputStream <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.242">hbckOutFd</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1980,7 +1980,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckLockCleanup</h4>
-<pre>private final&nbsp;<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>
+<pre>private final&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -1990,7 +1990,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>unsupportedOptionsInV2</h4>
-<pre>private static final&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.250">unsupportedOptionsInV2</a></pre>
+<pre>private static final&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.249">unsupportedOptionsInV2</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2000,7 +2000,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>details</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">details</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.257">details</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Options</div>
 </li>
@@ -2011,7 +2011,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>timelag</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">timelag</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.258">timelag</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2021,7 +2021,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>forceExclusive</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">forceExclusive</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.259">forceExclusive</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2031,7 +2031,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixAssignments</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixAssignments</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.260">fixAssignments</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2041,7 +2041,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixMeta</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">fixMeta</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.261">fixMeta</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2051,7 +2051,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHdfs</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">checkHdfs</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.262">checkHdfs</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2061,7 +2061,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsHoles</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsHoles</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.263">fixHdfsHoles</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2071,7 +2071,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsOverlaps</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOverlaps</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.264">fixHdfsOverlaps</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2081,7 +2081,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHdfsOrphans</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixHdfsOrphans</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.265">fixHdfsOrphans</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2091,7 +2091,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixTableOrphans</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixTableOrphans</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.266">fixTableOrphans</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2101,7 +2101,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixVersionFile</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixVersionFile</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.267">fixVersionFile</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2111,7 +2111,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixSplitParents</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">fixSplitParents</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.268">fixSplitParents</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2121,7 +2121,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>removeParents</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">removeParents</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.269">removeParents</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2131,7 +2131,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixReferenceFiles</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixReferenceFiles</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.270">fixReferenceFiles</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2141,7 +2141,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixHFileLinks</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixHFileLinks</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.271">fixHFileLinks</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2151,7 +2151,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixEmptyMetaCells</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixEmptyMetaCells</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.272">fixEmptyMetaCells</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2161,7 +2161,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixReplication</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">fixReplication</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.273">fixReplication</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2171,7 +2171,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrier</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">cleanReplicationBarrier</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.274">cleanReplicationBarrier</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2181,7 +2181,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixAny</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.276">fixAny</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.275">fixAny</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2191,7 +2191,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>tablesIncluded</h4>
-<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.280">tablesIncluded</a></pre>
+<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.279">tablesIncluded</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2201,7 +2201,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrierTable</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2211,7 +2211,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>maxMerge</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.282">maxMerge</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.281">maxMerge</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2221,7 +2221,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>maxOverlapsToSideline</h4>
-<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">maxOverlapsToSideline</a></pre>
+<pre>private&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.283">maxOverlapsToSideline</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2231,7 +2231,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineBigOverlaps</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineBigOverlaps</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.284">sidelineBigOverlaps</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2241,7 +2241,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineDir</h4>
-<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.286">sidelineDir</a></pre>
+<pre>private&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.285">sidelineDir</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2251,7 +2251,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>rerun</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">rerun</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.287">rerun</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2261,7 +2261,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>summary</h4>
-<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">summary</a></pre>
+<pre>private static&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.288">summary</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2271,7 +2271,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkMetaOnly</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkMetaOnly</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.289">checkMetaOnly</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2281,7 +2281,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionBoundaries</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">checkRegionBoundaries</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.290">checkRegionBoundaries</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2291,7 +2291,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>ignorePreCheckPermission</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.292">ignorePreCheckPermission</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.291">ignorePreCheckPermission</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2301,7 +2301,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>errors</h4>
-<pre>private final&nbsp;<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>
+<pre>private final&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">State</div>
 </li>
@@ -2312,7 +2312,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixes</h4>
-<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.298">fixes</a></pre>
+<pre>int <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.297">fixes</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2322,7 +2322,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>regionInfoMap</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apach [...]
+<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apach [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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
@@ -2335,7 +2335,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>emptyRegionInfoQualifiers</h4>
-<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.307">emptyRegionInfoQualifiers</a></pre>
+<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.306">emptyRegionInfoQualifiers</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2345,7 +2345,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>tablesInfo</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
+<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/H [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">This map from Tablename -> TableInfo contains the structures necessary to
  detect table consistency problems (holes, dupes, overlaps).  It is sorted
@@ -2363,7 +2363,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>orphanHdfsDirs</h4>
-<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.324">orphanHdfsDirs</a></pre>
+<pre>private&nbsp;<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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.323">orphanHdfsDirs</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">When initially looking at HDFS, we attempt to find any orphaned data.</div>
 </li>
@@ -2374,7 +2374,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>orphanTableDirs</h4>
-<pre>private&nbsp;<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>&lt;<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>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private&nbsp;<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>&lt;<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>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2384,7 +2384,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>tableStates</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
+<pre>private&nbsp;<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>&lt;<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>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html# [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2394,7 +2394,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>lockFileRetryCounterFactory</h4>
-<pre>private final&nbsp;<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>
+<pre>private final&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2404,7 +2404,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createZNodeRetryCounterFactory</h4>
-<pre>private final&nbsp;<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>
+<pre>private final&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2414,7 +2414,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>skippedRegions</h4>
-<pre>private&nbsp;<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>&lt;<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>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
+<pre>private&nbsp;<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>&lt;<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>&lt;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-e [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2424,7 +2424,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>zkw</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2434,7 +2434,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckEphemeralNodePath</h4>
-<pre>private&nbsp;<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>
+<pre>private&nbsp;<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>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2444,7 +2444,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hbckZodeCreated</h4>
-<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.335">hbckZodeCreated</a></pre>
+<pre>private&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.334">hbckZodeCreated</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2462,7 +2462,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>HBaseFsck</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.344">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.343">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;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>&nbsp;</div>
@@ -2484,7 +2484,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HBaseFsck</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.363">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.362">HBaseFsck</a>(org.apache.hadoop.conf.Configuration&nbsp;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>&nbsp;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>,
@@ -2517,7 +2517,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createThreadPool</h4>
-<pre>private static&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.348">createThreadPool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>private static&nbsp;<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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.347">createThreadPool</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2527,7 +2527,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createLockRetryCounterFactory</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.376">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.375">createLockRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
@@ -2541,7 +2541,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createZnodeRetryCounterFactory</h4>
-<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.388">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/RetryCounterFactory.html" title="class in org.apache.hadoop.hbase.util">RetryCounterFactory</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.387">createZnodeRetryCounterFactory</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
@@ -2555,7 +2555,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getTmpDir</h4>
-<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.401">getTmpDir</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>public static&nbsp;org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.400">getTmpDir</a>(org.apache.hadoop.conf.Configuration&nbsp;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>&nbsp;</div>
 <dl>
@@ -2572,7 +2572,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndMarkRunningHbck</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.482">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/Pair.html" title="class in org.apache.hadoop.hbase.util">Pair</a>&lt;org.apache.hadoop.fs.Path,org.apache.hadoop.fs.FSDataOutputStream&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.481">checkAndMarkRunningHbck</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                                                                                                               <a href="../../../../../org/apache/hadoop/hbase/util/RetryCounter.html" title="class in org.apache.hadoop.hbase.util">RetryCounter</a>&nbsp;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>&nbsp;</div>
@@ -2591,7 +2591,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>unlockHbck</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.508">unlockHbck</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.507">unlockHbck</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2601,7 +2601,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>connect</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.539">connect</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.538">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>&nbsp;</div>
 <div class="block">To repair region consistency, one must call connect() in order to repair
@@ -2618,7 +2618,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadDeployedRegions</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.585">loadDeployedRegions</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.584">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>&nbsp;</div>
@@ -2636,7 +2636,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>clearState</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.635">clearState</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.634">clearState</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Clear the current state of hbck.</div>
 </li>
@@ -2647,7 +2647,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineHdfsIntegrityRepair</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.652">offlineHdfsIntegrityRepair</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.651">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>&nbsp;</div>
@@ -2667,7 +2667,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>onlineConsistencyRepair</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.688">onlineConsistencyRepair</a>()
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.687">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>
@@ -2692,7 +2692,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setMasterInMaintenanceMode</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.754">setMasterInMaintenanceMode</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.753">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>&nbsp;</div>
 <div class="block">This method maintains an ephemeral znode. If the creation fails we return false or throw
@@ -2711,7 +2711,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanupHbckZnode</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.785">cleanupHbckZnode</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.784">cleanupHbckZnode</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2721,7 +2721,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>onlineHbck</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.803">onlineHbck</a>()
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.802">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>,
@@ -2745,7 +2745,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>keyOnly</h4>
-<pre>public static&nbsp;byte[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.844">keyOnly</a>(byte[]&nbsp;b)</pre>
+<pre>public static&nbsp;byte[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.843">keyOnly</a>(byte[]&nbsp;b)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2755,7 +2755,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>close</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.854">close</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.853">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>&nbsp;</div>
 <dl>
@@ -2774,7 +2774,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionBoundaries</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.887">checkRegionBoundaries</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.886">checkRegionBoundaries</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2784,7 +2784,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>adoptHdfsOrphans</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.972">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;orphanHdfsDirs)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.971">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&gt;&nbsp;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>&nbsp;</div>
 <div class="block">Iterates through the list of all orphan/invalid regiondirs.</div>
@@ -2800,7 +2800,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>adoptHdfsOrphan</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.989">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.988">adoptHdfsOrphan</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
 <div class="block">Orphaned regions are regions without a .regioninfo file in them.  We "adopt"
@@ -2822,7 +2822,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>restoreHdfsIntegrity</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1081">restoreHdfsIntegrity</a>()
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1080">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>&nbsp;</div>
@@ -2845,7 +2845,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineReferenceFileRepair</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1129">offlineReferenceFileRepair</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1128">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>&nbsp;</div>
@@ -2868,7 +2868,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>offlineHLinkFileRepair</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1183">offlineHLinkFileRepair</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1182">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>&nbsp;</div>
@@ -2888,7 +2888,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineFile</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1230">sidelineFile</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1229">sidelineFile</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                              org.apache.hadoop.fs.Path&nbsp;hbaseRoot,
                              org.apache.hadoop.fs.Path&nbsp;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>
@@ -2905,7 +2905,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>reportEmptyMetaCells</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1248">reportEmptyMetaCells</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1247">reportEmptyMetaCells</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">TODO -- need to add tests for this.</div>
 </li>
@@ -2916,7 +2916,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>reportTablesInFlux</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1261">reportTablesInFlux</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1260">reportTablesInFlux</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">TODO -- need to add tests for this.</div>
 </li>
@@ -2927,7 +2927,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getErrors</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1278">getErrors</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1277">getErrors</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -2937,7 +2937,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadHdfsRegionInfos</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<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>&nbsp;</div>
@@ -2955,7 +2955,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getColumnFamilyList</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1371">getColumnFamilyList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Set.html?is [...]
+<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1370">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>&nbsp;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>&nbsp;</div>
@@ -2977,7 +2977,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fabricateTableInfo</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1390">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a>&nbsp;fstd,
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1389">fabricateTableInfo</a>(<a href="../../../../../org/apache/hadoop/hbase/util/FSTableDescriptors.html" title="class in org.apache.hadoop.hbase.util">FSTableDescriptors</a>&nbsp;fstd,
                                    <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;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>&lt;<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>&gt;&nbsp;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>
@@ -2998,7 +2998,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixEmptyMetaCells</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1405">fixEmptyMetaCells</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1404">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>&nbsp;</div>
 <div class="block">To fix the empty REGIONINFO_QUALIFIER rows from hbase:meta <br></div>
@@ -3014,7 +3014,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>fixOrphanTables</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1425">fixOrphanTables</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1424">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>&nbsp;</div>
 <div class="block">To fix orphan table by creating a .tableinfo file under tableDir <br>
@@ -3035,7 +3035,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>logParallelMerge</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1481">logParallelMerge</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1480">logParallelMerge</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Log an appropriate message about whether or not overlapping merges are computed in parallel.</div>
 </li>
@@ -3046,7 +3046,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHdfsIntegrity</h4>
-<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
+<pre>private&nbsp;<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>&lt;<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>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/u [...]
                                                               boolean&nbsp;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>&nbsp;</div>
@@ -3062,7 +3062,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getSidelineDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1511">getSidelineDir</a>()
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1510">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>&nbsp;</div>
 <dl>
@@ -3077,7 +3077,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1524">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1523">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
                                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
@@ -3094,7 +3094,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>sidelineRegionDir</h4>
-<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1536">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;fs,
+<pre>org.apache.hadoop.fs.Path&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1535">sidelineRegionDir</a>(org.apache.hadoop.fs.FileSystem&nbsp;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>&nbsp;parentDir,
                                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>
@@ -3117,7 +3117,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadTableStates</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1611">loadTableStates</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1610">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>&nbsp;</div>
 <div class="block">Load the list of disabled tables in ZK into local set.</div>
@@ -3134,7 +3134,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>isTableDisabled</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1625">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1624">isTableDisabled</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Check if the specified region's table is disabled.</div>
 <dl>
@@ -3149,7 +3149,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadHdfsRegionDirs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1635">loadHdfsRegionDirs</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1634">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>&nbsp;</div>
@@ -3168,7 +3168,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>recordMetaRegion</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1693">recordMetaRegion</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1692">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>&nbsp;</div>
 <div class="block">Record the location of the hbase:meta region as found in ZooKeeper.</div>
@@ -3184,7 +3184,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createZooKeeperWatcher</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1729">createZooKeeperWatcher</a>()
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1728">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>&nbsp;</div>
 <dl>
@@ -3199,7 +3199,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>processRegionServers</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1750">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;regionServerList)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1749">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;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>&nbsp;</div>
@@ -3219,7 +3219,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixConsistency</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1778">checkAndFixConsistency</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1777">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>
@@ -3239,7 +3239,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionConsistencyConcurrently</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1823">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>&gt;&n [...]
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1822">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck.CheckRegionConsistencyWorkItem</a>&gt;&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>
@@ -3259,7 +3259,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>addSkippedRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1877">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1876">addSkippedRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hbi)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3269,7 +3269,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixTableStates</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1891">checkAndFixTableStates</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1890">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>&nbsp;</div>
 <div class="block">Check and fix table states, assumes full info available:
@@ -3287,7 +3287,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckPermission</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1933">preCheckPermission</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1932">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>,
                                 <a href="../../../../../org/apache/hadoop/hbase/security/AccessDeniedException.html" title="class in org.apache.hadoop.hbase.security">AccessDeniedException</a></pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
@@ -3304,7 +3304,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteMetaRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1959">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1958">deleteMetaRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
 <div class="block">Deletes region from meta table</div>
@@ -3320,7 +3320,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteMetaRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1966">deleteMetaRegion</a>(byte[]&nbsp;metaKey)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1965">deleteMetaRegion</a>(byte[]&nbsp;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>&nbsp;</div>
 <div class="block">Deletes region from meta table</div>
@@ -3336,7 +3336,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>resetSplitParent</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1975">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.1974">resetSplitParent</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
 <div class="block">Reset the split parent region info in meta table</div>
@@ -3352,7 +3352,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>offline</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2001">offline</a>(byte[]&nbsp;regionName)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2000">offline</a>(byte[]&nbsp;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>&nbsp;</div>
 <div class="block">This backwards-compatibility wrapper for permanently offlining a region
@@ -3373,7 +3373,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>closeRegion</h4>
-<pre>void&nbsp;<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>&nbsp;hi)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2041">closeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
@@ -3400,7 +3400,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>undeployRegions</h4>
-<pre>private&nbsp;void&nbsp;<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>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2089">undeployRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
@@ -3417,7 +3417,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>undeployRegionsForHbi</h4>
-<pre>private&nbsp;void&nbsp;<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>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2110">undeployRegionsForHbi</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
@@ -3434,7 +3434,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>tryAssignmentRepair</h4>
-<pre>private&nbsp;void&nbsp;<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>&nbsp;hbi,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2124">tryAssignmentRepair</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkRegionConsistency</h4>
-<pre>private&nbsp;void&nbsp;<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>&nbsp;key,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2160">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>&nbsp;key,
                                     <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <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>&lt;<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>&gt;&nbsp;<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>&lt;<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>&gt;&nbsp;<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>&nbsp;</div>
 <div class="block">Checks tables integrity. Goes over all regions and scans the tables.
@@ -3493,7 +3493,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadTableInfosForTablesWithNoRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2470">loadTableInfosForTablesWithNoRegion</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2469">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>&nbsp;</div>
 <div class="block">Loads table info's for tables that may not have been included, since there are no
@@ -3510,7 +3510,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>mergeRegionDirs</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2490">mergeRegionDirs</a>(org.apache.hadoop.fs.Path&nbsp;targetRegionDir,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2489">mergeRegionDirs</a>(org.apache.hadoop.fs.Path&nbsp;targetRegionDir,
                            <a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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>&nbsp;</div>
@@ -3529,7 +3529,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <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>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2588">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>&nbsp;numSkipped)</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2587">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>&nbsp;numSkipped)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <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>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2608">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>&lt;<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>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2607">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class i [...]
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3560,7 +3560,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getOrCreateInfo</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2625">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>&nbsp;name)</pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2624">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>&nbsp;name)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkAndFixReplication</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2634">checkAndFixReplication</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2633">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>&nbsp;</div>
 <dl>
@@ -3588,7 +3588,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkMetaRegion</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2653">checkMetaRegion</a>()
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2652">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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>unassignMetaReplica</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2708">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;hi)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2707">unassignMetaReplica</a>(<a href="../../../../../org/apache/hadoop/hbase/util/HbckRegionInfo.html" title="class in org.apache.hadoop.hbase.util">HbckRegionInfo</a>&nbsp;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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>assignMetaReplica</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2715">assignMetaReplica</a>(int&nbsp;replicaId)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2714">assignMetaReplica</a>(int&nbsp;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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>loadMetaEntries</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2734">loadMetaEntries</a>()
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2733">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>&nbsp;</div>
 <div class="block">Scan hbase:meta, adding all regions found to the regionInfo map.</div>
@@ -3665,7 +3665,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>printTableSummary</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2831">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>&lt;<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&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2830">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>&lt;<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>&nbsp;</div>
 <div class="block">Prints summary of all tables found on the system.</div>
 </li>
@@ -3676,7 +3676,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getErrorReporter</h4>
-<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2866">getErrorReporter</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.2865">getErrorReporter</a>(org.apache.hadoop.conf.Configuration&nbsp;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>&nbsp;</div>
 <dl>
@@ -3691,7 +3691,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setDisplayFullReport</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3230">setDisplayFullReport</a>()</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3229">setDisplayFullReport</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldDisplayFullReport</h4>
-<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3234">shouldDisplayFullReport</a>()</pre>
+<pre>public static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3233">shouldDisplayFullReport</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3713,7 +3713,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setForceExclusive</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3241">setForceExclusive</a>()</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3240">setForceExclusive</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set exclusive mode.</div>
 </li>
@@ -3724,7 +3724,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>isExclusive</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3248">isExclusive</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3247">isExclusive</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Only one instance of hbck can modify HBase at a time.</div>
 </li>
@@ -3735,7 +3735,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setSummary</h4>
-<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3256">setSummary</a>()</pre>
+<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3255">setSummary</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set summary mode.
  Print only summary of the tables and status (OK or INCONSISTENT)</div>
@@ -3747,7 +3747,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setCheckMetaOnly</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3264">setCheckMetaOnly</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3263">setCheckMetaOnly</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set hbase:meta check mode.
  Print only info about hbase:meta table deployment/state</div>
@@ -3759,7 +3759,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setRegionBoundariesCheck</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3271">setRegionBoundariesCheck</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3270">setRegionBoundariesCheck</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set region boundaries check mode.</div>
 </li>
@@ -3770,7 +3770,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixReplication</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3278">setFixReplication</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3277">setFixReplication</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Set replication fix mode.</div>
 </li>
@@ -3781,7 +3781,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setCleanReplicationBarrier</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3283">setCleanReplicationBarrier</a>(boolean&nbsp;shouldClean)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3282">setCleanReplicationBarrier</a>(boolean&nbsp;shouldClean)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3791,7 +3791,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setShouldRerun</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3293">setShouldRerun</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3292">setShouldRerun</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldRerun</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3297">shouldRerun</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3296">shouldRerun</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3815,7 +3815,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixAssignments</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3305">setFixAssignments</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3304">setFixAssignments</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixAssignments</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3310">shouldFixAssignments</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3309">shouldFixAssignments</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3837,7 +3837,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixMeta</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3314">setFixMeta</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3313">setFixMeta</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3847,7 +3847,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixMeta</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3319">shouldFixMeta</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3318">shouldFixMeta</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3857,7 +3857,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixEmptyMetaCells</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3323">setFixEmptyMetaCells</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3322">setFixEmptyMetaCells</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3867,7 +3867,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixEmptyMetaCells</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3328">shouldFixEmptyMetaCells</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3327">shouldFixEmptyMetaCells</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3877,7 +3877,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setCheckHdfs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3332">setCheckHdfs</a>(boolean&nbsp;checking)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3331">setCheckHdfs</a>(boolean&nbsp;checking)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3887,7 +3887,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldCheckHdfs</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3336">shouldCheckHdfs</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3335">shouldCheckHdfs</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3897,7 +3897,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsHoles</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3340">setFixHdfsHoles</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3339">setFixHdfsHoles</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3907,7 +3907,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsHoles</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3345">shouldFixHdfsHoles</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3344">shouldFixHdfsHoles</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3917,7 +3917,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixTableOrphans</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3349">setFixTableOrphans</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3348">setFixTableOrphans</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3927,7 +3927,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixTableOrphans</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3354">shouldFixTableOrphans</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3353">shouldFixTableOrphans</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3937,7 +3937,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsOverlaps</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3358">setFixHdfsOverlaps</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3357">setFixHdfsOverlaps</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3947,7 +3947,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsOverlaps</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3363">shouldFixHdfsOverlaps</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3362">shouldFixHdfsOverlaps</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3957,7 +3957,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHdfsOrphans</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3367">setFixHdfsOrphans</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3366">setFixHdfsOrphans</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3967,7 +3967,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHdfsOrphans</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3372">shouldFixHdfsOrphans</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3371">shouldFixHdfsOrphans</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3977,7 +3977,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixVersionFile</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3376">setFixVersionFile</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3375">setFixVersionFile</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3987,7 +3987,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixVersionFile</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3381">shouldFixVersionFile</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3380">shouldFixVersionFile</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -3997,7 +3997,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setSidelineBigOverlaps</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3385">setSidelineBigOverlaps</a>(boolean&nbsp;sbo)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3384">setSidelineBigOverlaps</a>(boolean&nbsp;sbo)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4007,7 +4007,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldSidelineBigOverlaps</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3389">shouldSidelineBigOverlaps</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3388">shouldSidelineBigOverlaps</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4017,7 +4017,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixSplitParents</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3393">setFixSplitParents</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3392">setFixSplitParents</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4027,7 +4027,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setRemoveParents</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3398">setRemoveParents</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3397">setRemoveParents</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4037,7 +4037,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixSplitParents</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3403">shouldFixSplitParents</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3402">shouldFixSplitParents</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4047,7 +4047,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldRemoveParents</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3407">shouldRemoveParents</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3406">shouldRemoveParents</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4057,7 +4057,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixReferenceFiles</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3411">setFixReferenceFiles</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3410">setFixReferenceFiles</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4067,7 +4067,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixReferenceFiles</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3416">shouldFixReferenceFiles</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3415">shouldFixReferenceFiles</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4077,7 +4077,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setFixHFileLinks</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3420">setFixHFileLinks</a>(boolean&nbsp;shouldFix)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3419">setFixHFileLinks</a>(boolean&nbsp;shouldFix)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4087,7 +4087,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldFixHFileLinks</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3425">shouldFixHFileLinks</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3424">shouldFixHFileLinks</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4097,7 +4097,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>shouldIgnorePreCheckPermission</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3429">shouldIgnorePreCheckPermission</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3428">shouldIgnorePreCheckPermission</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4107,7 +4107,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setIgnorePreCheckPermission</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3433">setIgnorePreCheckPermission</a>(boolean&nbsp;ignorePreCheckPermission)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3432">setIgnorePreCheckPermission</a>(boolean&nbsp;ignorePreCheckPermission)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4117,7 +4117,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setMaxMerge</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3440">setMaxMerge</a>(int&nbsp;mm)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3439">setMaxMerge</a>(int&nbsp;mm)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -4131,7 +4131,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxMerge</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3444">getMaxMerge</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3443">getMaxMerge</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4141,7 +4141,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setMaxOverlapsToSideline</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3448">setMaxOverlapsToSideline</a>(int&nbsp;mo)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3447">setMaxOverlapsToSideline</a>(int&nbsp;mo)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4151,7 +4151,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxOverlapsToSideline</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3452">getMaxOverlapsToSideline</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3451">getMaxOverlapsToSideline</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4161,7 +4161,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>isTableIncluded</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3460">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3459">isTableIncluded</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <div class="block">Only check/fix tables specified by the list,
  Empty list means all tables are included.</div>
@@ -4173,7 +4173,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>includeTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3464">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3463">includeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4183,7 +4183,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3468">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>&lt;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3467">getIncludedTables</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4193,7 +4193,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setTimeLag</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3477">setTimeLag</a>(long&nbsp;seconds)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3476">setTimeLag</a>(long&nbsp;seconds)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setSidelineDir</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3485">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>&nbsp;sidelineDir)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3484">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>&nbsp;sidelineDir)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -4223,7 +4223,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>createHFileCorruptionChecker</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3489">createHFileCorruptionChecker</a>(boolean&nbsp;sidelineCorruptHFiles)
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3488">createHFileCorruptionChecker</a>(boolean&nbsp;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>&nbsp;</div>
 <dl>
@@ -4238,7 +4238,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getHFilecorruptionChecker</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3493">getHFilecorruptionChecker</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3492">getHFilecorruptionChecker</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4248,7 +4248,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setHFileCorruptionChecker</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3497">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;hfcc)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3496">setHFileCorruptionChecker</a>(<a href="../../../../../org/apache/hadoop/hbase/util/hbck/HFileCorruptionChecker.html" title="class in org.apache.hadoop.hbase.util.hbck">HFileCorruptionChecker</a>&nbsp;hfcc)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4258,7 +4258,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setRetCode</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3501">setRetCode</a>(int&nbsp;code)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3500">setRetCode</a>(int&nbsp;code)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4268,7 +4268,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>getRetCode</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3505">getRetCode</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3504">getRetCode</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4278,7 +4278,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>printUsageAndExit</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3509">printUsageAndExit</a>()</pre>
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3508">printUsageAndExit</a>()</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4288,7 +4288,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>main</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3596">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>[]&nbsp;args)
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3595">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>[]&nbsp;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>&nbsp;</div>
 <div class="block">Main program</div>
@@ -4306,7 +4306,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>exec</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3620">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>&nbsp;exec,
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.html" title="class in org.apache.hadoop.hbase.util">HBaseFsck</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3619">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>&nbsp;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>[]&nbsp;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 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>isOptionsSupported</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3851">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>[]&nbsp;args)</pre>
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3850">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>[]&nbsp;args)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4338,7 +4338,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>setCleanReplicationBarrierTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3868">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>&nbsp;cleanReplicationBarrierTable)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3867">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>&nbsp;cleanReplicationBarrierTable)</pre>
 <div class="block"><span class="deprecatedLabel">Deprecated.</span>&nbsp;</div>
 </li>
 </ul>
@@ -4348,7 +4348,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanReplicationBarrier</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3872">cleanReplicationBarrier</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3871">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>&nbsp;</div>
 <dl>
@@ -4363,7 +4363,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3950">debugLsr</a>(org.apache.hadoop.fs.Path&nbsp;p)
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3949">debugLsr</a>(org.apache.hadoop.fs.Path&nbsp;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>&nbsp;</div>
 <div class="block">ls -r for debugging purposes</div>
@@ -4379,7 +4379,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3957">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3956">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                             org.apache.hadoop.fs.Path&nbsp;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>&nbsp;</div>
@@ -4396,7 +4396,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>debugLsr</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3965">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/util/HBaseFsck.html#line.3964">debugLsr</a>(org.apache.hadoop.conf.Configuration&nbsp;conf,
                             org.apache.hadoop.fs.Path&nbsp;p,
                             <a href="../../../../../org/apache/hadoop/hbase/util/HbckErrorReporter.html" title="interface in org.apache.hadoop.hbase.util">HbckErrorReporter</a>&nbsp;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 3eda70c..299ab0d 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -560,13 +560,13 @@
 <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>&lt;E&gt; (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>&lt;T&gt;, 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/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/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/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/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/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>&lt;T&gt;)</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>&lt;T&gt;)</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/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/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>&lt;T&gt;)</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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/Version.html b/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
index dd018d0..79d3cb4 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
@@ -18,9 +18,9 @@
 <span class="sourceLineNo">010</span>  justification="Intentional; to be modified in test")<a name="line.10"></a>
 <span class="sourceLineNo">011</span>public class Version {<a name="line.11"></a>
 <span class="sourceLineNo">012</span>  public static final String version = new String("3.0.0-SNAPSHOT");<a name="line.12"></a>
-<span class="sourceLineNo">013</span>  public static final String revision = "97e01070001ef81558b4dae3a3610d0c73651cb9";<a name="line.13"></a>
+<span class="sourceLineNo">013</span>  public static final String revision = "0f166edc3da303b6b9746db2dc02f2a30c1de4e0";<a name="line.13"></a>
 <span class="sourceLineNo">014</span>  public static final String user = "jenkins";<a name="line.14"></a>
-<span class="sourceLineNo">015</span>  public static final String date = "Mon Dec  2 14:36:41 UTC 2019";<a name="line.15"></a>
+<span class="sourceLineNo">015</span>  public static final String date = "Tue Dec  3 14:36:00 UTC 2019";<a name="line.15"></a>
 <span class="sourceLineNo">016</span>  public static final String url = "git://jenkins-websites-he-de.apache.org/home/jenkins/jenkins-slave/workspace/hbase_generate_website/hbase";<a name="line.16"></a>
 <span class="sourceLineNo">017</span>  public static final String srcChecksum = "(stdin)=";<a name="line.17"></a>
 <span class="sourceLineNo">018</span>}<a name="line.18"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
index d7ef2c2..0c070a4 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html
@@ -41,142 +41,141 @@
 <span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.33"></a>
 <span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.34"></a>
 <span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.replication.ReplicationQueueStorage;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.36"></a>
-<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.38"></a>
-<span class="sourceLineNo">039</span>import org.slf4j.Logger;<a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.slf4j.LoggerFactory;<a name="line.40"></a>
-<span class="sourceLineNo">041</span><a name="line.41"></a>
-<span class="sourceLineNo">042</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.42"></a>
-<span class="sourceLineNo">043</span><a name="line.43"></a>
-<span class="sourceLineNo">044</span>/**<a name="line.44"></a>
-<span class="sourceLineNo">045</span> * The base class for all replication peer related procedure.<a name="line.45"></a>
-<span class="sourceLineNo">046</span> */<a name="line.46"></a>
-<span class="sourceLineNo">047</span>@InterfaceAudience.Private<a name="line.47"></a>
-<span class="sourceLineNo">048</span>public abstract class AbstractPeerProcedure&lt;TState&gt; extends AbstractPeerNoLockProcedure&lt;TState&gt;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>    implements PeerProcedureInterface {<a name="line.49"></a>
-<span class="sourceLineNo">050</span><a name="line.50"></a>
-<span class="sourceLineNo">051</span>  private static final Logger LOG = LoggerFactory.getLogger(AbstractPeerProcedure.class);<a name="line.51"></a>
-<span class="sourceLineNo">052</span><a name="line.52"></a>
-<span class="sourceLineNo">053</span>  protected static final int UPDATE_LAST_SEQ_ID_BATCH_SIZE = 1000;<a name="line.53"></a>
-<span class="sourceLineNo">054</span><a name="line.54"></a>
-<span class="sourceLineNo">055</span>  // The sleep interval when waiting table to be enabled or disabled.<a name="line.55"></a>
-<span class="sourceLineNo">056</span>  protected static final int SLEEP_INTERVAL_MS = 1000;<a name="line.56"></a>
-<span class="sourceLineNo">057</span><a name="line.57"></a>
-<span class="sourceLineNo">058</span>  // used to keep compatible with old client where we can only returns after updateStorage.<a name="line.58"></a>
-<span class="sourceLineNo">059</span>  protected ProcedurePrepareLatch latch;<a name="line.59"></a>
-<span class="sourceLineNo">060</span><a name="line.60"></a>
-<span class="sourceLineNo">061</span>  protected AbstractPeerProcedure() {<a name="line.61"></a>
-<span class="sourceLineNo">062</span>  }<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span>  protected AbstractPeerProcedure(String peerId) {<a name="line.64"></a>
-<span class="sourceLineNo">065</span>    super(peerId);<a name="line.65"></a>
-<span class="sourceLineNo">066</span>    this.latch = ProcedurePrepareLatch.createLatch(2, 1);<a name="line.66"></a>
-<span class="sourceLineNo">067</span>  }<a name="line.67"></a>
-<span class="sourceLineNo">068</span><a name="line.68"></a>
-<span class="sourceLineNo">069</span>  public ProcedurePrepareLatch getLatch() {<a name="line.69"></a>
-<span class="sourceLineNo">070</span>    return latch;<a name="line.70"></a>
-<span class="sourceLineNo">071</span>  }<a name="line.71"></a>
-<span class="sourceLineNo">072</span><a name="line.72"></a>
-<span class="sourceLineNo">073</span>  @Override<a name="line.73"></a>
-<span class="sourceLineNo">074</span>  protected LockState acquireLock(MasterProcedureEnv env) {<a name="line.74"></a>
-<span class="sourceLineNo">075</span>    if (env.getProcedureScheduler().waitPeerExclusiveLock(this, peerId)) {<a name="line.75"></a>
-<span class="sourceLineNo">076</span>      return LockState.LOCK_EVENT_WAIT;<a name="line.76"></a>
-<span class="sourceLineNo">077</span>    }<a name="line.77"></a>
-<span class="sourceLineNo">078</span>    return LockState.LOCK_ACQUIRED;<a name="line.78"></a>
-<span class="sourceLineNo">079</span>  }<a name="line.79"></a>
-<span class="sourceLineNo">080</span><a name="line.80"></a>
-<span class="sourceLineNo">081</span>  @Override<a name="line.81"></a>
-<span class="sourceLineNo">082</span>  protected void releaseLock(MasterProcedureEnv env) {<a name="line.82"></a>
-<span class="sourceLineNo">083</span>    env.getProcedureScheduler().wakePeerExclusiveLock(this, peerId);<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>  @Override<a name="line.86"></a>
-<span class="sourceLineNo">087</span>  protected boolean holdLock(MasterProcedureEnv env) {<a name="line.87"></a>
-<span class="sourceLineNo">088</span>    return true;<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>  protected final void refreshPeer(MasterProcedureEnv env, PeerOperationType type) {<a name="line.91"></a>
-<span class="sourceLineNo">092</span>    addChildProcedure(env.getMasterServices().getServerManager().getOnlineServersList().stream()<a name="line.92"></a>
-<span class="sourceLineNo">093</span>      .map(sn -&gt; new RefreshPeerProcedure(peerId, type, sn)).toArray(RefreshPeerProcedure[]::new));<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>  // will be override in test to simulate error<a name="line.96"></a>
-<span class="sourceLineNo">097</span>  @VisibleForTesting<a name="line.97"></a>
-<span class="sourceLineNo">098</span>  protected void enablePeer(MasterProcedureEnv env) throws ReplicationException {<a name="line.98"></a>
-<span class="sourceLineNo">099</span>    env.getReplicationPeerManager().enablePeer(peerId);<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>  private void addToMap(Map&lt;String, Long&gt; lastSeqIds, String encodedRegionName, long barrier,<a name="line.102"></a>
-<span class="sourceLineNo">103</span>      ReplicationQueueStorage queueStorage) throws ReplicationException {<a name="line.103"></a>
-<span class="sourceLineNo">104</span>    if (barrier &gt;= 0) {<a name="line.104"></a>
-<span class="sourceLineNo">105</span>      lastSeqIds.put(encodedRegionName, barrier);<a name="line.105"></a>
-<span class="sourceLineNo">106</span>      if (lastSeqIds.size() &gt;= UPDATE_LAST_SEQ_ID_BATCH_SIZE) {<a name="line.106"></a>
-<span class="sourceLineNo">107</span>        queueStorage.setLastSequenceIds(peerId, lastSeqIds);<a name="line.107"></a>
-<span class="sourceLineNo">108</span>        lastSeqIds.clear();<a name="line.108"></a>
-<span class="sourceLineNo">109</span>      }<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><a name="line.112"></a>
-<span class="sourceLineNo">113</span>  protected final void setLastPushedSequenceId(MasterProcedureEnv env,<a name="line.113"></a>
-<span class="sourceLineNo">114</span>      ReplicationPeerConfig peerConfig) throws IOException, ReplicationException {<a name="line.114"></a>
-<span class="sourceLineNo">115</span>    Map&lt;String, Long&gt; lastSeqIds = new HashMap&lt;String, Long&gt;();<a name="line.115"></a>
-<span class="sourceLineNo">116</span>    for (TableDescriptor td : env.getMasterServices().getTableDescriptors().getAll().values()) {<a name="line.116"></a>
-<span class="sourceLineNo">117</span>      if (!td.hasGlobalReplicationScope()) {<a name="line.117"></a>
-<span class="sourceLineNo">118</span>        continue;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>      }<a name="line.119"></a>
-<span class="sourceLineNo">120</span>      TableName tn = td.getTableName();<a name="line.120"></a>
-<span class="sourceLineNo">121</span>      if (!ReplicationUtils.contains(peerConfig, tn)) {<a name="line.121"></a>
-<span class="sourceLineNo">122</span>        continue;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>      }<a name="line.123"></a>
-<span class="sourceLineNo">124</span>      setLastPushedSequenceIdForTable(env, tn, lastSeqIds);<a name="line.124"></a>
-<span class="sourceLineNo">125</span>    }<a name="line.125"></a>
-<span class="sourceLineNo">126</span>    if (!lastSeqIds.isEmpty()) {<a name="line.126"></a>
-<span class="sourceLineNo">127</span>      env.getReplicationPeerManager().getQueueStorage().setLastSequenceIds(peerId, lastSeqIds);<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><a name="line.130"></a>
-<span class="sourceLineNo">131</span>  // If the table is currently disabling, then we need to wait until it is disabled.We will write<a name="line.131"></a>
-<span class="sourceLineNo">132</span>  // replication barrier for a disabled table. And return whether we need to update the last pushed<a name="line.132"></a>
-<span class="sourceLineNo">133</span>  // sequence id, if the table has been deleted already, i.e, we hit TableStateNotFoundException,<a name="line.133"></a>
-<span class="sourceLineNo">134</span>  // then we do not need to update last pushed sequence id for this table.<a name="line.134"></a>
-<span class="sourceLineNo">135</span>  private boolean needSetLastPushedSequenceId(TableStateManager tsm, TableName tn)<a name="line.135"></a>
-<span class="sourceLineNo">136</span>      throws IOException {<a name="line.136"></a>
-<span class="sourceLineNo">137</span>    for (;;) {<a name="line.137"></a>
-<span class="sourceLineNo">138</span>      try {<a name="line.138"></a>
-<span class="sourceLineNo">139</span>        if (!tsm.getTableState(tn).isDisabling()) {<a name="line.139"></a>
-<span class="sourceLineNo">140</span>          return true;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>        }<a name="line.141"></a>
-<span class="sourceLineNo">142</span>        Thread.sleep(SLEEP_INTERVAL_MS);<a name="line.142"></a>
-<span class="sourceLineNo">143</span>      } catch (TableStateNotFoundException e) {<a name="line.143"></a>
-<span class="sourceLineNo">144</span>        return false;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>      } catch (InterruptedException e) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span>        throw (IOException) new InterruptedIOException(e.getMessage()).initCause(e);<a name="line.146"></a>
-<span class="sourceLineNo">147</span>      }<a name="line.147"></a>
-<span class="sourceLineNo">148</span>    }<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>  // Will put the encodedRegionName-&gt;lastPushedSeqId pair into the map passed in, if the map is<a name="line.151"></a>
-<span class="sourceLineNo">152</span>  // large enough we will call queueStorage.setLastSequenceIds and clear the map. So the caller<a name="line.152"></a>
-<span class="sourceLineNo">153</span>  // should not forget to check whether the map is empty at last, if not you should call<a name="line.153"></a>
-<span class="sourceLineNo">154</span>  // queueStorage.setLastSequenceIds to write out the remaining entries in the map.<a name="line.154"></a>
-<span class="sourceLineNo">155</span>  protected final void setLastPushedSequenceIdForTable(MasterProcedureEnv env, TableName tableName,<a name="line.155"></a>
-<span class="sourceLineNo">156</span>      Map&lt;String, Long&gt; lastSeqIds) throws IOException, ReplicationException {<a name="line.156"></a>
-<span class="sourceLineNo">157</span>    TableStateManager tsm = env.getMasterServices().getTableStateManager();<a name="line.157"></a>
-<span class="sourceLineNo">158</span>    ReplicationQueueStorage queueStorage = env.getReplicationPeerManager().getQueueStorage();<a name="line.158"></a>
-<span class="sourceLineNo">159</span>    Connection conn = env.getMasterServices().getConnection();<a name="line.159"></a>
-<span class="sourceLineNo">160</span>    if (!needSetLastPushedSequenceId(tsm, tableName)) {<a name="line.160"></a>
-<span class="sourceLineNo">161</span>      LOG.debug("Skip settting last pushed sequence id for {}", tableName);<a name="line.161"></a>
-<span class="sourceLineNo">162</span>      return;<a name="line.162"></a>
-<span class="sourceLineNo">163</span>    }<a name="line.163"></a>
-<span class="sourceLineNo">164</span>    for (Pair&lt;String, Long&gt; name2Barrier : MetaTableAccessor<a name="line.164"></a>
-<span class="sourceLineNo">165</span>      .getTableEncodedRegionNameAndLastBarrier(conn, tableName)) {<a name="line.165"></a>
-<span class="sourceLineNo">166</span>      LOG.trace("Update last pushed sequence id for {}, {}", tableName, name2Barrier);<a name="line.166"></a>
-<span class="sourceLineNo">167</span>      addToMap(lastSeqIds, name2Barrier.getFirst(), name2Barrier.getSecond().longValue() - 1,<a name="line.167"></a>
-<span class="sourceLineNo">168</span>        queueStorage);<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>}<a name="line.171"></a>
+<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.37"></a>
+<span class="sourceLineNo">038</span>import org.slf4j.Logger;<a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.slf4j.LoggerFactory;<a name="line.39"></a>
+<span class="sourceLineNo">040</span><a name="line.40"></a>
+<span class="sourceLineNo">041</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.41"></a>
+<span class="sourceLineNo">042</span><a name="line.42"></a>
+<span class="sourceLineNo">043</span>/**<a name="line.43"></a>
+<span class="sourceLineNo">044</span> * The base class for all replication peer related procedure.<a name="line.44"></a>
+<span class="sourceLineNo">045</span> */<a name="line.45"></a>
+<span class="sourceLineNo">046</span>@InterfaceAudience.Private<a name="line.46"></a>
+<span class="sourceLineNo">047</span>public abstract class AbstractPeerProcedure&lt;TState&gt; extends AbstractPeerNoLockProcedure&lt;TState&gt;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>    implements PeerProcedureInterface {<a name="line.48"></a>
+<span class="sourceLineNo">049</span><a name="line.49"></a>
+<span class="sourceLineNo">050</span>  private static final Logger LOG = LoggerFactory.getLogger(AbstractPeerProcedure.class);<a name="line.50"></a>
+<span class="sourceLineNo">051</span><a name="line.51"></a>
+<span class="sourceLineNo">052</span>  protected static final int UPDATE_LAST_SEQ_ID_BATCH_SIZE = 1000;<a name="line.52"></a>
+<span class="sourceLineNo">053</span><a name="line.53"></a>
+<span class="sourceLineNo">054</span>  // The sleep interval when waiting table to be enabled or disabled.<a name="line.54"></a>
+<span class="sourceLineNo">055</span>  protected static final int SLEEP_INTERVAL_MS = 1000;<a name="line.55"></a>
+<span class="sourceLineNo">056</span><a name="line.56"></a>
+<span class="sourceLineNo">057</span>  // used to keep compatible with old client where we can only returns after updateStorage.<a name="line.57"></a>
+<span class="sourceLineNo">058</span>  protected ProcedurePrepareLatch latch;<a name="line.58"></a>
+<span class="sourceLineNo">059</span><a name="line.59"></a>
+<span class="sourceLineNo">060</span>  protected AbstractPeerProcedure() {<a name="line.60"></a>
+<span class="sourceLineNo">061</span>  }<a name="line.61"></a>
+<span class="sourceLineNo">062</span><a name="line.62"></a>
+<span class="sourceLineNo">063</span>  protected AbstractPeerProcedure(String peerId) {<a name="line.63"></a>
+<span class="sourceLineNo">064</span>    super(peerId);<a name="line.64"></a>
+<span class="sourceLineNo">065</span>    this.latch = ProcedurePrepareLatch.createLatch(2, 1);<a name="line.65"></a>
+<span class="sourceLineNo">066</span>  }<a name="line.66"></a>
+<span class="sourceLineNo">067</span><a name="line.67"></a>
+<span class="sourceLineNo">068</span>  public ProcedurePrepareLatch getLatch() {<a name="line.68"></a>
+<span class="sourceLineNo">069</span>    return latch;<a name="line.69"></a>
+<span class="sourceLineNo">070</span>  }<a name="line.70"></a>
+<span class="sourceLineNo">071</span><a name="line.71"></a>
+<span class="sourceLineNo">072</span>  @Override<a name="line.72"></a>
+<span class="sourceLineNo">073</span>  protected LockState acquireLock(MasterProcedureEnv env) {<a name="line.73"></a>
+<span class="sourceLineNo">074</span>    if (env.getProcedureScheduler().waitPeerExclusiveLock(this, peerId)) {<a name="line.74"></a>
+<span class="sourceLineNo">075</span>      return LockState.LOCK_EVENT_WAIT;<a name="line.75"></a>
+<span class="sourceLineNo">076</span>    }<a name="line.76"></a>
+<span class="sourceLineNo">077</span>    return LockState.LOCK_ACQUIRED;<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>  @Override<a name="line.80"></a>
+<span class="sourceLineNo">081</span>  protected void releaseLock(MasterProcedureEnv env) {<a name="line.81"></a>
+<span class="sourceLineNo">082</span>    env.getProcedureScheduler().wakePeerExclusiveLock(this, peerId);<a name="line.82"></a>
+<span class="sourceLineNo">083</span>  }<a name="line.83"></a>
+<span class="sourceLineNo">084</span><a name="line.84"></a>
+<span class="sourceLineNo">085</span>  @Override<a name="line.85"></a>
+<span class="sourceLineNo">086</span>  protected boolean holdLock(MasterProcedureEnv env) {<a name="line.86"></a>
+<span class="sourceLineNo">087</span>    return true;<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>  protected final void refreshPeer(MasterProcedureEnv env, PeerOperationType type) {<a name="line.90"></a>
+<span class="sourceLineNo">091</span>    addChildProcedure(env.getMasterServices().getServerManager().getOnlineServersList().stream()<a name="line.91"></a>
+<span class="sourceLineNo">092</span>      .map(sn -&gt; new RefreshPeerProcedure(peerId, type, sn)).toArray(RefreshPeerProcedure[]::new));<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>  // will be override in test to simulate error<a name="line.95"></a>
+<span class="sourceLineNo">096</span>  @VisibleForTesting<a name="line.96"></a>
+<span class="sourceLineNo">097</span>  protected void enablePeer(MasterProcedureEnv env) throws ReplicationException {<a name="line.97"></a>
+<span class="sourceLineNo">098</span>    env.getReplicationPeerManager().enablePeer(peerId);<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>  private void addToMap(Map&lt;String, Long&gt; lastSeqIds, String encodedRegionName, long barrier,<a name="line.101"></a>
+<span class="sourceLineNo">102</span>      ReplicationQueueStorage queueStorage) throws ReplicationException {<a name="line.102"></a>
+<span class="sourceLineNo">103</span>    if (barrier &gt;= 0) {<a name="line.103"></a>
+<span class="sourceLineNo">104</span>      lastSeqIds.put(encodedRegionName, barrier);<a name="line.104"></a>
+<span class="sourceLineNo">105</span>      if (lastSeqIds.size() &gt;= UPDATE_LAST_SEQ_ID_BATCH_SIZE) {<a name="line.105"></a>
+<span class="sourceLineNo">106</span>        queueStorage.setLastSequenceIds(peerId, lastSeqIds);<a name="line.106"></a>
+<span class="sourceLineNo">107</span>        lastSeqIds.clear();<a name="line.107"></a>
+<span class="sourceLineNo">108</span>      }<a name="line.108"></a>
+<span class="sourceLineNo">109</span>    }<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>  protected final void setLastPushedSequenceId(MasterProcedureEnv env,<a name="line.112"></a>
+<span class="sourceLineNo">113</span>      ReplicationPeerConfig peerConfig) throws IOException, ReplicationException {<a name="line.113"></a>
+<span class="sourceLineNo">114</span>    Map&lt;String, Long&gt; lastSeqIds = new HashMap&lt;String, Long&gt;();<a name="line.114"></a>
+<span class="sourceLineNo">115</span>    for (TableDescriptor td : env.getMasterServices().getTableDescriptors().getAll().values()) {<a name="line.115"></a>
+<span class="sourceLineNo">116</span>      if (!td.hasGlobalReplicationScope()) {<a name="line.116"></a>
+<span class="sourceLineNo">117</span>        continue;<a name="line.117"></a>
+<span class="sourceLineNo">118</span>      }<a name="line.118"></a>
+<span class="sourceLineNo">119</span>      TableName tn = td.getTableName();<a name="line.119"></a>
+<span class="sourceLineNo">120</span>      if (!peerConfig.needToReplicate(tn)) {<a name="line.120"></a>
+<span class="sourceLineNo">121</span>        continue;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>      }<a name="line.122"></a>
+<span class="sourceLineNo">123</span>      setLastPushedSequenceIdForTable(env, tn, lastSeqIds);<a name="line.123"></a>
+<span class="sourceLineNo">124</span>    }<a name="line.124"></a>
+<span class="sourceLineNo">125</span>    if (!lastSeqIds.isEmpty()) {<a name="line.125"></a>
+<span class="sourceLineNo">126</span>      env.getReplicationPeerManager().getQueueStorage().setLastSequenceIds(peerId, lastSeqIds);<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><a name="line.129"></a>
+<span class="sourceLineNo">130</span>  // If the table is currently disabling, then we need to wait until it is disabled.We will write<a name="line.130"></a>
+<span class="sourceLineNo">131</span>  // replication barrier for a disabled table. And return whether we need to update the last pushed<a name="line.131"></a>
+<span class="sourceLineNo">132</span>  // sequence id, if the table has been deleted already, i.e, we hit TableStateNotFoundException,<a name="line.132"></a>
+<span class="sourceLineNo">133</span>  // then we do not need to update last pushed sequence id for this table.<a name="line.133"></a>
+<span class="sourceLineNo">134</span>  private boolean needSetLastPushedSequenceId(TableStateManager tsm, TableName tn)<a name="line.134"></a>
+<span class="sourceLineNo">135</span>      throws IOException {<a name="line.135"></a>
+<span class="sourceLineNo">136</span>    for (;;) {<a name="line.136"></a>
+<span class="sourceLineNo">137</span>      try {<a name="line.137"></a>
+<span class="sourceLineNo">138</span>        if (!tsm.getTableState(tn).isDisabling()) {<a name="line.138"></a>
+<span class="sourceLineNo">139</span>          return true;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>        }<a name="line.140"></a>
+<span class="sourceLineNo">141</span>        Thread.sleep(SLEEP_INTERVAL_MS);<a name="line.141"></a>
+<span class="sourceLineNo">142</span>      } catch (TableStateNotFoundException e) {<a name="line.142"></a>
+<span class="sourceLineNo">143</span>        return false;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>      } catch (InterruptedException e) {<a name="line.144"></a>
+<span class="sourceLineNo">145</span>        throw (IOException) new InterruptedIOException(e.getMessage()).initCause(e);<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>  }<a name="line.148"></a>
+<span class="sourceLineNo">149</span><a name="line.149"></a>
+<span class="sourceLineNo">150</span>  // Will put the encodedRegionName-&gt;lastPushedSeqId pair into the map passed in, if the map is<a name="line.150"></a>
+<span class="sourceLineNo">151</span>  // large enough we will call queueStorage.setLastSequenceIds and clear the map. So the caller<a name="line.151"></a>
+<span class="sourceLineNo">152</span>  // should not forget to check whether the map is empty at last, if not you should call<a name="line.152"></a>
+<span class="sourceLineNo">153</span>  // queueStorage.setLastSequenceIds to write out the remaining entries in the map.<a name="line.153"></a>
+<span class="sourceLineNo">154</span>  protected final void setLastPushedSequenceIdForTable(MasterProcedureEnv env, TableName tableName,<a name="line.154"></a>
+<span class="sourceLineNo">155</span>      Map&lt;String, Long&gt; lastSeqIds) throws IOException, ReplicationException {<a name="line.155"></a>
+<span class="sourceLineNo">156</span>    TableStateManager tsm = env.getMasterServices().getTableStateManager();<a name="line.156"></a>
+<span class="sourceLineNo">157</span>    ReplicationQueueStorage queueStorage = env.getReplicationPeerManager().getQueueStorage();<a name="line.157"></a>
+<span class="sourceLineNo">158</span>    Connection conn = env.getMasterServices().getConnection();<a name="line.158"></a>
+<span class="sourceLineNo">159</span>    if (!needSetLastPushedSequenceId(tsm, tableName)) {<a name="line.159"></a>
+<span class="sourceLineNo">160</span>      LOG.debug("Skip settting last pushed sequence id for {}", tableName);<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      return;<a name="line.161"></a>
+<span class="sourceLineNo">162</span>    }<a name="line.162"></a>
+<span class="sourceLineNo">163</span>    for (Pair&lt;String, Long&gt; name2Barrier : MetaTableAccessor<a name="line.163"></a>
+<span class="sourceLineNo">164</span>      .getTableEncodedRegionNameAndLastBarrier(conn, tableName)) {<a name="line.164"></a>
+<span class="sourceLineNo">165</span>      LOG.trace("Update last pushed sequence id for {}, {}", tableName, name2Barrier);<a name="line.165"></a>
+<span class="sourceLineNo">166</span>      addToMap(lastSeqIds, name2Barrier.getFirst(), name2Barrier.getSecond().longValue() - 1,<a name="line.166"></a>
+<span class="sourceLineNo">167</span>        queueStorage);<a name="line.167"></a>
+<span class="sourceLineNo">168</span>    }<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>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
index 924031e..7799e2a 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ModifyPeerProcedure.html
@@ -38,241 +38,240 @@
 <span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.procedure2.ProcedureSuspendedException;<a name="line.30"></a>
 <span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.replication.ReplicationException;<a name="line.31"></a>
 <span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.replication.ReplicationPeerConfig;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.34"></a>
-<span class="sourceLineNo">035</span>import org.slf4j.Logger;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.slf4j.LoggerFactory;<a name="line.36"></a>
-<span class="sourceLineNo">037</span><a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.38"></a>
-<span class="sourceLineNo">039</span><a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState;<a name="line.40"></a>
-<span class="sourceLineNo">041</span><a name="line.41"></a>
-<span class="sourceLineNo">042</span>/**<a name="line.42"></a>
-<span class="sourceLineNo">043</span> * The base class for all replication peer related procedure except sync replication state<a name="line.43"></a>
-<span class="sourceLineNo">044</span> * transition.<a name="line.44"></a>
-<span class="sourceLineNo">045</span> */<a name="line.45"></a>
-<span class="sourceLineNo">046</span>@InterfaceAudience.Private<a name="line.46"></a>
-<span class="sourceLineNo">047</span>public abstract class ModifyPeerProcedure extends AbstractPeerProcedure&lt;PeerModificationState&gt; {<a name="line.47"></a>
-<span class="sourceLineNo">048</span><a name="line.48"></a>
-<span class="sourceLineNo">049</span>  private static final Logger LOG = LoggerFactory.getLogger(ModifyPeerProcedure.class);<a name="line.49"></a>
-<span class="sourceLineNo">050</span><a name="line.50"></a>
-<span class="sourceLineNo">051</span>  protected ModifyPeerProcedure() {<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>  protected ModifyPeerProcedure(String peerId) {<a name="line.54"></a>
-<span class="sourceLineNo">055</span>    super(peerId);<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>  /**<a name="line.58"></a>
-<span class="sourceLineNo">059</span>   * Called before we start the actual processing. The implementation should call the pre CP hook,<a name="line.59"></a>
-<span class="sourceLineNo">060</span>   * and also the pre-check for the peer modification.<a name="line.60"></a>
-<span class="sourceLineNo">061</span>   * &lt;p&gt;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>   * If an IOException is thrown then we will give up and mark the procedure as failed directly. If<a name="line.62"></a>
-<span class="sourceLineNo">063</span>   * all checks passes then the procedure can not be rolled back any more.<a name="line.63"></a>
-<span class="sourceLineNo">064</span>   */<a name="line.64"></a>
-<span class="sourceLineNo">065</span>  protected abstract void prePeerModification(MasterProcedureEnv env)<a name="line.65"></a>
-<span class="sourceLineNo">066</span>      throws IOException, ReplicationException, InterruptedException;<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span>  protected abstract void updatePeerStorage(MasterProcedureEnv env) throws ReplicationException;<a name="line.68"></a>
-<span class="sourceLineNo">069</span><a name="line.69"></a>
-<span class="sourceLineNo">070</span>  /**<a name="line.70"></a>
-<span class="sourceLineNo">071</span>   * Called before we finish the procedure. The implementation can do some logging work, and also<a name="line.71"></a>
-<span class="sourceLineNo">072</span>   * call the coprocessor hook if any.<a name="line.72"></a>
-<span class="sourceLineNo">073</span>   * &lt;p&gt;<a name="line.73"></a>
-<span class="sourceLineNo">074</span>   * Notice that, since we have already done the actual work, throwing {@code IOException} here will<a name="line.74"></a>
-<span class="sourceLineNo">075</span>   * not fail this procedure, we will just ignore it and finish the procedure as suceeded. If<a name="line.75"></a>
-<span class="sourceLineNo">076</span>   * {@code ReplicationException} is thrown we will retry since this usually means we fails to<a name="line.76"></a>
-<span class="sourceLineNo">077</span>   * update the peer storage.<a name="line.77"></a>
-<span class="sourceLineNo">078</span>   */<a name="line.78"></a>
-<span class="sourceLineNo">079</span>  protected abstract void postPeerModification(MasterProcedureEnv env)<a name="line.79"></a>
-<span class="sourceLineNo">080</span>      throws IOException, ReplicationException;<a name="line.80"></a>
-<span class="sourceLineNo">081</span><a name="line.81"></a>
-<span class="sourceLineNo">082</span>  protected void releaseLatch(MasterProcedureEnv env) {<a name="line.82"></a>
-<span class="sourceLineNo">083</span>    ProcedurePrepareLatch.releaseLatch(latch, this);<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>   * Implementation class can override this method. By default we will jump to<a name="line.87"></a>
-<span class="sourceLineNo">088</span>   * POST_PEER_MODIFICATION and finish the procedure.<a name="line.88"></a>
-<span class="sourceLineNo">089</span>   */<a name="line.89"></a>
-<span class="sourceLineNo">090</span>  protected PeerModificationState nextStateAfterRefresh() {<a name="line.90"></a>
-<span class="sourceLineNo">091</span>    return PeerModificationState.POST_PEER_MODIFICATION;<a name="line.91"></a>
-<span class="sourceLineNo">092</span>  }<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>   * The implementation class should override this method if the procedure may enter the serial<a name="line.95"></a>
-<span class="sourceLineNo">096</span>   * related states.<a name="line.96"></a>
-<span class="sourceLineNo">097</span>   */<a name="line.97"></a>
-<span class="sourceLineNo">098</span>  protected boolean enablePeerBeforeFinish() {<a name="line.98"></a>
-<span class="sourceLineNo">099</span>    throw new UnsupportedOperationException();<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>  protected ReplicationPeerConfig getOldPeerConfig() {<a name="line.102"></a>
-<span class="sourceLineNo">103</span>    return null;<a name="line.103"></a>
-<span class="sourceLineNo">104</span>  }<a name="line.104"></a>
-<span class="sourceLineNo">105</span><a name="line.105"></a>
-<span class="sourceLineNo">106</span>  protected ReplicationPeerConfig getNewPeerConfig() {<a name="line.106"></a>
-<span class="sourceLineNo">107</span>    throw new UnsupportedOperationException();<a name="line.107"></a>
-<span class="sourceLineNo">108</span>  }<a name="line.108"></a>
-<span class="sourceLineNo">109</span><a name="line.109"></a>
-<span class="sourceLineNo">110</span>  protected void updateLastPushedSequenceIdForSerialPeer(MasterProcedureEnv env)<a name="line.110"></a>
-<span class="sourceLineNo">111</span>      throws IOException, ReplicationException {<a name="line.111"></a>
-<span class="sourceLineNo">112</span>    throw new UnsupportedOperationException();<a name="line.112"></a>
-<span class="sourceLineNo">113</span>  }<a name="line.113"></a>
-<span class="sourceLineNo">114</span><a name="line.114"></a>
-<span class="sourceLineNo">115</span>  // If the table is in enabling state, we need to wait until it is enabled and then reopen all its<a name="line.115"></a>
-<span class="sourceLineNo">116</span>  // regions.<a name="line.116"></a>
-<span class="sourceLineNo">117</span>  private boolean needReopen(TableStateManager tsm, TableName tn) throws IOException {<a name="line.117"></a>
-<span class="sourceLineNo">118</span>    for (;;) {<a name="line.118"></a>
-<span class="sourceLineNo">119</span>      try {<a name="line.119"></a>
-<span class="sourceLineNo">120</span>        TableState state = tsm.getTableState(tn);<a name="line.120"></a>
-<span class="sourceLineNo">121</span>        if (state.isEnabled()) {<a name="line.121"></a>
-<span class="sourceLineNo">122</span>          return true;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>        }<a name="line.123"></a>
-<span class="sourceLineNo">124</span>        if (!state.isEnabling()) {<a name="line.124"></a>
-<span class="sourceLineNo">125</span>          return false;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>        }<a name="line.126"></a>
-<span class="sourceLineNo">127</span>        Thread.sleep(SLEEP_INTERVAL_MS);<a name="line.127"></a>
-<span class="sourceLineNo">128</span>      } catch (TableStateNotFoundException e) {<a name="line.128"></a>
-<span class="sourceLineNo">129</span>        return false;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>      } catch (InterruptedException e) {<a name="line.130"></a>
-<span class="sourceLineNo">131</span>        throw (IOException) new InterruptedIOException(e.getMessage()).initCause(e);<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>  }<a name="line.134"></a>
-<span class="sourceLineNo">135</span><a name="line.135"></a>
-<span class="sourceLineNo">136</span>  // will be override in test to simulate error<a name="line.136"></a>
-<span class="sourceLineNo">137</span>  @VisibleForTesting<a name="line.137"></a>
-<span class="sourceLineNo">138</span>  protected void reopenRegions(MasterProcedureEnv env) throws IOException {<a name="line.138"></a>
-<span class="sourceLineNo">139</span>    ReplicationPeerConfig peerConfig = getNewPeerConfig();<a name="line.139"></a>
-<span class="sourceLineNo">140</span>    ReplicationPeerConfig oldPeerConfig = getOldPeerConfig();<a name="line.140"></a>
-<span class="sourceLineNo">141</span>    TableStateManager tsm = env.getMasterServices().getTableStateManager();<a name="line.141"></a>
-<span class="sourceLineNo">142</span>    for (TableDescriptor td : env.getMasterServices().getTableDescriptors().getAll().values()) {<a name="line.142"></a>
-<span class="sourceLineNo">143</span>      if (!td.hasGlobalReplicationScope()) {<a name="line.143"></a>
-<span class="sourceLineNo">144</span>        continue;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>      }<a name="line.145"></a>
-<span class="sourceLineNo">146</span>      TableName tn = td.getTableName();<a name="line.146"></a>
-<span class="sourceLineNo">147</span>      if (!ReplicationUtils.contains(peerConfig, tn)) {<a name="line.147"></a>
-<span class="sourceLineNo">148</span>        continue;<a name="line.148"></a>
-<span class="sourceLineNo">149</span>      }<a name="line.149"></a>
-<span class="sourceLineNo">150</span>      if (oldPeerConfig != null &amp;&amp; oldPeerConfig.isSerial() &amp;&amp;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>        ReplicationUtils.contains(oldPeerConfig, tn)) {<a name="line.151"></a>
-<span class="sourceLineNo">152</span>        continue;<a name="line.152"></a>
-<span class="sourceLineNo">153</span>      }<a name="line.153"></a>
-<span class="sourceLineNo">154</span>      if (needReopen(tsm, tn)) {<a name="line.154"></a>
-<span class="sourceLineNo">155</span>        addChildProcedure(new ReopenTableRegionsProcedure(tn));<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>  }<a name="line.158"></a>
-<span class="sourceLineNo">159</span><a name="line.159"></a>
-<span class="sourceLineNo">160</span>  @Override<a name="line.160"></a>
-<span class="sourceLineNo">161</span>  protected Flow executeFromState(MasterProcedureEnv env, PeerModificationState state)<a name="line.161"></a>
-<span class="sourceLineNo">162</span>      throws ProcedureSuspendedException, InterruptedException {<a name="line.162"></a>
-<span class="sourceLineNo">163</span>    switch (state) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span>      case PRE_PEER_MODIFICATION:<a name="line.164"></a>
-<span class="sourceLineNo">165</span>        try {<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          prePeerModification(env);<a name="line.166"></a>
-<span class="sourceLineNo">167</span>        } catch (IOException e) {<a name="line.167"></a>
-<span class="sourceLineNo">168</span>          LOG.warn("{} failed to call pre CP hook or the pre check is failed for peer {}, " +<a name="line.168"></a>
-<span class="sourceLineNo">169</span>            "mark the procedure as failure and give up", getClass().getName(), peerId, e);<a name="line.169"></a>
-<span class="sourceLineNo">170</span>          setFailure("master-" + getPeerOperationType().name().toLowerCase() + "-peer", e);<a name="line.170"></a>
-<span class="sourceLineNo">171</span>          releaseLatch(env);<a name="line.171"></a>
-<span class="sourceLineNo">172</span>          return Flow.NO_MORE_STATE;<a name="line.172"></a>
-<span class="sourceLineNo">173</span>        } catch (ReplicationException e) {<a name="line.173"></a>
-<span class="sourceLineNo">174</span>          throw suspend(env.getMasterConfiguration(),<a name="line.174"></a>
-<span class="sourceLineNo">175</span>            backoff -&gt; LOG.warn("{} failed to call prePeerModification for peer {}, sleep {} secs",<a name="line.175"></a>
-<span class="sourceLineNo">176</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.176"></a>
-<span class="sourceLineNo">177</span>        }<a name="line.177"></a>
-<span class="sourceLineNo">178</span>        resetRetry();<a name="line.178"></a>
-<span class="sourceLineNo">179</span>        setNextState(PeerModificationState.UPDATE_PEER_STORAGE);<a name="line.179"></a>
-<span class="sourceLineNo">180</span>        return Flow.HAS_MORE_STATE;<a name="line.180"></a>
-<span class="sourceLineNo">181</span>      case UPDATE_PEER_STORAGE:<a name="line.181"></a>
-<span class="sourceLineNo">182</span>        try {<a name="line.182"></a>
-<span class="sourceLineNo">183</span>          updatePeerStorage(env);<a name="line.183"></a>
-<span class="sourceLineNo">184</span>        } catch (ReplicationException e) {<a name="line.184"></a>
-<span class="sourceLineNo">185</span>          throw suspend(env.getMasterConfiguration(),<a name="line.185"></a>
-<span class="sourceLineNo">186</span>            backoff -&gt; LOG.warn("{} update peer storage for peer {} failed, sleep {} secs",<a name="line.186"></a>
-<span class="sourceLineNo">187</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.187"></a>
-<span class="sourceLineNo">188</span>        }<a name="line.188"></a>
-<span class="sourceLineNo">189</span>        resetRetry();<a name="line.189"></a>
-<span class="sourceLineNo">190</span>        setNextState(PeerModificationState.REFRESH_PEER_ON_RS);<a name="line.190"></a>
-<span class="sourceLineNo">191</span>        return Flow.HAS_MORE_STATE;<a name="line.191"></a>
-<span class="sourceLineNo">192</span>      case REFRESH_PEER_ON_RS:<a name="line.192"></a>
-<span class="sourceLineNo">193</span>        refreshPeer(env, getPeerOperationType());<a name="line.193"></a>
-<span class="sourceLineNo">194</span>        setNextState(nextStateAfterRefresh());<a name="line.194"></a>
-<span class="sourceLineNo">195</span>        return Flow.HAS_MORE_STATE;<a name="line.195"></a>
-<span class="sourceLineNo">196</span>      case SERIAL_PEER_REOPEN_REGIONS:<a name="line.196"></a>
-<span class="sourceLineNo">197</span>        try {<a name="line.197"></a>
-<span class="sourceLineNo">198</span>          reopenRegions(env);<a name="line.198"></a>
-<span class="sourceLineNo">199</span>        } catch (Exception e) {<a name="line.199"></a>
-<span class="sourceLineNo">200</span>          throw suspend(env.getMasterConfiguration(),<a name="line.200"></a>
-<span class="sourceLineNo">201</span>            backoff -&gt; LOG.warn("{} reopen regions for peer {} failed,  sleep {} secs",<a name="line.201"></a>
-<span class="sourceLineNo">202</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.202"></a>
-<span class="sourceLineNo">203</span>        }<a name="line.203"></a>
-<span class="sourceLineNo">204</span>        resetRetry();<a name="line.204"></a>
-<span class="sourceLineNo">205</span>        setNextState(PeerModificationState.SERIAL_PEER_UPDATE_LAST_PUSHED_SEQ_ID);<a name="line.205"></a>
-<span class="sourceLineNo">206</span>        return Flow.HAS_MORE_STATE;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>      case SERIAL_PEER_UPDATE_LAST_PUSHED_SEQ_ID:<a name="line.207"></a>
-<span class="sourceLineNo">208</span>        try {<a name="line.208"></a>
-<span class="sourceLineNo">209</span>          updateLastPushedSequenceIdForSerialPeer(env);<a name="line.209"></a>
-<span class="sourceLineNo">210</span>        } catch (Exception e) {<a name="line.210"></a>
-<span class="sourceLineNo">211</span>          throw suspend(env.getMasterConfiguration(),<a name="line.211"></a>
-<span class="sourceLineNo">212</span>            backoff -&gt; LOG.warn("{} set last sequence id for peer {} failed,  sleep {} secs",<a name="line.212"></a>
-<span class="sourceLineNo">213</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.213"></a>
-<span class="sourceLineNo">214</span>        }<a name="line.214"></a>
-<span class="sourceLineNo">215</span>        resetRetry();<a name="line.215"></a>
-<span class="sourceLineNo">216</span>        setNextState(enablePeerBeforeFinish() ? PeerModificationState.SERIAL_PEER_SET_PEER_ENABLED<a name="line.216"></a>
-<span class="sourceLineNo">217</span>          : PeerModificationState.POST_PEER_MODIFICATION);<a name="line.217"></a>
-<span class="sourceLineNo">218</span>        return Flow.HAS_MORE_STATE;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>      case SERIAL_PEER_SET_PEER_ENABLED:<a name="line.219"></a>
-<span class="sourceLineNo">220</span>        try {<a name="line.220"></a>
-<span class="sourceLineNo">221</span>          enablePeer(env);<a name="line.221"></a>
-<span class="sourceLineNo">222</span>        } catch (ReplicationException e) {<a name="line.222"></a>
-<span class="sourceLineNo">223</span>          throw suspend(env.getMasterConfiguration(),<a name="line.223"></a>
-<span class="sourceLineNo">224</span>            backoff -&gt; LOG.warn("{} enable peer before finish for peer {} failed,  sleep {} secs",<a name="line.224"></a>
-<span class="sourceLineNo">225</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.225"></a>
-<span class="sourceLineNo">226</span>        }<a name="line.226"></a>
-<span class="sourceLineNo">227</span>        resetRetry();<a name="line.227"></a>
-<span class="sourceLineNo">228</span>        setNextState(PeerModificationState.SERIAL_PEER_ENABLE_PEER_REFRESH_PEER_ON_RS);<a name="line.228"></a>
-<span class="sourceLineNo">229</span>        return Flow.HAS_MORE_STATE;<a name="line.229"></a>
-<span class="sourceLineNo">230</span>      case SERIAL_PEER_ENABLE_PEER_REFRESH_PEER_ON_RS:<a name="line.230"></a>
-<span class="sourceLineNo">231</span>        refreshPeer(env, PeerOperationType.ENABLE);<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        setNextState(PeerModificationState.POST_PEER_MODIFICATION);<a name="line.232"></a>
-<span class="sourceLineNo">233</span>        return Flow.HAS_MORE_STATE;<a name="line.233"></a>
-<span class="sourceLineNo">234</span>      case POST_PEER_MODIFICATION:<a name="line.234"></a>
-<span class="sourceLineNo">235</span>        try {<a name="line.235"></a>
-<span class="sourceLineNo">236</span>          postPeerModification(env);<a name="line.236"></a>
-<span class="sourceLineNo">237</span>        } catch (ReplicationException e) {<a name="line.237"></a>
-<span class="sourceLineNo">238</span>          throw suspend(env.getMasterConfiguration(),<a name="line.238"></a>
-<span class="sourceLineNo">239</span>            backoff -&gt; LOG.warn(<a name="line.239"></a>
-<span class="sourceLineNo">240</span>              "{} failed to call postPeerModification for peer {},  sleep {} secs",<a name="line.240"></a>
-<span class="sourceLineNo">241</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        } catch (IOException e) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>          LOG.warn("{} failed to call post CP hook for peer {}, " +<a name="line.243"></a>
-<span class="sourceLineNo">244</span>            "ignore since the procedure has already done", getClass().getName(), peerId, e);<a name="line.244"></a>
-<span class="sourceLineNo">245</span>        }<a name="line.245"></a>
-<span class="sourceLineNo">246</span>        releaseLatch(env);<a name="line.246"></a>
-<span class="sourceLineNo">247</span>        return Flow.NO_MORE_STATE;<a name="line.247"></a>
-<span class="sourceLineNo">248</span>      default:<a name="line.248"></a>
-<span class="sourceLineNo">249</span>        throw new UnsupportedOperationException("unhandled state=" + state);<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><a name="line.252"></a>
-<span class="sourceLineNo">253</span>  @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>  protected PeerModificationState getState(int stateId) {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>    return PeerModificationState.forNumber(stateId);<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>  @Override<a name="line.258"></a>
-<span class="sourceLineNo">259</span>  protected int getStateId(PeerModificationState state) {<a name="line.259"></a>
-<span class="sourceLineNo">260</span>    return state.getNumber();<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>  @Override<a name="line.263"></a>
-<span class="sourceLineNo">264</span>  protected PeerModificationState getInitialState() {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>    return PeerModificationState.PRE_PEER_MODIFICATION;<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">033</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.slf4j.Logger;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.slf4j.LoggerFactory;<a name="line.35"></a>
+<span class="sourceLineNo">036</span><a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.37"></a>
+<span class="sourceLineNo">038</span><a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.MasterProcedureProtos.PeerModificationState;<a name="line.39"></a>
+<span class="sourceLineNo">040</span><a name="line.40"></a>
+<span class="sourceLineNo">041</span>/**<a name="line.41"></a>
+<span class="sourceLineNo">042</span> * The base class for all replication peer related procedure except sync replication state<a name="line.42"></a>
+<span class="sourceLineNo">043</span> * transition.<a name="line.43"></a>
+<span class="sourceLineNo">044</span> */<a name="line.44"></a>
+<span class="sourceLineNo">045</span>@InterfaceAudience.Private<a name="line.45"></a>
+<span class="sourceLineNo">046</span>public abstract class ModifyPeerProcedure extends AbstractPeerProcedure&lt;PeerModificationState&gt; {<a name="line.46"></a>
+<span class="sourceLineNo">047</span><a name="line.47"></a>
+<span class="sourceLineNo">048</span>  private static final Logger LOG = LoggerFactory.getLogger(ModifyPeerProcedure.class);<a name="line.48"></a>
+<span class="sourceLineNo">049</span><a name="line.49"></a>
+<span class="sourceLineNo">050</span>  protected ModifyPeerProcedure() {<a name="line.50"></a>
+<span class="sourceLineNo">051</span>  }<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span>  protected ModifyPeerProcedure(String peerId) {<a name="line.53"></a>
+<span class="sourceLineNo">054</span>    super(peerId);<a name="line.54"></a>
+<span class="sourceLineNo">055</span>  }<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>   * Called before we start the actual processing. The implementation should call the pre CP hook,<a name="line.58"></a>
+<span class="sourceLineNo">059</span>   * and also the pre-check for the peer modification.<a name="line.59"></a>
+<span class="sourceLineNo">060</span>   * &lt;p&gt;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>   * If an IOException is thrown then we will give up and mark the procedure as failed directly. If<a name="line.61"></a>
+<span class="sourceLineNo">062</span>   * all checks passes then the procedure can not be rolled back any more.<a name="line.62"></a>
+<span class="sourceLineNo">063</span>   */<a name="line.63"></a>
+<span class="sourceLineNo">064</span>  protected abstract void prePeerModification(MasterProcedureEnv env)<a name="line.64"></a>
+<span class="sourceLineNo">065</span>      throws IOException, ReplicationException, InterruptedException;<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span>  protected abstract void updatePeerStorage(MasterProcedureEnv env) throws ReplicationException;<a name="line.67"></a>
+<span class="sourceLineNo">068</span><a name="line.68"></a>
+<span class="sourceLineNo">069</span>  /**<a name="line.69"></a>
+<span class="sourceLineNo">070</span>   * Called before we finish the procedure. The implementation can do some logging work, and also<a name="line.70"></a>
+<span class="sourceLineNo">071</span>   * call the coprocessor hook if any.<a name="line.71"></a>
+<span class="sourceLineNo">072</span>   * &lt;p&gt;<a name="line.72"></a>
+<span class="sourceLineNo">073</span>   * Notice that, since we have already done the actual work, throwing {@code IOException} here will<a name="line.73"></a>
+<span class="sourceLineNo">074</span>   * not fail this procedure, we will just ignore it and finish the procedure as suceeded. If<a name="line.74"></a>
+<span class="sourceLineNo">075</span>   * {@code ReplicationException} is thrown we will retry since this usually means we fails to<a name="line.75"></a>
+<span class="sourceLineNo">076</span>   * update the peer storage.<a name="line.76"></a>
+<span class="sourceLineNo">077</span>   */<a name="line.77"></a>
+<span class="sourceLineNo">078</span>  protected abstract void postPeerModification(MasterProcedureEnv env)<a name="line.78"></a>
+<span class="sourceLineNo">079</span>      throws IOException, ReplicationException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span><a name="line.80"></a>
+<span class="sourceLineNo">081</span>  protected void releaseLatch(MasterProcedureEnv env) {<a name="line.81"></a>
+<span class="sourceLineNo">082</span>    ProcedurePrepareLatch.releaseLatch(latch, this);<a name="line.82"></a>
+<span class="sourceLineNo">083</span>  }<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>   * Implementation class can override this method. By default we will jump to<a name="line.86"></a>
+<span class="sourceLineNo">087</span>   * POST_PEER_MODIFICATION and finish the procedure.<a name="line.87"></a>
+<span class="sourceLineNo">088</span>   */<a name="line.88"></a>
+<span class="sourceLineNo">089</span>  protected PeerModificationState nextStateAfterRefresh() {<a name="line.89"></a>
+<span class="sourceLineNo">090</span>    return PeerModificationState.POST_PEER_MODIFICATION;<a name="line.90"></a>
+<span class="sourceLineNo">091</span>  }<a name="line.91"></a>
+<span class="sourceLineNo">092</span><a name="line.92"></a>
+<span class="sourceLineNo">093</span>  /**<a name="line.93"></a>
+<span class="sourceLineNo">094</span>   * The implementation class should override this method if the procedure may enter the serial<a name="line.94"></a>
+<span class="sourceLineNo">095</span>   * related states.<a name="line.95"></a>
+<span class="sourceLineNo">096</span>   */<a name="line.96"></a>
+<span class="sourceLineNo">097</span>  protected boolean enablePeerBeforeFinish() {<a name="line.97"></a>
+<span class="sourceLineNo">098</span>    throw new UnsupportedOperationException();<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>  protected ReplicationPeerConfig getOldPeerConfig() {<a name="line.101"></a>
+<span class="sourceLineNo">102</span>    return null;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>  }<a name="line.103"></a>
+<span class="sourceLineNo">104</span><a name="line.104"></a>
+<span class="sourceLineNo">105</span>  protected ReplicationPeerConfig getNewPeerConfig() {<a name="line.105"></a>
+<span class="sourceLineNo">106</span>    throw new UnsupportedOperationException();<a name="line.106"></a>
+<span class="sourceLineNo">107</span>  }<a name="line.107"></a>
+<span class="sourceLineNo">108</span><a name="line.108"></a>
+<span class="sourceLineNo">109</span>  protected void updateLastPushedSequenceIdForSerialPeer(MasterProcedureEnv env)<a name="line.109"></a>
+<span class="sourceLineNo">110</span>      throws IOException, ReplicationException {<a name="line.110"></a>
+<span class="sourceLineNo">111</span>    throw new UnsupportedOperationException();<a name="line.111"></a>
+<span class="sourceLineNo">112</span>  }<a name="line.112"></a>
+<span class="sourceLineNo">113</span><a name="line.113"></a>
+<span class="sourceLineNo">114</span>  // If the table is in enabling state, we need to wait until it is enabled and then reopen all its<a name="line.114"></a>
+<span class="sourceLineNo">115</span>  // regions.<a name="line.115"></a>
+<span class="sourceLineNo">116</span>  private boolean needReopen(TableStateManager tsm, TableName tn) throws IOException {<a name="line.116"></a>
+<span class="sourceLineNo">117</span>    for (;;) {<a name="line.117"></a>
+<span class="sourceLineNo">118</span>      try {<a name="line.118"></a>
+<span class="sourceLineNo">119</span>        TableState state = tsm.getTableState(tn);<a name="line.119"></a>
+<span class="sourceLineNo">120</span>        if (state.isEnabled()) {<a name="line.120"></a>
+<span class="sourceLineNo">121</span>          return true;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>        }<a name="line.122"></a>
+<span class="sourceLineNo">123</span>        if (!state.isEnabling()) {<a name="line.123"></a>
+<span class="sourceLineNo">124</span>          return false;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>        }<a name="line.125"></a>
+<span class="sourceLineNo">126</span>        Thread.sleep(SLEEP_INTERVAL_MS);<a name="line.126"></a>
+<span class="sourceLineNo">127</span>      } catch (TableStateNotFoundException e) {<a name="line.127"></a>
+<span class="sourceLineNo">128</span>        return false;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>      } catch (InterruptedException e) {<a name="line.129"></a>
+<span class="sourceLineNo">130</span>        throw (IOException) new InterruptedIOException(e.getMessage()).initCause(e);<a name="line.130"></a>
+<span class="sourceLineNo">131</span>      }<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><a name="line.134"></a>
+<span class="sourceLineNo">135</span>  // will be override in test to simulate error<a name="line.135"></a>
+<span class="sourceLineNo">136</span>  @VisibleForTesting<a name="line.136"></a>
+<span class="sourceLineNo">137</span>  protected void reopenRegions(MasterProcedureEnv env) throws IOException {<a name="line.137"></a>
+<span class="sourceLineNo">138</span>    ReplicationPeerConfig peerConfig = getNewPeerConfig();<a name="line.138"></a>
+<span class="sourceLineNo">139</span>    ReplicationPeerConfig oldPeerConfig = getOldPeerConfig();<a name="line.139"></a>
+<span class="sourceLineNo">140</span>    TableStateManager tsm = env.getMasterServices().getTableStateManager();<a name="line.140"></a>
+<span class="sourceLineNo">141</span>    for (TableDescriptor td : env.getMasterServices().getTableDescriptors().getAll().values()) {<a name="line.141"></a>
+<span class="sourceLineNo">142</span>      if (!td.hasGlobalReplicationScope()) {<a name="line.142"></a>
+<span class="sourceLineNo">143</span>        continue;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>      }<a name="line.144"></a>
+<span class="sourceLineNo">145</span>      TableName tn = td.getTableName();<a name="line.145"></a>
+<span class="sourceLineNo">146</span>      if (!peerConfig.needToReplicate(tn)) {<a name="line.146"></a>
+<span class="sourceLineNo">147</span>        continue;<a name="line.147"></a>
+<span class="sourceLineNo">148</span>      }<a name="line.148"></a>
+<span class="sourceLineNo">149</span>      if (oldPeerConfig != null &amp;&amp; oldPeerConfig.isSerial() &amp;&amp;<a name="line.149"></a>
+<span class="sourceLineNo">150</span>        oldPeerConfig.needToReplicate(tn)) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span>        continue;<a name="line.151"></a>
+<span class="sourceLineNo">152</span>      }<a name="line.152"></a>
+<span class="sourceLineNo">153</span>      if (needReopen(tsm, tn)) {<a name="line.153"></a>
+<span class="sourceLineNo">154</span>        addChildProcedure(new ReopenTableRegionsProcedure(tn));<a name="line.154"></a>
+<span class="sourceLineNo">155</span>      }<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><a name="line.158"></a>
+<span class="sourceLineNo">159</span>  @Override<a name="line.159"></a>
+<span class="sourceLineNo">160</span>  protected Flow executeFromState(MasterProcedureEnv env, PeerModificationState state)<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      throws ProcedureSuspendedException, InterruptedException {<a name="line.161"></a>
+<span class="sourceLineNo">162</span>    switch (state) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span>      case PRE_PEER_MODIFICATION:<a name="line.163"></a>
+<span class="sourceLineNo">164</span>        try {<a name="line.164"></a>
+<span class="sourceLineNo">165</span>          prePeerModification(env);<a name="line.165"></a>
+<span class="sourceLineNo">166</span>        } catch (IOException e) {<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          LOG.warn("{} failed to call pre CP hook or the pre check is failed for peer {}, " +<a name="line.167"></a>
+<span class="sourceLineNo">168</span>            "mark the procedure as failure and give up", getClass().getName(), peerId, e);<a name="line.168"></a>
+<span class="sourceLineNo">169</span>          setFailure("master-" + getPeerOperationType().name().toLowerCase() + "-peer", e);<a name="line.169"></a>
+<span class="sourceLineNo">170</span>          releaseLatch(env);<a name="line.170"></a>
+<span class="sourceLineNo">171</span>          return Flow.NO_MORE_STATE;<a name="line.171"></a>
+<span class="sourceLineNo">172</span>        } catch (ReplicationException e) {<a name="line.172"></a>
+<span class="sourceLineNo">173</span>          throw suspend(env.getMasterConfiguration(),<a name="line.173"></a>
+<span class="sourceLineNo">174</span>            backoff -&gt; LOG.warn("{} failed to call prePeerModification for peer {}, sleep {} secs",<a name="line.174"></a>
+<span class="sourceLineNo">175</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.175"></a>
+<span class="sourceLineNo">176</span>        }<a name="line.176"></a>
+<span class="sourceLineNo">177</span>        resetRetry();<a name="line.177"></a>
+<span class="sourceLineNo">178</span>        setNextState(PeerModificationState.UPDATE_PEER_STORAGE);<a name="line.178"></a>
+<span class="sourceLineNo">179</span>        return Flow.HAS_MORE_STATE;<a name="line.179"></a>
+<span class="sourceLineNo">180</span>      case UPDATE_PEER_STORAGE:<a name="line.180"></a>
+<span class="sourceLineNo">181</span>        try {<a name="line.181"></a>
+<span class="sourceLineNo">182</span>          updatePeerStorage(env);<a name="line.182"></a>
+<span class="sourceLineNo">183</span>        } catch (ReplicationException e) {<a name="line.183"></a>
+<span class="sourceLineNo">184</span>          throw suspend(env.getMasterConfiguration(),<a name="line.184"></a>
+<span class="sourceLineNo">185</span>            backoff -&gt; LOG.warn("{} update peer storage for peer {} failed, sleep {} secs",<a name="line.185"></a>
+<span class="sourceLineNo">186</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.186"></a>
+<span class="sourceLineNo">187</span>        }<a name="line.187"></a>
+<span class="sourceLineNo">188</span>        resetRetry();<a name="line.188"></a>
+<span class="sourceLineNo">189</span>        setNextState(PeerModificationState.REFRESH_PEER_ON_RS);<a name="line.189"></a>
+<span class="sourceLineNo">190</span>        return Flow.HAS_MORE_STATE;<a name="line.190"></a>
+<span class="sourceLineNo">191</span>      case REFRESH_PEER_ON_RS:<a name="line.191"></a>
+<span class="sourceLineNo">192</span>        refreshPeer(env, getPeerOperationType());<a name="line.192"></a>
+<span class="sourceLineNo">193</span>        setNextState(nextStateAfterRefresh());<a name="line.193"></a>
+<span class="sourceLineNo">194</span>        return Flow.HAS_MORE_STATE;<a name="line.194"></a>
+<span class="sourceLineNo">195</span>      case SERIAL_PEER_REOPEN_REGIONS:<a name="line.195"></a>
+<span class="sourceLineNo">196</span>        try {<a name="line.196"></a>
+<span class="sourceLineNo">197</span>          reopenRegions(env);<a name="line.197"></a>
+<span class="sourceLineNo">198</span>        } catch (Exception e) {<a name="line.198"></a>
+<span class="sourceLineNo">199</span>          throw suspend(env.getMasterConfiguration(),<a name="line.199"></a>
+<span class="sourceLineNo">200</span>            backoff -&gt; LOG.warn("{} reopen regions for peer {} failed,  sleep {} secs",<a name="line.200"></a>
+<span class="sourceLineNo">201</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.201"></a>
+<span class="sourceLineNo">202</span>        }<a name="line.202"></a>
+<span class="sourceLineNo">203</span>        resetRetry();<a name="line.203"></a>
+<span class="sourceLineNo">204</span>        setNextState(PeerModificationState.SERIAL_PEER_UPDATE_LAST_PUSHED_SEQ_ID);<a name="line.204"></a>
+<span class="sourceLineNo">205</span>        return Flow.HAS_MORE_STATE;<a name="line.205"></a>
+<span class="sourceLineNo">206</span>      case SERIAL_PEER_UPDATE_LAST_PUSHED_SEQ_ID:<a name="line.206"></a>
+<span class="sourceLineNo">207</span>        try {<a name="line.207"></a>
+<span class="sourceLineNo">208</span>          updateLastPushedSequenceIdForSerialPeer(env);<a name="line.208"></a>
+<span class="sourceLineNo">209</span>        } catch (Exception e) {<a name="line.209"></a>
+<span class="sourceLineNo">210</span>          throw suspend(env.getMasterConfiguration(),<a name="line.210"></a>
+<span class="sourceLineNo">211</span>            backoff -&gt; LOG.warn("{} set last sequence id for peer {} failed,  sleep {} secs",<a name="line.211"></a>
+<span class="sourceLineNo">212</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.212"></a>
+<span class="sourceLineNo">213</span>        }<a name="line.213"></a>
+<span class="sourceLineNo">214</span>        resetRetry();<a name="line.214"></a>
+<span class="sourceLineNo">215</span>        setNextState(enablePeerBeforeFinish() ? PeerModificationState.SERIAL_PEER_SET_PEER_ENABLED<a name="line.215"></a>
+<span class="sourceLineNo">216</span>          : PeerModificationState.POST_PEER_MODIFICATION);<a name="line.216"></a>
+<span class="sourceLineNo">217</span>        return Flow.HAS_MORE_STATE;<a name="line.217"></a>
+<span class="sourceLineNo">218</span>      case SERIAL_PEER_SET_PEER_ENABLED:<a name="line.218"></a>
+<span class="sourceLineNo">219</span>        try {<a name="line.219"></a>
+<span class="sourceLineNo">220</span>          enablePeer(env);<a name="line.220"></a>
+<span class="sourceLineNo">221</span>        } catch (ReplicationException e) {<a name="line.221"></a>
+<span class="sourceLineNo">222</span>          throw suspend(env.getMasterConfiguration(),<a name="line.222"></a>
+<span class="sourceLineNo">223</span>            backoff -&gt; LOG.warn("{} enable peer before finish for peer {} failed,  sleep {} secs",<a name="line.223"></a>
+<span class="sourceLineNo">224</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.224"></a>
+<span class="sourceLineNo">225</span>        }<a name="line.225"></a>
+<span class="sourceLineNo">226</span>        resetRetry();<a name="line.226"></a>
+<span class="sourceLineNo">227</span>        setNextState(PeerModificationState.SERIAL_PEER_ENABLE_PEER_REFRESH_PEER_ON_RS);<a name="line.227"></a>
+<span class="sourceLineNo">228</span>        return Flow.HAS_MORE_STATE;<a name="line.228"></a>
+<span class="sourceLineNo">229</span>      case SERIAL_PEER_ENABLE_PEER_REFRESH_PEER_ON_RS:<a name="line.229"></a>
+<span class="sourceLineNo">230</span>        refreshPeer(env, PeerOperationType.ENABLE);<a name="line.230"></a>
+<span class="sourceLineNo">231</span>        setNextState(PeerModificationState.POST_PEER_MODIFICATION);<a name="line.231"></a>
+<span class="sourceLineNo">232</span>        return Flow.HAS_MORE_STATE;<a name="line.232"></a>
+<span class="sourceLineNo">233</span>      case POST_PEER_MODIFICATION:<a name="line.233"></a>
+<span class="sourceLineNo">234</span>        try {<a name="line.234"></a>
+<span class="sourceLineNo">235</span>          postPeerModification(env);<a name="line.235"></a>
+<span class="sourceLineNo">236</span>        } catch (ReplicationException e) {<a name="line.236"></a>
+<span class="sourceLineNo">237</span>          throw suspend(env.getMasterConfiguration(),<a name="line.237"></a>
+<span class="sourceLineNo">238</span>            backoff -&gt; LOG.warn(<a name="line.238"></a>
+<span class="sourceLineNo">239</span>              "{} failed to call postPeerModification for peer {},  sleep {} secs",<a name="line.239"></a>
+<span class="sourceLineNo">240</span>              getClass().getName(), peerId, backoff / 1000, e));<a name="line.240"></a>
+<span class="sourceLineNo">241</span>        } catch (IOException e) {<a name="line.241"></a>
+<span class="sourceLineNo">242</span>          LOG.warn("{} failed to call post CP hook for peer {}, " +<a name="line.242"></a>
+<span class="sourceLineNo">243</span>            "ignore since the procedure has already done", getClass().getName(), peerId, e);<a name="line.243"></a>
+<span class="sourceLineNo">244</span>        }<a name="line.244"></a>
+<span class="sourceLineNo">245</span>        releaseLatch(env);<a name="line.245"></a>
+<span class="sourceLineNo">246</span>        return Flow.NO_MORE_STATE;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      default:<a name="line.247"></a>
+<span class="sourceLineNo">248</span>        throw new UnsupportedOperationException("unhandled state=" + state);<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>  @Override<a name="line.252"></a>
+<span class="sourceLineNo">253</span>  protected PeerModificationState getState(int stateId) {<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    return PeerModificationState.forNumber(stateId);<a name="line.254"></a>
+<span class="sourceLineNo">255</span>  }<a name="line.255"></a>
+<span class="sourceLineNo">256</span><a name="line.256"></a>
+<span class="sourceLineNo">257</span>  @Override<a name="line.257"></a>
+<span class="sourceLineNo">258</span>  protected int getStateId(PeerModificationState state) {<a name="line.258"></a>
+<span class="sourceLineNo">259</span>    return state.getNumber();<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>  @Override<a name="line.262"></a>
+<span class="sourceLineNo">263</span>  protected PeerModificationState getInitialState() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>    return PeerModificationState.PRE_PEER_MODIFICATION;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>  }<a name="line.265"></a>
+<span class="sourceLineNo">266</span>}<a name="line.266"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html
index f232725..ce0583f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html
@@ -511,7 +511,7 @@
 <span class="sourceLineNo">503</span><a name="line.503"></a>
 <span class="sourceLineNo">504</span>  public List&lt;String&gt; getSerialPeerIdsBelongsTo(TableName tableName) {<a name="line.504"></a>
 <span class="sourceLineNo">505</span>    return peers.values().stream().filter(p -&gt; p.getPeerConfig().isSerial())<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      .filter(p -&gt; ReplicationUtils.contains(p.getPeerConfig(), tableName)).map(p -&gt; p.getPeerId())<a name="line.506"></a>
+<span class="sourceLineNo">506</span>      .filter(p -&gt; p.getPeerConfig().needToReplicate(tableName)).map(p -&gt; p.getPeerId())<a name="line.506"></a>
 <span class="sourceLineNo">507</span>      .collect(Collectors.toList());<a name="line.507"></a>
 <span class="sourceLineNo">508</span>  }<a name="line.508"></a>
 <span class="sourceLineNo">509</span><a name="line.509"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/UpdatePeerConfigProcedure.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/UpdatePeerConfigProcedure.html
index 3ce74a6..e8c1803 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/UpdatePeerConfigProcedure.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/replication/UpdatePeerConfigProcedure.html
@@ -136,15 +136,15 @@
 <span class="sourceLineNo">128</span>        continue;<a name="line.128"></a>
 <span class="sourceLineNo">129</span>      }<a name="line.129"></a>
 <span class="sourceLineNo">130</span>      TableName tn = td.getTableName();<a name="line.130"></a>
-<span class="sourceLineNo">131</span>      if (ReplicationUtils.contains(oldPeerConfig, tn)) {<a name="line.131"></a>
-<span class="sourceLineNo">132</span>        if (!ReplicationUtils.contains(peerConfig, tn)) {<a name="line.132"></a>
+<span class="sourceLineNo">131</span>      if (oldPeerConfig.needToReplicate(tn)) {<a name="line.131"></a>
+<span class="sourceLineNo">132</span>        if (!peerConfig.needToReplicate(tn)) {<a name="line.132"></a>
 <span class="sourceLineNo">133</span>          // removed from peer config<a name="line.133"></a>
 <span class="sourceLineNo">134</span>          for (String encodedRegionName : MetaTableAccessor<a name="line.134"></a>
 <span class="sourceLineNo">135</span>            .getTableEncodedRegionNamesForSerialReplication(conn, tn)) {<a name="line.135"></a>
 <span class="sourceLineNo">136</span>            addToList(encodedRegionNames, encodedRegionName, queueStorage);<a name="line.136"></a>
 <span class="sourceLineNo">137</span>          }<a name="line.137"></a>
 <span class="sourceLineNo">138</span>        }<a name="line.138"></a>
-<span class="sourceLineNo">139</span>      } else if (ReplicationUtils.contains(peerConfig, tn)) {<a name="line.139"></a>
+<span class="sourceLineNo">139</span>      } else if (peerConfig.needToReplicate(tn)) {<a name="line.139"></a>
 <span class="sourceLineNo">140</span>        // newly added to peer config<a name="line.140"></a>
 <span class="sourceLineNo">141</span>        setLastPushedSequenceIdForTable(env, tn, lastSeqIds);<a name="line.141"></a>
 <span class="sourceLineNo">142</span>      }<a name="line.142"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html b/devapidocs/src-html/org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html
index 53fef3d..5d143b4 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/replication/NamespaceTableCfWALEntryFilter.html
@@ -60,7 +60,7 @@
 <span class="sourceLineNo">052</span><a name="line.52"></a>
 <span class="sourceLineNo">053</span>  @Override<a name="line.53"></a>
 <span class="sourceLineNo">054</span>  public Entry filter(Entry entry) {<a name="line.54"></a>
-<span class="sourceLineNo">055</span>    if (ReplicationUtils.contains(this.peer.getPeerConfig(), entry.getKey().getTableName())) {<a name="line.55"></a>
+<span class="sourceLineNo">055</span>    if (this.peer.getPeerConfig().needToReplicate(entry.getKey().getTableName())) {<a name="line.55"></a>
 <span class="sourceLineNo">056</span>      return entry;<a name="line.56"></a>
 <span class="sourceLineNo">057</span>    } else {<a name="line.57"></a>
 <span class="sourceLineNo">058</span>      return null;<a name="line.58"></a>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.ReplicationPeerConfigBuilderImpl.html b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.ReplicationPeerConfigBuilderImpl.html
index 722424c..60884f8 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.ReplicationPeerConfigBuilderImpl.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.ReplicationPeerConfigBuilderImpl.html
@@ -400,25 +400,34 @@
 <span class="sourceLineNo">392</span>   * @return true if the table need replicate to the peer cluster<a name="line.392"></a>
 <span class="sourceLineNo">393</span>   */<a name="line.393"></a>
 <span class="sourceLineNo">394</span>  public boolean needToReplicate(TableName table) {<a name="line.394"></a>
-<span class="sourceLineNo">395</span>    if (replicateAllUserTables) {<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(table.getNamespaceAsString())) {<a name="line.396"></a>
-<span class="sourceLineNo">397</span>        return false;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>      }<a name="line.398"></a>
-<span class="sourceLineNo">399</span>      if (excludeTableCFsMap != null &amp;&amp; excludeTableCFsMap.containsKey(table)) {<a name="line.399"></a>
-<span class="sourceLineNo">400</span>        return false;<a name="line.400"></a>
-<span class="sourceLineNo">401</span>      }<a name="line.401"></a>
-<span class="sourceLineNo">402</span>      return true;<a name="line.402"></a>
-<span class="sourceLineNo">403</span>    } else {<a name="line.403"></a>
-<span class="sourceLineNo">404</span>      if (namespaces != null &amp;&amp; namespaces.contains(table.getNamespaceAsString())) {<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        return true;<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      }<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      if (tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table)) {<a name="line.407"></a>
-<span class="sourceLineNo">408</span>        return true;<a name="line.408"></a>
-<span class="sourceLineNo">409</span>      }<a name="line.409"></a>
-<span class="sourceLineNo">410</span>      return false;<a name="line.410"></a>
-<span class="sourceLineNo">411</span>    }<a name="line.411"></a>
-<span class="sourceLineNo">412</span>  }<a name="line.412"></a>
-<span class="sourceLineNo">413</span>}<a name="line.413"></a>
+<span class="sourceLineNo">395</span>    String namespace = table.getNamespaceAsString();<a name="line.395"></a>
+<span class="sourceLineNo">396</span>    if (replicateAllUserTables) {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>      // replicate all user tables, but filter by exclude namespaces and table-cfs config<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(namespace)) {<a name="line.398"></a>
+<span class="sourceLineNo">399</span>        return false;<a name="line.399"></a>
+<span class="sourceLineNo">400</span>      }<a name="line.400"></a>
+<span class="sourceLineNo">401</span>      // trap here, must check existence first since HashMap allows null value.<a name="line.401"></a>
+<span class="sourceLineNo">402</span>      if (excludeTableCFsMap == null || !excludeTableCFsMap.containsKey(table)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>        return true;<a name="line.403"></a>
+<span class="sourceLineNo">404</span>      }<a name="line.404"></a>
+<span class="sourceLineNo">405</span>      Collection&lt;String&gt; cfs = excludeTableCFsMap.get(table);<a name="line.405"></a>
+<span class="sourceLineNo">406</span>      // if cfs is null or empty then we can make sure that we do not need to replicate this table,<a name="line.406"></a>
+<span class="sourceLineNo">407</span>      // otherwise, we may still need to replicate the table but filter out some families.<a name="line.407"></a>
+<span class="sourceLineNo">408</span>      return cfs != null &amp;&amp; !cfs.isEmpty();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>    } else {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>      // Not replicate all user tables, so filter by namespaces and table-cfs config<a name="line.410"></a>
+<span class="sourceLineNo">411</span>      if (namespaces == null &amp;&amp; tableCFsMap == null) {<a name="line.411"></a>
+<span class="sourceLineNo">412</span>        return false;<a name="line.412"></a>
+<span class="sourceLineNo">413</span>      }<a name="line.413"></a>
+<span class="sourceLineNo">414</span>      // First filter by namespaces config<a name="line.414"></a>
+<span class="sourceLineNo">415</span>      // If table's namespace in peer config, all the tables data are applicable for replication<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      if (namespaces != null &amp;&amp; namespaces.contains(namespace)) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span>        return true;<a name="line.417"></a>
+<span class="sourceLineNo">418</span>      }<a name="line.418"></a>
+<span class="sourceLineNo">419</span>      return tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table);<a name="line.419"></a>
+<span class="sourceLineNo">420</span>    }<a name="line.420"></a>
+<span class="sourceLineNo">421</span>  }<a name="line.421"></a>
+<span class="sourceLineNo">422</span>}<a name="line.422"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
index 722424c..60884f8 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html
@@ -400,25 +400,34 @@
 <span class="sourceLineNo">392</span>   * @return true if the table need replicate to the peer cluster<a name="line.392"></a>
 <span class="sourceLineNo">393</span>   */<a name="line.393"></a>
 <span class="sourceLineNo">394</span>  public boolean needToReplicate(TableName table) {<a name="line.394"></a>
-<span class="sourceLineNo">395</span>    if (replicateAllUserTables) {<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(table.getNamespaceAsString())) {<a name="line.396"></a>
-<span class="sourceLineNo">397</span>        return false;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>      }<a name="line.398"></a>
-<span class="sourceLineNo">399</span>      if (excludeTableCFsMap != null &amp;&amp; excludeTableCFsMap.containsKey(table)) {<a name="line.399"></a>
-<span class="sourceLineNo">400</span>        return false;<a name="line.400"></a>
-<span class="sourceLineNo">401</span>      }<a name="line.401"></a>
-<span class="sourceLineNo">402</span>      return true;<a name="line.402"></a>
-<span class="sourceLineNo">403</span>    } else {<a name="line.403"></a>
-<span class="sourceLineNo">404</span>      if (namespaces != null &amp;&amp; namespaces.contains(table.getNamespaceAsString())) {<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        return true;<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      }<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      if (tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table)) {<a name="line.407"></a>
-<span class="sourceLineNo">408</span>        return true;<a name="line.408"></a>
-<span class="sourceLineNo">409</span>      }<a name="line.409"></a>
-<span class="sourceLineNo">410</span>      return false;<a name="line.410"></a>
-<span class="sourceLineNo">411</span>    }<a name="line.411"></a>
-<span class="sourceLineNo">412</span>  }<a name="line.412"></a>
-<span class="sourceLineNo">413</span>}<a name="line.413"></a>
+<span class="sourceLineNo">395</span>    String namespace = table.getNamespaceAsString();<a name="line.395"></a>
+<span class="sourceLineNo">396</span>    if (replicateAllUserTables) {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>      // replicate all user tables, but filter by exclude namespaces and table-cfs config<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(namespace)) {<a name="line.398"></a>
+<span class="sourceLineNo">399</span>        return false;<a name="line.399"></a>
+<span class="sourceLineNo">400</span>      }<a name="line.400"></a>
+<span class="sourceLineNo">401</span>      // trap here, must check existence first since HashMap allows null value.<a name="line.401"></a>
+<span class="sourceLineNo">402</span>      if (excludeTableCFsMap == null || !excludeTableCFsMap.containsKey(table)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>        return true;<a name="line.403"></a>
+<span class="sourceLineNo">404</span>      }<a name="line.404"></a>
+<span class="sourceLineNo">405</span>      Collection&lt;String&gt; cfs = excludeTableCFsMap.get(table);<a name="line.405"></a>
+<span class="sourceLineNo">406</span>      // if cfs is null or empty then we can make sure that we do not need to replicate this table,<a name="line.406"></a>
+<span class="sourceLineNo">407</span>      // otherwise, we may still need to replicate the table but filter out some families.<a name="line.407"></a>
+<span class="sourceLineNo">408</span>      return cfs != null &amp;&amp; !cfs.isEmpty();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>    } else {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>      // Not replicate all user tables, so filter by namespaces and table-cfs config<a name="line.410"></a>
+<span class="sourceLineNo">411</span>      if (namespaces == null &amp;&amp; tableCFsMap == null) {<a name="line.411"></a>
+<span class="sourceLineNo">412</span>        return false;<a name="line.412"></a>
+<span class="sourceLineNo">413</span>      }<a name="line.413"></a>
+<span class="sourceLineNo">414</span>      // First filter by namespaces config<a name="line.414"></a>
+<span class="sourceLineNo">415</span>      // If table's namespace in peer config, all the tables data are applicable for replication<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      if (namespaces != null &amp;&amp; namespaces.contains(namespace)) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span>        return true;<a name="line.417"></a>
+<span class="sourceLineNo">418</span>      }<a name="line.418"></a>
+<span class="sourceLineNo">419</span>      return tableCFsMap != null &amp;&amp; tableCFsMap.containsKey(table);<a name="line.419"></a>
+<span class="sourceLineNo">420</span>    }<a name="line.420"></a>
+<span class="sourceLineNo">421</span>  }<a name="line.421"></a>
+<span class="sourceLineNo">422</span>}<a name="line.422"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html
index 065bb43..b1ad208 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/replication/ReplicationUtils.html
@@ -162,103 +162,65 @@
 <span class="sourceLineNo">154</span>      HConstants.REPLICATION_BULKLOAD_ENABLE_DEFAULT);<a name="line.154"></a>
 <span class="sourceLineNo">155</span>  }<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>   * Returns whether we should replicate the given table.<a name="line.158"></a>
-<span class="sourceLineNo">159</span>   */<a name="line.159"></a>
-<span class="sourceLineNo">160</span>  public static boolean contains(ReplicationPeerConfig peerConfig, TableName tableName) {<a name="line.160"></a>
-<span class="sourceLineNo">161</span>    String namespace = tableName.getNamespaceAsString();<a name="line.161"></a>
-<span class="sourceLineNo">162</span>    if (peerConfig.replicateAllUserTables()) {<a name="line.162"></a>
-<span class="sourceLineNo">163</span>      // replicate all user tables, but filter by exclude namespaces and table-cfs config<a name="line.163"></a>
-<span class="sourceLineNo">164</span>      Set&lt;String&gt; excludeNamespaces = peerConfig.getExcludeNamespaces();<a name="line.164"></a>
-<span class="sourceLineNo">165</span>      if (excludeNamespaces != null &amp;&amp; excludeNamespaces.contains(namespace)) {<a name="line.165"></a>
-<span class="sourceLineNo">166</span>        return false;<a name="line.166"></a>
-<span class="sourceLineNo">167</span>      }<a name="line.167"></a>
-<span class="sourceLineNo">168</span>      Map&lt;TableName, List&lt;String&gt;&gt; excludedTableCFs = peerConfig.getExcludeTableCFsMap();<a name="line.168"></a>
-<span class="sourceLineNo">169</span>      // trap here, must check existence first since HashMap allows null value.<a name="line.169"></a>
-<span class="sourceLineNo">170</span>      if (excludedTableCFs == null || !excludedTableCFs.containsKey(tableName)) {<a name="line.170"></a>
-<span class="sourceLineNo">171</span>        return true;<a name="line.171"></a>
-<span class="sourceLineNo">172</span>      }<a name="line.172"></a>
-<span class="sourceLineNo">173</span>      List&lt;String&gt; cfs = excludedTableCFs.get(tableName);<a name="line.173"></a>
-<span class="sourceLineNo">174</span>      // if cfs is null or empty then we can make sure that we do not need to replicate this table,<a name="line.174"></a>
-<span class="sourceLineNo">175</span>      // otherwise, we may still need to replicate the table but filter out some families.<a name="line.175"></a>
-<span class="sourceLineNo">176</span>      return cfs != null &amp;&amp; !cfs.isEmpty();<a name="line.176"></a>
-<span class="sourceLineNo">177</span>    } else {<a name="line.177"></a>
-<span class="sourceLineNo">178</span>      // Not replicate all user tables, so filter by namespaces and table-cfs config<a name="line.178"></a>
-<span class="sourceLineNo">179</span>      Set&lt;String&gt; namespaces = peerConfig.getNamespaces();<a name="line.179"></a>
-<span class="sourceLineNo">180</span>      Map&lt;TableName, List&lt;String&gt;&gt; tableCFs = peerConfig.getTableCFsMap();<a name="line.180"></a>
+<span class="sourceLineNo">157</span>  public static FileSystem getRemoteWALFileSystem(Configuration conf, String remoteWALDir)<a name="line.157"></a>
+<span class="sourceLineNo">158</span>      throws IOException {<a name="line.158"></a>
+<span class="sourceLineNo">159</span>    return new Path(remoteWALDir).getFileSystem(conf);<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 static Path getPeerRemoteWALDir(String remoteWALDir, String peerId) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span>    return new Path(remoteWALDir, peerId);<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>  public static Path getPeerRemoteWALDir(Path remoteWALDir, String peerId) {<a name="line.166"></a>
+<span class="sourceLineNo">167</span>    return new Path(remoteWALDir, peerId);<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  }<a name="line.168"></a>
+<span class="sourceLineNo">169</span><a name="line.169"></a>
+<span class="sourceLineNo">170</span>  public static Path getPeerReplayWALDir(Path remoteWALDir, String peerId) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_REPLAY_SUFFIX);<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  }<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  public static Path getPeerSnapshotWALDir(String remoteWALDir, String peerId) {<a name="line.174"></a>
+<span class="sourceLineNo">175</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_SNAPSHOT_SUFFIX);<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>  public static Path getPeerSnapshotWALDir(Path remoteWALDir, String peerId) {<a name="line.178"></a>
+<span class="sourceLineNo">179</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_SNAPSHOT_SUFFIX);<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  }<a name="line.180"></a>
 <span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>      if (namespaces == null &amp;&amp; tableCFs == null) {<a name="line.182"></a>
-<span class="sourceLineNo">183</span>        return false;<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>      // First filter by namespaces config<a name="line.186"></a>
-<span class="sourceLineNo">187</span>      // If table's namespace in peer config, all the tables data are applicable for replication<a name="line.187"></a>
-<span class="sourceLineNo">188</span>      if (namespaces != null &amp;&amp; namespaces.contains(namespace)) {<a name="line.188"></a>
-<span class="sourceLineNo">189</span>        return true;<a name="line.189"></a>
-<span class="sourceLineNo">190</span>      }<a name="line.190"></a>
-<span class="sourceLineNo">191</span>      return tableCFs != null &amp;&amp; tableCFs.containsKey(tableName);<a name="line.191"></a>
-<span class="sourceLineNo">192</span>    }<a name="line.192"></a>
-<span class="sourceLineNo">193</span>  }<a name="line.193"></a>
-<span class="sourceLineNo">194</span><a name="line.194"></a>
-<span class="sourceLineNo">195</span>  public static FileSystem getRemoteWALFileSystem(Configuration conf, String remoteWALDir)<a name="line.195"></a>
-<span class="sourceLineNo">196</span>      throws IOException {<a name="line.196"></a>
-<span class="sourceLineNo">197</span>    return new Path(remoteWALDir).getFileSystem(conf);<a name="line.197"></a>
-<span class="sourceLineNo">198</span>  }<a name="line.198"></a>
-<span class="sourceLineNo">199</span><a name="line.199"></a>
-<span class="sourceLineNo">200</span>  public static Path getPeerRemoteWALDir(String remoteWALDir, String peerId) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span>    return new Path(remoteWALDir, peerId);<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  public static Path getPeerRemoteWALDir(Path remoteWALDir, String peerId) {<a name="line.204"></a>
-<span class="sourceLineNo">205</span>    return new Path(remoteWALDir, peerId);<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>  public static Path getPeerReplayWALDir(Path remoteWALDir, String peerId) {<a name="line.208"></a>
-<span class="sourceLineNo">209</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_REPLAY_SUFFIX);<a name="line.209"></a>
-<span class="sourceLineNo">210</span>  }<a name="line.210"></a>
-<span class="sourceLineNo">211</span><a name="line.211"></a>
-<span class="sourceLineNo">212</span>  public static Path getPeerSnapshotWALDir(String remoteWALDir, String peerId) {<a name="line.212"></a>
-<span class="sourceLineNo">213</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_SNAPSHOT_SUFFIX);<a name="line.213"></a>
+<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
+<span class="sourceLineNo">183</span>   * Do the sleeping logic<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * @param msg Why we sleep<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * @param sleepForRetries the base sleep time.<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * @param sleepMultiplier by how many times the default sleeping time is augmented<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   * @param maxRetriesMultiplier the max retry multiplier<a name="line.187"></a>
+<span class="sourceLineNo">188</span>   * @return True if &lt;code&gt;sleepMultiplier&lt;/code&gt; is &amp;lt; &lt;code&gt;maxRetriesMultiplier&lt;/code&gt;<a name="line.188"></a>
+<span class="sourceLineNo">189</span>   */<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static boolean sleepForRetries(String msg, long sleepForRetries, int sleepMultiplier,<a name="line.190"></a>
+<span class="sourceLineNo">191</span>      int maxRetriesMultiplier) {<a name="line.191"></a>
+<span class="sourceLineNo">192</span>    try {<a name="line.192"></a>
+<span class="sourceLineNo">193</span>      LOG.trace("{}, sleeping {} times {}", msg, sleepForRetries, sleepMultiplier);<a name="line.193"></a>
+<span class="sourceLineNo">194</span>      Thread.sleep(sleepForRetries * sleepMultiplier);<a name="line.194"></a>
+<span class="sourceLineNo">195</span>    } catch (InterruptedException e) {<a name="line.195"></a>
+<span class="sourceLineNo">196</span>      LOG.debug("Interrupted while sleeping between retries");<a name="line.196"></a>
+<span class="sourceLineNo">197</span>      Thread.currentThread().interrupt();<a name="line.197"></a>
+<span class="sourceLineNo">198</span>    }<a name="line.198"></a>
+<span class="sourceLineNo">199</span>    return sleepMultiplier &lt; maxRetriesMultiplier;<a name="line.199"></a>
+<span class="sourceLineNo">200</span>  }<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>   * Get the adaptive timeout value when performing a retry<a name="line.203"></a>
+<span class="sourceLineNo">204</span>   */<a name="line.204"></a>
+<span class="sourceLineNo">205</span>  public static int getAdaptiveTimeout(final int initialValue, final int retries) {<a name="line.205"></a>
+<span class="sourceLineNo">206</span>    int ntries = retries;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>    if (ntries &gt;= HConstants.RETRY_BACKOFF.length) {<a name="line.207"></a>
+<span class="sourceLineNo">208</span>      ntries = HConstants.RETRY_BACKOFF.length - 1;<a name="line.208"></a>
+<span class="sourceLineNo">209</span>    }<a name="line.209"></a>
+<span class="sourceLineNo">210</span>    if (ntries &lt; 0) {<a name="line.210"></a>
+<span class="sourceLineNo">211</span>      ntries = 0;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>    }<a name="line.212"></a>
+<span class="sourceLineNo">213</span>    return initialValue * HConstants.RETRY_BACKOFF[ntries];<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>  public static Path getPeerSnapshotWALDir(Path remoteWALDir, String peerId) {<a name="line.216"></a>
-<span class="sourceLineNo">217</span>    return getPeerRemoteWALDir(remoteWALDir, peerId).suffix(REMOTE_WAL_SNAPSHOT_SUFFIX);<a name="line.217"></a>
-<span class="sourceLineNo">218</span>  }<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>   * Do the sleeping logic<a name="line.221"></a>
-<span class="sourceLineNo">222</span>   * @param msg Why we sleep<a name="line.222"></a>
-<span class="sourceLineNo">223</span>   * @param sleepForRetries the base sleep time.<a name="line.223"></a>
-<span class="sourceLineNo">224</span>   * @param sleepMultiplier by how many times the default sleeping time is augmented<a name="line.224"></a>
-<span class="sourceLineNo">225</span>   * @param maxRetriesMultiplier the max retry multiplier<a name="line.225"></a>
-<span class="sourceLineNo">226</span>   * @return True if &lt;code&gt;sleepMultiplier&lt;/code&gt; is &amp;lt; &lt;code&gt;maxRetriesMultiplier&lt;/code&gt;<a name="line.226"></a>
-<span class="sourceLineNo">227</span>   */<a name="line.227"></a>
-<span class="sourceLineNo">228</span>  public static boolean sleepForRetries(String msg, long sleepForRetries, int sleepMultiplier,<a name="line.228"></a>
-<span class="sourceLineNo">229</span>      int maxRetriesMultiplier) {<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    try {<a name="line.230"></a>
-<span class="sourceLineNo">231</span>      LOG.trace("{}, sleeping {} times {}", msg, sleepForRetries, sleepMultiplier);<a name="line.231"></a>
-<span class="sourceLineNo">232</span>      Thread.sleep(sleepForRetries * sleepMultiplier);<a name="line.232"></a>
-<span class="sourceLineNo">233</span>    } catch (InterruptedException e) {<a name="line.233"></a>
-<span class="sourceLineNo">234</span>      LOG.debug("Interrupted while sleeping between retries");<a name="line.234"></a>
-<span class="sourceLineNo">235</span>      Thread.currentThread().interrupt();<a name="line.235"></a>
-<span class="sourceLineNo">236</span>    }<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    return sleepMultiplier &lt; maxRetriesMultiplier;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>  }<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>   * Get the adaptive timeout value when performing a retry<a name="line.241"></a>
-<span class="sourceLineNo">242</span>   */<a name="line.242"></a>
-<span class="sourceLineNo">243</span>  public static int getAdaptiveTimeout(final int initialValue, final int retries) {<a name="line.243"></a>
-<span class="sourceLineNo">244</span>    int ntries = retries;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>    if (ntries &gt;= HConstants.RETRY_BACKOFF.length) {<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      ntries = HConstants.RETRY_BACKOFF.length - 1;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span>    if (ntries &lt; 0) {<a name="line.248"></a>
-<span class="sourceLineNo">249</span>      ntries = 0;<a name="line.249"></a>
-<span class="sourceLineNo">250</span>    }<a name="line.250"></a>
-<span class="sourceLineNo">251</span>    return initialValue * HConstants.RETRY_BACKOFF[ntries];<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">215</span>}<a name="line.215"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html b/devapidocs/src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
index 78bd8b9..211f612 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/util/HBaseFsck.CheckRegionConsistencyWorkItem.html
@@ -124,3877 +124,3876 @@
 <span class="sourceLineNo">116</span>import org.apache.hadoop.hbase.replication.ReplicationPeerDescription;<a name="line.116"></a>
 <span class="sourceLineNo">117</span>import org.apache.hadoop.hbase.replication.ReplicationQueueStorage;<a name="line.117"></a>
 <span class="sourceLineNo">118</span>import org.apache.hadoop.hbase.replication.ReplicationStorageFactory;<a name="line.118"></a>
-<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.replication.ReplicationUtils;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.120"></a>
-<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.121"></a>
-<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.util.Bytes.ByteArrayComparator;<a name="line.122"></a>
-<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.util.HbckErrorReporter.ERROR_CODE;<a name="line.123"></a>
-<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.util.hbck.HFileCorruptionChecker;<a name="line.124"></a>
-<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.util.hbck.ReplicationChecker;<a name="line.125"></a>
-<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.util.hbck.TableIntegrityErrorHandler;<a name="line.126"></a>
-<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.wal.WALSplitUtil;<a name="line.127"></a>
-<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.128"></a>
-<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.129"></a>
-<span class="sourceLineNo">130</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.130"></a>
-<span class="sourceLineNo">131</span>import org.apache.hadoop.hdfs.protocol.AlreadyBeingCreatedException;<a name="line.131"></a>
-<span class="sourceLineNo">132</span>import org.apache.hadoop.ipc.RemoteException;<a name="line.132"></a>
-<span class="sourceLineNo">133</span>import org.apache.hadoop.security.UserGroupInformation;<a name="line.133"></a>
-<span class="sourceLineNo">134</span>import org.apache.hadoop.util.ReflectionUtils;<a name="line.134"></a>
-<span class="sourceLineNo">135</span>import org.apache.hadoop.util.Tool;<a name="line.135"></a>
-<span class="sourceLineNo">136</span>import org.apache.hadoop.util.ToolRunner;<a name="line.136"></a>
-<span class="sourceLineNo">137</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.137"></a>
-<span class="sourceLineNo">138</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.138"></a>
-<span class="sourceLineNo">139</span>import org.apache.zookeeper.KeeperException;<a name="line.139"></a>
-<span class="sourceLineNo">140</span>import org.slf4j.Logger;<a name="line.140"></a>
-<span class="sourceLineNo">141</span>import org.slf4j.LoggerFactory;<a name="line.141"></a>
-<span class="sourceLineNo">142</span><a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.com.google.common.base.Preconditions;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.146"></a>
-<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.147"></a>
-<span class="sourceLineNo">148</span><a name="line.148"></a>
-<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * HBaseFsck (hbck) is a tool for checking and repairing region consistency and<a name="line.150"></a>
-<span class="sourceLineNo">151</span> * table integrity problems in a corrupted HBase. This tool was written for hbase-1.x. It does not<a name="line.151"></a>
-<span class="sourceLineNo">152</span> * work with hbase-2.x; it can read state but is not allowed to change state; i.e. effect 'repair'.<a name="line.152"></a>
-<span class="sourceLineNo">153</span> * Even though it can 'read' state, given how so much has changed in how hbase1 and hbase2 operate,<a name="line.153"></a>
-<span class="sourceLineNo">154</span> * it will often misread. See hbck2 (HBASE-19121) for a hbck tool for hbase2. This class is<a name="line.154"></a>
-<span class="sourceLineNo">155</span> * deprecated.<a name="line.155"></a>
-<span class="sourceLineNo">156</span> *<a name="line.156"></a>
-<span class="sourceLineNo">157</span> * &lt;p&gt;<a name="line.157"></a>
-<span class="sourceLineNo">158</span> * Region consistency checks verify that hbase:meta, region deployment on region<a name="line.158"></a>
-<span class="sourceLineNo">159</span> * servers and the state of data in HDFS (.regioninfo files) all are in<a name="line.159"></a>
-<span class="sourceLineNo">160</span> * accordance.<a name="line.160"></a>
-<span class="sourceLineNo">161</span> * &lt;p&gt;<a name="line.161"></a>
-<span class="sourceLineNo">162</span> * Table integrity checks verify that all possible row keys resolve to exactly<a name="line.162"></a>
-<span class="sourceLineNo">163</span> * one region of a table.  This means there are no individual degenerate<a name="line.163"></a>
-<span class="sourceLineNo">164</span> * or backwards regions; no holes between regions; and that there are no<a name="line.164"></a>
-<span class="sourceLineNo">165</span> * overlapping regions.<a name="line.165"></a>
-<span class="sourceLineNo">166</span> * &lt;p&gt;<a name="line.166"></a>
-<span class="sourceLineNo">167</span> * The general repair strategy works in two phases:<a name="line.167"></a>
-<span class="sourceLineNo">168</span> * &lt;ol&gt;<a name="line.168"></a>
-<span class="sourceLineNo">169</span> * &lt;li&gt; Repair Table Integrity on HDFS. (merge or fabricate regions)<a name="line.169"></a>
-<span class="sourceLineNo">170</span> * &lt;li&gt; Repair Region Consistency with hbase:meta and assignments<a name="line.170"></a>
-<span class="sourceLineNo">171</span> * &lt;/ol&gt;<a name="line.171"></a>
-<span class="sourceLineNo">172</span> * &lt;p&gt;<a name="line.172"></a>
-<span class="sourceLineNo">173</span> * For table integrity repairs, the tables' region directories are scanned<a name="line.173"></a>
-<span class="sourceLineNo">174</span> * for .regioninfo files.  Each table's integrity is then verified.  If there<a name="line.174"></a>
-<span class="sourceLineNo">175</span> * are any orphan regions (regions with no .regioninfo files) or holes, new<a name="line.175"></a>
-<span class="sourceLineNo">176</span> * regions are fabricated.  Backwards regions are sidelined as well as empty<a name="line.176"></a>
-<span class="sourceLineNo">177</span> * degenerate (endkey==startkey) regions.  If there are any overlapping regions,<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * a new region is created and all data is merged into the new region.<a name="line.178"></a>
-<span class="sourceLineNo">179</span> * &lt;p&gt;<a name="line.179"></a>
-<span class="sourceLineNo">180</span> * Table integrity repairs deal solely with HDFS and could potentially be done<a name="line.180"></a>
-<span class="sourceLineNo">181</span> * offline -- the hbase region servers or master do not need to be running.<a name="line.181"></a>
-<span class="sourceLineNo">182</span> * This phase can eventually be used to completely reconstruct the hbase:meta table in<a name="line.182"></a>
-<span class="sourceLineNo">183</span> * an offline fashion.<a name="line.183"></a>
-<span class="sourceLineNo">184</span> * &lt;p&gt;<a name="line.184"></a>
-<span class="sourceLineNo">185</span> * Region consistency requires three conditions -- 1) valid .regioninfo file<a name="line.185"></a>
-<span class="sourceLineNo">186</span> * present in an HDFS region dir,  2) valid row with .regioninfo data in META,<a name="line.186"></a>
-<span class="sourceLineNo">187</span> * and 3) a region is deployed only at the regionserver that was assigned to<a name="line.187"></a>
-<span class="sourceLineNo">188</span> * with proper state in the master.<a name="line.188"></a>
-<span class="sourceLineNo">189</span> * &lt;p&gt;<a name="line.189"></a>
-<span class="sourceLineNo">190</span> * Region consistency repairs require hbase to be online so that hbck can<a name="line.190"></a>
-<span class="sourceLineNo">191</span> * contact the HBase master and region servers.  The hbck#connect() method must<a name="line.191"></a>
-<span class="sourceLineNo">192</span> * first be called successfully.  Much of the region consistency information<a name="line.192"></a>
-<span class="sourceLineNo">193</span> * is transient and less risky to repair.<a name="line.193"></a>
-<span class="sourceLineNo">194</span> * &lt;p&gt;<a name="line.194"></a>
-<span class="sourceLineNo">195</span> * If hbck is run from the command line, there are a handful of arguments that<a name="line.195"></a>
-<span class="sourceLineNo">196</span> * can be used to limit the kinds of repairs hbck will do.  See the code in<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * {@link #printUsageAndExit()} for more details.<a name="line.197"></a>
-<span class="sourceLineNo">198</span> * @deprecated For removal in hbase-4.0.0. Use HBCK2 instead.<a name="line.198"></a>
-<span class="sourceLineNo">199</span> */<a name="line.199"></a>
-<span class="sourceLineNo">200</span>@Deprecated<a name="line.200"></a>
-<span class="sourceLineNo">201</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)<a name="line.201"></a>
-<span class="sourceLineNo">202</span>@InterfaceStability.Evolving<a name="line.202"></a>
-<span class="sourceLineNo">203</span>public class HBaseFsck extends Configured implements Closeable {<a name="line.203"></a>
-<span class="sourceLineNo">204</span>  public static final long DEFAULT_TIME_LAG = 60000; // default value of 1 minute<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final long DEFAULT_SLEEP_BEFORE_RERUN = 10000;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  private static final int MAX_NUM_THREADS = 50; // #threads to contact regions<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  private static boolean rsSupportsOffline = true;<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private static final int DEFAULT_OVERLAPS_TO_SIDELINE = 2;<a name="line.208"></a>
-<span class="sourceLineNo">209</span>  private static final int DEFAULT_MAX_MERGE = 5;<a name="line.209"></a>
-<span class="sourceLineNo">210</span><a name="line.210"></a>
-<span class="sourceLineNo">211</span>  /**<a name="line.211"></a>
-<span class="sourceLineNo">212</span>   * Here is where hbase-1.x used to default the lock for hbck1.<a name="line.212"></a>
-<span class="sourceLineNo">213</span>   * It puts in place a lock when it goes to write/make changes.<a name="line.213"></a>
-<span class="sourceLineNo">214</span>   */<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  @VisibleForTesting<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  public static final String HBCK_LOCK_FILE = "hbase-hbck.lock";<a name="line.216"></a>
-<span class="sourceLineNo">217</span>  private static final int DEFAULT_MAX_LOCK_FILE_ATTEMPTS = 5;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private static final int DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL = 200; // milliseconds<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private static final int DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME = 5000; // milliseconds<a name="line.219"></a>
-<span class="sourceLineNo">220</span>  // We have to set the timeout value &gt; HdfsConstants.LEASE_SOFTLIMIT_PERIOD.<a name="line.220"></a>
-<span class="sourceLineNo">221</span>  // In HADOOP-2.6 and later, the Namenode proxy now created with custom RetryPolicy for<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  // AlreadyBeingCreatedException which is implies timeout on this operations up to<a name="line.222"></a>
-<span class="sourceLineNo">223</span>  // HdfsConstants.LEASE_SOFTLIMIT_PERIOD (60 seconds).<a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private static final int DEFAULT_WAIT_FOR_LOCK_TIMEOUT = 80; // seconds<a name="line.224"></a>
-<span class="sourceLineNo">225</span>  private static final int DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS = 5;<a name="line.225"></a>
-<span class="sourceLineNo">226</span>  private static final int DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL = 200; // milliseconds<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  private static final int DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME = 5000; // milliseconds<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span>  /**********************<a name="line.229"></a>
-<span class="sourceLineNo">230</span>   * Internal resources<a name="line.230"></a>
-<span class="sourceLineNo">231</span>   **********************/<a name="line.231"></a>
-<span class="sourceLineNo">232</span>  private static final Logger LOG = LoggerFactory.getLogger(HBaseFsck.class.getName());<a name="line.232"></a>
-<span class="sourceLineNo">233</span>  private ClusterMetrics status;<a name="line.233"></a>
-<span class="sourceLineNo">234</span>  private Connection connection;<a name="line.234"></a>
-<span class="sourceLineNo">235</span>  private Admin admin;<a name="line.235"></a>
-<span class="sourceLineNo">236</span>  private Table meta;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>  // threads to do ||izable tasks: retrieve data from regionservers, handle overlapping regions<a name="line.237"></a>
-<span class="sourceLineNo">238</span>  protected ExecutorService executor;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>  private long startMillis = EnvironmentEdgeManager.currentTime();<a name="line.239"></a>
-<span class="sourceLineNo">240</span>  private HFileCorruptionChecker hfcc;<a name="line.240"></a>
-<span class="sourceLineNo">241</span>  private int retcode = 0;<a name="line.241"></a>
-<span class="sourceLineNo">242</span>  private Path HBCK_LOCK_PATH;<a name="line.242"></a>
-<span class="sourceLineNo">243</span>  private FSDataOutputStream hbckOutFd;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>  // This lock is to prevent cleanup of balancer resources twice between<a name="line.244"></a>
-<span class="sourceLineNo">245</span>  // ShutdownHook and the main code. We cleanup only if the connect() is<a name="line.245"></a>
-<span class="sourceLineNo">246</span>  // successful<a name="line.246"></a>
-<span class="sourceLineNo">247</span>  private final AtomicBoolean hbckLockCleanup = new AtomicBoolean(false);<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>  // Unsupported options in HBase 2.0+<a name="line.249"></a>
-<span class="sourceLineNo">250</span>  private static final Set&lt;String&gt; unsupportedOptionsInV2 = Sets.newHashSet("-fix",<a name="line.250"></a>
-<span class="sourceLineNo">251</span>      "-fixAssignments", "-fixMeta", "-fixHdfsHoles", "-fixHdfsOrphans", "-fixTableOrphans",<a name="line.251"></a>
-<span class="sourceLineNo">252</span>      "-fixHdfsOverlaps", "-sidelineBigOverlaps", "-fixSplitParents", "-removeParents",<a name="line.252"></a>
-<span class="sourceLineNo">253</span>      "-fixEmptyMetaCells", "-repair", "-repairHoles", "-maxOverlapsToSideline", "-maxMerge");<a name="line.253"></a>
-<span class="sourceLineNo">254</span><a name="line.254"></a>
-<span class="sourceLineNo">255</span>  /***********<a name="line.255"></a>
-<span class="sourceLineNo">256</span>   * Options<a name="line.256"></a>
-<span class="sourceLineNo">257</span>   ***********/<a name="line.257"></a>
-<span class="sourceLineNo">258</span>  private static boolean details = false; // do we display the full report<a name="line.258"></a>
-<span class="sourceLineNo">259</span>  private long timelag = DEFAULT_TIME_LAG; // tables whose modtime is older<a name="line.259"></a>
-<span class="sourceLineNo">260</span>  private static boolean forceExclusive = false; // only this hbck can modify HBase<a name="line.260"></a>
-<span class="sourceLineNo">261</span>  private boolean fixAssignments = false; // fix assignment errors?<a name="line.261"></a>
-<span class="sourceLineNo">262</span>  private boolean fixMeta = false; // fix meta errors?<a name="line.262"></a>
-<span class="sourceLineNo">263</span>  private boolean checkHdfs = true; // load and check fs consistency?<a name="line.263"></a>
-<span class="sourceLineNo">264</span>  private boolean fixHdfsHoles = false; // fix fs holes?<a name="line.264"></a>
-<span class="sourceLineNo">265</span>  private boolean fixHdfsOverlaps = false; // fix fs overlaps (risky)<a name="line.265"></a>
-<span class="sourceLineNo">266</span>  private boolean fixHdfsOrphans = false; // fix fs holes (missing .regioninfo)<a name="line.266"></a>
-<span class="sourceLineNo">267</span>  private boolean fixTableOrphans = false; // fix fs holes (missing .tableinfo)<a name="line.267"></a>
-<span class="sourceLineNo">268</span>  private boolean fixVersionFile = false; // fix missing hbase.version file in hdfs<a name="line.268"></a>
-<span class="sourceLineNo">269</span>  private boolean fixSplitParents = false; // fix lingering split parents<a name="line.269"></a>
-<span class="sourceLineNo">270</span>  private boolean removeParents = false; // remove split parents<a name="line.270"></a>
-<span class="sourceLineNo">271</span>  private boolean fixReferenceFiles = false; // fix lingering reference store file<a name="line.271"></a>
-<span class="sourceLineNo">272</span>  private boolean fixHFileLinks = false; // fix lingering HFileLinks<a name="line.272"></a>
-<span class="sourceLineNo">273</span>  private boolean fixEmptyMetaCells = false; // fix (remove) empty REGIONINFO_QUALIFIER rows<a name="line.273"></a>
-<span class="sourceLineNo">274</span>  private boolean fixReplication = false; // fix undeleted replication queues for removed peer<a name="line.274"></a>
-<span class="sourceLineNo">275</span>  private boolean cleanReplicationBarrier = false; // clean replication barriers of a table<a name="line.275"></a>
-<span class="sourceLineNo">276</span>  private boolean fixAny = false; // Set to true if any of the fix is required.<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>  // limit checking/fixes to listed tables, if empty attempt to check/fix all<a name="line.278"></a>
-<span class="sourceLineNo">279</span>  // hbase:meta are always checked<a name="line.279"></a>
-<span class="sourceLineNo">280</span>  private Set&lt;TableName&gt; tablesIncluded = new HashSet&lt;&gt;();<a name="line.280"></a>
-<span class="sourceLineNo">281</span>  private TableName cleanReplicationBarrierTable;<a name="line.281"></a>
-<span class="sourceLineNo">282</span>  private int maxMerge = DEFAULT_MAX_MERGE; // maximum number of overlapping regions to merge<a name="line.282"></a>
-<span class="sourceLineNo">283</span>  // maximum number of overlapping regions to sideline<a name="line.283"></a>
-<span class="sourceLineNo">284</span>  private int maxOverlapsToSideline = DEFAULT_OVERLAPS_TO_SIDELINE;<a name="line.284"></a>
-<span class="sourceLineNo">285</span>  private boolean sidelineBigOverlaps = false; // sideline overlaps with &gt;maxMerge regions<a name="line.285"></a>
-<span class="sourceLineNo">286</span>  private Path sidelineDir = null;<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>  private boolean rerun = false; // if we tried to fix something, rerun hbck<a name="line.288"></a>
-<span class="sourceLineNo">289</span>  private static boolean summary = false; // if we want to print less output<a name="line.289"></a>
-<span class="sourceLineNo">290</span>  private boolean checkMetaOnly = false;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>  private boolean checkRegionBoundaries = false;<a name="line.291"></a>
-<span class="sourceLineNo">292</span>  private boolean ignorePreCheckPermission = false; // if pre-check permission<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>   * State<a name="line.295"></a>
-<span class="sourceLineNo">296</span>   *********/<a name="line.296"></a>
-<span class="sourceLineNo">297</span>  final private HbckErrorReporter errors;<a name="line.297"></a>
-<span class="sourceLineNo">298</span>  int fixes = 0;<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>   * This map contains the state of all hbck items.  It maps from encoded region<a name="line.301"></a>
-<span class="sourceLineNo">302</span>   * name to HbckRegionInfo structure.  The information contained in HbckRegionInfo is used<a name="line.302"></a>
-<span class="sourceLineNo">303</span>   * to detect and correct consistency (hdfs/meta/deployment) problems.<a name="line.303"></a>
-<span class="sourceLineNo">304</span>   */<a name="line.304"></a>
-<span class="sourceLineNo">305</span>  private TreeMap&lt;String, HbckRegionInfo&gt; regionInfoMap = new TreeMap&lt;&gt;();<a name="line.305"></a>
-<span class="sourceLineNo">306</span>  // Empty regioninfo qualifiers in hbase:meta<a name="line.306"></a>
-<span class="sourceLineNo">307</span>  private Set&lt;Result&gt; emptyRegionInfoQualifiers = new HashSet&lt;&gt;();<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>   * This map from Tablename -&gt; TableInfo contains the structures necessary to<a name="line.310"></a>
-<span class="sourceLineNo">311</span>   * detect table consistency problems (holes, dupes, overlaps).  It is sorted<a name="line.311"></a>
-<span class="sourceLineNo">312</span>   * to prevent dupes.<a name="line.312"></a>
-<span class="sourceLineNo">313</span>   *<a name="line.313"></a>
-<span class="sourceLineNo">314</span>   * If tablesIncluded is empty, this map contains all tables.<a name="line.314"></a>
-<span class="sourceLineNo">315</span>   * Otherwise, it contains only meta tables and tables in tablesIncluded,<a name="line.315"></a>
-<span class="sourceLineNo">316</span>   * unless checkMetaOnly is specified, in which case, it contains only<a name="line.316"></a>
-<span class="sourceLineNo">317</span>   * the meta table<a name="line.317"></a>
-<span class="sourceLineNo">318</span>   */<a name="line.318"></a>
-<span class="sourceLineNo">319</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; tablesInfo = new ConcurrentSkipListMap&lt;&gt;();<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>   * When initially looking at HDFS, we attempt to find any orphaned data.<a name="line.322"></a>
-<span class="sourceLineNo">323</span>   */<a name="line.323"></a>
-<span class="sourceLineNo">324</span>  private List&lt;HbckRegionInfo&gt; orphanHdfsDirs = Collections.synchronizedList(new ArrayList&lt;&gt;());<a name="line.324"></a>
-<span class="sourceLineNo">325</span><a name="line.325"></a>
-<span class="sourceLineNo">326</span>  private Map&lt;TableName, Set&lt;String&gt;&gt; orphanTableDirs = new HashMap&lt;&gt;();<a name="line.326"></a>
-<span class="sourceLineNo">327</span>  private Map&lt;TableName, TableState&gt; tableStates = new HashMap&lt;&gt;();<a name="line.327"></a>
-<span class="sourceLineNo">328</span>  private final RetryCounterFactory lockFileRetryCounterFactory;<a name="line.328"></a>
-<span class="sourceLineNo">329</span>  private final RetryCounterFactory createZNodeRetryCounterFactory;<a name="line.329"></a>
-<span class="sourceLineNo">330</span><a name="line.330"></a>
-<span class="sourceLineNo">331</span>  private Map&lt;TableName, Set&lt;String&gt;&gt; skippedRegions = new HashMap&lt;&gt;();<a name="line.331"></a>
-<span class="sourceLineNo">332</span><a name="line.332"></a>
-<span class="sourceLineNo">333</span>  private ZKWatcher zkw = null;<a name="line.333"></a>
-<span class="sourceLineNo">334</span>  private String hbckEphemeralNodePath = null;<a name="line.334"></a>
-<span class="sourceLineNo">335</span>  private boolean hbckZodeCreated = false;<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>   * Constructor<a name="line.338"></a>
-<span class="sourceLineNo">339</span>   *<a name="line.339"></a>
-<span class="sourceLineNo">340</span>   * @param conf Configuration object<a name="line.340"></a>
-<span class="sourceLineNo">341</span>   * @throws MasterNotRunningException if the master is not running<a name="line.341"></a>
-<span class="sourceLineNo">342</span>   * @throws ZooKeeperConnectionException if unable to connect to ZooKeeper<a name="line.342"></a>
-<span class="sourceLineNo">343</span>   */<a name="line.343"></a>
-<span class="sourceLineNo">344</span>  public HBaseFsck(Configuration conf) throws IOException, ClassNotFoundException {<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    this(conf, createThreadPool(conf));<a name="line.345"></a>
-<span class="sourceLineNo">346</span>  }<a name="line.346"></a>
-<span class="sourceLineNo">347</span><a name="line.347"></a>
-<span class="sourceLineNo">348</span>  private static ExecutorService createThreadPool(Configuration conf) {<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    int numThreads = conf.getInt("hbasefsck.numthreads", MAX_NUM_THREADS);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    return new ScheduledThreadPoolExecutor(numThreads, Threads.newDaemonThreadFactory("hbasefsck"));<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>   * Constructor<a name="line.354"></a>
-<span class="sourceLineNo">355</span>   *<a name="line.355"></a>
-<span class="sourceLineNo">356</span>   * @param conf<a name="line.356"></a>
-<span class="sourceLineNo">357</span>   *          Configuration object<a name="line.357"></a>
-<span class="sourceLineNo">358</span>   * @throws MasterNotRunningException<a name="line.358"></a>
-<span class="sourceLineNo">359</span>   *           if the master is not running<a name="line.359"></a>
-<span class="sourceLineNo">360</span>   * @throws ZooKeeperConnectionException<a name="line.360"></a>
-<span class="sourceLineNo">361</span>   *           if unable to connect to ZooKeeper<a name="line.361"></a>
-<span class="sourceLineNo">362</span>   */<a name="line.362"></a>
-<span class="sourceLineNo">363</span>  public HBaseFsck(Configuration conf, ExecutorService exec) throws MasterNotRunningException,<a name="line.363"></a>
-<span class="sourceLineNo">364</span>      ZooKeeperConnectionException, IOException, ClassNotFoundException {<a name="line.364"></a>
-<span class="sourceLineNo">365</span>    super(conf);<a name="line.365"></a>
-<span class="sourceLineNo">366</span>    errors = getErrorReporter(getConf());<a name="line.366"></a>
-<span class="sourceLineNo">367</span>    this.executor = exec;<a name="line.367"></a>
-<span class="sourceLineNo">368</span>    lockFileRetryCounterFactory = createLockRetryCounterFactory(getConf());<a name="line.368"></a>
-<span class="sourceLineNo">369</span>    createZNodeRetryCounterFactory = createZnodeRetryCounterFactory(getConf());<a name="line.369"></a>
-<span class="sourceLineNo">370</span>    zkw = createZooKeeperWatcher();<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>   * @return A retry counter factory configured for retrying lock file creation.<a name="line.374"></a>
-<span class="sourceLineNo">375</span>   */<a name="line.375"></a>
-<span class="sourceLineNo">376</span>  public static RetryCounterFactory createLockRetryCounterFactory(Configuration conf) {<a name="line.376"></a>
-<span class="sourceLineNo">377</span>    return new RetryCounterFactory(<a name="line.377"></a>
-<span class="sourceLineNo">378</span>        conf.getInt("hbase.hbck.lockfile.attempts", DEFAULT_MAX_LOCK_FILE_ATTEMPTS),<a name="line.378"></a>
-<span class="sourceLineNo">379</span>        conf.getInt("hbase.hbck.lockfile.attempt.sleep.interval",<a name="line.379"></a>
-<span class="sourceLineNo">380</span>            DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL),<a name="line.380"></a>
-<span class="sourceLineNo">381</span>        conf.getInt("hbase.hbck.lockfile.attempt.maxsleeptime",<a name="line.381"></a>
-<span class="sourceLineNo">382</span>            DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME));<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>  /**<a name="line.385"></a>
-<span class="sourceLineNo">386</span>   * @return A retry counter factory configured for retrying znode creation.<a name="line.386"></a>
-<span class="sourceLineNo">387</span>   */<a name="line.387"></a>
-<span class="sourceLineNo">388</span>  private static RetryCounterFactory createZnodeRetryCounterFactory(Configuration conf) {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>    return new RetryCounterFactory(<a name="line.389"></a>
-<span class="sourceLineNo">390</span>        conf.getInt("hbase.hbck.createznode.attempts", DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS),<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        conf.getInt("hbase.hbck.createznode.attempt.sleep.interval",<a name="line.391"></a>
-<span class="sourceLineNo">392</span>            DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL),<a name="line.392"></a>
-<span class="sourceLineNo">393</span>        conf.getInt("hbase.hbck.createznode.attempt.maxsleeptime",<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME));<a name="line.394"></a>
-<span class="sourceLineNo">395</span>  }<a name="line.395"></a>
-<span class="sourceLineNo">396</span><a name="line.396"></a>
-<span class="sourceLineNo">397</span>  /**<a name="line.397"></a>
-<span class="sourceLineNo">398</span>   * @return Return the tmp dir this tool writes too.<a name="line.398"></a>
-<span class="sourceLineNo">399</span>   */<a name="line.399"></a>
-<span class="sourceLineNo">400</span>  @VisibleForTesting<a name="line.400"></a>
-<span class="sourceLineNo">401</span>  public static Path getTmpDir(Configuration conf) throws IOException {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>    return new Path(FSUtils.getRootDir(conf), HConstants.HBASE_TEMP_DIRECTORY);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>  }<a name="line.403"></a>
-<span class="sourceLineNo">404</span><a name="line.404"></a>
-<span class="sourceLineNo">405</span>  private static class FileLockCallable implements Callable&lt;FSDataOutputStream&gt; {<a name="line.405"></a>
-<span class="sourceLineNo">406</span>    RetryCounter retryCounter;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>    private final Configuration conf;<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    private Path hbckLockPath = null;<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>    public FileLockCallable(Configuration conf, RetryCounter retryCounter) {<a name="line.410"></a>
-<span class="sourceLineNo">411</span>      this.retryCounter = retryCounter;<a name="line.411"></a>
-<span class="sourceLineNo">412</span>      this.conf = conf;<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 Will be &lt;code&gt;null&lt;/code&gt; unless you call {@link #call()}<a name="line.416"></a>
-<span class="sourceLineNo">417</span>     */<a name="line.417"></a>
-<span class="sourceLineNo">418</span>    Path getHbckLockPath() {<a name="line.418"></a>
-<span class="sourceLineNo">419</span>      return this.hbckLockPath;<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    }<a name="line.420"></a>
-<span class="sourceLineNo">421</span><a name="line.421"></a>
-<span class="sourceLineNo">422</span>    @Override<a name="line.422"></a>
-<span class="sourceLineNo">423</span>    public FSDataOutputStream call() throws IOException {<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      try {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        FileSystem fs = FSUtils.getCurrentFileSystem(this.conf);<a name="line.425"></a>
-<span class="sourceLineNo">426</span>        FsPermission defaultPerms = FSUtils.getFilePermissions(fs, this.conf,<a name="line.426"></a>
-<span class="sourceLineNo">427</span>            HConstants.DATA_FILE_UMASK_KEY);<a name="line.427"></a>
-<span class="sourceLineNo">428</span>        Path tmpDir = getTmpDir(conf);<a name="line.428"></a>
-<span class="sourceLineNo">429</span>        this.hbckLockPath = new Path(tmpDir, HBCK_LOCK_FILE);<a name="line.429"></a>
-<span class="sourceLineNo">430</span>        fs.mkdirs(tmpDir);<a name="line.430"></a>
-<span class="sourceLineNo">431</span>        final FSDataOutputStream out = createFileWithRetries(fs, this.hbckLockPath, defaultPerms);<a name="line.431"></a>
-<span class="sourceLineNo">432</span>        out.writeBytes(InetAddress.getLocalHost().toString());<a name="line.432"></a>
-<span class="sourceLineNo">433</span>        // Add a note into the file we write on why hbase2 is writing out an hbck1 lock file.<a name="line.433"></a>
-<span class="sourceLineNo">434</span>        out.writeBytes(" Written by an hbase-2.x Master to block an " +<a name="line.434"></a>
-<span class="sourceLineNo">435</span>            "attempt by an hbase-1.x HBCK tool making modification to state. " +<a name="line.435"></a>
-<span class="sourceLineNo">436</span>            "See 'HBCK must match HBase server version' in the hbase refguide.");<a name="line.436"></a>
-<span class="sourceLineNo">437</span>        out.flush();<a name="line.437"></a>
-<span class="sourceLineNo">438</span>        return out;<a name="line.438"></a>
-<span class="sourceLineNo">439</span>      } catch(RemoteException e) {<a name="line.439"></a>
-<span class="sourceLineNo">440</span>        if(AlreadyBeingCreatedException.class.getName().equals(e.getClassName())){<a name="line.440"></a>
-<span class="sourceLineNo">441</span>          return null;<a name="line.441"></a>
-<span class="sourceLineNo">442</span>        } else {<a name="line.442"></a>
-<span class="sourceLineNo">443</span>          throw e;<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>    private FSDataOutputStream createFileWithRetries(final FileSystem fs,<a name="line.448"></a>
-<span class="sourceLineNo">449</span>        final Path hbckLockFilePath, final FsPermission defaultPerms)<a name="line.449"></a>
-<span class="sourceLineNo">450</span>        throws IOException {<a name="line.450"></a>
-<span class="sourceLineNo">451</span>      IOException exception = null;<a name="line.451"></a>
-<span class="sourceLineNo">452</span>      do {<a name="line.452"></a>
-<span class="sourceLineNo">453</span>        try {<a name="line.453"></a>
-<span class="sourceLineNo">454</span>          return FSUtils.create(fs, hbckLockFilePath, defaultPerms, false);<a name="line.454"></a>
-<span class="sourceLineNo">455</span>        } catch (IOException ioe) {<a name="line.455"></a>
-<span class="sourceLineNo">456</span>          LOG.info("Failed to create lock file " + hbckLockFilePath.getName()<a name="line.456"></a>
-<span class="sourceLineNo">457</span>              + ", try=" + (retryCounter.getAttemptTimes() + 1) + " of "<a name="line.457"></a>
-<span class="sourceLineNo">458</span>              + retryCounter.getMaxAttempts());<a name="line.458"></a>
-<span class="sourceLineNo">459</span>          LOG.debug("Failed to create lock file " + hbckLockFilePath.getName(),<a name="line.459"></a>
-<span class="sourceLineNo">460</span>              ioe);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>          try {<a name="line.461"></a>
-<span class="sourceLineNo">462</span>            exception = ioe;<a name="line.462"></a>
-<span class="sourceLineNo">463</span>            retryCounter.sleepUntilNextRetry();<a name="line.463"></a>
-<span class="sourceLineNo">464</span>          } catch (InterruptedException ie) {<a name="line.464"></a>
-<span class="sourceLineNo">465</span>            throw (InterruptedIOException) new InterruptedIOException(<a name="line.465"></a>
-<span class="sourceLineNo">466</span>                "Can't create lock file " + hbckLockFilePath.getName())<a name="line.466"></a>
-<span class="sourceLineNo">467</span>            .initCause(ie);<a name="line.467"></a>
-<span class="sourceLineNo">468</span>          }<a name="line.468"></a>
-<span class="sourceLineNo">469</span>        }<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      } while (retryCounter.shouldRetry());<a name="line.470"></a>
-<span class="sourceLineNo">471</span><a name="line.471"></a>
-<span class="sourceLineNo">472</span>      throw exception;<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><a name="line.475"></a>
-<span class="sourceLineNo">476</span>  /**<a name="line.476"></a>
-<span class="sourceLineNo">477</span>   * This method maintains a lock using a file. If the creation fails we return null<a name="line.477"></a>
-<span class="sourceLineNo">478</span>   *<a name="line.478"></a>
-<span class="sourceLineNo">479</span>   * @return FSDataOutputStream object corresponding to the newly opened lock file<a name="line.479"></a>
-<span class="sourceLineNo">480</span>   * @throws IOException if IO failure occurs<a name="line.480"></a>
-<span class="sourceLineNo">481</span>   */<a name="line.481"></a>
-<span class="sourceLineNo">482</span>  public static Pair&lt;Path, FSDataOutputStream&gt; checkAndMarkRunningHbck(Configuration conf,<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      RetryCounter retryCounter) throws IOException {<a name="line.483"></a>
-<span class="sourceLineNo">484</span>    FileLockCallable callable = new FileLockCallable(conf, retryCounter);<a name="line.484"></a>
-<span class="sourceLineNo">485</span>    ExecutorService executor = Executors.newFixedThreadPool(1);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>    FutureTask&lt;FSDataOutputStream&gt; futureTask = new FutureTask&lt;&gt;(callable);<a name="line.486"></a>
-<span class="sourceLineNo">487</span>    executor.execute(futureTask);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>    final int timeoutInSeconds = conf.getInt(<a name="line.488"></a>
-<span class="sourceLineNo">489</span>      "hbase.hbck.lockfile.maxwaittime", DEFAULT_WAIT_FOR_LOCK_TIMEOUT);<a name="line.489"></a>
-<span class="sourceLineNo">490</span>    FSDataOutputStream stream = null;<a name="line.490"></a>
-<span class="sourceLineNo">491</span>    try {<a name="line.491"></a>
-<span class="sourceLineNo">492</span>      stream = futureTask.get(timeoutInSeconds, TimeUnit.SECONDS);<a name="line.492"></a>
-<span class="sourceLineNo">493</span>    } catch (ExecutionException ee) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>      LOG.warn("Encountered exception when opening lock file", ee);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>    } catch (InterruptedException ie) {<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      LOG.warn("Interrupted when opening lock file", ie);<a name="line.496"></a>
-<span class="sourceLineNo">497</span>      Thread.currentThread().interrupt();<a name="line.497"></a>
-<span class="sourceLineNo">498</span>    } catch (TimeoutException exception) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>      // took too long to obtain lock<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      LOG.warn("Took more than " + timeoutInSeconds + " seconds in obtaining lock");<a name="line.500"></a>
-<span class="sourceLineNo">501</span>      futureTask.cancel(true);<a name="line.501"></a>
-<span class="sourceLineNo">502</span>    } finally {<a name="line.502"></a>
-<span class="sourceLineNo">503</span>      executor.shutdownNow();<a name="line.503"></a>
-<span class="sourceLineNo">504</span>    }<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    return new Pair&lt;Path, FSDataOutputStream&gt;(callable.getHbckLockPath(), stream);<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>  private void unlockHbck() {<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    if (isExclusive() &amp;&amp; hbckLockCleanup.compareAndSet(true, false)) {<a name="line.509"></a>
-<span class="sourceLineNo">510</span>      RetryCounter retryCounter = lockFileRetryCounterFactory.create();<a name="line.510"></a>
-<span class="sourceLineNo">511</span>      do {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>        try {<a name="line.512"></a>
-<span class="sourceLineNo">513</span>          IOUtils.closeQuietly(hbckOutFd);<a name="line.513"></a>
-<span class="sourceLineNo">514</span>          FSUtils.delete(FSUtils.getCurrentFileSystem(getConf()), HBCK_LOCK_PATH, true);<a name="line.514"></a>
-<span class="sourceLineNo">515</span>          LOG.info("Finishing hbck");<a name="line.515"></a>
-<span class="sourceLineNo">516</span>          return;<a name="line.516"></a>
-<span class="sourceLineNo">517</span>        } catch (IOException ioe) {<a name="line.517"></a>
-<span class="sourceLineNo">518</span>          LOG.info("Failed to delete " + HBCK_LOCK_PATH + ", try="<a name="line.518"></a>
-<span class="sourceLineNo">519</span>              + (retryCounter.getAttemptTimes() + 1) + " of "<a name="line.519"></a>
-<span class="sourceLineNo">520</span>              + retryCounter.getMaxAttempts());<a name="line.520"></a>
-<span class="sourceLineNo">521</span>          LOG.debug("Failed to delete " + HBCK_LOCK_PATH, ioe);<a name="line.521"></a>
-<span class="sourceLineNo">522</span>          try {<a name="line.522"></a>
-<span class="sourceLineNo">523</span>            retryCounter.sleepUntilNextRetry();<a name="line.523"></a>
-<span class="sourceLineNo">524</span>          } catch (InterruptedException ie) {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>            Thread.currentThread().interrupt();<a name="line.525"></a>
-<span class="sourceLineNo">526</span>            LOG.warn("Interrupted while deleting lock file" +<a name="line.526"></a>
-<span class="sourceLineNo">527</span>                HBCK_LOCK_PATH);<a name="line.527"></a>
-<span class="sourceLineNo">528</span>            return;<a name="line.528"></a>
-<span class="sourceLineNo">529</span>          }<a name="line.529"></a>
-<span class="sourceLineNo">530</span>        }<a name="line.530"></a>
-<span class="sourceLineNo">531</span>      } while (retryCounter.shouldRetry());<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><a name="line.534"></a>
-<span class="sourceLineNo">535</span>  /**<a name="line.535"></a>
-<span class="sourceLineNo">536</span>   * To repair region consistency, one must call connect() in order to repair<a name="line.536"></a>
-<span class="sourceLineNo">537</span>   * online state.<a name="line.537"></a>
-<span class="sourceLineNo">538</span>   */<a name="line.538"></a>
-<span class="sourceLineNo">539</span>  public void connect() throws IOException {<a name="line.539"></a>
-<span class="sourceLineNo">540</span><a name="line.540"></a>
-<span class="sourceLineNo">541</span>    if (isExclusive()) {<a name="line.541"></a>
-<span class="sourceLineNo">542</span>      // Grab the lock<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      Pair&lt;Path, FSDataOutputStream&gt; pair =<a name="line.543"></a>
-<span class="sourceLineNo">544</span>          checkAndMarkRunningHbck(getConf(), this.lockFileRetryCounterFactory.create());<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      HBCK_LOCK_PATH = pair.getFirst();<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      this.hbckOutFd = pair.getSecond();<a name="line.546"></a>
-<span class="sourceLineNo">547</span>      if (hbckOutFd == null) {<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        setRetCode(-1);<a name="line.548"></a>
-<span class="sourceLineNo">549</span>        LOG.error("Another instance of hbck is fixing HBase, exiting this instance. " +<a name="line.549"></a>
-<span class="sourceLineNo">550</span>            "[If you are sure no other instance is running, delete the lock file " +<a name="line.550"></a>
-<span class="sourceLineNo">551</span>            HBCK_LOCK_PATH + " and rerun the tool]");<a name="line.551"></a>
-<span class="sourceLineNo">552</span>        throw new IOException("Duplicate hbck - Abort");<a name="line.552"></a>
-<span class="sourceLineNo">553</span>      }<a name="line.553"></a>
-<span class="sourceLineNo">554</span><a name="line.554"></a>
-<span class="sourceLineNo">555</span>      // Make sure to cleanup the lock<a name="line.555"></a>
-<span class="sourceLineNo">556</span>      hbckLockCleanup.set(true);<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    }<a name="line.557"></a>
+<span class="sourceLineNo">119</span>import org.apache.hadoop.hbase.security.AccessDeniedException;<a name="line.119"></a>
+<span class="sourceLineNo">120</span>import org.apache.hadoop.hbase.security.UserProvider;<a name="line.120"></a>
+<span class="sourceLineNo">121</span>import org.apache.hadoop.hbase.util.Bytes.ByteArrayComparator;<a name="line.121"></a>
+<span class="sourceLineNo">122</span>import org.apache.hadoop.hbase.util.HbckErrorReporter.ERROR_CODE;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>import org.apache.hadoop.hbase.util.hbck.HFileCorruptionChecker;<a name="line.123"></a>
+<span class="sourceLineNo">124</span>import org.apache.hadoop.hbase.util.hbck.ReplicationChecker;<a name="line.124"></a>
+<span class="sourceLineNo">125</span>import org.apache.hadoop.hbase.util.hbck.TableIntegrityErrorHandler;<a name="line.125"></a>
+<span class="sourceLineNo">126</span>import org.apache.hadoop.hbase.wal.WALSplitUtil;<a name="line.126"></a>
+<span class="sourceLineNo">127</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.127"></a>
+<span class="sourceLineNo">128</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.128"></a>
+<span class="sourceLineNo">129</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.129"></a>
+<span class="sourceLineNo">130</span>import org.apache.hadoop.hdfs.protocol.AlreadyBeingCreatedException;<a name="line.130"></a>
+<span class="sourceLineNo">131</span>import org.apache.hadoop.ipc.RemoteException;<a name="line.131"></a>
+<span class="sourceLineNo">132</span>import org.apache.hadoop.security.UserGroupInformation;<a name="line.132"></a>
+<span class="sourceLineNo">133</span>import org.apache.hadoop.util.ReflectionUtils;<a name="line.133"></a>
+<span class="sourceLineNo">134</span>import org.apache.hadoop.util.Tool;<a name="line.134"></a>
+<span class="sourceLineNo">135</span>import org.apache.hadoop.util.ToolRunner;<a name="line.135"></a>
+<span class="sourceLineNo">136</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.136"></a>
+<span class="sourceLineNo">137</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.137"></a>
+<span class="sourceLineNo">138</span>import org.apache.zookeeper.KeeperException;<a name="line.138"></a>
+<span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
+<span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
+<span class="sourceLineNo">141</span><a name="line.141"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.base.Preconditions;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.146"></a>
+<span class="sourceLineNo">147</span><a name="line.147"></a>
+<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
+<span class="sourceLineNo">149</span> * HBaseFsck (hbck) is a tool for checking and repairing region consistency and<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * table integrity problems in a corrupted HBase. This tool was written for hbase-1.x. It does not<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * work with hbase-2.x; it can read state but is not allowed to change state; i.e. effect 'repair'.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> * Even though it can 'read' state, given how so much has changed in how hbase1 and hbase2 operate,<a name="line.152"></a>
+<span class="sourceLineNo">153</span> * it will often misread. See hbck2 (HBASE-19121) for a hbck tool for hbase2. This class is<a name="line.153"></a>
+<span class="sourceLineNo">154</span> * deprecated.<a name="line.154"></a>
+<span class="sourceLineNo">155</span> *<a name="line.155"></a>
+<span class="sourceLineNo">156</span> * &lt;p&gt;<a name="line.156"></a>
+<span class="sourceLineNo">157</span> * Region consistency checks verify that hbase:meta, region deployment on region<a name="line.157"></a>
+<span class="sourceLineNo">158</span> * servers and the state of data in HDFS (.regioninfo files) all are in<a name="line.158"></a>
+<span class="sourceLineNo">159</span> * accordance.<a name="line.159"></a>
+<span class="sourceLineNo">160</span> * &lt;p&gt;<a name="line.160"></a>
+<span class="sourceLineNo">161</span> * Table integrity checks verify that all possible row keys resolve to exactly<a name="line.161"></a>
+<span class="sourceLineNo">162</span> * one region of a table.  This means there are no individual degenerate<a name="line.162"></a>
+<span class="sourceLineNo">163</span> * or backwards regions; no holes between regions; and that there are no<a name="line.163"></a>
+<span class="sourceLineNo">164</span> * overlapping regions.<a name="line.164"></a>
+<span class="sourceLineNo">165</span> * &lt;p&gt;<a name="line.165"></a>
+<span class="sourceLineNo">166</span> * The general repair strategy works in two phases:<a name="line.166"></a>
+<span class="sourceLineNo">167</span> * &lt;ol&gt;<a name="line.167"></a>
+<span class="sourceLineNo">168</span> * &lt;li&gt; Repair Table Integrity on HDFS. (merge or fabricate regions)<a name="line.168"></a>
+<span class="sourceLineNo">169</span> * &lt;li&gt; Repair Region Consistency with hbase:meta and assignments<a name="line.169"></a>
+<span class="sourceLineNo">170</span> * &lt;/ol&gt;<a name="line.170"></a>
+<span class="sourceLineNo">171</span> * &lt;p&gt;<a name="line.171"></a>
+<span class="sourceLineNo">172</span> * For table integrity repairs, the tables' region directories are scanned<a name="line.172"></a>
+<span class="sourceLineNo">173</span> * for .regioninfo files.  Each table's integrity is then verified.  If there<a name="line.173"></a>
+<span class="sourceLineNo">174</span> * are any orphan regions (regions with no .regioninfo files) or holes, new<a name="line.174"></a>
+<span class="sourceLineNo">175</span> * regions are fabricated.  Backwards regions are sidelined as well as empty<a name="line.175"></a>
+<span class="sourceLineNo">176</span> * degenerate (endkey==startkey) regions.  If there are any overlapping regions,<a name="line.176"></a>
+<span class="sourceLineNo">177</span> * a new region is created and all data is merged into the new region.<a name="line.177"></a>
+<span class="sourceLineNo">178</span> * &lt;p&gt;<a name="line.178"></a>
+<span class="sourceLineNo">179</span> * Table integrity repairs deal solely with HDFS and could potentially be done<a name="line.179"></a>
+<span class="sourceLineNo">180</span> * offline -- the hbase region servers or master do not need to be running.<a name="line.180"></a>
+<span class="sourceLineNo">181</span> * This phase can eventually be used to completely reconstruct the hbase:meta table in<a name="line.181"></a>
+<span class="sourceLineNo">182</span> * an offline fashion.<a name="line.182"></a>
+<span class="sourceLineNo">183</span> * &lt;p&gt;<a name="line.183"></a>
+<span class="sourceLineNo">184</span> * Region consistency requires three conditions -- 1) valid .regioninfo file<a name="line.184"></a>
+<span class="sourceLineNo">185</span> * present in an HDFS region dir,  2) valid row with .regioninfo data in META,<a name="line.185"></a>
+<span class="sourceLineNo">186</span> * and 3) a region is deployed only at the regionserver that was assigned to<a name="line.186"></a>
+<span class="sourceLineNo">187</span> * with proper state in the master.<a name="line.187"></a>
+<span class="sourceLineNo">188</span> * &lt;p&gt;<a name="line.188"></a>
+<span class="sourceLineNo">189</span> * Region consistency repairs require hbase to be online so that hbck can<a name="line.189"></a>
+<span class="sourceLineNo">190</span> * contact the HBase master and region servers.  The hbck#connect() method must<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * first be called successfully.  Much of the region consistency information<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * is transient and less risky to repair.<a name="line.192"></a>
+<span class="sourceLineNo">193</span> * &lt;p&gt;<a name="line.193"></a>
+<span class="sourceLineNo">194</span> * If hbck is run from the command line, there are a handful of arguments that<a name="line.194"></a>
+<span class="sourceLineNo">195</span> * can be used to limit the kinds of repairs hbck will do.  See the code in<a name="line.195"></a>
+<span class="sourceLineNo">196</span> * {@link #printUsageAndExit()} for more details.<a name="line.196"></a>
+<span class="sourceLineNo">197</span> * @deprecated For removal in hbase-4.0.0. Use HBCK2 instead.<a name="line.197"></a>
+<span class="sourceLineNo">198</span> */<a name="line.198"></a>
+<span class="sourceLineNo">199</span>@Deprecated<a name="line.199"></a>
+<span class="sourceLineNo">200</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)<a name="line.200"></a>
+<span class="sourceLineNo">201</span>@InterfaceStability.Evolving<a name="line.201"></a>
+<span class="sourceLineNo">202</span>public class HBaseFsck extends Configured implements Closeable {<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  public static final long DEFAULT_TIME_LAG = 60000; // default value of 1 minute<a name="line.203"></a>
+<span class="sourceLineNo">204</span>  public static final long DEFAULT_SLEEP_BEFORE_RERUN = 10000;<a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final int MAX_NUM_THREADS = 50; // #threads to contact regions<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  private static boolean rsSupportsOffline = true;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  private static final int DEFAULT_OVERLAPS_TO_SIDELINE = 2;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  private static final int DEFAULT_MAX_MERGE = 5;<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>   * Here is where hbase-1.x used to default the lock for hbck1.<a name="line.211"></a>
+<span class="sourceLineNo">212</span>   * It puts in place a lock when it goes to write/make changes.<a name="line.212"></a>
+<span class="sourceLineNo">213</span>   */<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  @VisibleForTesting<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  public static final String HBCK_LOCK_FILE = "hbase-hbck.lock";<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private static final int DEFAULT_MAX_LOCK_FILE_ATTEMPTS = 5;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private static final int DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL = 200; // milliseconds<a name="line.217"></a>
+<span class="sourceLineNo">218</span>  private static final int DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME = 5000; // milliseconds<a name="line.218"></a>
+<span class="sourceLineNo">219</span>  // We have to set the timeout value &gt; HdfsConstants.LEASE_SOFTLIMIT_PERIOD.<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  // In HADOOP-2.6 and later, the Namenode proxy now created with custom RetryPolicy for<a name="line.220"></a>
+<span class="sourceLineNo">221</span>  // AlreadyBeingCreatedException which is implies timeout on this operations up to<a name="line.221"></a>
+<span class="sourceLineNo">222</span>  // HdfsConstants.LEASE_SOFTLIMIT_PERIOD (60 seconds).<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private static final int DEFAULT_WAIT_FOR_LOCK_TIMEOUT = 80; // seconds<a name="line.223"></a>
+<span class="sourceLineNo">224</span>  private static final int DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS = 5;<a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private static final int DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL = 200; // milliseconds<a name="line.225"></a>
+<span class="sourceLineNo">226</span>  private static final int DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME = 5000; // milliseconds<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>   * Internal resources<a name="line.229"></a>
+<span class="sourceLineNo">230</span>   **********************/<a name="line.230"></a>
+<span class="sourceLineNo">231</span>  private static final Logger LOG = LoggerFactory.getLogger(HBaseFsck.class.getName());<a name="line.231"></a>
+<span class="sourceLineNo">232</span>  private ClusterMetrics status;<a name="line.232"></a>
+<span class="sourceLineNo">233</span>  private Connection connection;<a name="line.233"></a>
+<span class="sourceLineNo">234</span>  private Admin admin;<a name="line.234"></a>
+<span class="sourceLineNo">235</span>  private Table meta;<a name="line.235"></a>
+<span class="sourceLineNo">236</span>  // threads to do ||izable tasks: retrieve data from regionservers, handle overlapping regions<a name="line.236"></a>
+<span class="sourceLineNo">237</span>  protected ExecutorService executor;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>  private long startMillis = EnvironmentEdgeManager.currentTime();<a name="line.238"></a>
+<span class="sourceLineNo">239</span>  private HFileCorruptionChecker hfcc;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>  private int retcode = 0;<a name="line.240"></a>
+<span class="sourceLineNo">241</span>  private Path HBCK_LOCK_PATH;<a name="line.241"></a>
+<span class="sourceLineNo">242</span>  private FSDataOutputStream hbckOutFd;<a name="line.242"></a>
+<span class="sourceLineNo">243</span>  // This lock is to prevent cleanup of balancer resources twice between<a name="line.243"></a>
+<span class="sourceLineNo">244</span>  // ShutdownHook and the main code. We cleanup only if the connect() is<a name="line.244"></a>
+<span class="sourceLineNo">245</span>  // successful<a name="line.245"></a>
+<span class="sourceLineNo">246</span>  private final AtomicBoolean hbckLockCleanup = new AtomicBoolean(false);<a name="line.246"></a>
+<span class="sourceLineNo">247</span><a name="line.247"></a>
+<span class="sourceLineNo">248</span>  // Unsupported options in HBase 2.0+<a name="line.248"></a>
+<span class="sourceLineNo">249</span>  private static final Set&lt;String&gt; unsupportedOptionsInV2 = Sets.newHashSet("-fix",<a name="line.249"></a>
+<span class="sourceLineNo">250</span>      "-fixAssignments", "-fixMeta", "-fixHdfsHoles", "-fixHdfsOrphans", "-fixTableOrphans",<a name="line.250"></a>
+<span class="sourceLineNo">251</span>      "-fixHdfsOverlaps", "-sidelineBigOverlaps", "-fixSplitParents", "-removeParents",<a name="line.251"></a>
+<span class="sourceLineNo">252</span>      "-fixEmptyMetaCells", "-repair", "-repairHoles", "-maxOverlapsToSideline", "-maxMerge");<a name="line.252"></a>
+<span class="sourceLineNo">253</span><a name="line.253"></a>
+<span class="sourceLineNo">254</span>  /***********<a name="line.254"></a>
+<span class="sourceLineNo">255</span>   * Options<a name="line.255"></a>
+<span class="sourceLineNo">256</span>   ***********/<a name="line.256"></a>
+<span class="sourceLineNo">257</span>  private static boolean details = false; // do we display the full report<a name="line.257"></a>
+<span class="sourceLineNo">258</span>  private long timelag = DEFAULT_TIME_LAG; // tables whose modtime is older<a name="line.258"></a>
+<span class="sourceLineNo">259</span>  private static boolean forceExclusive = false; // only this hbck can modify HBase<a name="line.259"></a>
+<span class="sourceLineNo">260</span>  private boolean fixAssignments = false; // fix assignment errors?<a name="line.260"></a>
+<span class="sourceLineNo">261</span>  private boolean fixMeta = false; // fix meta errors?<a name="line.261"></a>
+<span class="sourceLineNo">262</span>  private boolean checkHdfs = true; // load and check fs consistency?<a name="line.262"></a>
+<span class="sourceLineNo">263</span>  private boolean fixHdfsHoles = false; // fix fs holes?<a name="line.263"></a>
+<span class="sourceLineNo">264</span>  private boolean fixHdfsOverlaps = false; // fix fs overlaps (risky)<a name="line.264"></a>
+<span class="sourceLineNo">265</span>  private boolean fixHdfsOrphans = false; // fix fs holes (missing .regioninfo)<a name="line.265"></a>
+<span class="sourceLineNo">266</span>  private boolean fixTableOrphans = false; // fix fs holes (missing .tableinfo)<a name="line.266"></a>
+<span class="sourceLineNo">267</span>  private boolean fixVersionFile = false; // fix missing hbase.version file in hdfs<a name="line.267"></a>
+<span class="sourceLineNo">268</span>  private boolean fixSplitParents = false; // fix lingering split parents<a name="line.268"></a>
+<span class="sourceLineNo">269</span>  private boolean removeParents = false; // remove split parents<a name="line.269"></a>
+<span class="sourceLineNo">270</span>  private boolean fixReferenceFiles = false; // fix lingering reference store file<a name="line.270"></a>
+<span class="sourceLineNo">271</span>  private boolean fixHFileLinks = false; // fix lingering HFileLinks<a name="line.271"></a>
+<span class="sourceLineNo">272</span>  private boolean fixEmptyMetaCells = false; // fix (remove) empty REGIONINFO_QUALIFIER rows<a name="line.272"></a>
+<span class="sourceLineNo">273</span>  private boolean fixReplication = false; // fix undeleted replication queues for removed peer<a name="line.273"></a>
+<span class="sourceLineNo">274</span>  private boolean cleanReplicationBarrier = false; // clean replication barriers of a table<a name="line.274"></a>
+<span class="sourceLineNo">275</span>  private boolean fixAny = false; // Set to true if any of the fix is required.<a name="line.275"></a>
+<span class="sourceLineNo">276</span><a name="line.276"></a>
+<span class="sourceLineNo">277</span>  // limit checking/fixes to listed tables, if empty attempt to check/fix all<a name="line.277"></a>
+<span class="sourceLineNo">278</span>  // hbase:meta are always checked<a name="line.278"></a>
+<span class="sourceLineNo">279</span>  private Set&lt;TableName&gt; tablesIncluded = new HashSet&lt;&gt;();<a name="line.279"></a>
+<span class="sourceLineNo">280</span>  private TableName cleanReplicationBarrierTable;<a name="line.280"></a>
+<span class="sourceLineNo">281</span>  private int maxMerge = DEFAULT_MAX_MERGE; // maximum number of overlapping regions to merge<a name="line.281"></a>
+<span class="sourceLineNo">282</span>  // maximum number of overlapping regions to sideline<a name="line.282"></a>
+<span class="sourceLineNo">283</span>  private int maxOverlapsToSideline = DEFAULT_OVERLAPS_TO_SIDELINE;<a name="line.283"></a>
+<span class="sourceLineNo">284</span>  private boolean sidelineBigOverlaps = false; // sideline overlaps with &gt;maxMerge regions<a name="line.284"></a>
+<span class="sourceLineNo">285</span>  private Path sidelineDir = null;<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>  private boolean rerun = false; // if we tried to fix something, rerun hbck<a name="line.287"></a>
+<span class="sourceLineNo">288</span>  private static boolean summary = false; // if we want to print less output<a name="line.288"></a>
+<span class="sourceLineNo">289</span>  private boolean checkMetaOnly = false;<a name="line.289"></a>
+<span class="sourceLineNo">290</span>  private boolean checkRegionBoundaries = false;<a name="line.290"></a>
+<span class="sourceLineNo">291</span>  private boolean ignorePreCheckPermission = false; // if pre-check permission<a name="line.291"></a>
+<span class="sourceLineNo">292</span><a name="line.292"></a>
+<span class="sourceLineNo">293</span>  /*********<a name="line.293"></a>
+<span class="sourceLineNo">294</span>   * State<a name="line.294"></a>
+<span class="sourceLineNo">295</span>   *********/<a name="line.295"></a>
+<span class="sourceLineNo">296</span>  final private HbckErrorReporter errors;<a name="line.296"></a>
+<span class="sourceLineNo">297</span>  int fixes = 0;<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>   * This map contains the state of all hbck items.  It maps from encoded region<a name="line.300"></a>
+<span class="sourceLineNo">301</span>   * name to HbckRegionInfo structure.  The information contained in HbckRegionInfo is used<a name="line.301"></a>
+<span class="sourceLineNo">302</span>   * to detect and correct consistency (hdfs/meta/deployment) problems.<a name="line.302"></a>
+<span class="sourceLineNo">303</span>   */<a name="line.303"></a>
+<span class="sourceLineNo">304</span>  private TreeMap&lt;String, HbckRegionInfo&gt; regionInfoMap = new TreeMap&lt;&gt;();<a name="line.304"></a>
+<span class="sourceLineNo">305</span>  // Empty regioninfo qualifiers in hbase:meta<a name="line.305"></a>
+<span class="sourceLineNo">306</span>  private Set&lt;Result&gt; emptyRegionInfoQualifiers = new HashSet&lt;&gt;();<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>   * This map from Tablename -&gt; TableInfo contains the structures necessary to<a name="line.309"></a>
+<span class="sourceLineNo">310</span>   * detect table consistency problems (holes, dupes, overlaps).  It is sorted<a name="line.310"></a>
+<span class="sourceLineNo">311</span>   * to prevent dupes.<a name="line.311"></a>
+<span class="sourceLineNo">312</span>   *<a name="line.312"></a>
+<span class="sourceLineNo">313</span>   * If tablesIncluded is empty, this map contains all tables.<a name="line.313"></a>
+<span class="sourceLineNo">314</span>   * Otherwise, it contains only meta tables and tables in tablesIncluded,<a name="line.314"></a>
+<span class="sourceLineNo">315</span>   * unless checkMetaOnly is specified, in which case, it contains only<a name="line.315"></a>
+<span class="sourceLineNo">316</span>   * the meta table<a name="line.316"></a>
+<span class="sourceLineNo">317</span>   */<a name="line.317"></a>
+<span class="sourceLineNo">318</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; tablesInfo = new ConcurrentSkipListMap&lt;&gt;();<a name="line.318"></a>
+<span class="sourceLineNo">319</span><a name="line.319"></a>
+<span class="sourceLineNo">320</span>  /**<a name="line.320"></a>
+<span class="sourceLineNo">321</span>   * When initially looking at HDFS, we attempt to find any orphaned data.<a name="line.321"></a>
+<span class="sourceLineNo">322</span>   */<a name="line.322"></a>
+<span class="sourceLineNo">323</span>  private List&lt;HbckRegionInfo&gt; orphanHdfsDirs = Collections.synchronizedList(new ArrayList&lt;&gt;());<a name="line.323"></a>
+<span class="sourceLineNo">324</span><a name="line.324"></a>
+<span class="sourceLineNo">325</span>  private Map&lt;TableName, Set&lt;String&gt;&gt; orphanTableDirs = new HashMap&lt;&gt;();<a name="line.325"></a>
+<span class="sourceLineNo">326</span>  private Map&lt;TableName, TableState&gt; tableStates = new HashMap&lt;&gt;();<a name="line.326"></a>
+<span class="sourceLineNo">327</span>  private final RetryCounterFactory lockFileRetryCounterFactory;<a name="line.327"></a>
+<span class="sourceLineNo">328</span>  private final RetryCounterFactory createZNodeRetryCounterFactory;<a name="line.328"></a>
+<span class="sourceLineNo">329</span><a name="line.329"></a>
+<span class="sourceLineNo">330</span>  private Map&lt;TableName, Set&lt;String&gt;&gt; skippedRegions = new HashMap&lt;&gt;();<a name="line.330"></a>
+<span class="sourceLineNo">331</span><a name="line.331"></a>
+<span class="sourceLineNo">332</span>  private ZKWatcher zkw = null;<a name="line.332"></a>
+<span class="sourceLineNo">333</span>  private String hbckEphemeralNodePath = null;<a name="line.333"></a>
+<span class="sourceLineNo">334</span>  private boolean hbckZodeCreated = false;<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>   * Constructor<a name="line.337"></a>
+<span class="sourceLineNo">338</span>   *<a name="line.338"></a>
+<span class="sourceLineNo">339</span>   * @param conf Configuration object<a name="line.339"></a>
+<span class="sourceLineNo">340</span>   * @throws MasterNotRunningException if the master is not running<a name="line.340"></a>
+<span class="sourceLineNo">341</span>   * @throws ZooKeeperConnectionException if unable to connect to ZooKeeper<a name="line.341"></a>
+<span class="sourceLineNo">342</span>   */<a name="line.342"></a>
+<span class="sourceLineNo">343</span>  public HBaseFsck(Configuration conf) throws IOException, ClassNotFoundException {<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    this(conf, createThreadPool(conf));<a name="line.344"></a>
+<span class="sourceLineNo">345</span>  }<a name="line.345"></a>
+<span class="sourceLineNo">346</span><a name="line.346"></a>
+<span class="sourceLineNo">347</span>  private static ExecutorService createThreadPool(Configuration conf) {<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    int numThreads = conf.getInt("hbasefsck.numthreads", MAX_NUM_THREADS);<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    return new ScheduledThreadPoolExecutor(numThreads, Threads.newDaemonThreadFactory("hbasefsck"));<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>   * Constructor<a name="line.353"></a>
+<span class="sourceLineNo">354</span>   *<a name="line.354"></a>
+<span class="sourceLineNo">355</span>   * @param conf<a name="line.355"></a>
+<span class="sourceLineNo">356</span>   *          Configuration object<a name="line.356"></a>
+<span class="sourceLineNo">357</span>   * @throws MasterNotRunningException<a name="line.357"></a>
+<span class="sourceLineNo">358</span>   *           if the master is not running<a name="line.358"></a>
+<span class="sourceLineNo">359</span>   * @throws ZooKeeperConnectionException<a name="line.359"></a>
+<span class="sourceLineNo">360</span>   *           if unable to connect to ZooKeeper<a name="line.360"></a>
+<span class="sourceLineNo">361</span>   */<a name="line.361"></a>
+<span class="sourceLineNo">362</span>  public HBaseFsck(Configuration conf, ExecutorService exec) throws MasterNotRunningException,<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      ZooKeeperConnectionException, IOException, ClassNotFoundException {<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    super(conf);<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    errors = getErrorReporter(getConf());<a name="line.365"></a>
+<span class="sourceLineNo">366</span>    this.executor = exec;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>    lockFileRetryCounterFactory = createLockRetryCounterFactory(getConf());<a name="line.367"></a>
+<span class="sourceLineNo">368</span>    createZNodeRetryCounterFactory = createZnodeRetryCounterFactory(getConf());<a name="line.368"></a>
+<span class="sourceLineNo">369</span>    zkw = createZooKeeperWatcher();<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>   * @return A retry counter factory configured for retrying lock file creation.<a name="line.373"></a>
+<span class="sourceLineNo">374</span>   */<a name="line.374"></a>
+<span class="sourceLineNo">375</span>  public static RetryCounterFactory createLockRetryCounterFactory(Configuration conf) {<a name="line.375"></a>
+<span class="sourceLineNo">376</span>    return new RetryCounterFactory(<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        conf.getInt("hbase.hbck.lockfile.attempts", DEFAULT_MAX_LOCK_FILE_ATTEMPTS),<a name="line.377"></a>
+<span class="sourceLineNo">378</span>        conf.getInt("hbase.hbck.lockfile.attempt.sleep.interval",<a name="line.378"></a>
+<span class="sourceLineNo">379</span>            DEFAULT_LOCK_FILE_ATTEMPT_SLEEP_INTERVAL),<a name="line.379"></a>
+<span class="sourceLineNo">380</span>        conf.getInt("hbase.hbck.lockfile.attempt.maxsleeptime",<a name="line.380"></a>
+<span class="sourceLineNo">381</span>            DEFAULT_LOCK_FILE_ATTEMPT_MAX_SLEEP_TIME));<a name="line.381"></a>
+<span class="sourceLineNo">382</span>  }<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>   * @return A retry counter factory configured for retrying znode creation.<a name="line.385"></a>
+<span class="sourceLineNo">386</span>   */<a name="line.386"></a>
+<span class="sourceLineNo">387</span>  private static RetryCounterFactory createZnodeRetryCounterFactory(Configuration conf) {<a name="line.387"></a>
+<span class="sourceLineNo">388</span>    return new RetryCounterFactory(<a name="line.388"></a>
+<span class="sourceLineNo">389</span>        conf.getInt("hbase.hbck.createznode.attempts", DEFAULT_MAX_CREATE_ZNODE_ATTEMPTS),<a name="line.389"></a>
+<span class="sourceLineNo">390</span>        conf.getInt("hbase.hbck.createznode.attempt.sleep.interval",<a name="line.390"></a>
+<span class="sourceLineNo">391</span>            DEFAULT_CREATE_ZNODE_ATTEMPT_SLEEP_INTERVAL),<a name="line.391"></a>
+<span class="sourceLineNo">392</span>        conf.getInt("hbase.hbck.createznode.attempt.maxsleeptime",<a name="line.392"></a>
+<span class="sourceLineNo">393</span>            DEFAULT_CREATE_ZNODE_ATTEMPT_MAX_SLEEP_TIME));<a name="line.393"></a>
+<span class="sourceLineNo">394</span>  }<a name="line.394"></a>
+<span class="sourceLineNo">395</span><a name="line.395"></a>
+<span class="sourceLineNo">396</span>  /**<a name="line.396"></a>
+<span class="sourceLineNo">397</span>   * @return Return the tmp dir this tool writes too.<a name="line.397"></a>
+<span class="sourceLineNo">398</span>   */<a name="line.398"></a>
+<span class="sourceLineNo">399</span>  @VisibleForTesting<a name="line.399"></a>
+<span class="sourceLineNo">400</span>  public static Path getTmpDir(Configuration conf) throws IOException {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>    return new Path(FSUtils.getRootDir(conf), HConstants.HBASE_TEMP_DIRECTORY);<a name="line.401"></a>
+<span class="sourceLineNo">402</span>  }<a name="line.402"></a>
+<span class="sourceLineNo">403</span><a name="line.403"></a>
+<span class="sourceLineNo">404</span>  private static class FileLockCallable implements Callable&lt;FSDataOutputStream&gt; {<a name="line.404"></a>
+<span class="sourceLineNo">405</span>    RetryCounter retryCounter;<a name="line.405"></a>
+<span class="sourceLineNo">406</span>    private final Configuration conf;<a name="line.406"></a>
+<span class="sourceLineNo">407</span>    private Path hbckLockPath = null;<a name="line.407"></a>
+<span class="sourceLineNo">408</span><a name="line.408"></a>
+<span class="sourceLineNo">409</span>    public FileLockCallable(Configuration conf, RetryCounter retryCounter) {<a name="line.409"></a>
+<span class="sourceLineNo">410</span>      this.retryCounter = retryCounter;<a name="line.410"></a>
+<span class="sourceLineNo">411</span>      this.conf = conf;<a name="line.411"></a>
+<span class="sourceLineNo">412</span>    }<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>     * @return Will be &lt;code&gt;null&lt;/code&gt; unless you call {@link #call()}<a name="line.415"></a>
+<span class="sourceLineNo">416</span>     */<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    Path getHbckLockPath() {<a name="line.417"></a>
+<span class="sourceLineNo">418</span>      return this.hbckLockPath;<a name="line.418"></a>
+<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>    @Override<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    public FSDataOutputStream call() throws IOException {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      try {<a name="line.423"></a>
+<span class="sourceLineNo">424</span>        FileSystem fs = FSUtils.getCurrentFileSystem(this.conf);<a name="line.424"></a>
+<span class="sourceLineNo">425</span>        FsPermission defaultPerms = FSUtils.getFilePermissions(fs, this.conf,<a name="line.425"></a>
+<span class="sourceLineNo">426</span>            HConstants.DATA_FILE_UMASK_KEY);<a name="line.426"></a>
+<span class="sourceLineNo">427</span>        Path tmpDir = getTmpDir(conf);<a name="line.427"></a>
+<span class="sourceLineNo">428</span>        this.hbckLockPath = new Path(tmpDir, HBCK_LOCK_FILE);<a name="line.428"></a>
+<span class="sourceLineNo">429</span>        fs.mkdirs(tmpDir);<a name="line.429"></a>
+<span class="sourceLineNo">430</span>        final FSDataOutputStream out = createFileWithRetries(fs, this.hbckLockPath, defaultPerms);<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        out.writeBytes(InetAddress.getLocalHost().toString());<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        // Add a note into the file we write on why hbase2 is writing out an hbck1 lock file.<a name="line.432"></a>
+<span class="sourceLineNo">433</span>        out.writeBytes(" Written by an hbase-2.x Master to block an " +<a name="line.433"></a>
+<span class="sourceLineNo">434</span>            "attempt by an hbase-1.x HBCK tool making modification to state. " +<a name="line.434"></a>
+<span class="sourceLineNo">435</span>            "See 'HBCK must match HBase server version' in the hbase refguide.");<a name="line.435"></a>
+<span class="sourceLineNo">436</span>        out.flush();<a name="line.436"></a>
+<span class="sourceLineNo">437</span>        return out;<a name="line.437"></a>
+<span class="sourceLineNo">438</span>      } catch(RemoteException e) {<a name="line.438"></a>
+<span class="sourceLineNo">439</span>        if(AlreadyBeingCreatedException.class.getName().equals(e.getClassName())){<a name="line.439"></a>
+<span class="sourceLineNo">440</span>          return null;<a name="line.440"></a>
+<span class="sourceLineNo">441</span>        } else {<a name="line.441"></a>
+<span class="sourceLineNo">442</span>          throw e;<a name="line.442"></a>
+<span class="sourceLineNo">443</span>        }<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>    private FSDataOutputStream createFileWithRetries(final FileSystem fs,<a name="line.447"></a>
+<span class="sourceLineNo">448</span>        final Path hbckLockFilePath, final FsPermission defaultPerms)<a name="line.448"></a>
+<span class="sourceLineNo">449</span>        throws IOException {<a name="line.449"></a>
+<span class="sourceLineNo">450</span>      IOException exception = null;<a name="line.450"></a>
+<span class="sourceLineNo">451</span>      do {<a name="line.451"></a>
+<span class="sourceLineNo">452</span>        try {<a name="line.452"></a>
+<span class="sourceLineNo">453</span>          return FSUtils.create(fs, hbckLockFilePath, defaultPerms, false);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>        } catch (IOException ioe) {<a name="line.454"></a>
+<span class="sourceLineNo">455</span>          LOG.info("Failed to create lock file " + hbckLockFilePath.getName()<a name="line.455"></a>
+<span class="sourceLineNo">456</span>              + ", try=" + (retryCounter.getAttemptTimes() + 1) + " of "<a name="line.456"></a>
+<span class="sourceLineNo">457</span>              + retryCounter.getMaxAttempts());<a name="line.457"></a>
+<span class="sourceLineNo">458</span>          LOG.debug("Failed to create lock file " + hbckLockFilePath.getName(),<a name="line.458"></a>
+<span class="sourceLineNo">459</span>              ioe);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>          try {<a name="line.460"></a>
+<span class="sourceLineNo">461</span>            exception = ioe;<a name="line.461"></a>
+<span class="sourceLineNo">462</span>            retryCounter.sleepUntilNextRetry();<a name="line.462"></a>
+<span class="sourceLineNo">463</span>          } catch (InterruptedException ie) {<a name="line.463"></a>
+<span class="sourceLineNo">464</span>            throw (InterruptedIOException) new InterruptedIOException(<a name="line.464"></a>
+<span class="sourceLineNo">465</span>                "Can't create lock file " + hbckLockFilePath.getName())<a name="line.465"></a>
+<span class="sourceLineNo">466</span>            .initCause(ie);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>          }<a name="line.467"></a>
+<span class="sourceLineNo">468</span>        }<a name="line.468"></a>
+<span class="sourceLineNo">469</span>      } while (retryCounter.shouldRetry());<a name="line.469"></a>
+<span class="sourceLineNo">470</span><a name="line.470"></a>
+<span class="sourceLineNo">471</span>      throw exception;<a name="line.471"></a>
+<span class="sourceLineNo">472</span>    }<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>  /**<a name="line.475"></a>
+<span class="sourceLineNo">476</span>   * This method maintains a lock using a file. If the creation fails we return null<a name="line.476"></a>
+<span class="sourceLineNo">477</span>   *<a name="line.477"></a>
+<span class="sourceLineNo">478</span>   * @return FSDataOutputStream object corresponding to the newly opened lock file<a name="line.478"></a>
+<span class="sourceLineNo">479</span>   * @throws IOException if IO failure occurs<a name="line.479"></a>
+<span class="sourceLineNo">480</span>   */<a name="line.480"></a>
+<span class="sourceLineNo">481</span>  public static Pair&lt;Path, FSDataOutputStream&gt; checkAndMarkRunningHbck(Configuration conf,<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      RetryCounter retryCounter) throws IOException {<a name="line.482"></a>
+<span class="sourceLineNo">483</span>    FileLockCallable callable = new FileLockCallable(conf, retryCounter);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>    ExecutorService executor = Executors.newFixedThreadPool(1);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>    FutureTask&lt;FSDataOutputStream&gt; futureTask = new FutureTask&lt;&gt;(callable);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>    executor.execute(futureTask);<a name="line.486"></a>
+<span class="sourceLineNo">487</span>    final int timeoutInSeconds = conf.getInt(<a name="line.487"></a>
+<span class="sourceLineNo">488</span>      "hbase.hbck.lockfile.maxwaittime", DEFAULT_WAIT_FOR_LOCK_TIMEOUT);<a name="line.488"></a>
+<span class="sourceLineNo">489</span>    FSDataOutputStream stream = null;<a name="line.489"></a>
+<span class="sourceLineNo">490</span>    try {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>      stream = futureTask.get(timeoutInSeconds, TimeUnit.SECONDS);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>    } catch (ExecutionException ee) {<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      LOG.warn("Encountered exception when opening lock file", ee);<a name="line.493"></a>
+<span class="sourceLineNo">494</span>    } catch (InterruptedException ie) {<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      LOG.warn("Interrupted when opening lock file", ie);<a name="line.495"></a>
+<span class="sourceLineNo">496</span>      Thread.currentThread().interrupt();<a name="line.496"></a>
+<span class="sourceLineNo">497</span>    } catch (TimeoutException exception) {<a name="line.497"></a>
+<span class="sourceLineNo">498</span>      // took too long to obtain lock<a name="line.498"></a>
+<span class="sourceLineNo">499</span>      LOG.warn("Took more than " + timeoutInSeconds + " seconds in obtaining lock");<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      futureTask.cancel(true);<a name="line.500"></a>
+<span class="sourceLineNo">501</span>    } finally {<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      executor.shutdownNow();<a name="line.502"></a>
+<span class="sourceLineNo">503</span>    }<a name="line.503"></a>
+<span class="sourceLineNo">504</span>    return new Pair&lt;Path, FSDataOutputStream&gt;(callable.getHbckLockPath(), stream);<a name="line.504"></a>
+<span class="sourceLineNo">505</span>  }<a name="line.505"></a>
+<span class="sourceLineNo">506</span><a name="line.506"></a>
+<span class="sourceLineNo">507</span>  private void unlockHbck() {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>    if (isExclusive() &amp;&amp; hbckLockCleanup.compareAndSet(true, false)) {<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      RetryCounter retryCounter = lockFileRetryCounterFactory.create();<a name="line.509"></a>
+<span class="sourceLineNo">510</span>      do {<a name="line.510"></a>
+<span class="sourceLineNo">511</span>        try {<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          IOUtils.closeQuietly(hbckOutFd);<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          FSUtils.delete(FSUtils.getCurrentFileSystem(getConf()), HBCK_LOCK_PATH, true);<a name="line.513"></a>
+<span class="sourceLineNo">514</span>          LOG.info("Finishing hbck");<a name="line.514"></a>
+<span class="sourceLineNo">515</span>          return;<a name="line.515"></a>
+<span class="sourceLineNo">516</span>        } catch (IOException ioe) {<a name="line.516"></a>
+<span class="sourceLineNo">517</span>          LOG.info("Failed to delete " + HBCK_LOCK_PATH + ", try="<a name="line.517"></a>
+<span class="sourceLineNo">518</span>              + (retryCounter.getAttemptTimes() + 1) + " of "<a name="line.518"></a>
+<span class="sourceLineNo">519</span>              + retryCounter.getMaxAttempts());<a name="line.519"></a>
+<span class="sourceLineNo">520</span>          LOG.debug("Failed to delete " + HBCK_LOCK_PATH, ioe);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>          try {<a name="line.521"></a>
+<span class="sourceLineNo">522</span>            retryCounter.sleepUntilNextRetry();<a name="line.522"></a>
+<span class="sourceLineNo">523</span>          } catch (InterruptedException ie) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>            Thread.currentThread().interrupt();<a name="line.524"></a>
+<span class="sourceLineNo">525</span>            LOG.warn("Interrupted while deleting lock file" +<a name="line.525"></a>
+<span class="sourceLineNo">526</span>                HBCK_LOCK_PATH);<a name="line.526"></a>
+<span class="sourceLineNo">527</span>            return;<a name="line.527"></a>
+<span class="sourceLineNo">528</span>          }<a name="line.528"></a>
+<span class="sourceLineNo">529</span>        }<a name="line.529"></a>
+<span class="sourceLineNo">530</span>      } while (retryCounter.shouldRetry());<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>  /**<a name="line.534"></a>
+<span class="sourceLineNo">535</span>   * To repair region consistency, one must call connect() in order to repair<a name="line.535"></a>
+<span class="sourceLineNo">536</span>   * online state.<a name="line.536"></a>
+<span class="sourceLineNo">537</span>   */<a name="line.537"></a>
+<span class="sourceLineNo">538</span>  public void connect() throws IOException {<a name="line.538"></a>
+<span class="sourceLineNo">539</span><a name="line.539"></a>
+<span class="sourceLineNo">540</span>    if (isExclusive()) {<a name="line.540"></a>
+<span class="sourceLineNo">541</span>      // Grab the lock<a name="line.541"></a>
+<span class="sourceLineNo">542</span>      Pair&lt;Path, FSDataOutputStream&gt; pair =<a name="line.542"></a>
+<span class="sourceLineNo">543</span>          checkAndMarkRunningHbck(getConf(), this.lockFileRetryCounterFactory.create());<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      HBCK_LOCK_PATH = pair.getFirst();<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      this.hbckOutFd = pair.getSecond();<a name="line.545"></a>
+<span class="sourceLineNo">546</span>      if (hbckOutFd == null) {<a name="line.546"></a>
+<span class="sourceLineNo">547</span>        setRetCode(-1);<a name="line.547"></a>
+<span class="sourceLineNo">548</span>        LOG.error("Another instance of hbck is fixing HBase, exiting this instance. " +<a name="line.548"></a>
+<span class="sourceLineNo">549</span>            "[If you are sure no other instance is running, delete the lock file " +<a name="line.549"></a>
+<span class="sourceLineNo">550</span>            HBCK_LOCK_PATH + " and rerun the tool]");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>        throw new IOException("Duplicate hbck - Abort");<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      }<a name="line.552"></a>
+<span class="sourceLineNo">553</span><a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Make sure to cleanup the lock<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      hbckLockCleanup.set(true);<a name="line.555"></a>
+<span class="sourceLineNo">556</span>    }<a name="line.556"></a>
+<span class="sourceLineNo">557</span><a name="line.557"></a>
 <span class="sourceLineNo">558</span><a name="line.558"></a>
-<span class="sourceLineNo">559</span><a name="line.559"></a>
-<span class="sourceLineNo">560</span>    // Add a shutdown hook to this thread, in case user tries to<a name="line.560"></a>
-<span class="sourceLineNo">561</span>    // kill the hbck with a ctrl-c, we want to cleanup the lock so that<a name="line.561"></a>
-<span class="sourceLineNo">562</span>    // it is available for further calls<a name="line.562"></a>
-<span class="sourceLineNo">563</span>    Runtime.getRuntime().addShutdownHook(new Thread() {<a name="line.563"></a>
-<span class="sourceLineNo">564</span>      @Override<a name="line.564"></a>
-<span class="sourceLineNo">565</span>      public void run() {<a name="line.565"></a>
-<span class="sourceLineNo">566</span>        IOUtils.closeQuietly(HBaseFsck.this);<a name="line.566"></a>
-<span class="sourceLineNo">567</span>        cleanupHbckZnode();<a name="line.567"></a>
-<span class="sourceLineNo">568</span>        unlockHbck();<a name="line.568"></a>
-<span class="sourceLineNo">569</span>      }<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>    LOG.info("Launching hbck");<a name="line.572"></a>
-<span class="sourceLineNo">573</span><a name="line.573"></a>
-<span class="sourceLineNo">574</span>    connection = ConnectionFactory.createConnection(getConf());<a name="line.574"></a>
-<span class="sourceLineNo">575</span>    admin = connection.getAdmin();<a name="line.575"></a>
-<span class="sourceLineNo">576</span>    meta = connection.getTable(TableName.META_TABLE_NAME);<a name="line.576"></a>
-<span class="sourceLineNo">577</span>    status = admin.getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS,<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      Option.DEAD_SERVERS, Option.MASTER, Option.BACKUP_MASTERS,<a name="line.578"></a>
-<span class="sourceLineNo">579</span>      Option.REGIONS_IN_TRANSITION, Option.HBASE_VERSION));<a name="line.579"></a>
-<span class="sourceLineNo">580</span>  }<a name="line.580"></a>
-<span class="sourceLineNo">581</span><a name="line.581"></a>
-<span class="sourceLineNo">582</span>  /**<a name="line.582"></a>
-<span class="sourceLineNo">583</span>   * Get deployed regions according to the region servers.<a name="line.583"></a>
-<span class="sourceLineNo">584</span>   */<a name="line.584"></a>
-<span class="sourceLineNo">585</span>  private void loadDeployedRegions() throws IOException, InterruptedException {<a name="line.585"></a>
-<span class="sourceLineNo">586</span>    // From the master, get a list of all known live region servers<a name="line.586"></a>
-<span class="sourceLineNo">587</span>    Collection&lt;ServerName&gt; regionServers = status.getLiveServerMetrics().keySet();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    errors.print("Number of live region servers: " + regionServers.size());<a name="line.588"></a>
-<span class="sourceLineNo">589</span>    if (details) {<a name="line.589"></a>
-<span class="sourceLineNo">590</span>      for (ServerName rsinfo: regionServers) {<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        errors.print("  " + rsinfo.getServerName());<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>    // From the master, get a list of all dead region servers<a name="line.595"></a>
-<span class="sourceLineNo">596</span>    Collection&lt;ServerName&gt; deadRegionServers = status.getDeadServerNames();<a name="line.596"></a>
-<span class="sourceLineNo">597</span>    errors.print("Number of dead region servers: " + deadRegionServers.size());<a name="line.597"></a>
-<span class="sourceLineNo">598</span>    if (details) {<a name="line.598"></a>
-<span class="sourceLineNo">599</span>      for (ServerName name: deadRegionServers) {<a name="line.599"></a>
-<span class="sourceLineNo">600</span>        errors.print("  " + name);<a name="line.600"></a>
-<span class="sourceLineNo">601</span>      }<a name="line.601"></a>
-<span class="sourceLineNo">602</span>    }<a name="line.602"></a>
-<span class="sourceLineNo">603</span><a name="line.603"></a>
-<span class="sourceLineNo">604</span>    // Print the current master name and state<a name="line.604"></a>
-<span class="sourceLineNo">605</span>    errors.print("Master: " + status.getMasterName());<a name="line.605"></a>
-<span class="sourceLineNo">606</span><a name="line.606"></a>
-<span class="sourceLineNo">607</span>    // Print the list of all backup masters<a name="line.607"></a>
-<span class="sourceLineNo">608</span>    Collection&lt;ServerName&gt; backupMasters = status.getBackupMasterNames();<a name="line.608"></a>
-<span class="sourceLineNo">609</span>    errors.print("Number of backup masters: " + backupMasters.size());<a name="line.609"></a>
-<span class="sourceLineNo">610</span>    if (details) {<a name="line.610"></a>
-<span class="sourceLineNo">611</span>      for (ServerName name: backupMasters) {<a name="line.611"></a>
-<span class="sourceLineNo">612</span>        errors.print("  " + name);<a name="line.612"></a>
-<span class="sourceLineNo">613</span>      }<a name="line.613"></a>
-<span class="sourceLineNo">614</span>    }<a name="line.614"></a>
-<span class="sourceLineNo">615</span><a name="line.615"></a>
-<span class="sourceLineNo">616</span>    errors.print("Average load: " + status.getAverageLoad());<a name="line.616"></a>
-<span class="sourceLineNo">617</span>    errors.print("Number of requests: " + status.getRequestCount());<a name="line.617"></a>
-<span class="sourceLineNo">618</span>    errors.print("Number of regions: " + status.getRegionCount());<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>    List&lt;RegionState&gt; rits = status.getRegionStatesInTransition();<a name="line.620"></a>
-<span class="sourceLineNo">621</span>    errors.print("Number of regions in transition: " + rits.size());<a name="line.621"></a>
-<span class="sourceLineNo">622</span>    if (details) {<a name="line.622"></a>
-<span class="sourceLineNo">623</span>      for (RegionState state: rits) {<a name="line.623"></a>
-<span class="sourceLineNo">624</span>        errors.print("  " + state.toDescriptiveString());<a name="line.624"></a>
-<span class="sourceLineNo">625</span>      }<a name="line.625"></a>
-<span class="sourceLineNo">626</span>    }<a name="line.626"></a>
-<span class="sourceLineNo">627</span><a name="line.627"></a>
-<span class="sourceLineNo">628</span>    // Determine what's deployed<a name="line.628"></a>
-<span class="sourceLineNo">629</span>    processRegionServers(regionServers);<a name="line.629"></a>
-<span class="sourceLineNo">630</span>  }<a name="line.630"></a>
-<span class="sourceLineNo">631</span><a name="line.631"></a>
-<span class="sourceLineNo">632</span>  /**<a name="line.632"></a>
-<span class="sourceLineNo">633</span>   * Clear the current state of hbck.<a name="line.633"></a>
-<span class="sourceLineNo">634</span>   */<a name="line.634"></a>
-<span class="sourceLineNo">635</span>  private void clearState() {<a name="line.635"></a>
-<span class="sourceLineNo">636</span>    // Make sure regionInfo is empty before starting<a name="line.636"></a>
-<span class="sourceLineNo">637</span>    fixes = 0;<a name="line.637"></a>
-<span class="sourceLineNo">638</span>    regionInfoMap.clear();<a name="line.638"></a>
-<span class="sourceLineNo">639</span>    emptyRegionInfoQualifiers.clear();<a name="line.639"></a>
-<span class="sourceLineNo">640</span>    tableStates.clear();<a name="line.640"></a>
-<span class="sourceLineNo">641</span>    errors.clear();<a name="line.641"></a>
-<span class="sourceLineNo">642</span>    tablesInfo.clear();<a name="line.642"></a>
-<span class="sourceLineNo">643</span>    orphanHdfsDirs.clear();<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    skippedRegions.clear();<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>   * This repair method analyzes hbase data in hdfs and repairs it to satisfy<a name="line.648"></a>
-<span class="sourceLineNo">649</span>   * the table integrity rules.  HBase doesn't need to be online for this<a name="line.649"></a>
-<span class="sourceLineNo">650</span>   * operation to work.<a name="line.650"></a>
-<span class="sourceLineNo">651</span>   */<a name="line.651"></a>
-<span class="sourceLineNo">652</span>  public void offlineHdfsIntegrityRepair() throws IOException, InterruptedException {<a name="line.652"></a>
-<span class="sourceLineNo">653</span>    // Initial pass to fix orphans.<a name="line.653"></a>
-<span class="sourceLineNo">654</span>    if (shouldCheckHdfs() &amp;&amp; (shouldFixHdfsOrphans() || shouldFixHdfsHoles()<a name="line.654"></a>
-<span class="sourceLineNo">655</span>        || shouldFixHdfsOverlaps() || shouldFixTableOrphans())) {<a name="line.655"></a>
-<span class="sourceLineNo">656</span>      LOG.info("Loading regioninfos HDFS");<a name="line.656"></a>
-<span class="sourceLineNo">657</span>      // if nothing is happening this should always complete in two iterations.<a name="line.657"></a>
-<span class="sourceLineNo">658</span>      int maxIterations = getConf().getInt("hbase.hbck.integrityrepair.iterations.max", 3);<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      int curIter = 0;<a name="line.659"></a>
-<span class="sourceLineNo">660</span>      do {<a name="line.660"></a>
-<span class="sourceLineNo">661</span>        clearState(); // clears hbck state and reset fixes to 0 and.<a name="line.661"></a>
-<span class="sourceLineNo">662</span>        // repair what's on HDFS<a name="line.662"></a>
-<span class="sourceLineNo">663</span>        restoreHdfsIntegrity();<a name="line.663"></a>
-<span class="sourceLineNo">664</span>        curIter++;// limit the number of iterations.<a name="line.664"></a>
-<span class="sourceLineNo">665</span>      } while (fixes &gt; 0 &amp;&amp; curIter &lt;= maxIterations);<a name="line.665"></a>
-<span class="sourceLineNo">666</span><a name="line.666"></a>
-<span class="sourceLineNo">667</span>      // Repairs should be done in the first iteration and verification in the second.<a name="line.667"></a>
-<span class="sourceLineNo">668</span>      // If there are more than 2 passes, something funny has happened.<a name="line.668"></a>
-<span class="sourceLineNo">669</span>      if (curIter &gt; 2) {<a name="line.669"></a>
-<span class="sourceLineNo">670</span>        if (curIter == maxIterations) {<a name="line.670"></a>
-<span class="sourceLineNo">671</span>          LOG.warn("Exiting integrity repairs after max " + curIter + " iterations. "<a name="line.671"></a>
-<span class="sourceLineNo">672</span>              + "Tables integrity may not be fully repaired!");<a name="line.672"></a>
-<span class="sourceLineNo">673</span>        } else {<a name="line.673"></a>
-<span class="sourceLineNo">674</span>          LOG.info("Successfully exiting integrity repairs after " + curIter + " iterations");<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>  }<a name="line.678"></a>
-<span class="sourceLineNo">679</span><a name="line.679"></a>
-<span class="sourceLineNo">680</span>  /**<a name="line.680"></a>
-<span class="sourceLineNo">681</span>   * This repair method requires the cluster to be online since it contacts<a name="line.681"></a>
-<span class="sourceLineNo">682</span>   * region servers and the masters.  It makes each region's state in HDFS, in<a name="line.682"></a>
-<span class="sourceLineNo">683</span>   * hbase:meta, and deployments consistent.<a name="line.683"></a>
-<span class="sourceLineNo">684</span>   *<a name="line.684"></a>
-<span class="sourceLineNo">685</span>   * @return If &amp;gt; 0 , number of errors detected, if &amp;lt; 0 there was an unrecoverable<a name="line.685"></a>
-<span class="sourceLineNo">686</span>   *     error.  If 0, we have a clean hbase.<a name="line.686"></a>
-<span class="sourceLineNo">687</span>   */<a name="line.687"></a>
-<span class="sourceLineNo">688</span>  public int onlineConsistencyRepair() throws IOException, KeeperException,<a name="line.688"></a>
-<span class="sourceLineNo">689</span>    InterruptedException {<a name="line.689"></a>
-<span class="sourceLineNo">690</span><a name="line.690"></a>
-<span class="sourceLineNo">691</span>    // get regions according to what is online on each RegionServer<a name="line.691"></a>
-<span class="sourceLineNo">692</span>    loadDeployedRegions();<a name="line.692"></a>
-<span class="sourceLineNo">693</span>    // check whether hbase:meta is deployed and online<a name="line.693"></a>
-<span class="sourceLineNo">694</span>    recordMetaRegion();<a name="line.694"></a>
-<span class="sourceLineNo">695</span>    // Check if hbase:meta is found only once and in the right place<a name="line.695"></a>
-<span class="sourceLineNo">696</span>    if (!checkMetaRegion()) {<a name="line.696"></a>
-<span class="sourceLineNo">697</span>      String errorMsg = "hbase:meta table is not consistent. ";<a name="line.697"></a>
-<span class="sourceLineNo">698</span>      if (shouldFixAssignments()) {<a name="line.698"></a>
-<span class="sourceLineNo">699</span>        errorMsg += "HBCK will try fixing it. Rerun once hbase:meta is back to consistent state.";<a name="line.699"></a>
-<span class="sourceLineNo">700</span>      } else {<a name="line.700"></a>
-<span class="sourceLineNo">701</span>        errorMsg += "Run HBCK with proper fix options to fix hbase:meta inconsistency.";<a name="line.701"></a>
-<span class="sourceLineNo">702</span>      }<a name="line.702"></a>
-<span class="sourceLineNo">703</span>      errors.reportError(errorMsg + " Exiting...");<a name="line.703"></a>
-<span class="sourceLineNo">704</span>      return -2;<a name="line.704"></a>
-<span class="sourceLineNo">705</span>    }<a name="line.705"></a>
-<span class="sourceLineNo">706</span>    // Not going with further consistency check for tables when hbase:meta itself is not consistent.<a name="line.706"></a>
-<span class="sourceLineNo">707</span>    LOG.info("Loading regionsinfo from the hbase:meta table");<a name="line.707"></a>
-<span class="sourceLineNo">708</span>    boolean success = loadMetaEntries();<a name="line.708"></a>
-<span class="sourceLineNo">709</span>    if (!success) return -1;<a name="line.709"></a>
-<span class="sourceLineNo">710</span><a name="line.710"></a>
-<span class="sourceLineNo">711</span>    // Empty cells in hbase:meta?<a name="line.711"></a>
-<span class="sourceLineNo">712</span>    reportEmptyMetaCells();<a name="line.712"></a>
-<span class="sourceLineNo">713</span><a name="line.713"></a>
-<span class="sourceLineNo">714</span>    // Check if we have to cleanup empty REGIONINFO_QUALIFIER rows from hbase:meta<a name="line.714"></a>
-<span class="sourceLineNo">715</span>    if (shouldFixEmptyMetaCells()) {<a name="line.715"></a>
-<span class="sourceLineNo">716</span>      fixEmptyMetaCells();<a name="line.716"></a>
-<span class="sourceLineNo">717</span>    }<a name="line.717"></a>
-<span class="sourceLineNo">718</span><a name="line.718"></a>
-<span class="sourceLineNo">719</span>    // get a list of all tables that have not changed recently.<a name="line.719"></a>
-<span class="sourceLineNo">720</span>    if (!checkMetaOnly) {<a name="line.720"></a>
-<span class="sourceLineNo">721</span>      reportTablesInFlux();<a name="line.721"></a>
-<span class="sourceLineNo">722</span>    }<a name="line.722"></a>
-<span class="sourceLineNo">723</span><a name="line.723"></a>
-<span class="sourceLineNo">724</span>    // Get disabled tables states<a name="line.724"></a>
-<span class="sourceLineNo">725</span>    loadTableStates();<a name="line.725"></a>
-<span class="sourceLineNo">726</span><a name="line.726"></a>
-<span class="sourceLineNo">727</span>    // load regiondirs and regioninfos from HDFS<a name="line.727"></a>
-<span class="sourceLineNo">728</span>    if (shouldCheckHdfs()) {<a name="line.728"></a>
-<span class="sourceLineNo">729</span>      LOG.info("Loading region directories from HDFS");<a name="line.729"></a>
-<span class="sourceLineNo">730</span>      loadHdfsRegionDirs();<a name="line.730"></a>
-<span class="sourceLineNo">731</span>      LOG.info("Loading region information from HDFS");<a name="line.731"></a>
-<span class="sourceLineNo">732</span>      loadHdfsRegionInfos();<a name="line.732"></a>
-<span class="sourceLineNo">733</span>    }<a name="line.733"></a>
-<span class="sourceLineNo">734</span><a name="line.734"></a>
-<span class="sourceLineNo">735</span>    // fix the orphan tables<a name="line.735"></a>
-<span class="sourceLineNo">736</span>    fixOrphanTables();<a name="line.736"></a>
-<span class="sourceLineNo">737</span><a name="line.737"></a>
-<span class="sourceLineNo">738</span>    LOG.info("Checking and fixing region consistency");<a name="line.738"></a>
-<span class="sourceLineNo">739</span>    // Check and fix consistency<a name="line.739"></a>
-<span class="sourceLineNo">740</span>    checkAndFixConsistency();<a name="line.740"></a>
-<span class="sourceLineNo">741</span><a name="line.741"></a>
-<span class="sourceLineNo">742</span>    // Check integrity (does not fix)<a name="line.742"></a>
-<span class="sourceLineNo">743</span>    checkIntegrity();<a name="line.743"></a>
-<span class="sourceLineNo">744</span>    return errors.getErrorList().size();<a name="line.744"></a>
-<span class="sourceLineNo">745</span>  }<a name="line.745"></a>
-<span class="sourceLineNo">746</span><a name="line.746"></a>
-<span class="sourceLineNo">747</span>  /**<a name="line.747"></a>
-<span class="sourceLineNo">748</span>   * This method maintains an ephemeral znode. If the creation fails we return false or throw<a name="line.748"></a>
-<span class="sourceLineNo">749</span>   * exception<a name="line.749"></a>
-<span class="sourceLineNo">750</span>   *<a name="line.750"></a>
-<span class="sourceLineNo">751</span>   * @return true if creating znode succeeds; false otherwise<a name="line.751"></a>
-<span class="sourceLineNo">752</span>   * @throws IOException if IO failure occurs<a name="line.752"></a>
-<span class="sourceLineNo">753</span>   */<a name="line.753"></a>
-<span class="sourceLineNo">754</span>  private boolean setMasterInMaintenanceMode() throws IOException {<a name="line.754"></a>
-<span class="sourceLineNo">755</span>    RetryCounter retryCounter = createZNodeRetryCounterFactory.create();<a name="line.755"></a>
-<span class="sourceLineNo">756</span>    hbckEphemeralNodePath = ZNodePaths.joinZNode(<a name="line.756"></a>
-<span class="sourceLineNo">757</span>      zkw.getZNodePaths().masterMaintZNode,<a name="line.757"></a>
-<span class="sourceLineNo">758</span>      "hbck-" + Long.toString(EnvironmentEdgeManager.currentTime()));<a name="line.758"></a>
-<span class="sourceLineNo">759</span>    do {<a name="line.759"></a>
-<span class="sourceLineNo">760</span>      try {<a name="line.760"></a>
-<span class="sourceLineNo">761</span>        hbckZodeCreated = ZKUtil.createEphemeralNodeAndWatch(zkw, hbckEphemeralNodePath, null);<a name="line.761"></a>
-<span class="sourceLineNo">762</span>        if (hbckZodeCreated) {<a name="line.762"></a>
-<span class="sourceLineNo">763</span>          break;<a name="line.763"></a>
-<span class="sourceLineNo">764</span>        }<a name="line.764"></a>
-<span class="sourceLineNo">765</span>      } catch (KeeperException e) {<a name="line.765"></a>
-<span class="sourceLineNo">766</span>        if (retryCounter.getAttemptTimes() &gt;= retryCounter.getMaxAttempts()) {<a name="line.766"></a>
-<span class="sourceLineNo">767</span>           throw new IOException("Can't create znode " + hbckEphemeralNodePath, e);<a name="line.767"></a>
-<span class="sourceLineNo">768</span>        }<a name="line.768"></a>
-<span class="sourceLineNo">769</span>        // fall through and retry<a name="line.769"></a>
-<span class="sourceLineNo">770</span>      }<a name="line.770"></a>
-<span class="sourceLineNo">771</span><a name="line.771"></a>
-<span class="sourceLineNo">772</span>      LOG.warn("Fail to create znode " + hbckEphemeralNodePath + ", try=" +<a name="line.772"></a>
-<span class="sourceLineNo">773</span>          (retryCounter.getAttemptTimes() + 1) + " of " + retryCounter.getMaxAttempts());<a name="line.773"></a>
-<span class="sourceLineNo">774</span><a name="line.774"></a>
-<span class="sourceLineNo">775</span>      try {<a name="line.775"></a>
-<span class="sourceLineNo">776</span>        retryCounter.sleepUntilNextRetry();<a name="line.776"></a>
-<span class="sourceLineNo">777</span>      } catch (InterruptedException ie) {<a name="line.777"></a>
-<span class="sourceLineNo">778</span>        throw (InterruptedIOException) new InterruptedIOException(<a name="line.778"></a>
-<span class="sourceLineNo">779</span>              "Can't create znode " + hbckEphemeralNodePath).initCause(ie);<a name="line.779"></a>
-<span class="sourceLineNo">780</span>      }<a name="line.780"></a>
-<span class="sourceLineNo">781</span>    } while (retryCounter.shouldRetry());<a name="line.781"></a>
-<span class="sourceLineNo">782</span>    return hbckZodeCreated;<a name="line.782"></a>
-<span class="sourceLineNo">783</span>  }<a name="line.783"></a>
-<span class="sourceLineNo">784</span><a name="line.784"></a>
-<span class="sourceLineNo">785</span>  private void cleanupHbckZnode() {<a name="line.785"></a>
-<span class="sourceLineNo">786</span>    try {<a name="line.786"></a>
-<span class="sourceLineNo">787</span>      if (zkw != null &amp;&amp; hbckZodeCreated) {<a name="line.787"></a>
-<span class="sourceLineNo">788</span>        ZKUtil.deleteNode(zkw, hbckEphemeralNodePath);<a name="line.788"></a>
-<span class="sourceLineNo">789</span>        hbckZodeCreated = false;<a name="line.789"></a>
-<span class="sourceLineNo">790</span>      }<a name="line.790"></a>
-<span class="sourceLineNo">791</span>    } catch (KeeperException e) {<a name="line.791"></a>
-<span class="sourceLineNo">792</span>      // Ignore<a name="line.792"></a>
-<span class="sourceLineNo">793</span>      if (!e.code().equals(KeeperException.Code.NONODE)) {<a name="line.793"></a>
-<span class="sourceLineNo">794</span>        LOG.warn("Delete HBCK znode " + hbckEphemeralNodePath + " failed ", e);<a name="line.794"></a>
-<span class="sourceLineNo">795</span>      }<a name="line.795"></a>
-<span class="sourceLineNo">796</span>    }<a name="line.796"></a>
-<span class="sourceLineNo">797</span>  }<a name="line.797"></a>
-<span class="sourceLineNo">798</span><a name="line.798"></a>
-<span class="sourceLineNo">799</span>  /**<a name="line.799"></a>
-<span class="sourceLineNo">800</span>   * Contacts the master and prints out cluster-wide information<a name="line.800"></a>
-<span class="sourceLineNo">801</span>   * @return 0 on success, non-zero on failure<a name="line.801"></a>
-<span class="sourceLineNo">802</span>   */<a name="line.802"></a>
-<span class="sourceLineNo">803</span>  public int onlineHbck()<a name="line.803"></a>
-<span class="sourceLineNo">804</span>      throws IOException, KeeperException, InterruptedException, ReplicationException {<a name="line.804"></a>
-<span class="sourceLineNo">805</span>    // print hbase server version<a name="line.805"></a>
-<span class="sourceLineNo">806</span>    errors.print("Version: " + status.getHBaseVersion());<a name="line.806"></a>
-<span class="sourceLineNo">807</span><a name="line.807"></a>
-<span class="sourceLineNo">808</span>    // Clean start<a name="line.808"></a>
-<span class="sourceLineNo">809</span>    clearState();<a name="line.809"></a>
-<span class="sourceLineNo">810</span>    // Do offline check and repair first<a name="line.810"></a>
-<span class="sourceLineNo">811</span>    offlineHdfsIntegrityRepair();<a name="line.811"></a>
-<span class="sourceLineNo">812</span>    offlineReferenceFileRepair();<a name="line.812"></a>
-<span class="sourceLineNo">813</span>    offlineHLinkFileRepair();<a name="line.813"></a>
-<span class="sourceLineNo">814</span>    // If Master runs maintenance tasks (such as balancer, catalog janitor, etc) during online<a name="line.814"></a>
-<span class="sourceLineNo">815</span>    // hbck, it is likely that hbck would be misled and report transient errors.  Therefore, it<a name="line.815"></a>
-<span class="sourceLineNo">816</span>    // is better to set Master into maintenance mode during online hbck.<a name="line.816"></a>
-<span class="sourceLineNo">817</span>    //<a name="line.817"></a>
-<span class="sourceLineNo">818</span>    if (!setMasterInMaintenanceMode()) {<a name="line.818"></a>
-<span class="sourceLineNo">819</span>      LOG.warn("HBCK is running while master is not in maintenance mode, you might see transient "<a name="line.819"></a>
-<span class="sourceLineNo">820</span>        + "error.  Please run HBCK multiple times to reduce the chance of transient error.");<a name="line.820"></a>
-<span class="sourceLineNo">821</span>    }<a name="line.821"></a>
-<span class="sourceLineNo">822</span><a name="line.822"></a>
-<span class="sourceLineNo">823</span>    onlineConsistencyRepair();<a name="line.823"></a>
-<span class="sourceLineNo">824</span><a name="line.824"></a>
-<span class="sourceLineNo">825</span>    if (checkRegionBoundaries) {<a name="line.825"></a>
-<span class="sourceLineNo">826</span>      checkRegionBoundaries();<a name="line.826"></a>
-<span class="sourceLineNo">827</span>    }<a name="line.827"></a>
-<span class="sourceLineNo">828</span><a name="line.828"></a>
-<span class="sourceLineNo">829</span>    checkAndFixReplication();<a name="line.829"></a>
-<span class="sourceLineNo">830</span><a name="line.830"></a>
-<span class="sourceLineNo">831</span>    cleanReplicationBarrier();<a name="line.831"></a>
-<span class="sourceLineNo">832</span><a name="line.832"></a>
-<span class="sourceLineNo">833</span>    // Remove the hbck znode<a name="line.833"></a>
-<span class="sourceLineNo">834</span>    cleanupHbckZnode();<a name="line.834"></a>
-<span class="sourceLineNo">835</span><a name="line.835"></a>
-<span class="sourceLineNo">836</span>    // Remove the hbck lock<a name="line.836"></a>
-<span class="sourceLineNo">837</span>    unlockHbck();<a name="line.837"></a>
-<span class="sourceLineNo">838</span><a name="line.838"></a>
-<span class="sourceLineNo">839</span>    // Print table summary<a name="line.839"></a>
-<span class="sourceLineNo">840</span>    printTableSummary(tablesInfo);<a name="line.840"></a>
-<span class="sourceLineNo">841</span>    return errors.summarize();<a name="line.841"></a>
-<span class="sourceLineNo">842</span>  }<a name="line.842"></a>
-<span class="sourceLineNo">843</span><a name="line.843"></a>
-<span class="sourceLineNo">844</span>  public static byte[] keyOnly(byte[] b) {<a name="line.844"></a>
-<span class="sourceLineNo">845</span>    if (b == null)<a name="line.845"></a>
-<span class="sourceLineNo">846</span>      return b;<a name="line.846"></a>
-<span class="sourceLineNo">847</span>    int rowlength = Bytes.toShort(b, 0);<a name="line.847"></a>
-<span class="sourceLineNo">848</span>    byte[] result = new byte[rowlength];<a name="line.848"></a>
-<span class="sourceLineNo">849</span>    System.arraycopy(b, Bytes.SIZEOF_SHORT, result, 0, rowlength);<a name="line.849"></a>
-<span class="sourceLineNo">850</span>    return result;<a name="line.850"></a>
-<span class="sourceLineNo">851</span>  }<a name="line.851"></a>
-<span class="sourceLineNo">852</span><a name="line.852"></a>
-<span class="sourceLineNo">853</span>  @Override<a name="line.853"></a>
-<span class="sourceLineNo">854</span>  public void close() throws IOException {<a name="line.854"></a>
-<span class="sourceLineNo">855</span>    try {<a name="line.855"></a>
-<span class="sourceLineNo">856</span>      cleanupHbckZnode();<a name="line.856"></a>
-<span class="sourceLineNo">857</span>      unlockHbck();<a name="line.857"></a>
-<span class="sourceLineNo">858</span>    } catch (Exception io) {<a name="line.858"></a>
-<span class="sourceLineNo">859</span>      LOG.warn(io.toString(), io);<a name="line.859"></a>
-<span class="sourceLineNo">860</span>    } finally {<a name="line.860"></a>
-<span class="sourceLineNo">861</span>      if (zkw != null) {<a name="line.861"></a>
-<span class="sourceLineNo">862</span>        zkw.close();<a name="line.862"></a>
-<span class="sourceLineNo">863</span>        zkw = null;<a name="line.863"></a>
-<span class="sourceLineNo">864</span>      }<a name="line.864"></a>
-<span class="sourceLineNo">865</span>      IOUtils.closeQuietly(admin);<a name="line.865"></a>
-<span class="sourceLineNo">866</span>      IOUtils.closeQuietly(meta);<a name="line.866"></a>
-<span class="sourceLineNo">867</span>      IOUtils.closeQuietly(connection);<a name="line.867"></a>
-<span class="sourceLineNo">868</span>    }<a name="line.868"></a>
-<span class="sourceLineNo">869</span>  }<a name="line.869"></a>
-<span class="sourceLineNo">870</span><a name="line.870"></a>
-<span class="sourceLineNo">871</span>  private static class RegionBoundariesInformation {<a name="line.871"></a>
-<span class="sourceLineNo">872</span>    public byte [] regionName;<a name="line.872"></a>
-<span class="sourceLineNo">873</span>    public byte [] metaFirstKey;<a name="line.873"></a>
-<span class="sourceLineNo">874</span>    public byte [] metaLastKey;<a name="line.874"></a>
-<span class="sourceLineNo">875</span>    public byte [] storesFirstKey;<a name="line.875"></a>
-<span class="sourceLineNo">876</span>    public byte [] storesLastKey;<a name="line.876"></a>
-<span class="sourceLineNo">877</span>    @Override<a name="line.877"></a>
-<span class="sourceLineNo">878</span>    public String toString () {<a name="line.878"></a>
-<span class="sourceLineNo">879</span>      return "regionName=" + Bytes.toStringBinary(regionName) +<a name="line.879"></a>
-<span class="sourceLineNo">880</span>             "\nmetaFirstKey=" + Bytes.toStringBinary(metaFirstKey) +<a name="line.880"></a>
-<span class="sourceLineNo">881</span>             "\nmetaLastKey=" + Bytes.toStringBinary(metaLastKey) +<a name="line.881"></a>
-<span class="sourceLineNo">882</span>             "\nstoresFirstKey=" + Bytes.toStringBinary(storesFirstKey) +<a name="line.882"></a>
-<span class="sourceLineNo">883</span>             "\nstoresLastKey=" + Bytes.toStringBinary(storesLastKey);<a name="line.883"></a>
-<span class="sourceLineNo">884</span>    }<a name="line.884"></a>
-<span class="sourceLineNo">885</span>  }<a name="line.885"></a>
-<span class="sourceLineNo">886</span><a name="line.886"></a>
-<span class="sourceLineNo">887</span>  public void checkRegionBoundaries() {<a name="line.887"></a>
-<span class="sourceLineNo">888</span>    try {<a name="line.888"></a>
-<span class="sourceLineNo">889</span>      ByteArrayComparator comparator = new ByteArrayComparator();<a name="line.889"></a>
-<span class="sourceLineNo">890</span>      List&lt;RegionInfo&gt; regions = MetaTableAccessor.getAllRegions(connection, true);<a name="line.890"></a>
-<span class="sourceLineNo">891</span>      final RegionBoundariesInformation currentRegionBoundariesInformation =<a name="line.891"></a>
-<span class="sourceLineNo">892</span>          new RegionBoundariesInformation();<a name="line.892"></a>
-<span class="sourceLineNo">893</span>      Path hbaseRoot = FSUtils.getRootDir(getConf());<a name="line.893"></a>
-<span class="sourceLineNo">894</span>      for (RegionInfo regionInfo : regions) {<a name="line.894"></a>
-<span class="sourceLineNo">895</span>        Path tableDir = FSUtils.getTableDir(hbaseRoot, regionInfo.getTable());<a name="line.895"></a>
-<span class="sourceLineNo">896</span>        currentRegionBoundariesInformation.regionName = regionInfo.getRegionName();<a name="line.896"></a>
-<span class="sourceLineNo">897</span>        // For each region, get the start and stop key from the META and compare them to the<a name="line.897"></a>
-<span class="sourceLineNo">898</span>        // same information from the Stores.<a name="line.898"></a>
-<span class="sourceLineNo">899</span>        Path path = new Path(tableDir, regionInfo.getEncodedName());<a name="line.899"></a>
-<span class="sourceLineNo">900</span>        FileSystem fs = path.getFileSystem(getConf());<a name="line.900"></a>
-<span class="sourceLineNo">901</span>        FileStatus[] files = fs.listStatus(path);<a name="line.901"></a>
-<span class="sourceLineNo">902</span>        // For all the column families in this region...<a name="line.902"></a>
-<span class="sourceLineNo">903</span>        byte[] storeFirstKey = null;<a name="line.903"></a>
-<span class="sourceLineNo">904</span>        byte[] storeLastKey = null;<a name="line.904"></a>
-<span class="sourceLineNo">905</span>        for (FileStatus file : files) {<a name="line.905"></a>
-<span class="sourceLineNo">906</span>          String fileName = file.getPath().toString();<a name="line.906"></a>
-<span class="sourceLineNo">907</span>          fileName = fileName.substring(fileName.lastIndexOf("/") + 1);<a name="line.907"></a>
-<span class="sourceLineNo">908</span>          if (!fileName.startsWith(".") &amp;&amp; !fileName.endsWith("recovered.edits")) {<a name="line.908"></a>
-<span class="sourceLineNo">909</span>            FileStatus[] storeFiles = fs.listStatus(file.getPath());<a name="line.909"></a>
-<span class="sourceLineNo">910</span>            // For all the stores in this column family.<a name="line.910"></a>
-<span class="sourceLineNo">911</span>            for (FileStatus storeFile : storeFiles) {<a name="line.911"></a>
-<span class="sourceLineNo">912</span>              HFile.Reader reader = HFile.createReader(fs, storeFile.getPath(),<a name="line.912"></a>
-<span class="sourceLineNo">913</span>                CacheConfig.DISABLED, true, getConf());<a name="line.913"></a>
-<span class="sourceLineNo">914</span>              if ((reader.getFirstKey() != null)<a name="line.914"></a>
-<span class="sourceLineNo">915</span>                  &amp;&amp; ((storeFirstKey == null) || (comparator.compare(storeFirstKey,<a name="line.915"></a>
-<span class="sourceLineNo">916</span>                      ((KeyValue.KeyOnlyKeyValue) reader.getFirstKey().get()).getKey()) &gt; 0))) {<a name="line.916"></a>
-<span class="sourceLineNo">917</span>                storeFirstKey = ((KeyValue.KeyOnlyKeyValue)reader.getFirstKey().get()).getKey();<a name="line.917"></a>
-<span class="sourceLineNo">918</span>              }<a name="line.918"></a>
-<span class="sourceLineNo">919</span>              if ((reader.getLastKey() != null)<a name="line.919"></a>
-<span class="sourceLineNo">920</span>                  &amp;&amp; ((storeLastKey == null) || (comparator.compare(storeLastKey,<a name="line.920"></a>
-<span class="sourceLineNo">921</span>                      ((KeyValue.KeyOnlyKeyValue)reader.getLastKey().get()).getKey())) &lt; 0)) {<a name="line.921"></a>
-<span class="sourceLineNo">922</span>                storeLastKey = ((KeyValue.KeyOnlyKeyValue)reader.getLastKey().get()).getKey();<a name="line.922"></a>
-<span class="sourceLineNo">923</span>              }<a name="line.923"></a>
-<span class="sourceLineNo">924</span>              reader.close();<a name="line.924"></a>
-<span class="sourceLineNo">925</span>            }<a name="line.925"></a>
-<span class="sourceLineNo">926</span>          }<a name="line.926"></a>
-<span class="sourceLineNo">927</span>        }<a name="line.927"></a>
-<span class="sourceLineNo">928</span>        currentRegionBoundariesInformation.metaFirstKey = regionInfo.getStartKey();<a name="line.928"></a>
-<span class="sourceLineNo">929</span>        currentRegionBoundariesInformation.metaLastKey = regionInfo.getEndKey();<a name="line.929"></a>
-<span class="sourceLineNo">930</span>        currentRegionBoundariesInformation.storesFirstKey = keyOnly(storeFirstKey);<a name="line.930"></a>
-<span class="sourceLineNo">931</span>        currentRegionBoundariesInformation.storesLastKey = keyOnly(storeLastKey);<a name="line.931"></a>
-<span class="sourceLineNo">932</span>        if (currentRegionBoundariesInformation.metaFirstKey.length == 0)<a name="line.932"></a>
-<span class="sourceLineNo">933</span>          currentRegionBoundariesInformation.metaFirstKey = null;<a name="line.933"></a>
-<span class="sourceLineNo">934</span>        if (currentRegionBoundariesInformation.metaLastKey.length == 0)<a name="line.934"></a>
-<span class="sourceLineNo">935</span>          currentRegionBoundariesInformation.metaLastKey = null;<a name="line.935"></a>
-<span class="sourceLineNo">936</span><a name="line.936"></a>
-<span class="sourceLineNo">937</span>        // For a region to be correct, we need the META start key to be smaller or equal to the<a name="line.937"></a>
-<span class="sourceLineNo">938</span>        // smallest start key from all the stores, and the start key from the next META entry to<a name="line.938"></a>
-<span class="sourceLineNo">939</span>        // be bigger than the last key from all the current stores. First region start key is null;<a name="line.939"></a>
-<span class="sourceLineNo">940</span>        // Last region end key is null; some regions can be empty and not have any store.<a name="line.940"></a>
-<span class="sourceLineNo">941</span><a name="line.941"></a>
-<span class="sourceLineNo">942</span>        boolean valid = true;<a name="line.942"></a>
-<span class="sourceLineNo">943</span>        // Checking start key.<a name="line.943"></a>
-<span class="sourceLineNo">944</span>        if ((currentRegionBoundariesInformation.storesFirstKey != null)<a name="line.944"></a>
-<span class="sourceLineNo">945</span>            &amp;&amp; (currentRegionBoundariesInformation.metaFirstKey != null)) {<a name="line.945"></a>
-<span class="sourceLineNo">946</span>          valid = valid<a name="line.946"></a>
-<span class="sourceLineNo">947</span>              &amp;&amp; comparator.compare(currentRegionBoundariesInformation.storesFirstKey,<a name="line.947"></a>
-<span class="sourceLineNo">948</span>                currentRegionBoundariesInformation.metaFirstKey) &gt;= 0;<a name="line.948"></a>
-<span class="sourceLineNo">949</span>        }<a name="line.949"></a>
-<span class="sourceLineNo">950</span>        // Checking stop key.<a name="line.950"></a>
-<span class="sourceLineNo">951</span>        if ((currentRegionBoundariesInformation.storesLastKey != null)<a name="line.951"></a>
-<span class="sourceLineNo">952</span>            &amp;&amp; (currentRegionBoundariesInformation.metaLastKey != null)) {<a name="line.952"></a>
-<span class="sourceLineNo">953</span>          valid = valid<a name="line.953"></a>
-<span class="sourceLineNo">954</span>              &amp;&amp; comparator.compare(currentRegionBoundariesInformation.storesLastKey,<a name="line.954"></a>
-<span class="sourceLineNo">955</span>                currentRegionBoundariesInformation.metaLastKey) &lt; 0;<a name="line.955"></a>
-<span class="sourceLineNo">956</span>        }<a name="line.956"></a>
-<span class="sourceLineNo">957</span>        if (!valid) {<a name="line.957"></a>
-<span class="sourceLineNo">958</span>          errors.reportError(ERROR_CODE.BOUNDARIES_ERROR, "Found issues with regions boundaries",<a name="line.958"></a>
-<span class="sourceLineNo">959</span>            tablesInfo.get(regionInfo.getTable()));<a name="line.959"></a>
-<span class="sourceLineNo">960</span>          LOG.warn("Region's boundaries not aligned between stores and META for:");<a name="line.960"></a>
-<span class="sourceLineNo">961</span>          LOG.warn(Objects.toString(currentRegionBoundariesInformation));<a name="line.961"></a>
-<span class="sourceLineNo">962</span>        }<a name="line.962"></a>
-<span class="sourceLineNo">963</span>      }<a name="line.963"></a>
-<span class="sourceLineNo">964</span>    } catch (IOException e) {<a name="line.964"></a>
-<span class="sourceLineNo">965</span>      LOG.error(e.toString(), e);<a name="line.965"></a>
-<span class="sourceLineNo">966</span>    }<a name="line.966"></a>
-<span class="sourceLineNo">967</span>  }<a name="line.967"></a>
-<span class="sourceLineNo">968</span><a name="line.968"></a>
-<span class="sourceLineNo">969</span>  /**<a name="line.969"></a>
-<span class="sourceLineNo">970</span>   * Iterates through the list of all orphan/invalid regiondirs.<a name="line.970"></a>
-<span class="sourceLineNo">971</span>   */<a name="line.971"></a>
-<span class="sourceLineNo">972</span>  private void adoptHdfsOrphans(Collection&lt;HbckRegionInfo&gt; orphanHdfsDirs) throws IOException {<a name="line.972"></a>
-<span class="sourceLineNo">973</span>    for (HbckRegionInfo hi : orphanHdfsDirs) {<a name="line.973"></a>
-<span class="sourceLineNo">974</span>      LOG.info("Attempting to handle orphan hdfs dir: " + hi.getHdfsRegionDir());<a name="line.974"></a>
-<span class="sourceLineNo">975</span>      adoptHdfsOrphan(hi);<a name="line.975"></a>
-<span class="sourceLineNo">976</span>    }<a name="line.976"></a>
-<span class="sourceLineNo">977</span>  }<a name="line.977"></a>
-<span class="sourceLineNo">978</span><a name="line.978"></a>
-<span class="sourceLineNo">979</span>  /**<a name="line.979"></a>
-<span class="sourceLineNo">980</span>   * Orphaned regions are regions without a .regioninfo file in them.  We "adopt"<a name="line.980"></a>
-<span class="sourceLineNo">981</span>   * these orphans by creating a new region, and moving the column families,<a name="line.981"></a>
-<span class="sourceLineNo">982</span>   * recovered edits, WALs, into the new region dir.  We determine the region<a name="line.982"></a>
-<span class="sourceLineNo">983</span>   * startkey and endkeys by looking at all of the hfiles inside the column<a name="line.983"></a>
-<span class="sourceLineNo">984</span>   * families to identify the min and max keys. The resulting region will<a name="line.984"></a>
-<span class="sourceLineNo">985</span>   * likely violate table integrity but will be dealt with by merging<a name="line.985"></a>
-<span class="sourceLineNo">986</span>   * overlapping regions.<a name="line.986"></a>
-<span class="sourceLineNo">987</span>   */<a name="line.987"></a>
-<span class="sourceLineNo">988</span>  @SuppressWarnings("deprecation")<a name="line.988"></a>
-<span class="sourceLineNo">989</span>  private void adoptHdfsOrphan(HbckRegionInfo hi) throws IOException {<a name="line.989"></a>
-<span class="sourceLineNo">990</span>    Path p = hi.getHdfsRegionDir();<a name="line.990"></a>
-<span class="sourceLineNo">991</span>    FileSystem fs = p.getFileSystem(getConf());<a name="line.991"></a>
-<span class="sourceLineNo">992</span>    FileStatus[] dirs = fs.listStatus(p);<a name="line.992"></a>
-<span class="sourceLineNo">993</span>    if (dirs == null) {<a name="line.993"></a>
-<span class="sourceLineNo">994</span>      LOG.warn("Attempt to adopt orphan hdfs region skipped because no files present in " +<a name="line.994"></a>
-<span class="sourceLineNo">995</span>          p + ". This dir could probably be deleted.");<a name="line.995"></a>
-<span class="sourceLineNo">996</span>      return ;<a name="line.996"></a>
-<span class="sourceLineNo">997</span>    }<a name="line.997"></a>
-<span class="sourceLineNo">998</span><a name="line.998"></a>
-<span class="sourceLineNo">999</span>    TableName tableName = hi.getTableName();<a name="line.999"></a>
-<span class="sourceLineNo">1000</span>    HbckTableInfo tableInfo = tablesInfo.get(tableName);<a name="line.1000"></a>
-<span class="sourceLineNo">1001</span>    Preconditions.checkNotNull(tableInfo, "Table '" + tableName + "' not present!");<a name="line.1001"></a>
-<span class="sourceLineNo">1002</span>    TableDescriptor template = tableInfo.getTableDescriptor();<a name="line.1002"></a>
-<span class="sourceLineNo">1003</span><a name="line.1003"></a>
-<span class="sourceLineNo">1004</span>    // find min and max key values<a name="line.1004"></a>
-<span class="sourceLineNo">1005</span>    Pair&lt;byte[],byte[]&gt; orphanRegionRange = null;<a name="line.1005"></a>
-<span class="sourceLineNo">1006</span>    for (FileStatus cf : dirs) {<a name="line.1006"></a>
-<span class="sourceLineNo">1007</span>      String cfName= cf.getPath().getName();<a name="line.1007"></a>
-<span class="sourceLineNo">1008</span>      // TODO Figure out what the special dirs are<a name="line.1008"></a>
-<span class="sourceLineNo">1009</span>      if (cfName.startsWith(".") || cfName.equals(HConstants.SPLIT_LOGDIR_NAME)) continue;<a name="line.1009"></a>
-<span class="sourceLineNo">1010</span><a name="line.1010"></a>
-<span class="sourceLineNo">1011</span>      FileStatus[] hfiles = fs.listStatus(cf.getPath());<a name="line.1011"></a>
-<span class="sourceLineNo">1012</span>      for (FileStatus hfile : hfiles) {<a name="line.1012"></a>
-<span class="sourceLineNo">1013</span>        byte[] start, end;<a name="line.1013"></a>
-<span class="sourceLineNo">1014</span>        HFile.Reader hf = null;<a name="line.1014"></a>
-<span class="sourceLineNo">1015</span>        try {<a name="line.1015"></a>
-<span class="sourceLineNo">1016</span>          hf = HFile.createReader(fs, hfile.getPath(), CacheConfig.DISABLED, true, getConf());<a name="line.1016"></a>
-<span class="sourceLineNo">1017</span>          Optional&lt;Cell&gt; startKv = hf.getFirstKey();<a name="line.1017"></a>
-<span class="sourceLineNo">1018</span>          start = CellUtil.cloneRow(startKv.get());<a name="line.1018"></a>
-<span class="sourceLineNo">1019</span>          Optional&lt;Cell&gt; endKv = hf.getLastKey();<a name="line.1019"></a>
-<span class="sourceLineNo">1020</span>          end = CellUtil.cloneRow(endKv.get());<a name="line.1020"></a>
-<span class="sourceLineNo">1021</span>        } catch (IOException ioe) {<a name="line.1021"></a>
-<span class="sourceLineNo">1022</span>          LOG.warn("Problem reading orphan file " + hfile + ", skipping");<a name="line.1022"></a>
-<span class="sourceLineNo">1023</span>          continue;<a name="line.1023"></a>
-<span class="sourceLineNo">1024</span>        } catch (NullPointerException ioe) {<a name="line.1024"></a>
-<span class="sourceLineNo">1025</span>          LOG.warn("Orphan file " + hfile + " is possibly corrupted HFile, skipping");<a name="line.1025"></a>
-<span class="sourceLineNo">1026</span>          continue;<a name="line.1026"></a>
-<span class="sourceLineNo">1027</span>        } finally {<a name="line.1027"></a>
-<span class="sourceLineNo">1028</span>          if (hf != null) {<a name="line.1028"></a>
-<span class="sourceLineNo">1029</span>            hf.close();<a name="line.1029"></a>
-<span class="sourceLineNo">1030</span>          }<a name="line.1030"></a>
-<span class="sourceLineNo">1031</span>        }<a name="line.1031"></a>
-<span class="sourceLineNo">1032</span><a name="line.1032"></a>
-<span class="sourceLineNo">1033</span>        // expand the range to include the range of all hfiles<a name="line.1033"></a>
-<span class="sourceLineNo">1034</span>        if (orphanRegionRange == null) {<a name="line.1034"></a>
-<span class="sourceLineNo">1035</span>          // first range<a name="line.1035"></a>
-<span class="sourceLineNo">1036</span>          orphanRegionRange = new Pair&lt;&gt;(start, end);<a name="line.1036"></a>
-<span class="sourceLineNo">1037</span>        } else {<a name="line.1037"></a>
-<span class="sourceLineNo">1038</span>          // TODO add test<a name="line.1038"></a>
-<span class="sourceLineNo">1039</span><a name="line.1039"></a>
-<span class="sourceLineNo">1040</span>          // expand range only if the hfile is wider.<a name="line.1040"></a>
-<span class="sourceLineNo">1041</span>          if (Bytes.compareTo(orphanRegionRange.getFirst(), start) &gt; 0) {<a name="line.1041"></a>
-<span class="sourceLineNo">1042</span>            orphanRegionRange.setFirst(start);<a name="line.1042"></a>
-<span class="sourceLineNo">1043</span>          }<a name="line.1043"></a>
-<span class="sourceLineNo">1044</span>          if (Bytes.compareTo(orphanRegionRange.getSecond(), end) &lt; 0 ) {<a name="line.1044"></a>
-<span class="sourceLineNo">1045</span>            orphanRegionRange.setSecond(end);<a name="line.1045"></a>
-<span class="sourceLineNo">1046</span>          }<a name="line.1046"></a>
-<span class="sourceLineNo">1047</span>        }<a name="line.1047"></a>
-<span class="sourceLineNo">1048</span>      }<a name="line.1048"></a>
-<span class="sourceLineNo">1049</span>    }<a name="line.1049"></a>
-<span class="sourceLineNo">1050</span>    if (orphanRegionRange == null) {<a name="line.1050"></a>
-<span class="sourceLineNo">1051</span>      LOG.warn("No data in dir " + p + ", sidelining data");<a name="line.1051"></a>
-<span class="sourceLineNo">1052</span>      fixes++;<a name="line.1052"></a>
-<span class="sourceLineNo">1053</span>      sidelineRegionDir(fs, hi);<a name="line.1053"></a>
-<span class="sourceLineNo">1054</span>      return;<a name="line.1054"></a>
-<span class="sourceLineNo">1055</span>    }<a name="line.1055"></a>
-<span class="sourceLineNo">1056</span>    LOG.info("Min max keys are : [" + Bytes.toString(orphanRegionRange.getFirst()) + ", " +<a name="line.1056"></a>
-<span class="sourceLineNo">1057</span>        Bytes.toString(orphanRegionRange.getSecond()) + ")");<a name="line.1057"></a>
-<span class="sourceLineNo">1058</span><a name="line.1058"></a>
-<span class="sourceLineNo">1059</span>    // create new region on hdfs. move data into place.<a name="line.1059"></a>
-<span class="sourceLineNo">1060</span>    RegionInfo regionInfo = RegionInfoBuilder.newBuilder(template.getTableName())<a name="line.1060"></a>
-<span class="sourceLineNo">1061</span>        .setStartKey(orphanRegionRange.getFirst())<a name="line.1061"></a>
-<span class="sourceLineNo">1062</span>        .setEndKey(Bytes.add(orphanRegionRange.getSecond(), new byte[1]))<a name="line.1062"></a>
-<span class="sourceLineNo">1063</span>        .build();<a name="line.1063"></a>
-<span class="sourceLineNo">1064</span>    LOG.info("Creating new region : " + regionInfo);<a name="line.1064"></a>
-<span class="sourceLineNo">1065</span>    HRegion region = HBaseFsckRepair.createHDFSRegionDir(getConf(), regionInfo, template);<a name="line.1065"></a>
-<span class="sourceLineNo">1066</span>    Path target = region.getRegionFileSystem().getRegionDir();<a name="line.1066"></a>
-<span class="sourceLineNo">1067</span><a name="line.1067"></a>
-<span class="sourceLineNo">1068</span>    // rename all the data to new region<a name="line.1068"></a>
-<span class="sourceLineNo">1069</span>    mergeRegionDirs(target, hi);<a name="line.1069"></a>
-<span class="sourceLineNo">1070</span>    fixes++;<a name="line.1070"></a>
-<span class="sourceLineNo">1071</span>  }<a name="line.1071"></a>
-<span class="sourceLineNo">1072</span><a name="line.1072"></a>
-<span class="sourceLineNo">1073</span>  /**<a name="line.1073"></a>
-<span class="sourceLineNo">1074</span>   * This method determines if there are table integrity errors in HDFS.  If<a name="line.1074"></a>
-<span class="sourceLineNo">1075</span>   * there are errors and the appropriate "fix" options are enabled, the method<a name="line.1075"></a>
-<span class="sourceLineNo">1076</span>   * will first correct orphan regions making them into legit regiondirs, and<a name="line.1076"></a>
-<span class="sourceLineNo">1077</span>   * then reload to merge potentially overlapping regions.<a name="line.1077"></a>
-<span class="sourceLineNo">1078</span>   *<a name="line.1078"></a>
-<span class="sourceLineNo">1079</span>   * @return number of table integrity errors found<a name="line.1079"></a>
-<span class="sourceLineNo">1080</span>   */<a name="line.1080"></a>
-<span class="sourceLineNo">1081</span>  private int restoreHdfsIntegrity() throws IOException, InterruptedException {<a name="line.1081"></a>
-<span class="sourceLineNo">1082</span>    // Determine what's on HDFS<a name="line.1082"></a>
-<span class="sourceLineNo">1083</span>    LOG.info("Loading HBase regioninfo from HDFS...");<a name="line.1083"></a>
-<span class="sourceLineNo">1084</span>    loadHdfsRegionDirs(); // populating regioninfo table.<a name="line.1084"></a>
-<span class="sourceLineNo">1085</span><a name="line.1085"></a>
-<span class="sourceLineNo">1086</span>    int errs = errors.getErrorList().size();<a name="line.1086"></a>
-<span class="sourceLineNo">1087</span>    // First time just get suggestions.<a name="line.1087"></a>
-<span class="sourceLineNo">1088</span>    tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1088"></a>
-<span class="sourceLineNo">1089</span>    checkHdfsIntegrity(false, false);<a name="line.1089"></a>
-<span class="sourceLineNo">1090</span><a name="line.1090"></a>
-<span class="sourceLineNo">1091</span>    if (errors.getErrorList().size() == errs) {<a name="line.1091"></a>
-<span class="sourceLineNo">1092</span>      LOG.info("No integrity errors.  We are done with this phase. Glorious.");<a name="line.1092"></a>
-<span class="sourceLineNo">1093</span>      return 0;<a name="line.1093"></a>
-<span class="sourceLineNo">1094</span>    }<a name="line.1094"></a>
-<span class="sourceLineNo">1095</span><a name="line.1095"></a>
-<span class="sourceLineNo">1096</span>    if (shouldFixHdfsOrphans() &amp;&amp; orphanHdfsDirs.size() &gt; 0) {<a name="line.1096"></a>
-<span class="sourceLineNo">1097</span>      adoptHdfsOrphans(orphanHdfsDirs);<a name="line.1097"></a>
-<span class="sourceLineNo">1098</span>      // TODO optimize by incrementally adding instead of reloading.<a name="line.1098"></a>
-<span class="sourceLineNo">1099</span>    }<a name="line.1099"></a>
-<span class="sourceLineNo">1100</span><a name="line.1100"></a>
-<span class="sourceLineNo">1101</span>    // Make sure there are no holes now.<a name="line.1101"></a>
-<span class="sourceLineNo">1102</span>    if (shouldFixHdfsHoles()) {<a name="line.1102"></a>
-<span class="sourceLineNo">1103</span>      clearState(); // this also resets # fixes.<a name="line.1103"></a>
-<span class="sourceLineNo">1104</span>      loadHdfsRegionDirs();<a name="line.1104"></a>
-<span class="sourceLineNo">1105</span>      tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1105"></a>
-<span class="sourceLineNo">1106</span>      tablesInfo = checkHdfsIntegrity(shouldFixHdfsHoles(), false);<a name="line.1106"></a>
-<span class="sourceLineNo">1107</span>    }<a name="line.1107"></a>
-<span class="sourceLineNo">1108</span><a name="line.1108"></a>
-<span class="sourceLineNo">1109</span>    // Now we fix overlaps<a name="line.1109"></a>
-<span class="sourceLineNo">1110</span>    if (shouldFixHdfsOverlaps()) {<a name="line.1110"></a>
-<span class="sourceLineNo">1111</span>      // second pass we fix overlaps.<a name="line.1111"></a>
-<span class="sourceLineNo">1112</span>      clearState(); // this also resets # fixes.<a name="line.1112"></a>
-<span class="sourceLineNo">1113</span>      loadHdfsRegionDirs();<a name="line.1113"></a>
-<span class="sourceLineNo">1114</span>      tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1114"></a>
-<span class="sourceLineNo">1115</span>      tablesInfo = checkHdfsIntegrity(false, shouldFixHdfsOverlaps());<a name="line.1115"></a>
-<span class="sourceLineNo">1116</span>    }<a name="line.1116"></a>
-<span class="sourceLineNo">1117</span><a name="line.1117"></a>
-<span class="sourceLineNo">1118</span>    return errors.getErrorList().size();<a name="line.1118"></a>
-<span class="sourceLineNo">1119</span>  }<a name="line.1119"></a>
-<span class="sourceLineNo">1120</span><a name="line.1120"></a>
-<span class="sourceLineNo">1121</span>  /**<a name="line.1121"></a>
-<span class="sourceLineNo">1122</span>   * Scan all the store file names to find any lingering reference files,<a name="line.1122"></a>
-<span class="sourceLineNo">1123</span>   * which refer to some none-exiting files. If "fix" option is enabled,<a name="line.1123"></a>
-<span class="sourceLineNo">1124</span>   * any lingering reference file will be sidelined if found.<a name="line.1124"></a>
-<span class="sourceLineNo">1125</span>   * &lt;p&gt;<a name="line.1125"></a>
-<span class="sourceLineNo">1126</span>   * Lingering reference file prevents a region from opening. It has to<a name="line.1126"></a>
-<span class="sourceLineNo">1127</span>   * be fixed before a cluster can start properly.<a name="line.1127"></a>
-<span class="sourceLineNo">1128</span>   */<a name="line.1128"></a>
-<span class="sourceLineNo">1129</span>  private void offlineReferenceFileRepair() throws IOException, InterruptedException {<a name="line.1129"></a>
-<span class="sourceLineNo">1130</span>    clearState();<a name="line.1130"></a>
-<span class="sourceLineNo">1131</span>    Configuration conf = getConf();<a name="line.1131"></a>
-<span class="sourceLineNo">1132</span>    Path hbaseRoot = FSUtils.getRootDir(conf);<a name="line.1132"></a>
-<span class="sourceLineNo">1133</span>    FileSystem fs = hbaseRoot.getFileSystem(conf);<a name="line.1133"></a>
-<span class="sourceLineNo">1134</span>    LOG.info("Computing mapping of all store files");<a name="line.1134"></a>
-<span class="sourceLineNo">1135</span>    Map&lt;String, Path&gt; allFiles = FSUtils.getTableStoreFilePathMap(fs, hbaseRoot,<a name="line.1135"></a>
-<span class="sourceLineNo">1136</span>      new FSUtils.ReferenceFileFilter(fs), executor, errors);<a name="line.1136"></a>
-<span class="sourceLineNo">1137</span>    errors.print("");<a name="line.1137"></a>
-<span class="sourceLineNo">1138</span>    LOG.info("Validating mapping using HDFS state");<a name="line.1138"></a>
-<span class="sourceLineNo">1139</span>    for (Path path: allFiles.values()) {<a name="line.1139"></a>
-<span class="sourceLineNo">1140</span>      Path referredToFile = StoreFileInfo.getReferredToFile(path);<a name="line.1140"></a>
-<span class="sourceLineNo">1141</span>      if (fs.exists(referredToFile)) continue;  // good, expected<a name="line.1141"></a>
-<span class="sourceLineNo">1142</span><a name="line.1142"></a>
-<span class="sourceLineNo">1143</span>      // Found a lingering reference file<a name="line.1143"></a>
-<span class="sourceLineNo">1144</span>      errors.reportError(ERROR_CODE.LINGERING_REFERENCE_HFILE,<a name="line.1144"></a>
-<span class="sourceLineNo">1145</span>        "Found lingering reference file " + path);<a name="line.1145"></a>
-<span class="sourceLineNo">1146</span>      if (!shouldFixReferenceFiles()) continue;<a name="line.1146"></a>
-<span class="sourceLineNo">1147</span><a name="line.1147"></a>
-<span class="sourceLineNo">1148</span>      // Now, trying to fix it since requested<a name="line.1148"></a>
-<span class="sourceLineNo">1149</span>      boolean success = false;<a name="line.1149"></a>
-<span class="sourceLineNo">1150</span>      String pathStr = path.toString();<a name="line.1150"></a>
-<span class="sourceLineNo">1151</span><a name="line.1151"></a>
-<span class="sourceLineNo">1152</span>      // A reference file path should be like<a name="line.1152"></a>
-<span class="sourceLineNo">1153</span>      // ${hbase.rootdir}/data/namespace/table_name/region_id/family_name/referred_file.region_name<a name="line.1153"></a>
-<span class="sourceLineNo">1154</span>      // Up 5 directories to get the root folder.<a name="line.1154"></a>
-<span class="sourceLineNo">1155</span>      // So the file will be sidelined to a similar folder structure.<a name="line.1155"></a>
-<span class="sourceLineNo">1156</span>      int index = pathStr.lastIndexOf(Path.SEPARATOR_CHAR);<a name="line.1156"></a>
-<span class="sourceLineNo">1157</span>      for (int i = 0; index &gt; 0 &amp;&amp; i &lt; 5; i++) {<a name="line.1157"></a>
-<span class="sourceLineNo">1158</span>        index = pathStr.lastIndexOf(Path.SEPARATOR_CHAR, index - 1);<a name="line.1158"></a>
-<span class="sourceLineNo">1159</span>      }<a name="line.1159"></a>
-<span class="sourceLineNo">1160</span>      if (index &gt; 0) {<a name="line.1160"></a>
-<span class="sourceLineNo">1161</span>        Path rootDir = getSidelineDir();<a name="line.1161"></a>
-<span class="sourceLineNo">1162</span>        Path dst = new Path(rootDir, pathStr.substring(index + 1));<a name="line.1162"></a>
-<span class="sourceLineNo">1163</span>        fs.mkdirs(dst.getParent());<a name="line.1163"></a>
-<span class="sourceLineNo">1164</span>        LOG.info("Trying to sideline reference file "<a name="line.1164"></a>
-<span class="sourceLineNo">1165</span>          + path + " to " + dst);<a name="line.1165"></a>
-<span class="sourceLineNo">1166</span>        setShouldRerun();<a name="line.1166"></a>
-<span class="sourceLineNo">1167</span><a name="line.1167"></a>
-<span class="sourceLineNo">1168</span>        success = fs.rename(path, dst);<a name="line.1168"></a>
-<span class="sourceLineNo">1169</span>        debugLsr(dst);<a name="line.1169"></a>
-<span class="sourceLineNo">1170</span><a name="line.1170"></a>
-<span class="sourceLineNo">1171</span>      }<a name="line.1171"></a>
-<span class="sourceLineNo">1172</span>      if (!success) {<a name="line.1172"></a>
-<span class="sourceLineNo">1173</span>        LOG.error("Failed to sideline reference file " + path);<a name="line.1173"></a>
-<span class="sourceLineNo">1174</span>      }<a name="line.1174"></a>
-<span class="sourceLineNo">1175</span>    }<a name="line.1175"></a>
-<span class="sourceLineNo">1176</span>  }<a name="line.1176"></a>
-<span class="sourceLineNo">1177</span><a name="line.1177"></a>
-<span class="sourceLineNo">1178</span>  /**<a name="line.1178"></a>
-<span class="sourceLineNo">1179</span>   * Scan all the store file names to find any lingering HFileLink files,<a name="line.1179"></a>
-<span class="sourceLineNo">1180</span>   * which refer to some none-exiting files. If "fix" option is enabled,<a name="line.1180"></a>
-<span class="sourceLineNo">1181</span>   * any lingering HFileLink file will be sidelined if found.<a name="line.1181"></a>
-<span class="sourceLineNo">1182</span>   */<a name="line.1182"></a>
-<span class="sourceLineNo">1183</span>  private void offlineHLinkFileRepair() throws IOException, InterruptedException {<a name="line.1183"></a>
-<span class="sourceLineNo">1184</span>    Configuration conf = getConf();<a name="line.1184"></a>
-<span class="sourceLineNo">1185</span>    Path hbaseRoot = FSUtils.getRootDir(conf);<a name="line.1185"></a>
-<span class="sourceLineNo">1186</span>    FileSystem fs = hbaseRoot.getFileSystem(conf);<a name="line.1186"></a>
-<span class="sourceLineNo">1187</span>    LOG.info("Computing mapping of all link files");<a name="line.1187"></a>
-<span class="sourceLineNo">1188</span>    Map&lt;String, Path&gt; allFiles = FSUtils<a name="line.1188"></a>
-<span class="sourceLineNo">1189</span>        .getTableStoreFilePathMap(fs, hbaseRoot, new FSUtils.HFileLinkFilter(), executor, errors);<a name="line.1189"></a>
-<span class="sourceLineNo">1190</span>    errors.print("");<a name="line.1190"></a>
-<span class="sourceLineNo">1191</span><a name="line.1191"></a>
-<span class="sourceLineNo">1192</span>    LOG.info("Validating mapping using HDFS state");<a name="line.1192"></a>
-<span class="sourceLineNo">1193</span>    for (Path path : allFiles.values()) {<a name="line.1193"></a>
-<span class="sourceLineNo">1194</span>      // building HFileLink object to gather locations<a name="line.1194"></a>
-<span class="sourceLineNo">1195</span>      HFileLink actualLink = HFileLink.buildFromHFileLinkPattern(conf, path);<a name="line.1195"></a>
-<span class="sourceLineNo">1196</span>      if (actualLink.exists(fs)) continue; // good, expected<a name="line.1196"></a>
-<span class="sourceLineNo">1197</span><a name="line.1197"></a>
-<span class="sourceLineNo">1198</span>      // Found a lingering HFileLink<a name="line.1198"></a>
-<span class="sourceLineNo">1199</span>      errors.reportError(ERROR_CODE.LINGERING_HFILELINK, "Found lingering HFileLink " + path);<a name="line.1199"></a>
-<span class="sourceLineNo">1200</span>      if (!shouldFixHFileLinks()) continue;<a name="line.1200"></a>
-<span class="sourceLineNo">1201</span><a name="line.1201"></a>
-<span class="sourceLineNo">1202</span>      // Now, trying to fix it since requested<a name="line.1202"></a>
-<span class="sourceLineNo">1203</span>      setShouldRerun();<a name="line.1203"></a>
-<span class="sourceLineNo">1204</span><a name="line.1204"></a>
-<span class="sourceLineNo">1205</span>      // An HFileLink path should be like<a name="line.1205"></a>
-<span class="sourceLineNo">1206</span>      // ${hbase.rootdir}/data/namespace/table_name/region_id/family_name/linkedtable=linkedregionname-linkedhfilename<a name="line.1206"></a>
-<span class="sourceLineNo">1207</span>      // sidelineing will happen in the ${hbase.rootdir}/${sidelinedir} directory with the same folder structure.<a name="line.1207"></a>
-<span class="sourceLineNo">1208</span>      boolean success = sidelineFile(fs, hbaseRoot, path);<a name="line.1208"></a>
-<span class="sourceLineNo">1209</span><a name="line.1209"></a>
-<span class="sourceLineNo">1210</span>      if (!success) {<a name="line.1210"></a>
-<span class="sourceLineNo">1211</span>        LOG.error("Failed to sideline HFileLink file " + path);<a name="line.1211"></a>
-<span class="sourceLineNo">1212</span>      }<a name="line.1212"></a>
-<span class="sourceLineNo">1213</span><a name="line.1213"></a>
-<span class="sourceLineNo">1214</span>      // An HFileLink backreference path should be like<a name="line.1214"></a>
-<span class="sourceLineNo">1215</span>      // ${hbase.rootdir}/archive/data/namespace/table_name/region_id/family_name/.links-linkedhfilename<a name="line.1215"></a>
-<span class="sourceLineNo">1216</span>      // sidelineing will happen in the ${hbase.rootdir}/${sidelinedir} directory with the same folder structure.<a name="line.1216"></a>
-<span class="sourceLineNo">1217</span>      Path backRefPath = FileLink.getBackReferencesDir(HFileArchiveUtil<a name="line.1217"></a>
-<span class="sourceLineNo">1218</span>              .getStoreArchivePath(conf, HFileLink.getReferencedTableName(path.getName().toString()),<a name="line.1218"></a>
-<span class="sourceLineNo">1219</span>                  HFileLink.getReferencedRegionName(path.getName().toString()),<a name="line.1219"></a>
-<span class="sourceLineNo">1220</span>                  path.getParent().getName()),<a name="line.1220"></a>
-<span class="sourceLineNo">1221</span>          HFileLink.getReferencedHFileName(path.getName().toString()));<a name="line.1221"></a>
-<span class="sourceLineNo">1222</span>      success = sidelineFile(fs, hbaseRoot, backRefPath);<a name="line.1222"></a>
-<span class="sourceLineNo">1223</span><a name="line.1223"></a>
-<span class="sourceLineNo">1224</span>      if (!success) {<a name="line.1224"></a>
-<span class="sourceLineNo">1225</span>        LOG.error("Failed to sideline HFileLink backreference file " + path);<a name="line.1225"></a>
-<span class="sourceLineNo">1226</span>      }<a name="line.1226"></a>
-<span class="sourceLineNo">1227</span>    }<a name="line.1227"></a>
-<span class="sourceLineNo">1228</span>  }<a name="line.1228"></a>
-<span class="sourceLineNo">1229</span><a name="line.1229"></a>
-<span class="sourceLineNo">1230</span>  private boolean sidelineFile(FileSystem fs, Path hbaseRoot, Path path) throws IOException {<a name="line.1230"></a>
-<span class="sourceLineNo">1231</span>    URI uri = hbaseRoot.toUri().relativize(path.toUri());<a name="line.1231"></a>
-<span class="sourceLineNo">1232</span>    if (uri.isAbsolute()) return false;<a name="line.1232"></a>
-<span class="sourceLineNo">1233</span>    String relativePath = uri.getPath();<a name="line.1233"></a>
-<span class="sourceLineNo">1234</span>    Path rootDir = getSidelineDir();<a name="line.1234"></a>
-<span class="sourceLineNo">1235</span>    Path dst = new Path(rootDir, relativePath);<a name="line.1235"></a>
-<span class="sourceLineNo">1236</span>    boolean pathCreated = fs.mkdirs(dst.getParent());<a name="line.1236"></a>
-<span class="sourceLineNo">1237</span>    if (!pathCreated) {<a name="line.1237"></a>
-<span class="sourceLineNo">1238</span>      LOG.error("Failed to create path: " + dst.getParent());<a name="line.1238"></a>
-<span class="sourceLineNo">1239</span>      return false;<a name="line.1239"></a>
-<span class="sourceLineNo">1240</span>    }<a name="line.1240"></a>
-<span class="sourceLineNo">1241</span>    LOG.info("Trying to sideline file " + path + " to " + dst);<a name="line.1241"></a>
-<span class="sourceLineNo">1242</span>    return fs.rename(path, dst);<a name="line.1242"></a>
-<span class="sourceLineNo">1243</span>  }<a name="line.1243"></a>
-<span class="sourceLineNo">1244</span><a name="line.1244"></a>
-<span class="sourceLineNo">1245</span>  /**<a name="line.1245"></a>
-<span class="sourceLineNo">1246</span>   * TODO -- need to add tests for this.<a name="line.1246"></a>
-<span class="sourceLineNo">1247</span>   */<a name="line.1247"></a>
-<span class="sourceLineNo">1248</span>  private void reportEmptyMetaCells() {<a name="line.1248"></a>
-<span class="sourceLineNo">1249</span>    errors.print("Number of empty REGIONINFO_QUALIFIER rows in hbase:meta: " +<a name="line.1249"></a>
-<span class="sourceLineNo">1250</span>      emptyRegionInfoQualifiers.size());<a name="line.1250"></a>
-<span class="sourceLineNo">1251</span>    if (details) {<a name="line.1251"></a>
-<span class="sourceLineNo">1252</span>      for (Result r: emptyRegionInfoQualifiers) {<a name="line.1252"></a>
-<span class="sourceLineNo">1253</span>        errors.print("  " + r);<a name="line.1253"></a>
-<span class="sourceLineNo">1254</span>      }<a name="line.1254"></a>
-<span class="sourceLineNo">1255</span>    }<a name="line.1255"></a>
-<span class="sourceLineNo">1256</span>  }<a name="line.1256"></a>
-<span class="sourceLineNo">1257</span><a name="line.1257"></a>
-<span class="sourceLineNo">1258</span>  /**<a name="line.1258"></a>
-<span class="sourceLineNo">1259</span>   * TODO -- need to add tests for this.<a name="line.1259"></a>
-<span class="sourceLineNo">1260</span>   */<a name="line.1260"></a>
-<span class="sourceLineNo">1261</span>  private void reportTablesInFlux() {<a name="line.1261"></a>
-<span class="sourceLineNo">1262</span>    AtomicInteger numSkipped = new AtomicInteger(0);<a name="line.1262"></a>
-<span class="sourceLineNo">1263</span>    TableDescriptor[] allTables = getTables(numSkipped);<a name="line.1263"></a>
-<span class="sourceLineNo">1264</span>    errors.print("Number of Tables: " + allTables.length);<a name="line.1264"></a>
-<span class="sourceLineNo">1265</span>    if (details) {<a name="line.1265"></a>
-<span class="sourceLineNo">1266</span>      if (numSkipped.get() &gt; 0) {<a name="line.1266"></a>
-<span class="sourceLineNo">1267</span>        errors.detail("Number of Tables in flux: " + numSkipped.get());<a name="line.1267"></a>
-<span class="sourceLineNo">1268</span>      }<a name="line.1268"></a>
-<span class="sourceLineNo">1269</span>      for (TableDescriptor td : allTables) {<a name="line.1269"></a>
-<span class="sourceLineNo">1270</span>        errors.detail("  Table: " + td.getTableName() + "\t" +<a name="line.1270"></a>
-<span class="sourceLineNo">1271</span>                           (td.isReadOnly() ? "ro" : "rw") + "\t" +<a name="line.1271"></a>
-<span class="sourceLineNo">1272</span>                            (td.isMetaRegion() ? "META" : "    ") + "\t" +<a name="line.1272"></a>
-<span class="sourceLineNo">1273</span>                           " families: " + td.getColumnFamilyCount());<a name="line.1273"></a>
-<span class="sourceLineNo">1274</span>      }<a name="line.1274"></a>
-<span class="sourceLineNo">1275</span>    }<a name="line.1275"></a>
-<span class="sourceLineNo">1276</span>  }<a name="line.1276"></a>
-<span class="sourceLineNo">1277</span><a name="line.1277"></a>
-<span class="sourceLineNo">1278</span>  public HbckErrorReporter getErrors() {<a name="line.1278"></a>
-<span class="sourceLineNo">1279</span>    return errors;<a name="line.1279"></a>
-<span class="sourceLineNo">1280</span>  }<a name="line.1280"></a>
-<span class="sourceLineNo">1281</span><a name="line.1281"></a>
-<span class="sourceLineNo">1282</span>  /**<a name="line.1282"></a>
-<span class="sourceLineNo">1283</span>   * Populate hbi's from regionInfos loaded from file system.<a name="line.1283"></a>
-<span class="sourceLineNo">1284</span>   */<a name="line.1284"></a>
-<span class="sourceLineNo">1285</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; loadHdfsRegionInfos()<a name="line.1285"></a>
-<span class="sourceLineNo">1286</span>      throws IOException, InterruptedException {<a name="line.1286"></a>
-<span class="sourceLineNo">1287</span>    tablesInfo.clear(); // regenerating the data<a name="line.1287"></a>
-<span class="sourceLineNo">1288</span>    // generate region split structure<a name="line.1288"></a>
-<span class="sourceLineNo">1289</span>    Collection&lt;HbckRegionInfo&gt; hbckRegionInfos = regionInfoMap.values();<a name="line.1289"></a>
-<span class="sourceLineNo">1290</span><a name="line.1290"></a>
-<span class="sourceLineNo">1291</span>    // Parallelized read of .regioninfo files.<a name="line.1291"></a>
-<span class="sourceLineNo">1292</span>    List&lt;WorkItemHdfsRegionInfo&gt; hbis = new ArrayList&lt;&gt;(hbckRegionInfos.size());<a name="line.1292"></a>
-<span class="sourceLineNo">1293</span>    List&lt;Future&lt;Void&gt;&gt; hbiFutures;<a name="line.1293"></a>
-<span class="sourceLineNo">1294</span><a name="line.1294"></a>
-<span class="sourceLineNo">1295</span>    for (HbckRegionInfo hbi : hbckRegionInfos) {<a name="line.1295"></a>
-<span class="sourceLineNo">1296</span>      WorkItemHdfsRegionInfo work = new WorkItemHdfsRegionInfo(hbi, this, errors);<a name="line.1296"></a>
-<span class="sourceLineNo">1297</span>      hbis.add(work);<a name="line.1297"></a>
-<span class="sourceLineNo">1298</span>    }<a name="line.1298"></a>
-<span class="sourceLineNo">1299</span><a name="line.1299"></a>
-<span class="sourceLineNo">1300</span>    // Submit and wait for completion<a name="line.1300"></a>
-<span class="sourceLineNo">1301</span>    hbiFutures = executor.invokeAll(hbis);<a name="line.1301"></a>
-<span class="sourceLineNo">1302</span><a name="line.1302"></a>
-<span class="sourceLineNo">1303</span>    for(int i=0; i&lt;hbiFutures.size(); i++) {<a name="line.1303"></a>
-<span class="sourceLineNo">1304</span>      WorkItemHdfsRegionInfo work = hbis.get(i);<a name="line.1304"></a>
-<span class="sourceLineNo">1305</span>      Future&lt;Void&gt; f = hbiFutures.get(i);<a name="line.1305"></a>
-<span class="sourceLineNo">1306</span>      try {<a name="line.1306"></a>
-<span class="sourceLineNo">1307</span>        f.get();<a name="line.1307"></a>
-<span class="sourceLineNo">1308</span>      } catch(ExecutionException e) {<a name="line.1308"></a>
-<span class="sourceLineNo">1309</span>        LOG.warn("Failed to read .regioninfo file for region " +<a name="line.1309"></a>
-<span class="sourceLineNo">1310</span>              work.hbi.getRegionNameAsString(), e.getCause());<a name="line.1310"></a>
-<span class="sourceLineNo">1311</span>      }<a name="line.1311"></a>
-<span class="sourceLineNo">1312</span>    }<a name="line.1312"></a>
-<span class="sourceLineNo">1313</span><a name="line.1313"></a>
-<span class="sourceLineNo">1314</span>    Path hbaseRoot = FSUtils.getRootDir(getConf());<a name="line.1314"></a>
-<span class="sourceLineNo">1315</span>    FileSystem fs = hbaseRoot.getFileSystem(getConf());<a name="line.1315"></a>
-<span class="sourceLineNo">1316</span>    // serialized table info gathering.<a name="line.1316"></a>
-<span class="sourceLineNo">1317</span>    for (HbckRegionInfo hbi: hbckRegionInfos) {<a name="line.1317"></a>
-<span class="sourceLineNo">1318</span><a name="line.1318"></a>
-<span class="sourceLineNo">1319</span>      if (hbi.getHdfsHRI() == null) {<a name="line.1319"></a>
-<span class="sourceLineNo">1320</span>        // was an orphan<a name="line.1320"></a>
-<span class="sourceLineNo">1321</span>        continue;<a name="line.1321"></a>
-<span class="sourceLineNo">1322</span>      }<a name="line.1322"></a>
+<span class="sourceLineNo">559</span>    // Add a shutdown hook to this thread, in case user tries to<a name="line.559"></a>
+<span class="sourceLineNo">560</span>    // kill the hbck with a ctrl-c, we want to cleanup the lock so that<a name="line.560"></a>
+<span class="sourceLineNo">561</span>    // it is available for further calls<a name="line.561"></a>
+<span class="sourceLineNo">562</span>    Runtime.getRuntime().addShutdownHook(new Thread() {<a name="line.562"></a>
+<span class="sourceLineNo">563</span>      @Override<a name="line.563"></a>
+<span class="sourceLineNo">564</span>      public void run() {<a name="line.564"></a>
+<span class="sourceLineNo">565</span>        IOUtils.closeQuietly(HBaseFsck.this);<a name="line.565"></a>
+<span class="sourceLineNo">566</span>        cleanupHbckZnode();<a name="line.566"></a>
+<span class="sourceLineNo">567</span>        unlockHbck();<a name="line.567"></a>
+<span class="sourceLineNo">568</span>      }<a name="line.568"></a>
+<span class="sourceLineNo">569</span>    });<a name="line.569"></a>
+<span class="sourceLineNo">570</span><a name="line.570"></a>
+<span class="sourceLineNo">571</span>    LOG.info("Launching hbck");<a name="line.571"></a>
+<span class="sourceLineNo">572</span><a name="line.572"></a>
+<span class="sourceLineNo">573</span>    connection = ConnectionFactory.createConnection(getConf());<a name="line.573"></a>
+<span class="sourceLineNo">574</span>    admin = connection.getAdmin();<a name="line.574"></a>
+<span class="sourceLineNo">575</span>    meta = connection.getTable(TableName.META_TABLE_NAME);<a name="line.575"></a>
+<span class="sourceLineNo">576</span>    status = admin.getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS,<a name="line.576"></a>
+<span class="sourceLineNo">577</span>      Option.DEAD_SERVERS, Option.MASTER, Option.BACKUP_MASTERS,<a name="line.577"></a>
+<span class="sourceLineNo">578</span>      Option.REGIONS_IN_TRANSITION, Option.HBASE_VERSION));<a name="line.578"></a>
+<span class="sourceLineNo">579</span>  }<a name="line.579"></a>
+<span class="sourceLineNo">580</span><a name="line.580"></a>
+<span class="sourceLineNo">581</span>  /**<a name="line.581"></a>
+<span class="sourceLineNo">582</span>   * Get deployed regions according to the region servers.<a name="line.582"></a>
+<span class="sourceLineNo">583</span>   */<a name="line.583"></a>
+<span class="sourceLineNo">584</span>  private void loadDeployedRegions() throws IOException, InterruptedException {<a name="line.584"></a>
+<span class="sourceLineNo">585</span>    // From the master, get a list of all known live region servers<a name="line.585"></a>
+<span class="sourceLineNo">586</span>    Collection&lt;ServerName&gt; regionServers = status.getLiveServerMetrics().keySet();<a name="line.586"></a>
+<span class="sourceLineNo">587</span>    errors.print("Number of live region servers: " + regionServers.size());<a name="line.587"></a>
+<span class="sourceLineNo">588</span>    if (details) {<a name="line.588"></a>
+<span class="sourceLineNo">589</span>      for (ServerName rsinfo: regionServers) {<a name="line.589"></a>
+<span class="sourceLineNo">590</span>        errors.print("  " + rsinfo.getServerName());<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>    // From the master, get a list of all dead region servers<a name="line.594"></a>
+<span class="sourceLineNo">595</span>    Collection&lt;ServerName&gt; deadRegionServers = status.getDeadServerNames();<a name="line.595"></a>
+<span class="sourceLineNo">596</span>    errors.print("Number of dead region servers: " + deadRegionServers.size());<a name="line.596"></a>
+<span class="sourceLineNo">597</span>    if (details) {<a name="line.597"></a>
+<span class="sourceLineNo">598</span>      for (ServerName name: deadRegionServers) {<a name="line.598"></a>
+<span class="sourceLineNo">599</span>        errors.print("  " + name);<a name="line.599"></a>
+<span class="sourceLineNo">600</span>      }<a name="line.600"></a>
+<span class="sourceLineNo">601</span>    }<a name="line.601"></a>
+<span class="sourceLineNo">602</span><a name="line.602"></a>
+<span class="sourceLineNo">603</span>    // Print the current master name and state<a name="line.603"></a>
+<span class="sourceLineNo">604</span>    errors.print("Master: " + status.getMasterName());<a name="line.604"></a>
+<span class="sourceLineNo">605</span><a name="line.605"></a>
+<span class="sourceLineNo">606</span>    // Print the list of all backup masters<a name="line.606"></a>
+<span class="sourceLineNo">607</span>    Collection&lt;ServerName&gt; backupMasters = status.getBackupMasterNames();<a name="line.607"></a>
+<span class="sourceLineNo">608</span>    errors.print("Number of backup masters: " + backupMasters.size());<a name="line.608"></a>
+<span class="sourceLineNo">609</span>    if (details) {<a name="line.609"></a>
+<span class="sourceLineNo">610</span>      for (ServerName name: backupMasters) {<a name="line.610"></a>
+<span class="sourceLineNo">611</span>        errors.print("  " + name);<a name="line.611"></a>
+<span class="sourceLineNo">612</span>      }<a name="line.612"></a>
+<span class="sourceLineNo">613</span>    }<a name="line.613"></a>
+<span class="sourceLineNo">614</span><a name="line.614"></a>
+<span class="sourceLineNo">615</span>    errors.print("Average load: " + status.getAverageLoad());<a name="line.615"></a>
+<span class="sourceLineNo">616</span>    errors.print("Number of requests: " + status.getRequestCount());<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    errors.print("Number of regions: " + status.getRegionCount());<a name="line.617"></a>
+<span class="sourceLineNo">618</span><a name="line.618"></a>
+<span class="sourceLineNo">619</span>    List&lt;RegionState&gt; rits = status.getRegionStatesInTransition();<a name="line.619"></a>
+<span class="sourceLineNo">620</span>    errors.print("Number of regions in transition: " + rits.size());<a name="line.620"></a>
+<span class="sourceLineNo">621</span>    if (details) {<a name="line.621"></a>
+<span class="sourceLineNo">622</span>      for (RegionState state: rits) {<a name="line.622"></a>
+<span class="sourceLineNo">623</span>        errors.print("  " + state.toDescriptiveString());<a name="line.623"></a>
+<span class="sourceLineNo">624</span>      }<a name="line.624"></a>
+<span class="sourceLineNo">625</span>    }<a name="line.625"></a>
+<span class="sourceLineNo">626</span><a name="line.626"></a>
+<span class="sourceLineNo">627</span>    // Determine what's deployed<a name="line.627"></a>
+<span class="sourceLineNo">628</span>    processRegionServers(regionServers);<a name="line.628"></a>
+<span class="sourceLineNo">629</span>  }<a name="line.629"></a>
+<span class="sourceLineNo">630</span><a name="line.630"></a>
+<span class="sourceLineNo">631</span>  /**<a name="line.631"></a>
+<span class="sourceLineNo">632</span>   * Clear the current state of hbck.<a name="line.632"></a>
+<span class="sourceLineNo">633</span>   */<a name="line.633"></a>
+<span class="sourceLineNo">634</span>  private void clearState() {<a name="line.634"></a>
+<span class="sourceLineNo">635</span>    // Make sure regionInfo is empty before starting<a name="line.635"></a>
+<span class="sourceLineNo">636</span>    fixes = 0;<a name="line.636"></a>
+<span class="sourceLineNo">637</span>    regionInfoMap.clear();<a name="line.637"></a>
+<span class="sourceLineNo">638</span>    emptyRegionInfoQualifiers.clear();<a name="line.638"></a>
+<span class="sourceLineNo">639</span>    tableStates.clear();<a name="line.639"></a>
+<span class="sourceLineNo">640</span>    errors.clear();<a name="line.640"></a>
+<span class="sourceLineNo">641</span>    tablesInfo.clear();<a name="line.641"></a>
+<span class="sourceLineNo">642</span>    orphanHdfsDirs.clear();<a name="line.642"></a>
+<span class="sourceLineNo">643</span>    skippedRegions.clear();<a name="line.643"></a>
+<span class="sourceLineNo">644</span>  }<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>   * This repair method analyzes hbase data in hdfs and repairs it to satisfy<a name="line.647"></a>
+<span class="sourceLineNo">648</span>   * the table integrity rules.  HBase doesn't need to be online for this<a name="line.648"></a>
+<span class="sourceLineNo">649</span>   * operation to work.<a name="line.649"></a>
+<span class="sourceLineNo">650</span>   */<a name="line.650"></a>
+<span class="sourceLineNo">651</span>  public void offlineHdfsIntegrityRepair() throws IOException, InterruptedException {<a name="line.651"></a>
+<span class="sourceLineNo">652</span>    // Initial pass to fix orphans.<a name="line.652"></a>
+<span class="sourceLineNo">653</span>    if (shouldCheckHdfs() &amp;&amp; (shouldFixHdfsOrphans() || shouldFixHdfsHoles()<a name="line.653"></a>
+<span class="sourceLineNo">654</span>        || shouldFixHdfsOverlaps() || shouldFixTableOrphans())) {<a name="line.654"></a>
+<span class="sourceLineNo">655</span>      LOG.info("Loading regioninfos HDFS");<a name="line.655"></a>
+<span class="sourceLineNo">656</span>      // if nothing is happening this should always complete in two iterations.<a name="line.656"></a>
+<span class="sourceLineNo">657</span>      int maxIterations = getConf().getInt("hbase.hbck.integrityrepair.iterations.max", 3);<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      int curIter = 0;<a name="line.658"></a>
+<span class="sourceLineNo">659</span>      do {<a name="line.659"></a>
+<span class="sourceLineNo">660</span>        clearState(); // clears hbck state and reset fixes to 0 and.<a name="line.660"></a>
+<span class="sourceLineNo">661</span>        // repair what's on HDFS<a name="line.661"></a>
+<span class="sourceLineNo">662</span>        restoreHdfsIntegrity();<a name="line.662"></a>
+<span class="sourceLineNo">663</span>        curIter++;// limit the number of iterations.<a name="line.663"></a>
+<span class="sourceLineNo">664</span>      } while (fixes &gt; 0 &amp;&amp; curIter &lt;= maxIterations);<a name="line.664"></a>
+<span class="sourceLineNo">665</span><a name="line.665"></a>
+<span class="sourceLineNo">666</span>      // Repairs should be done in the first iteration and verification in the second.<a name="line.666"></a>
+<span class="sourceLineNo">667</span>      // If there are more than 2 passes, something funny has happened.<a name="line.667"></a>
+<span class="sourceLineNo">668</span>      if (curIter &gt; 2) {<a name="line.668"></a>
+<span class="sourceLineNo">669</span>        if (curIter == maxIterations) {<a name="line.669"></a>
+<span class="sourceLineNo">670</span>          LOG.warn("Exiting integrity repairs after max " + curIter + " iterations. "<a name="line.670"></a>
+<span class="sourceLineNo">671</span>              + "Tables integrity may not be fully repaired!");<a name="line.671"></a>
+<span class="sourceLineNo">672</span>        } else {<a name="line.672"></a>
+<span class="sourceLineNo">673</span>          LOG.info("Successfully exiting integrity repairs after " + curIter + " iterations");<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>  }<a name="line.677"></a>
+<span class="sourceLineNo">678</span><a name="line.678"></a>
+<span class="sourceLineNo">679</span>  /**<a name="line.679"></a>
+<span class="sourceLineNo">680</span>   * This repair method requires the cluster to be online since it contacts<a name="line.680"></a>
+<span class="sourceLineNo">681</span>   * region servers and the masters.  It makes each region's state in HDFS, in<a name="line.681"></a>
+<span class="sourceLineNo">682</span>   * hbase:meta, and deployments consistent.<a name="line.682"></a>
+<span class="sourceLineNo">683</span>   *<a name="line.683"></a>
+<span class="sourceLineNo">684</span>   * @return If &amp;gt; 0 , number of errors detected, if &amp;lt; 0 there was an unrecoverable<a name="line.684"></a>
+<span class="sourceLineNo">685</span>   *     error.  If 0, we have a clean hbase.<a name="line.685"></a>
+<span class="sourceLineNo">686</span>   */<a name="line.686"></a>
+<span class="sourceLineNo">687</span>  public int onlineConsistencyRepair() throws IOException, KeeperException,<a name="line.687"></a>
+<span class="sourceLineNo">688</span>    InterruptedException {<a name="line.688"></a>
+<span class="sourceLineNo">689</span><a name="line.689"></a>
+<span class="sourceLineNo">690</span>    // get regions according to what is online on each RegionServer<a name="line.690"></a>
+<span class="sourceLineNo">691</span>    loadDeployedRegions();<a name="line.691"></a>
+<span class="sourceLineNo">692</span>    // check whether hbase:meta is deployed and online<a name="line.692"></a>
+<span class="sourceLineNo">693</span>    recordMetaRegion();<a name="line.693"></a>
+<span class="sourceLineNo">694</span>    // Check if hbase:meta is found only once and in the right place<a name="line.694"></a>
+<span class="sourceLineNo">695</span>    if (!checkMetaRegion()) {<a name="line.695"></a>
+<span class="sourceLineNo">696</span>      String errorMsg = "hbase:meta table is not consistent. ";<a name="line.696"></a>
+<span class="sourceLineNo">697</span>      if (shouldFixAssignments()) {<a name="line.697"></a>
+<span class="sourceLineNo">698</span>        errorMsg += "HBCK will try fixing it. Rerun once hbase:meta is back to consistent state.";<a name="line.698"></a>
+<span class="sourceLineNo">699</span>      } else {<a name="line.699"></a>
+<span class="sourceLineNo">700</span>        errorMsg += "Run HBCK with proper fix options to fix hbase:meta inconsistency.";<a name="line.700"></a>
+<span class="sourceLineNo">701</span>      }<a name="line.701"></a>
+<span class="sourceLineNo">702</span>      errors.reportError(errorMsg + " Exiting...");<a name="line.702"></a>
+<span class="sourceLineNo">703</span>      return -2;<a name="line.703"></a>
+<span class="sourceLineNo">704</span>    }<a name="line.704"></a>
+<span class="sourceLineNo">705</span>    // Not going with further consistency check for tables when hbase:meta itself is not consistent.<a name="line.705"></a>
+<span class="sourceLineNo">706</span>    LOG.info("Loading regionsinfo from the hbase:meta table");<a name="line.706"></a>
+<span class="sourceLineNo">707</span>    boolean success = loadMetaEntries();<a name="line.707"></a>
+<span class="sourceLineNo">708</span>    if (!success) return -1;<a name="line.708"></a>
+<span class="sourceLineNo">709</span><a name="line.709"></a>
+<span class="sourceLineNo">710</span>    // Empty cells in hbase:meta?<a name="line.710"></a>
+<span class="sourceLineNo">711</span>    reportEmptyMetaCells();<a name="line.711"></a>
+<span class="sourceLineNo">712</span><a name="line.712"></a>
+<span class="sourceLineNo">713</span>    // Check if we have to cleanup empty REGIONINFO_QUALIFIER rows from hbase:meta<a name="line.713"></a>
+<span class="sourceLineNo">714</span>    if (shouldFixEmptyMetaCells()) {<a name="line.714"></a>
+<span class="sourceLineNo">715</span>      fixEmptyMetaCells();<a name="line.715"></a>
+<span class="sourceLineNo">716</span>    }<a name="line.716"></a>
+<span class="sourceLineNo">717</span><a name="line.717"></a>
+<span class="sourceLineNo">718</span>    // get a list of all tables that have not changed recently.<a name="line.718"></a>
+<span class="sourceLineNo">719</span>    if (!checkMetaOnly) {<a name="line.719"></a>
+<span class="sourceLineNo">720</span>      reportTablesInFlux();<a name="line.720"></a>
+<span class="sourceLineNo">721</span>    }<a name="line.721"></a>
+<span class="sourceLineNo">722</span><a name="line.722"></a>
+<span class="sourceLineNo">723</span>    // Get disabled tables states<a name="line.723"></a>
+<span class="sourceLineNo">724</span>    loadTableStates();<a name="line.724"></a>
+<span class="sourceLineNo">725</span><a name="line.725"></a>
+<span class="sourceLineNo">726</span>    // load regiondirs and regioninfos from HDFS<a name="line.726"></a>
+<span class="sourceLineNo">727</span>    if (shouldCheckHdfs()) {<a name="line.727"></a>
+<span class="sourceLineNo">728</span>      LOG.info("Loading region directories from HDFS");<a name="line.728"></a>
+<span class="sourceLineNo">729</span>      loadHdfsRegionDirs();<a name="line.729"></a>
+<span class="sourceLineNo">730</span>      LOG.info("Loading region information from HDFS");<a name="line.730"></a>
+<span class="sourceLineNo">731</span>      loadHdfsRegionInfos();<a name="line.731"></a>
+<span class="sourceLineNo">732</span>    }<a name="line.732"></a>
+<span class="sourceLineNo">733</span><a name="line.733"></a>
+<span class="sourceLineNo">734</span>    // fix the orphan tables<a name="line.734"></a>
+<span class="sourceLineNo">735</span>    fixOrphanTables();<a name="line.735"></a>
+<span class="sourceLineNo">736</span><a name="line.736"></a>
+<span class="sourceLineNo">737</span>    LOG.info("Checking and fixing region consistency");<a name="line.737"></a>
+<span class="sourceLineNo">738</span>    // Check and fix consistency<a name="line.738"></a>
+<span class="sourceLineNo">739</span>    checkAndFixConsistency();<a name="line.739"></a>
+<span class="sourceLineNo">740</span><a name="line.740"></a>
+<span class="sourceLineNo">741</span>    // Check integrity (does not fix)<a name="line.741"></a>
+<span class="sourceLineNo">742</span>    checkIntegrity();<a name="line.742"></a>
+<span class="sourceLineNo">743</span>    return errors.getErrorList().size();<a name="line.743"></a>
+<span class="sourceLineNo">744</span>  }<a name="line.744"></a>
+<span class="sourceLineNo">745</span><a name="line.745"></a>
+<span class="sourceLineNo">746</span>  /**<a name="line.746"></a>
+<span class="sourceLineNo">747</span>   * This method maintains an ephemeral znode. If the creation fails we return false or throw<a name="line.747"></a>
+<span class="sourceLineNo">748</span>   * exception<a name="line.748"></a>
+<span class="sourceLineNo">749</span>   *<a name="line.749"></a>
+<span class="sourceLineNo">750</span>   * @return true if creating znode succeeds; false otherwise<a name="line.750"></a>
+<span class="sourceLineNo">751</span>   * @throws IOException if IO failure occurs<a name="line.751"></a>
+<span class="sourceLineNo">752</span>   */<a name="line.752"></a>
+<span class="sourceLineNo">753</span>  private boolean setMasterInMaintenanceMode() throws IOException {<a name="line.753"></a>
+<span class="sourceLineNo">754</span>    RetryCounter retryCounter = createZNodeRetryCounterFactory.create();<a name="line.754"></a>
+<span class="sourceLineNo">755</span>    hbckEphemeralNodePath = ZNodePaths.joinZNode(<a name="line.755"></a>
+<span class="sourceLineNo">756</span>      zkw.getZNodePaths().masterMaintZNode,<a name="line.756"></a>
+<span class="sourceLineNo">757</span>      "hbck-" + Long.toString(EnvironmentEdgeManager.currentTime()));<a name="line.757"></a>
+<span class="sourceLineNo">758</span>    do {<a name="line.758"></a>
+<span class="sourceLineNo">759</span>      try {<a name="line.759"></a>
+<span class="sourceLineNo">760</span>        hbckZodeCreated = ZKUtil.createEphemeralNodeAndWatch(zkw, hbckEphemeralNodePath, null);<a name="line.760"></a>
+<span class="sourceLineNo">761</span>        if (hbckZodeCreated) {<a name="line.761"></a>
+<span class="sourceLineNo">762</span>          break;<a name="line.762"></a>
+<span class="sourceLineNo">763</span>        }<a name="line.763"></a>
+<span class="sourceLineNo">764</span>      } catch (KeeperException e) {<a name="line.764"></a>
+<span class="sourceLineNo">765</span>        if (retryCounter.getAttemptTimes() &gt;= retryCounter.getMaxAttempts()) {<a name="line.765"></a>
+<span class="sourceLineNo">766</span>           throw new IOException("Can't create znode " + hbckEphemeralNodePath, e);<a name="line.766"></a>
+<span class="sourceLineNo">767</span>        }<a name="line.767"></a>
+<span class="sourceLineNo">768</span>        // fall through and retry<a name="line.768"></a>
+<span class="sourceLineNo">769</span>      }<a name="line.769"></a>
+<span class="sourceLineNo">770</span><a name="line.770"></a>
+<span class="sourceLineNo">771</span>      LOG.warn("Fail to create znode " + hbckEphemeralNodePath + ", try=" +<a name="line.771"></a>
+<span class="sourceLineNo">772</span>          (retryCounter.getAttemptTimes() + 1) + " of " + retryCounter.getMaxAttempts());<a name="line.772"></a>
+<span class="sourceLineNo">773</span><a name="line.773"></a>
+<span class="sourceLineNo">774</span>      try {<a name="line.774"></a>
+<span class="sourceLineNo">775</span>        retryCounter.sleepUntilNextRetry();<a name="line.775"></a>
+<span class="sourceLineNo">776</span>      } catch (InterruptedException ie) {<a name="line.776"></a>
+<span class="sourceLineNo">777</span>        throw (InterruptedIOException) new InterruptedIOException(<a name="line.777"></a>
+<span class="sourceLineNo">778</span>              "Can't create znode " + hbckEphemeralNodePath).initCause(ie);<a name="line.778"></a>
+<span class="sourceLineNo">779</span>      }<a name="line.779"></a>
+<span class="sourceLineNo">780</span>    } while (retryCounter.shouldRetry());<a name="line.780"></a>
+<span class="sourceLineNo">781</span>    return hbckZodeCreated;<a name="line.781"></a>
+<span class="sourceLineNo">782</span>  }<a name="line.782"></a>
+<span class="sourceLineNo">783</span><a name="line.783"></a>
+<span class="sourceLineNo">784</span>  private void cleanupHbckZnode() {<a name="line.784"></a>
+<span class="sourceLineNo">785</span>    try {<a name="line.785"></a>
+<span class="sourceLineNo">786</span>      if (zkw != null &amp;&amp; hbckZodeCreated) {<a name="line.786"></a>
+<span class="sourceLineNo">787</span>        ZKUtil.deleteNode(zkw, hbckEphemeralNodePath);<a name="line.787"></a>
+<span class="sourceLineNo">788</span>        hbckZodeCreated = false;<a name="line.788"></a>
+<span class="sourceLineNo">789</span>      }<a name="line.789"></a>
+<span class="sourceLineNo">790</span>    } catch (KeeperException e) {<a name="line.790"></a>
+<span class="sourceLineNo">791</span>      // Ignore<a name="line.791"></a>
+<span class="sourceLineNo">792</span>      if (!e.code().equals(KeeperException.Code.NONODE)) {<a name="line.792"></a>
+<span class="sourceLineNo">793</span>        LOG.warn("Delete HBCK znode " + hbckEphemeralNodePath + " failed ", e);<a name="line.793"></a>
+<span class="sourceLineNo">794</span>      }<a name="line.794"></a>
+<span class="sourceLineNo">795</span>    }<a name="line.795"></a>
+<span class="sourceLineNo">796</span>  }<a name="line.796"></a>
+<span class="sourceLineNo">797</span><a name="line.797"></a>
+<span class="sourceLineNo">798</span>  /**<a name="line.798"></a>
+<span class="sourceLineNo">799</span>   * Contacts the master and prints out cluster-wide information<a name="line.799"></a>
+<span class="sourceLineNo">800</span>   * @return 0 on success, non-zero on failure<a name="line.800"></a>
+<span class="sourceLineNo">801</span>   */<a name="line.801"></a>
+<span class="sourceLineNo">802</span>  public int onlineHbck()<a name="line.802"></a>
+<span class="sourceLineNo">803</span>      throws IOException, KeeperException, InterruptedException, ReplicationException {<a name="line.803"></a>
+<span class="sourceLineNo">804</span>    // print hbase server version<a name="line.804"></a>
+<span class="sourceLineNo">805</span>    errors.print("Version: " + status.getHBaseVersion());<a name="line.805"></a>
+<span class="sourceLineNo">806</span><a name="line.806"></a>
+<span class="sourceLineNo">807</span>    // Clean start<a name="line.807"></a>
+<span class="sourceLineNo">808</span>    clearState();<a name="line.808"></a>
+<span class="sourceLineNo">809</span>    // Do offline check and repair first<a name="line.809"></a>
+<span class="sourceLineNo">810</span>    offlineHdfsIntegrityRepair();<a name="line.810"></a>
+<span class="sourceLineNo">811</span>    offlineReferenceFileRepair();<a name="line.811"></a>
+<span class="sourceLineNo">812</span>    offlineHLinkFileRepair();<a name="line.812"></a>
+<span class="sourceLineNo">813</span>    // If Master runs maintenance tasks (such as balancer, catalog janitor, etc) during online<a name="line.813"></a>
+<span class="sourceLineNo">814</span>    // hbck, it is likely that hbck would be misled and report transient errors.  Therefore, it<a name="line.814"></a>
+<span class="sourceLineNo">815</span>    // is better to set Master into maintenance mode during online hbck.<a name="line.815"></a>
+<span class="sourceLineNo">816</span>    //<a name="line.816"></a>
+<span class="sourceLineNo">817</span>    if (!setMasterInMaintenanceMode()) {<a name="line.817"></a>
+<span class="sourceLineNo">818</span>      LOG.warn("HBCK is running while master is not in maintenance mode, you might see transient "<a name="line.818"></a>
+<span class="sourceLineNo">819</span>        + "error.  Please run HBCK multiple times to reduce the chance of transient error.");<a name="line.819"></a>
+<span class="sourceLineNo">820</span>    }<a name="line.820"></a>
+<span class="sourceLineNo">821</span><a name="line.821"></a>
+<span class="sourceLineNo">822</span>    onlineConsistencyRepair();<a name="line.822"></a>
+<span class="sourceLineNo">823</span><a name="line.823"></a>
+<span class="sourceLineNo">824</span>    if (checkRegionBoundaries) {<a name="line.824"></a>
+<span class="sourceLineNo">825</span>      checkRegionBoundaries();<a name="line.825"></a>
+<span class="sourceLineNo">826</span>    }<a name="line.826"></a>
+<span class="sourceLineNo">827</span><a name="line.827"></a>
+<span class="sourceLineNo">828</span>    checkAndFixReplication();<a name="line.828"></a>
+<span class="sourceLineNo">829</span><a name="line.829"></a>
+<span class="sourceLineNo">830</span>    cleanReplicationBarrier();<a name="line.830"></a>
+<span class="sourceLineNo">831</span><a name="line.831"></a>
+<span class="sourceLineNo">832</span>    // Remove the hbck znode<a name="line.832"></a>
+<span class="sourceLineNo">833</span>    cleanupHbckZnode();<a name="line.833"></a>
+<span class="sourceLineNo">834</span><a name="line.834"></a>
+<span class="sourceLineNo">835</span>    // Remove the hbck lock<a name="line.835"></a>
+<span class="sourceLineNo">836</span>    unlockHbck();<a name="line.836"></a>
+<span class="sourceLineNo">837</span><a name="line.837"></a>
+<span class="sourceLineNo">838</span>    // Print table summary<a name="line.838"></a>
+<span class="sourceLineNo">839</span>    printTableSummary(tablesInfo);<a name="line.839"></a>
+<span class="sourceLineNo">840</span>    return errors.summarize();<a name="line.840"></a>
+<span class="sourceLineNo">841</span>  }<a name="line.841"></a>
+<span class="sourceLineNo">842</span><a name="line.842"></a>
+<span class="sourceLineNo">843</span>  public static byte[] keyOnly(byte[] b) {<a name="line.843"></a>
+<span class="sourceLineNo">844</span>    if (b == null)<a name="line.844"></a>
+<span class="sourceLineNo">845</span>      return b;<a name="line.845"></a>
+<span class="sourceLineNo">846</span>    int rowlength = Bytes.toShort(b, 0);<a name="line.846"></a>
+<span class="sourceLineNo">847</span>    byte[] result = new byte[rowlength];<a name="line.847"></a>
+<span class="sourceLineNo">848</span>    System.arraycopy(b, Bytes.SIZEOF_SHORT, result, 0, rowlength);<a name="line.848"></a>
+<span class="sourceLineNo">849</span>    return result;<a name="line.849"></a>
+<span class="sourceLineNo">850</span>  }<a name="line.850"></a>
+<span class="sourceLineNo">851</span><a name="line.851"></a>
+<span class="sourceLineNo">852</span>  @Override<a name="line.852"></a>
+<span class="sourceLineNo">853</span>  public void close() throws IOException {<a name="line.853"></a>
+<span class="sourceLineNo">854</span>    try {<a name="line.854"></a>
+<span class="sourceLineNo">855</span>      cleanupHbckZnode();<a name="line.855"></a>
+<span class="sourceLineNo">856</span>      unlockHbck();<a name="line.856"></a>
+<span class="sourceLineNo">857</span>    } catch (Exception io) {<a name="line.857"></a>
+<span class="sourceLineNo">858</span>      LOG.warn(io.toString(), io);<a name="line.858"></a>
+<span class="sourceLineNo">859</span>    } finally {<a name="line.859"></a>
+<span class="sourceLineNo">860</span>      if (zkw != null) {<a name="line.860"></a>
+<span class="sourceLineNo">861</span>        zkw.close();<a name="line.861"></a>
+<span class="sourceLineNo">862</span>        zkw = null;<a name="line.862"></a>
+<span class="sourceLineNo">863</span>      }<a name="line.863"></a>
+<span class="sourceLineNo">864</span>      IOUtils.closeQuietly(admin);<a name="line.864"></a>
+<span class="sourceLineNo">865</span>      IOUtils.closeQuietly(meta);<a name="line.865"></a>
+<span class="sourceLineNo">866</span>      IOUtils.closeQuietly(connection);<a name="line.866"></a>
+<span class="sourceLineNo">867</span>    }<a name="line.867"></a>
+<span class="sourceLineNo">868</span>  }<a name="line.868"></a>
+<span class="sourceLineNo">869</span><a name="line.869"></a>
+<span class="sourceLineNo">870</span>  private static class RegionBoundariesInformation {<a name="line.870"></a>
+<span class="sourceLineNo">871</span>    public byte [] regionName;<a name="line.871"></a>
+<span class="sourceLineNo">872</span>    public byte [] metaFirstKey;<a name="line.872"></a>
+<span class="sourceLineNo">873</span>    public byte [] metaLastKey;<a name="line.873"></a>
+<span class="sourceLineNo">874</span>    public byte [] storesFirstKey;<a name="line.874"></a>
+<span class="sourceLineNo">875</span>    public byte [] storesLastKey;<a name="line.875"></a>
+<span class="sourceLineNo">876</span>    @Override<a name="line.876"></a>
+<span class="sourceLineNo">877</span>    public String toString () {<a name="line.877"></a>
+<span class="sourceLineNo">878</span>      return "regionName=" + Bytes.toStringBinary(regionName) +<a name="line.878"></a>
+<span class="sourceLineNo">879</span>             "\nmetaFirstKey=" + Bytes.toStringBinary(metaFirstKey) +<a name="line.879"></a>
+<span class="sourceLineNo">880</span>             "\nmetaLastKey=" + Bytes.toStringBinary(metaLastKey) +<a name="line.880"></a>
+<span class="sourceLineNo">881</span>             "\nstoresFirstKey=" + Bytes.toStringBinary(storesFirstKey) +<a name="line.881"></a>
+<span class="sourceLineNo">882</span>             "\nstoresLastKey=" + Bytes.toStringBinary(storesLastKey);<a name="line.882"></a>
+<span class="sourceLineNo">883</span>    }<a name="line.883"></a>
+<span class="sourceLineNo">884</span>  }<a name="line.884"></a>
+<span class="sourceLineNo">885</span><a name="line.885"></a>
+<span class="sourceLineNo">886</span>  public void checkRegionBoundaries() {<a name="line.886"></a>
+<span class="sourceLineNo">887</span>    try {<a name="line.887"></a>
+<span class="sourceLineNo">888</span>      ByteArrayComparator comparator = new ByteArrayComparator();<a name="line.888"></a>
+<span class="sourceLineNo">889</span>      List&lt;RegionInfo&gt; regions = MetaTableAccessor.getAllRegions(connection, true);<a name="line.889"></a>
+<span class="sourceLineNo">890</span>      final RegionBoundariesInformation currentRegionBoundariesInformation =<a name="line.890"></a>
+<span class="sourceLineNo">891</span>          new RegionBoundariesInformation();<a name="line.891"></a>
+<span class="sourceLineNo">892</span>      Path hbaseRoot = FSUtils.getRootDir(getConf());<a name="line.892"></a>
+<span class="sourceLineNo">893</span>      for (RegionInfo regionInfo : regions) {<a name="line.893"></a>
+<span class="sourceLineNo">894</span>        Path tableDir = FSUtils.getTableDir(hbaseRoot, regionInfo.getTable());<a name="line.894"></a>
+<span class="sourceLineNo">895</span>        currentRegionBoundariesInformation.regionName = regionInfo.getRegionName();<a name="line.895"></a>
+<span class="sourceLineNo">896</span>        // For each region, get the start and stop key from the META and compare them to the<a name="line.896"></a>
+<span class="sourceLineNo">897</span>        // same information from the Stores.<a name="line.897"></a>
+<span class="sourceLineNo">898</span>        Path path = new Path(tableDir, regionInfo.getEncodedName());<a name="line.898"></a>
+<span class="sourceLineNo">899</span>        FileSystem fs = path.getFileSystem(getConf());<a name="line.899"></a>
+<span class="sourceLineNo">900</span>        FileStatus[] files = fs.listStatus(path);<a name="line.900"></a>
+<span class="sourceLineNo">901</span>        // For all the column families in this region...<a name="line.901"></a>
+<span class="sourceLineNo">902</span>        byte[] storeFirstKey = null;<a name="line.902"></a>
+<span class="sourceLineNo">903</span>        byte[] storeLastKey = null;<a name="line.903"></a>
+<span class="sourceLineNo">904</span>        for (FileStatus file : files) {<a name="line.904"></a>
+<span class="sourceLineNo">905</span>          String fileName = file.getPath().toString();<a name="line.905"></a>
+<span class="sourceLineNo">906</span>          fileName = fileName.substring(fileName.lastIndexOf("/") + 1);<a name="line.906"></a>
+<span class="sourceLineNo">907</span>          if (!fileName.startsWith(".") &amp;&amp; !fileName.endsWith("recovered.edits")) {<a name="line.907"></a>
+<span class="sourceLineNo">908</span>            FileStatus[] storeFiles = fs.listStatus(file.getPath());<a name="line.908"></a>
+<span class="sourceLineNo">909</span>            // For all the stores in this column family.<a name="line.909"></a>
+<span class="sourceLineNo">910</span>            for (FileStatus storeFile : storeFiles) {<a name="line.910"></a>
+<span class="sourceLineNo">911</span>              HFile.Reader reader = HFile.createReader(fs, storeFile.getPath(),<a name="line.911"></a>
+<span class="sourceLineNo">912</span>                CacheConfig.DISABLED, true, getConf());<a name="line.912"></a>
+<span class="sourceLineNo">913</span>              if ((reader.getFirstKey() != null)<a name="line.913"></a>
+<span class="sourceLineNo">914</span>                  &amp;&amp; ((storeFirstKey == null) || (comparator.compare(storeFirstKey,<a name="line.914"></a>
+<span class="sourceLineNo">915</span>                      ((KeyValue.KeyOnlyKeyValue) reader.getFirstKey().get()).getKey()) &gt; 0))) {<a name="line.915"></a>
+<span class="sourceLineNo">916</span>                storeFirstKey = ((KeyValue.KeyOnlyKeyValue)reader.getFirstKey().get()).getKey();<a name="line.916"></a>
+<span class="sourceLineNo">917</span>              }<a name="line.917"></a>
+<span class="sourceLineNo">918</span>              if ((reader.getLastKey() != null)<a name="line.918"></a>
+<span class="sourceLineNo">919</span>                  &amp;&amp; ((storeLastKey == null) || (comparator.compare(storeLastKey,<a name="line.919"></a>
+<span class="sourceLineNo">920</span>                      ((KeyValue.KeyOnlyKeyValue)reader.getLastKey().get()).getKey())) &lt; 0)) {<a name="line.920"></a>
+<span class="sourceLineNo">921</span>                storeLastKey = ((KeyValue.KeyOnlyKeyValue)reader.getLastKey().get()).getKey();<a name="line.921"></a>
+<span class="sourceLineNo">922</span>              }<a name="line.922"></a>
+<span class="sourceLineNo">923</span>              reader.close();<a name="line.923"></a>
+<span class="sourceLineNo">924</span>            }<a name="line.924"></a>
+<span class="sourceLineNo">925</span>          }<a name="line.925"></a>
+<span class="sourceLineNo">926</span>        }<a name="line.926"></a>
+<span class="sourceLineNo">927</span>        currentRegionBoundariesInformation.metaFirstKey = regionInfo.getStartKey();<a name="line.927"></a>
+<span class="sourceLineNo">928</span>        currentRegionBoundariesInformation.metaLastKey = regionInfo.getEndKey();<a name="line.928"></a>
+<span class="sourceLineNo">929</span>        currentRegionBoundariesInformation.storesFirstKey = keyOnly(storeFirstKey);<a name="line.929"></a>
+<span class="sourceLineNo">930</span>        currentRegionBoundariesInformation.storesLastKey = keyOnly(storeLastKey);<a name="line.930"></a>
+<span class="sourceLineNo">931</span>        if (currentRegionBoundariesInformation.metaFirstKey.length == 0)<a name="line.931"></a>
+<span class="sourceLineNo">932</span>          currentRegionBoundariesInformation.metaFirstKey = null;<a name="line.932"></a>
+<span class="sourceLineNo">933</span>        if (currentRegionBoundariesInformation.metaLastKey.length == 0)<a name="line.933"></a>
+<span class="sourceLineNo">934</span>          currentRegionBoundariesInformation.metaLastKey = null;<a name="line.934"></a>
+<span class="sourceLineNo">935</span><a name="line.935"></a>
+<span class="sourceLineNo">936</span>        // For a region to be correct, we need the META start key to be smaller or equal to the<a name="line.936"></a>
+<span class="sourceLineNo">937</span>        // smallest start key from all the stores, and the start key from the next META entry to<a name="line.937"></a>
+<span class="sourceLineNo">938</span>        // be bigger than the last key from all the current stores. First region start key is null;<a name="line.938"></a>
+<span class="sourceLineNo">939</span>        // Last region end key is null; some regions can be empty and not have any store.<a name="line.939"></a>
+<span class="sourceLineNo">940</span><a name="line.940"></a>
+<span class="sourceLineNo">941</span>        boolean valid = true;<a name="line.941"></a>
+<span class="sourceLineNo">942</span>        // Checking start key.<a name="line.942"></a>
+<span class="sourceLineNo">943</span>        if ((currentRegionBoundariesInformation.storesFirstKey != null)<a name="line.943"></a>
+<span class="sourceLineNo">944</span>            &amp;&amp; (currentRegionBoundariesInformation.metaFirstKey != null)) {<a name="line.944"></a>
+<span class="sourceLineNo">945</span>          valid = valid<a name="line.945"></a>
+<span class="sourceLineNo">946</span>              &amp;&amp; comparator.compare(currentRegionBoundariesInformation.storesFirstKey,<a name="line.946"></a>
+<span class="sourceLineNo">947</span>                currentRegionBoundariesInformation.metaFirstKey) &gt;= 0;<a name="line.947"></a>
+<span class="sourceLineNo">948</span>        }<a name="line.948"></a>
+<span class="sourceLineNo">949</span>        // Checking stop key.<a name="line.949"></a>
+<span class="sourceLineNo">950</span>        if ((currentRegionBoundariesInformation.storesLastKey != null)<a name="line.950"></a>
+<span class="sourceLineNo">951</span>            &amp;&amp; (currentRegionBoundariesInformation.metaLastKey != null)) {<a name="line.951"></a>
+<span class="sourceLineNo">952</span>          valid = valid<a name="line.952"></a>
+<span class="sourceLineNo">953</span>              &amp;&amp; comparator.compare(currentRegionBoundariesInformation.storesLastKey,<a name="line.953"></a>
+<span class="sourceLineNo">954</span>                currentRegionBoundariesInformation.metaLastKey) &lt; 0;<a name="line.954"></a>
+<span class="sourceLineNo">955</span>        }<a name="line.955"></a>
+<span class="sourceLineNo">956</span>        if (!valid) {<a name="line.956"></a>
+<span class="sourceLineNo">957</span>          errors.reportError(ERROR_CODE.BOUNDARIES_ERROR, "Found issues with regions boundaries",<a name="line.957"></a>
+<span class="sourceLineNo">958</span>            tablesInfo.get(regionInfo.getTable()));<a name="line.958"></a>
+<span class="sourceLineNo">959</span>          LOG.warn("Region's boundaries not aligned between stores and META for:");<a name="line.959"></a>
+<span class="sourceLineNo">960</span>          LOG.warn(Objects.toString(currentRegionBoundariesInformation));<a name="line.960"></a>
+<span class="sourceLineNo">961</span>        }<a name="line.961"></a>
+<span class="sourceLineNo">962</span>      }<a name="line.962"></a>
+<span class="sourceLineNo">963</span>    } catch (IOException e) {<a name="line.963"></a>
+<span class="sourceLineNo">964</span>      LOG.error(e.toString(), e);<a name="line.964"></a>
+<span class="sourceLineNo">965</span>    }<a name="line.965"></a>
+<span class="sourceLineNo">966</span>  }<a name="line.966"></a>
+<span class="sourceLineNo">967</span><a name="line.967"></a>
+<span class="sourceLineNo">968</span>  /**<a name="line.968"></a>
+<span class="sourceLineNo">969</span>   * Iterates through the list of all orphan/invalid regiondirs.<a name="line.969"></a>
+<span class="sourceLineNo">970</span>   */<a name="line.970"></a>
+<span class="sourceLineNo">971</span>  private void adoptHdfsOrphans(Collection&lt;HbckRegionInfo&gt; orphanHdfsDirs) throws IOException {<a name="line.971"></a>
+<span class="sourceLineNo">972</span>    for (HbckRegionInfo hi : orphanHdfsDirs) {<a name="line.972"></a>
+<span class="sourceLineNo">973</span>      LOG.info("Attempting to handle orphan hdfs dir: " + hi.getHdfsRegionDir());<a name="line.973"></a>
+<span class="sourceLineNo">974</span>      adoptHdfsOrphan(hi);<a name="line.974"></a>
+<span class="sourceLineNo">975</span>    }<a name="line.975"></a>
+<span class="sourceLineNo">976</span>  }<a name="line.976"></a>
+<span class="sourceLineNo">977</span><a name="line.977"></a>
+<span class="sourceLineNo">978</span>  /**<a name="line.978"></a>
+<span class="sourceLineNo">979</span>   * Orphaned regions are regions without a .regioninfo file in them.  We "adopt"<a name="line.979"></a>
+<span class="sourceLineNo">980</span>   * these orphans by creating a new region, and moving the column families,<a name="line.980"></a>
+<span class="sourceLineNo">981</span>   * recovered edits, WALs, into the new region dir.  We determine the region<a name="line.981"></a>
+<span class="sourceLineNo">982</span>   * startkey and endkeys by looking at all of the hfiles inside the column<a name="line.982"></a>
+<span class="sourceLineNo">983</span>   * families to identify the min and max keys. The resulting region will<a name="line.983"></a>
+<span class="sourceLineNo">984</span>   * likely violate table integrity but will be dealt with by merging<a name="line.984"></a>
+<span class="sourceLineNo">985</span>   * overlapping regions.<a name="line.985"></a>
+<span class="sourceLineNo">986</span>   */<a name="line.986"></a>
+<span class="sourceLineNo">987</span>  @SuppressWarnings("deprecation")<a name="line.987"></a>
+<span class="sourceLineNo">988</span>  private void adoptHdfsOrphan(HbckRegionInfo hi) throws IOException {<a name="line.988"></a>
+<span class="sourceLineNo">989</span>    Path p = hi.getHdfsRegionDir();<a name="line.989"></a>
+<span class="sourceLineNo">990</span>    FileSystem fs = p.getFileSystem(getConf());<a name="line.990"></a>
+<span class="sourceLineNo">991</span>    FileStatus[] dirs = fs.listStatus(p);<a name="line.991"></a>
+<span class="sourceLineNo">992</span>    if (dirs == null) {<a name="line.992"></a>
+<span class="sourceLineNo">993</span>      LOG.warn("Attempt to adopt orphan hdfs region skipped because no files present in " +<a name="line.993"></a>
+<span class="sourceLineNo">994</span>          p + ". This dir could probably be deleted.");<a name="line.994"></a>
+<span class="sourceLineNo">995</span>      return ;<a name="line.995"></a>
+<span class="sourceLineNo">996</span>    }<a name="line.996"></a>
+<span class="sourceLineNo">997</span><a name="line.997"></a>
+<span class="sourceLineNo">998</span>    TableName tableName = hi.getTableName();<a name="line.998"></a>
+<span class="sourceLineNo">999</span>    HbckTableInfo tableInfo = tablesInfo.get(tableName);<a name="line.999"></a>
+<span class="sourceLineNo">1000</span>    Preconditions.checkNotNull(tableInfo, "Table '" + tableName + "' not present!");<a name="line.1000"></a>
+<span class="sourceLineNo">1001</span>    TableDescriptor template = tableInfo.getTableDescriptor();<a name="line.1001"></a>
+<span class="sourceLineNo">1002</span><a name="line.1002"></a>
+<span class="sourceLineNo">1003</span>    // find min and max key values<a name="line.1003"></a>
+<span class="sourceLineNo">1004</span>    Pair&lt;byte[],byte[]&gt; orphanRegionRange = null;<a name="line.1004"></a>
+<span class="sourceLineNo">1005</span>    for (FileStatus cf : dirs) {<a name="line.1005"></a>
+<span class="sourceLineNo">1006</span>      String cfName= cf.getPath().getName();<a name="line.1006"></a>
+<span class="sourceLineNo">1007</span>      // TODO Figure out what the special dirs are<a name="line.1007"></a>
+<span class="sourceLineNo">1008</span>      if (cfName.startsWith(".") || cfName.equals(HConstants.SPLIT_LOGDIR_NAME)) continue;<a name="line.1008"></a>
+<span class="sourceLineNo">1009</span><a name="line.1009"></a>
+<span class="sourceLineNo">1010</span>      FileStatus[] hfiles = fs.listStatus(cf.getPath());<a name="line.1010"></a>
+<span class="sourceLineNo">1011</span>      for (FileStatus hfile : hfiles) {<a name="line.1011"></a>
+<span class="sourceLineNo">1012</span>        byte[] start, end;<a name="line.1012"></a>
+<span class="sourceLineNo">1013</span>        HFile.Reader hf = null;<a name="line.1013"></a>
+<span class="sourceLineNo">1014</span>        try {<a name="line.1014"></a>
+<span class="sourceLineNo">1015</span>          hf = HFile.createReader(fs, hfile.getPath(), CacheConfig.DISABLED, true, getConf());<a name="line.1015"></a>
+<span class="sourceLineNo">1016</span>          Optional&lt;Cell&gt; startKv = hf.getFirstKey();<a name="line.1016"></a>
+<span class="sourceLineNo">1017</span>          start = CellUtil.cloneRow(startKv.get());<a name="line.1017"></a>
+<span class="sourceLineNo">1018</span>          Optional&lt;Cell&gt; endKv = hf.getLastKey();<a name="line.1018"></a>
+<span class="sourceLineNo">1019</span>          end = CellUtil.cloneRow(endKv.get());<a name="line.1019"></a>
+<span class="sourceLineNo">1020</span>        } catch (IOException ioe) {<a name="line.1020"></a>
+<span class="sourceLineNo">1021</span>          LOG.warn("Problem reading orphan file " + hfile + ", skipping");<a name="line.1021"></a>
+<span class="sourceLineNo">1022</span>          continue;<a name="line.1022"></a>
+<span class="sourceLineNo">1023</span>        } catch (NullPointerException ioe) {<a name="line.1023"></a>
+<span class="sourceLineNo">1024</span>          LOG.warn("Orphan file " + hfile + " is possibly corrupted HFile, skipping");<a name="line.1024"></a>
+<span class="sourceLineNo">1025</span>          continue;<a name="line.1025"></a>
+<span class="sourceLineNo">1026</span>        } finally {<a name="line.1026"></a>
+<span class="sourceLineNo">1027</span>          if (hf != null) {<a name="line.1027"></a>
+<span class="sourceLineNo">1028</span>            hf.close();<a name="line.1028"></a>
+<span class="sourceLineNo">1029</span>          }<a name="line.1029"></a>
+<span class="sourceLineNo">1030</span>        }<a name="line.1030"></a>
+<span class="sourceLineNo">1031</span><a name="line.1031"></a>
+<span class="sourceLineNo">1032</span>        // expand the range to include the range of all hfiles<a name="line.1032"></a>
+<span class="sourceLineNo">1033</span>        if (orphanRegionRange == null) {<a name="line.1033"></a>
+<span class="sourceLineNo">1034</span>          // first range<a name="line.1034"></a>
+<span class="sourceLineNo">1035</span>          orphanRegionRange = new Pair&lt;&gt;(start, end);<a name="line.1035"></a>
+<span class="sourceLineNo">1036</span>        } else {<a name="line.1036"></a>
+<span class="sourceLineNo">1037</span>          // TODO add test<a name="line.1037"></a>
+<span class="sourceLineNo">1038</span><a name="line.1038"></a>
+<span class="sourceLineNo">1039</span>          // expand range only if the hfile is wider.<a name="line.1039"></a>
+<span class="sourceLineNo">1040</span>          if (Bytes.compareTo(orphanRegionRange.getFirst(), start) &gt; 0) {<a name="line.1040"></a>
+<span class="sourceLineNo">1041</span>            orphanRegionRange.setFirst(start);<a name="line.1041"></a>
+<span class="sourceLineNo">1042</span>          }<a name="line.1042"></a>
+<span class="sourceLineNo">1043</span>          if (Bytes.compareTo(orphanRegionRange.getSecond(), end) &lt; 0 ) {<a name="line.1043"></a>
+<span class="sourceLineNo">1044</span>            orphanRegionRange.setSecond(end);<a name="line.1044"></a>
+<span class="sourceLineNo">1045</span>          }<a name="line.1045"></a>
+<span class="sourceLineNo">1046</span>        }<a name="line.1046"></a>
+<span class="sourceLineNo">1047</span>      }<a name="line.1047"></a>
+<span class="sourceLineNo">1048</span>    }<a name="line.1048"></a>
+<span class="sourceLineNo">1049</span>    if (orphanRegionRange == null) {<a name="line.1049"></a>
+<span class="sourceLineNo">1050</span>      LOG.warn("No data in dir " + p + ", sidelining data");<a name="line.1050"></a>
+<span class="sourceLineNo">1051</span>      fixes++;<a name="line.1051"></a>
+<span class="sourceLineNo">1052</span>      sidelineRegionDir(fs, hi);<a name="line.1052"></a>
+<span class="sourceLineNo">1053</span>      return;<a name="line.1053"></a>
+<span class="sourceLineNo">1054</span>    }<a name="line.1054"></a>
+<span class="sourceLineNo">1055</span>    LOG.info("Min max keys are : [" + Bytes.toString(orphanRegionRange.getFirst()) + ", " +<a name="line.1055"></a>
+<span class="sourceLineNo">1056</span>        Bytes.toString(orphanRegionRange.getSecond()) + ")");<a name="line.1056"></a>
+<span class="sourceLineNo">1057</span><a name="line.1057"></a>
+<span class="sourceLineNo">1058</span>    // create new region on hdfs. move data into place.<a name="line.1058"></a>
+<span class="sourceLineNo">1059</span>    RegionInfo regionInfo = RegionInfoBuilder.newBuilder(template.getTableName())<a name="line.1059"></a>
+<span class="sourceLineNo">1060</span>        .setStartKey(orphanRegionRange.getFirst())<a name="line.1060"></a>
+<span class="sourceLineNo">1061</span>        .setEndKey(Bytes.add(orphanRegionRange.getSecond(), new byte[1]))<a name="line.1061"></a>
+<span class="sourceLineNo">1062</span>        .build();<a name="line.1062"></a>
+<span class="sourceLineNo">1063</span>    LOG.info("Creating new region : " + regionInfo);<a name="line.1063"></a>
+<span class="sourceLineNo">1064</span>    HRegion region = HBaseFsckRepair.createHDFSRegionDir(getConf(), regionInfo, template);<a name="line.1064"></a>
+<span class="sourceLineNo">1065</span>    Path target = region.getRegionFileSystem().getRegionDir();<a name="line.1065"></a>
+<span class="sourceLineNo">1066</span><a name="line.1066"></a>
+<span class="sourceLineNo">1067</span>    // rename all the data to new region<a name="line.1067"></a>
+<span class="sourceLineNo">1068</span>    mergeRegionDirs(target, hi);<a name="line.1068"></a>
+<span class="sourceLineNo">1069</span>    fixes++;<a name="line.1069"></a>
+<span class="sourceLineNo">1070</span>  }<a name="line.1070"></a>
+<span class="sourceLineNo">1071</span><a name="line.1071"></a>
+<span class="sourceLineNo">1072</span>  /**<a name="line.1072"></a>
+<span class="sourceLineNo">1073</span>   * This method determines if there are table integrity errors in HDFS.  If<a name="line.1073"></a>
+<span class="sourceLineNo">1074</span>   * there are errors and the appropriate "fix" options are enabled, the method<a name="line.1074"></a>
+<span class="sourceLineNo">1075</span>   * will first correct orphan regions making them into legit regiondirs, and<a name="line.1075"></a>
+<span class="sourceLineNo">1076</span>   * then reload to merge potentially overlapping regions.<a name="line.1076"></a>
+<span class="sourceLineNo">1077</span>   *<a name="line.1077"></a>
+<span class="sourceLineNo">1078</span>   * @return number of table integrity errors found<a name="line.1078"></a>
+<span class="sourceLineNo">1079</span>   */<a name="line.1079"></a>
+<span class="sourceLineNo">1080</span>  private int restoreHdfsIntegrity() throws IOException, InterruptedException {<a name="line.1080"></a>
+<span class="sourceLineNo">1081</span>    // Determine what's on HDFS<a name="line.1081"></a>
+<span class="sourceLineNo">1082</span>    LOG.info("Loading HBase regioninfo from HDFS...");<a name="line.1082"></a>
+<span class="sourceLineNo">1083</span>    loadHdfsRegionDirs(); // populating regioninfo table.<a name="line.1083"></a>
+<span class="sourceLineNo">1084</span><a name="line.1084"></a>
+<span class="sourceLineNo">1085</span>    int errs = errors.getErrorList().size();<a name="line.1085"></a>
+<span class="sourceLineNo">1086</span>    // First time just get suggestions.<a name="line.1086"></a>
+<span class="sourceLineNo">1087</span>    tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1087"></a>
+<span class="sourceLineNo">1088</span>    checkHdfsIntegrity(false, false);<a name="line.1088"></a>
+<span class="sourceLineNo">1089</span><a name="line.1089"></a>
+<span class="sourceLineNo">1090</span>    if (errors.getErrorList().size() == errs) {<a name="line.1090"></a>
+<span class="sourceLineNo">1091</span>      LOG.info("No integrity errors.  We are done with this phase. Glorious.");<a name="line.1091"></a>
+<span class="sourceLineNo">1092</span>      return 0;<a name="line.1092"></a>
+<span class="sourceLineNo">1093</span>    }<a name="line.1093"></a>
+<span class="sourceLineNo">1094</span><a name="line.1094"></a>
+<span class="sourceLineNo">1095</span>    if (shouldFixHdfsOrphans() &amp;&amp; orphanHdfsDirs.size() &gt; 0) {<a name="line.1095"></a>
+<span class="sourceLineNo">1096</span>      adoptHdfsOrphans(orphanHdfsDirs);<a name="line.1096"></a>
+<span class="sourceLineNo">1097</span>      // TODO optimize by incrementally adding instead of reloading.<a name="line.1097"></a>
+<span class="sourceLineNo">1098</span>    }<a name="line.1098"></a>
+<span class="sourceLineNo">1099</span><a name="line.1099"></a>
+<span class="sourceLineNo">1100</span>    // Make sure there are no holes now.<a name="line.1100"></a>
+<span class="sourceLineNo">1101</span>    if (shouldFixHdfsHoles()) {<a name="line.1101"></a>
+<span class="sourceLineNo">1102</span>      clearState(); // this also resets # fixes.<a name="line.1102"></a>
+<span class="sourceLineNo">1103</span>      loadHdfsRegionDirs();<a name="line.1103"></a>
+<span class="sourceLineNo">1104</span>      tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1104"></a>
+<span class="sourceLineNo">1105</span>      tablesInfo = checkHdfsIntegrity(shouldFixHdfsHoles(), false);<a name="line.1105"></a>
+<span class="sourceLineNo">1106</span>    }<a name="line.1106"></a>
+<span class="sourceLineNo">1107</span><a name="line.1107"></a>
+<span class="sourceLineNo">1108</span>    // Now we fix overlaps<a name="line.1108"></a>
+<span class="sourceLineNo">1109</span>    if (shouldFixHdfsOverlaps()) {<a name="line.1109"></a>
+<span class="sourceLineNo">1110</span>      // second pass we fix overlaps.<a name="line.1110"></a>
+<span class="sourceLineNo">1111</span>      clearState(); // this also resets # fixes.<a name="line.1111"></a>
+<span class="sourceLineNo">1112</span>      loadHdfsRegionDirs();<a name="line.1112"></a>
+<span class="sourceLineNo">1113</span>      tablesInfo = loadHdfsRegionInfos(); // update tableInfos based on region info in fs.<a name="line.1113"></a>
+<span class="sourceLineNo">1114</span>      tablesInfo = checkHdfsIntegrity(false, shouldFixHdfsOverlaps());<a name="line.1114"></a>
+<span class="sourceLineNo">1115</span>    }<a name="line.1115"></a>
+<span class="sourceLineNo">1116</span><a name="line.1116"></a>
+<span class="sourceLineNo">1117</span>    return errors.getErrorList().size();<a name="line.1117"></a>
+<span class="sourceLineNo">1118</span>  }<a name="line.1118"></a>
+<span class="sourceLineNo">1119</span><a name="line.1119"></a>
+<span class="sourceLineNo">1120</span>  /**<a name="line.1120"></a>
+<span class="sourceLineNo">1121</span>   * Scan all the store file names to find any lingering reference files,<a name="line.1121"></a>
+<span class="sourceLineNo">1122</span>   * which refer to some none-exiting files. If "fix" option is enabled,<a name="line.1122"></a>
+<span class="sourceLineNo">1123</span>   * any lingering reference file will be sidelined if found.<a name="line.1123"></a>
+<span class="sourceLineNo">1124</span>   * &lt;p&gt;<a name="line.1124"></a>
+<span class="sourceLineNo">1125</span>   * Lingering reference file prevents a region from opening. It has to<a name="line.1125"></a>
+<span class="sourceLineNo">1126</span>   * be fixed before a cluster can start properly.<a name="line.1126"></a>
+<span class="sourceLineNo">1127</span>   */<a name="line.1127"></a>
+<span class="sourceLineNo">1128</span>  private void offlineReferenceFileRepair() throws IOException, InterruptedException {<a name="line.1128"></a>
+<span class="sourceLineNo">1129</span>    clearState();<a name="line.1129"></a>
+<span class="sourceLineNo">1130</span>    Configuration conf = getConf();<a name="line.1130"></a>
+<span class="sourceLineNo">1131</span>    Path hbaseRoot = FSUtils.getRootDir(conf);<a name="line.1131"></a>
+<span class="sourceLineNo">1132</span>    FileSystem fs = hbaseRoot.getFileSystem(conf);<a name="line.1132"></a>
+<span class="sourceLineNo">1133</span>    LOG.info("Computing mapping of all store files");<a name="line.1133"></a>
+<span class="sourceLineNo">1134</span>    Map&lt;String, Path&gt; allFiles = FSUtils.getTableStoreFilePathMap(fs, hbaseRoot,<a name="line.1134"></a>
+<span class="sourceLineNo">1135</span>      new FSUtils.ReferenceFileFilter(fs), executor, errors);<a name="line.1135"></a>
+<span class="sourceLineNo">1136</span>    errors.print("");<a name="line.1136"></a>
+<span class="sourceLineNo">1137</span>    LOG.info("Validating mapping using HDFS state");<a name="line.1137"></a>
+<span class="sourceLineNo">1138</span>    for (Path path: allFiles.values()) {<a name="line.1138"></a>
+<span class="sourceLineNo">1139</span>      Path referredToFile = StoreFileInfo.getReferredToFile(path);<a name="line.1139"></a>
+<span class="sourceLineNo">1140</span>      if (fs.exists(referredToFile)) continue;  // good, expected<a name="line.1140"></a>
+<span class="sourceLineNo">1141</span><a name="line.1141"></a>
+<span class="sourceLineNo">1142</span>      // Found a lingering reference file<a name="line.1142"></a>
+<span class="sourceLineNo">1143</span>      errors.reportError(ERROR_CODE.LINGERING_REFERENCE_HFILE,<a name="line.1143"></a>
+<span class="sourceLineNo">1144</span>        "Found lingering reference file " + path);<a name="line.1144"></a>
+<span class="sourceLineNo">1145</span>      if (!shouldFixReferenceFiles()) continue;<a name="line.1145"></a>
+<span class="sourceLineNo">1146</span><a name="line.1146"></a>
+<span class="sourceLineNo">1147</span>      // Now, trying to fix it since requested<a name="line.1147"></a>
+<span class="sourceLineNo">1148</span>      boolean success = false;<a name="line.1148"></a>
+<span class="sourceLineNo">1149</span>      String pathStr = path.toString();<a name="line.1149"></a>
+<span class="sourceLineNo">1150</span><a name="line.1150"></a>
+<span class="sourceLineNo">1151</span>      // A reference file path should be like<a name="line.1151"></a>
+<span class="sourceLineNo">1152</span>      // ${hbase.rootdir}/data/namespace/table_name/region_id/family_name/referred_file.region_name<a name="line.1152"></a>
+<span class="sourceLineNo">1153</span>      // Up 5 directories to get the root folder.<a name="line.1153"></a>
+<span class="sourceLineNo">1154</span>      // So the file will be sidelined to a similar folder structure.<a name="line.1154"></a>
+<span class="sourceLineNo">1155</span>      int index = pathStr.lastIndexOf(Path.SEPARATOR_CHAR);<a name="line.1155"></a>
+<span class="sourceLineNo">1156</span>      for (int i = 0; index &gt; 0 &amp;&amp; i &lt; 5; i++) {<a name="line.1156"></a>
+<span class="sourceLineNo">1157</span>        index = pathStr.lastIndexOf(Path.SEPARATOR_CHAR, index - 1);<a name="line.1157"></a>
+<span class="sourceLineNo">1158</span>      }<a name="line.1158"></a>
+<span class="sourceLineNo">1159</span>      if (index &gt; 0) {<a name="line.1159"></a>
+<span class="sourceLineNo">1160</span>        Path rootDir = getSidelineDir();<a name="line.1160"></a>
+<span class="sourceLineNo">1161</span>        Path dst = new Path(rootDir, pathStr.substring(index + 1));<a name="line.1161"></a>
+<span class="sourceLineNo">1162</span>        fs.mkdirs(dst.getParent());<a name="line.1162"></a>
+<span class="sourceLineNo">1163</span>        LOG.info("Trying to sideline reference file "<a name="line.1163"></a>
+<span class="sourceLineNo">1164</span>          + path + " to " + dst);<a name="line.1164"></a>
+<span class="sourceLineNo">1165</span>        setShouldRerun();<a name="line.1165"></a>
+<span class="sourceLineNo">1166</span><a name="line.1166"></a>
+<span class="sourceLineNo">1167</span>        success = fs.rename(path, dst);<a name="line.1167"></a>
+<span class="sourceLineNo">1168</span>        debugLsr(dst);<a name="line.1168"></a>
+<span class="sourceLineNo">1169</span><a name="line.1169"></a>
+<span class="sourceLineNo">1170</span>      }<a name="line.1170"></a>
+<span class="sourceLineNo">1171</span>      if (!success) {<a name="line.1171"></a>
+<span class="sourceLineNo">1172</span>        LOG.error("Failed to sideline reference file " + path);<a name="line.1172"></a>
+<span class="sourceLineNo">1173</span>      }<a name="line.1173"></a>
+<span class="sourceLineNo">1174</span>    }<a name="line.1174"></a>
+<span class="sourceLineNo">1175</span>  }<a name="line.1175"></a>
+<span class="sourceLineNo">1176</span><a name="line.1176"></a>
+<span class="sourceLineNo">1177</span>  /**<a name="line.1177"></a>
+<span class="sourceLineNo">1178</span>   * Scan all the store file names to find any lingering HFileLink files,<a name="line.1178"></a>
+<span class="sourceLineNo">1179</span>   * which refer to some none-exiting files. If "fix" option is enabled,<a name="line.1179"></a>
+<span class="sourceLineNo">1180</span>   * any lingering HFileLink file will be sidelined if found.<a name="line.1180"></a>
+<span class="sourceLineNo">1181</span>   */<a name="line.1181"></a>
+<span class="sourceLineNo">1182</span>  private void offlineHLinkFileRepair() throws IOException, InterruptedException {<a name="line.1182"></a>
+<span class="sourceLineNo">1183</span>    Configuration conf = getConf();<a name="line.1183"></a>
+<span class="sourceLineNo">1184</span>    Path hbaseRoot = FSUtils.getRootDir(conf);<a name="line.1184"></a>
+<span class="sourceLineNo">1185</span>    FileSystem fs = hbaseRoot.getFileSystem(conf);<a name="line.1185"></a>
+<span class="sourceLineNo">1186</span>    LOG.info("Computing mapping of all link files");<a name="line.1186"></a>
+<span class="sourceLineNo">1187</span>    Map&lt;String, Path&gt; allFiles = FSUtils<a name="line.1187"></a>
+<span class="sourceLineNo">1188</span>        .getTableStoreFilePathMap(fs, hbaseRoot, new FSUtils.HFileLinkFilter(), executor, errors);<a name="line.1188"></a>
+<span class="sourceLineNo">1189</span>    errors.print("");<a name="line.1189"></a>
+<span class="sourceLineNo">1190</span><a name="line.1190"></a>
+<span class="sourceLineNo">1191</span>    LOG.info("Validating mapping using HDFS state");<a name="line.1191"></a>
+<span class="sourceLineNo">1192</span>    for (Path path : allFiles.values()) {<a name="line.1192"></a>
+<span class="sourceLineNo">1193</span>      // building HFileLink object to gather locations<a name="line.1193"></a>
+<span class="sourceLineNo">1194</span>      HFileLink actualLink = HFileLink.buildFromHFileLinkPattern(conf, path);<a name="line.1194"></a>
+<span class="sourceLineNo">1195</span>      if (actualLink.exists(fs)) continue; // good, expected<a name="line.1195"></a>
+<span class="sourceLineNo">1196</span><a name="line.1196"></a>
+<span class="sourceLineNo">1197</span>      // Found a lingering HFileLink<a name="line.1197"></a>
+<span class="sourceLineNo">1198</span>      errors.reportError(ERROR_CODE.LINGERING_HFILELINK, "Found lingering HFileLink " + path);<a name="line.1198"></a>
+<span class="sourceLineNo">1199</span>      if (!shouldFixHFileLinks()) continue;<a name="line.1199"></a>
+<span class="sourceLineNo">1200</span><a name="line.1200"></a>
+<span class="sourceLineNo">1201</span>      // Now, trying to fix it since requested<a name="line.1201"></a>
+<span class="sourceLineNo">1202</span>      setShouldRerun();<a name="line.1202"></a>
+<span class="sourceLineNo">1203</span><a name="line.1203"></a>
+<span class="sourceLineNo">1204</span>      // An HFileLink path should be like<a name="line.1204"></a>
+<span class="sourceLineNo">1205</span>      // ${hbase.rootdir}/data/namespace/table_name/region_id/family_name/linkedtable=linkedregionname-linkedhfilename<a name="line.1205"></a>
+<span class="sourceLineNo">1206</span>      // sidelineing will happen in the ${hbase.rootdir}/${sidelinedir} directory with the same folder structure.<a name="line.1206"></a>
+<span class="sourceLineNo">1207</span>      boolean success = sidelineFile(fs, hbaseRoot, path);<a name="line.1207"></a>
+<span class="sourceLineNo">1208</span><a name="line.1208"></a>
+<span class="sourceLineNo">1209</span>      if (!success) {<a name="line.1209"></a>
+<span class="sourceLineNo">1210</span>        LOG.error("Failed to sideline HFileLink file " + path);<a name="line.1210"></a>
+<span class="sourceLineNo">1211</span>      }<a name="line.1211"></a>
+<span class="sourceLineNo">1212</span><a name="line.1212"></a>
+<span class="sourceLineNo">1213</span>      // An HFileLink backreference path should be like<a name="line.1213"></a>
+<span class="sourceLineNo">1214</span>      // ${hbase.rootdir}/archive/data/namespace/table_name/region_id/family_name/.links-linkedhfilename<a name="line.1214"></a>
+<span class="sourceLineNo">1215</span>      // sidelineing will happen in the ${hbase.rootdir}/${sidelinedir} directory with the same folder structure.<a name="line.1215"></a>
+<span class="sourceLineNo">1216</span>      Path backRefPath = FileLink.getBackReferencesDir(HFileArchiveUtil<a name="line.1216"></a>
+<span class="sourceLineNo">1217</span>              .getStoreArchivePath(conf, HFileLink.getReferencedTableName(path.getName().toString()),<a name="line.1217"></a>
+<span class="sourceLineNo">1218</span>                  HFileLink.getReferencedRegionName(path.getName().toString()),<a name="line.1218"></a>
+<span class="sourceLineNo">1219</span>                  path.getParent().getName()),<a name="line.1219"></a>
+<span class="sourceLineNo">1220</span>          HFileLink.getReferencedHFileName(path.getName().toString()));<a name="line.1220"></a>
+<span class="sourceLineNo">1221</span>      success = sidelineFile(fs, hbaseRoot, backRefPath);<a name="line.1221"></a>
+<span class="sourceLineNo">1222</span><a name="line.1222"></a>
+<span class="sourceLineNo">1223</span>      if (!success) {<a name="line.1223"></a>
+<span class="sourceLineNo">1224</span>        LOG.error("Failed to sideline HFileLink backreference file " + path);<a name="line.1224"></a>
+<span class="sourceLineNo">1225</span>      }<a name="line.1225"></a>
+<span class="sourceLineNo">1226</span>    }<a name="line.1226"></a>
+<span class="sourceLineNo">1227</span>  }<a name="line.1227"></a>
+<span class="sourceLineNo">1228</span><a name="line.1228"></a>
+<span class="sourceLineNo">1229</span>  private boolean sidelineFile(FileSystem fs, Path hbaseRoot, Path path) throws IOException {<a name="line.1229"></a>
+<span class="sourceLineNo">1230</span>    URI uri = hbaseRoot.toUri().relativize(path.toUri());<a name="line.1230"></a>
+<span class="sourceLineNo">1231</span>    if (uri.isAbsolute()) return false;<a name="line.1231"></a>
+<span class="sourceLineNo">1232</span>    String relativePath = uri.getPath();<a name="line.1232"></a>
+<span class="sourceLineNo">1233</span>    Path rootDir = getSidelineDir();<a name="line.1233"></a>
+<span class="sourceLineNo">1234</span>    Path dst = new Path(rootDir, relativePath);<a name="line.1234"></a>
+<span class="sourceLineNo">1235</span>    boolean pathCreated = fs.mkdirs(dst.getParent());<a name="line.1235"></a>
+<span class="sourceLineNo">1236</span>    if (!pathCreated) {<a name="line.1236"></a>
+<span class="sourceLineNo">1237</span>      LOG.error("Failed to create path: " + dst.getParent());<a name="line.1237"></a>
+<span class="sourceLineNo">1238</span>      return false;<a name="line.1238"></a>
+<span class="sourceLineNo">1239</span>    }<a name="line.1239"></a>
+<span class="sourceLineNo">1240</span>    LOG.info("Trying to sideline file " + path + " to " + dst);<a name="line.1240"></a>
+<span class="sourceLineNo">1241</span>    return fs.rename(path, dst);<a name="line.1241"></a>
+<span class="sourceLineNo">1242</span>  }<a name="line.1242"></a>
+<span class="sourceLineNo">1243</span><a name="line.1243"></a>
+<span class="sourceLineNo">1244</span>  /**<a name="line.1244"></a>
+<span class="sourceLineNo">1245</span>   * TODO -- need to add tests for this.<a name="line.1245"></a>
+<span class="sourceLineNo">1246</span>   */<a name="line.1246"></a>
+<span class="sourceLineNo">1247</span>  private void reportEmptyMetaCells() {<a name="line.1247"></a>
+<span class="sourceLineNo">1248</span>    errors.print("Number of empty REGIONINFO_QUALIFIER rows in hbase:meta: " +<a name="line.1248"></a>
+<span class="sourceLineNo">1249</span>      emptyRegionInfoQualifiers.size());<a name="line.1249"></a>
+<span class="sourceLineNo">1250</span>    if (details) {<a name="line.1250"></a>
+<span class="sourceLineNo">1251</span>      for (Result r: emptyRegionInfoQualifiers) {<a name="line.1251"></a>
+<span class="sourceLineNo">1252</span>        errors.print("  " + r);<a name="line.1252"></a>
+<span class="sourceLineNo">1253</span>      }<a name="line.1253"></a>
+<span class="sourceLineNo">1254</span>    }<a name="line.1254"></a>
+<span class="sourceLineNo">1255</span>  }<a name="line.1255"></a>
+<span class="sourceLineNo">1256</span><a name="line.1256"></a>
+<span class="sourceLineNo">1257</span>  /**<a name="line.1257"></a>
+<span class="sourceLineNo">1258</span>   * TODO -- need to add tests for this.<a name="line.1258"></a>
+<span class="sourceLineNo">1259</span>   */<a name="line.1259"></a>
+<span class="sourceLineNo">1260</span>  private void reportTablesInFlux() {<a name="line.1260"></a>
+<span class="sourceLineNo">1261</span>    AtomicInteger numSkipped = new AtomicInteger(0);<a name="line.1261"></a>
+<span class="sourceLineNo">1262</span>    TableDescriptor[] allTables = getTables(numSkipped);<a name="line.1262"></a>
+<span class="sourceLineNo">1263</span>    errors.print("Number of Tables: " + allTables.length);<a name="line.1263"></a>
+<span class="sourceLineNo">1264</span>    if (details) {<a name="line.1264"></a>
+<span class="sourceLineNo">1265</span>      if (numSkipped.get() &gt; 0) {<a name="line.1265"></a>
+<span class="sourceLineNo">1266</span>        errors.detail("Number of Tables in flux: " + numSkipped.get());<a name="line.1266"></a>
+<span class="sourceLineNo">1267</span>      }<a name="line.1267"></a>
+<span class="sourceLineNo">1268</span>      for (TableDescriptor td : allTables) {<a name="line.1268"></a>
+<span class="sourceLineNo">1269</span>        errors.detail("  Table: " + td.getTableName() + "\t" +<a name="line.1269"></a>
+<span class="sourceLineNo">1270</span>                           (td.isReadOnly() ? "ro" : "rw") + "\t" +<a name="line.1270"></a>
+<span class="sourceLineNo">1271</span>                            (td.isMetaRegion() ? "META" : "    ") + "\t" +<a name="line.1271"></a>
+<span class="sourceLineNo">1272</span>                           " families: " + td.getColumnFamilyCount());<a name="line.1272"></a>
+<span class="sourceLineNo">1273</span>      }<a name="line.1273"></a>
+<span class="sourceLineNo">1274</span>    }<a name="line.1274"></a>
+<span class="sourceLineNo">1275</span>  }<a name="line.1275"></a>
+<span class="sourceLineNo">1276</span><a name="line.1276"></a>
+<span class="sourceLineNo">1277</span>  public HbckErrorReporter getErrors() {<a name="line.1277"></a>
+<span class="sourceLineNo">1278</span>    return errors;<a name="line.1278"></a>
+<span class="sourceLineNo">1279</span>  }<a name="line.1279"></a>
+<span class="sourceLineNo">1280</span><a name="line.1280"></a>
+<span class="sourceLineNo">1281</span>  /**<a name="line.1281"></a>
+<span class="sourceLineNo">1282</span>   * Populate hbi's from regionInfos loaded from file system.<a name="line.1282"></a>
+<span class="sourceLineNo">1283</span>   */<a name="line.1283"></a>
+<span class="sourceLineNo">1284</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; loadHdfsRegionInfos()<a name="line.1284"></a>
+<span class="sourceLineNo">1285</span>      throws IOException, InterruptedException {<a name="line.1285"></a>
+<span class="sourceLineNo">1286</span>    tablesInfo.clear(); // regenerating the data<a name="line.1286"></a>
+<span class="sourceLineNo">1287</span>    // generate region split structure<a name="line.1287"></a>
+<span class="sourceLineNo">1288</span>    Collection&lt;HbckRegionInfo&gt; hbckRegionInfos = regionInfoMap.values();<a name="line.1288"></a>
+<span class="sourceLineNo">1289</span><a name="line.1289"></a>
+<span class="sourceLineNo">1290</span>    // Parallelized read of .regioninfo files.<a name="line.1290"></a>
+<span class="sourceLineNo">1291</span>    List&lt;WorkItemHdfsRegionInfo&gt; hbis = new ArrayList&lt;&gt;(hbckRegionInfos.size());<a name="line.1291"></a>
+<span class="sourceLineNo">1292</span>    List&lt;Future&lt;Void&gt;&gt; hbiFutures;<a name="line.1292"></a>
+<span class="sourceLineNo">1293</span><a name="line.1293"></a>
+<span class="sourceLineNo">1294</span>    for (HbckRegionInfo hbi : hbckRegionInfos) {<a name="line.1294"></a>
+<span class="sourceLineNo">1295</span>      WorkItemHdfsRegionInfo work = new WorkItemHdfsRegionInfo(hbi, this, errors);<a name="line.1295"></a>
+<span class="sourceLineNo">1296</span>      hbis.add(work);<a name="line.1296"></a>
+<span class="sourceLineNo">1297</span>    }<a name="line.1297"></a>
+<span class="sourceLineNo">1298</span><a name="line.1298"></a>
+<span class="sourceLineNo">1299</span>    // Submit and wait for completion<a name="line.1299"></a>
+<span class="sourceLineNo">1300</span>    hbiFutures = executor.invokeAll(hbis);<a name="line.1300"></a>
+<span class="sourceLineNo">1301</span><a name="line.1301"></a>
+<span class="sourceLineNo">1302</span>    for(int i=0; i&lt;hbiFutures.size(); i++) {<a name="line.1302"></a>
+<span class="sourceLineNo">1303</span>      WorkItemHdfsRegionInfo work = hbis.get(i);<a name="line.1303"></a>
+<span class="sourceLineNo">1304</span>      Future&lt;Void&gt; f = hbiFutures.get(i);<a name="line.1304"></a>
+<span class="sourceLineNo">1305</span>      try {<a name="line.1305"></a>
+<span class="sourceLineNo">1306</span>        f.get();<a name="line.1306"></a>
+<span class="sourceLineNo">1307</span>      } catch(ExecutionException e) {<a name="line.1307"></a>
+<span class="sourceLineNo">1308</span>        LOG.warn("Failed to read .regioninfo file for region " +<a name="line.1308"></a>
+<span class="sourceLineNo">1309</span>              work.hbi.getRegionNameAsString(), e.getCause());<a name="line.1309"></a>
+<span class="sourceLineNo">1310</span>      }<a name="line.1310"></a>
+<span class="sourceLineNo">1311</span>    }<a name="line.1311"></a>
+<span class="sourceLineNo">1312</span><a name="line.1312"></a>
+<span class="sourceLineNo">1313</span>    Path hbaseRoot = FSUtils.getRootDir(getConf());<a name="line.1313"></a>
+<span class="sourceLineNo">1314</span>    FileSystem fs = hbaseRoot.getFileSystem(getConf());<a name="line.1314"></a>
+<span class="sourceLineNo">1315</span>    // serialized table info gathering.<a name="line.1315"></a>
+<span class="sourceLineNo">1316</span>    for (HbckRegionInfo hbi: hbckRegionInfos) {<a name="line.1316"></a>
+<span class="sourceLineNo">1317</span><a name="line.1317"></a>
+<span class="sourceLineNo">1318</span>      if (hbi.getHdfsHRI() == null) {<a name="line.1318"></a>
+<span class="sourceLineNo">1319</span>        // was an orphan<a name="line.1319"></a>
+<span class="sourceLineNo">1320</span>        continue;<a name="line.1320"></a>
+<span class="sourceLineNo">1321</span>      }<a name="line.1321"></a>
+<span class="sourceLineNo">1322</span><a name="line.1322"></a>
 <span class="sourceLineNo">1323</span><a name="line.1323"></a>
-<span class="sourceLineNo">1324</span><a name="line.1324"></a>
-<span class="sourceLineNo">1325</span>      // get table name from hdfs, populate various HBaseFsck tables.<a name="line.1325"></a>
-<span class="sourceLineNo">1326</span>      TableName tableName = hbi.getTableName();<a name="line.1326"></a>
-<span class="sourceLineNo">1327</span>      if (tableName == null) {<a name="line.1327"></a>
-<span class="sourceLineNo">1328</span>        // There was an entry in hbase:meta not in the HDFS?<a name="line.1328"></a>
-<span class="sourceLineNo">1329</span>        LOG.warn("tableName was null for: " + hbi);<a name="line.1329"></a>
-<span class="sourceLineNo">1330</span>        continue;<a name="line.1330"></a>
-<span class="sourceLineNo">1331</span>      }<a name="line.1331"></a>
-<span class="sourceLineNo">1332</span><a name="line.1332"></a>
-<span class="sourceLineNo">1333</span>      HbckTableInfo modTInfo = tablesInfo.get(tableName);<a name="line.1333"></a>
-<span class="sourceLineNo">1334</span>      if (modTInfo == null) {<a name="line.1334"></a>
-<span class="sourceLineNo">1335</span>        // only executed once per table.<a name="line.1335"></a>
-<span class="sourceLineNo">1336</span>        modTInfo = new HbckTableInfo(tableName, this);<a name="line.1336"></a>
-<span class="sourceLineNo">1337</span>        tablesInfo.put(tableName, modTInfo);<a name="line.1337"></a>
-<span class="sourceLineNo">1338</span>        try {<a name="line.1338"></a>
-<span class="sourceLineNo">1339</span>          TableDescriptor htd =<a name="line.1339"></a>
-<span class="sourceLineNo">1340</span>              FSTableDescriptors.getTableDescriptorFromFs(fs, hbaseRoot, tableName);<a name="line.1340"></a>
-<span class="sourceLineNo">1341</span>          modTInfo.htds.add(htd);<a name="line.1341"></a>
-<span class="sourceLineNo">1342</span>        } catch (IOException ioe) {<a name="line.1342"></a>
-<span class="sourceLineNo">1343</span>          if (!orphanTableDirs.containsKey(tableName)) {<a name="line.1343"></a>
-<span class="sourceLineNo">1344</span>            LOG.warn("Unable to read .tableinfo from " + hbaseRoot, ioe);<a name="line.1344"></a>
-<span class="sourceLineNo">1345</span>            //should only report once for each table<a name="line.1345"></a>
-<span class="sourceLineNo">1346</span>            errors.reportError(ERROR_CODE.NO_TABLEINFO_FILE,<a name="line.1346"></a>
-<span class="sourceLineNo">1347</span>                "Unable to read .tableinfo from " + hbaseRoot + "/" + tableName);<a name="line.1347"></a>
-<span class="sourceLineNo">1348</span>            Set&lt;String&gt; columns = new HashSet&lt;&gt;();<a name="line.1348"></a>
-<span class="sourceLineNo">1349</span>            orphanTableDirs.put(tableName, getColumnFamilyList(columns, hbi));<a name="line.1349"></a>
-<span class="sourceLineNo">1350</span>          }<a name="line.1350"></a>
-<span class="sourceLineNo">1351</span>        }<a name="line.1351"></a>
-<span class="sourceLineNo">1352</span>      }<a name="line.1352"></a>
-<span class="sourceLineNo">1353</span>      if (!hbi.isSkipChecks()) {<a name="line.1353"></a>
-<span class="sourceLineNo">1354</span>        modTInfo.addRegionInfo(hbi);<a name="line.1354"></a>
-<span class="sourceLineNo">1355</span>      }<a name="line.1355"></a>
-<span class="sourceLineNo">1356</span>    }<a name="line.1356"></a>
-<span class="sourceLineNo">1357</span><a name="line.1357"></a>
-<span class="sourceLineNo">1358</span>    loadTableInfosForTablesWithNoRegion();<a name="line.1358"></a>
-<span class="sourceLineNo">1359</span>    errors.print("");<a name="line.1359"></a>
-<span class="sourceLineNo">1360</span><a name="line.1360"></a>
-<span class="sourceLineNo">1361</span>    return tablesInfo;<a name="line.1361"></a>
-<span class="sourceLineNo">1362</span>  }<a name="line.1362"></a>
-<span class="sourceLineNo">1363</span><a name="line.1363"></a>
-<span class="sourceLineNo">1364</span>  /**<a name="line.1364"></a>
-<span class="sourceLineNo">1365</span>   * To get the column family list according to the column family dirs<a name="line.1365"></a>
-<span class="sourceLineNo">1366</span>   * @param columns<a name="line.1366"></a>
-<span class="sourceLineNo">1367</span>   * @param hbi<a name="line.1367"></a>
-<span class="sourceLineNo">1368</span>   * @return a set of column families<a name="line.1368"></a>
-<span class="sourceLineNo">1369</span>   * @throws IOException<a name="line.1369"></a>
-<span class="sourceLineNo">1370</span>   */<a name="line.1370"></a>
-<span class="sourceLineNo">1371</span>  private Set&lt;String&gt; getColumnFamilyList(Set&lt;String&gt; columns, HbckRegionInfo hbi)<a name="line.1371"></a>
-<span class="sourceLineNo">1372</span>      throws IOException {<a name="line.1372"></a>
-<span class="sourceLineNo">1373</span>    Path regionDir = hbi.getHdfsRegionDir();<a name="line.1373"></a>
-<span class="sourceLineNo">1374</span>    FileSystem fs = regionDir.getFileSystem(getConf());<a name="line.1374"></a>
-<span class="sourceLineNo">1375</span>    FileStatus[] subDirs = fs.listStatus(regionDir, new FSUtils.FamilyDirFilter(fs));<a name="line.1375"></a>
-<span class="sourceLineNo">1376</span>    for (FileStatus subdir : subDirs) {<a name="line.1376"></a>
-<span class="sourceLineNo">1377</span>      String columnfamily = subdir.getPath().getName();<a name="line.1377"></a>
-<span class="sourceLineNo">1378</span>      columns.add(columnfamily);<a name="line.1378"></a>
-<span class="sourceLineNo">1379</span>    }<a name="line.1379"></a>
-<span class="sourceLineNo">1380</span>    return columns;<a name="line.1380"></a>
-<span class="sourceLineNo">1381</span>  }<a name="line.1381"></a>
-<span class="sourceLineNo">1382</span><a name="line.1382"></a>
-<span class="sourceLineNo">1383</span>  /**<a name="line.1383"></a>
-<span class="sourceLineNo">1384</span>   * To fabricate a .tableinfo file with following contents&lt;br&gt;<a name="line.1384"></a>
-<span class="sourceLineNo">1385</span>   * 1. the correct tablename &lt;br&gt;<a name="line.1385"></a>
-<span class="sourceLineNo">1386</span>   * 2. the correct colfamily list&lt;br&gt;<a name="line.1386"></a>
-<span class="sourceLineNo">1387</span>   * 3. the default properties for both {@link TableDescriptor} and {@link ColumnFamilyDescriptor}&lt;br&gt;<a name="line.1387"></a>
-<span class="sourceLineNo">1388</span>   * @throws IOException<a name="line.1388"></a>
-<span class="sourceLineNo">1389</span>   */<a name="line.1389"></a>
-<span class="sourceLineNo">1390</span>  private boolean fabricateTableInfo(FSTableDescriptors fstd, TableName tableName,<a name="line.1390"></a>
-<span class="sourceLineNo">1391</span>      Set&lt;String&gt; columns) throws IOException {<a name="line.1391"></a>
-<span class="sourceLineNo">1392</span>    if (columns ==null || columns.isEmpty()) return false;<a name="line.1392"></a>
-<span class="sourceLineNo">1393</span>    TableDescriptorBuilder builder = TableDescriptorBuilder.newBuilder(tableName);<a name="line.1393"></a>
-<span class="sourceLineNo">1394</span>    for (String columnfamimly : columns) {<a name="line.1394"></a>
-<span class="sourceLineNo">1395</span>      builder.setColumnFamily(ColumnFamilyDescriptorBuilder.of(columnfamimly));<a name="line.1395"></a>
-<span class="sourceLineNo">1396</span>    }<a name="line.1396"></a>
-<span class="sourceLineNo">1397</span>    fstd.createTableDescriptor(builder.build(), true);<a name="line.1397"></a>
-<span class="sourceLineNo">1398</span>    return true;<a name="line.1398"></a>
-<span class="sourceLineNo">1399</span>  }<a name="line.1399"></a>
-<span class="sourceLineNo">1400</span><a name="line.1400"></a>
-<span class="sourceLineNo">1401</span>  /**<a name="line.1401"></a>
-<span class="sourceLineNo">1402</span>   * To fix the empty REGIONINFO_QUALIFIER rows from hbase:meta &lt;br&gt;<a name="line.1402"></a>
-<span class="sourceLineNo">1403</span>   * @throws IOException<a name="line.1403"></a>
-<span class="sourceLineNo">1404</span>   */<a name="line.1404"></a>
-<span class="sourceLineNo">1405</span>  public void fixEmptyMetaCells() throws IOException {<a name="line.1405"></a>
-<span class="sourceLineNo">1406</span>    if (shouldFixEmptyMetaCells() &amp;&amp; !emptyRegionInfoQualifiers.isEmpty()) {<a name="line.1406"></a>
-<span class="sourceLineNo">1407</span>      LOG.info("Trying to fix empty REGIONINFO_QUALIFIER hbase:meta rows.");<a name="line.1407"></a>
-<span class="sourceLineNo">1408</span>      for (Result region : emptyRegionInfoQualifiers) {<a name="line.1408"></a>
-<span class="sourceLineNo">1409</span>        deleteMetaRegion(region.getRow());<a name="line.1409"></a>
-<span class="sourceLineNo">1410</span>        errors.getErrorList().remove(ERROR_CODE.EMPTY_META_CELL);<a name="line.1410"></a>
-<span class="sourceLineNo">1411</span>      }<a name="line.1411"></a>
-<span class="sourceLineNo">1412</span>      emptyRegionInfoQualifiers.clear();<a name="line.1412"></a>
-<span class="sourceLineNo">1413</span>    }<a name="line.1413"></a>
-<span class="sourceLineNo">1414</span>  }<a name="line.1414"></a>
-<span class="sourceLineNo">1415</span><a name="line.1415"></a>
-<span class="sourceLineNo">1416</span>  /**<a name="line.1416"></a>
-<span class="sourceLineNo">1417</span>   * To fix orphan table by creating a .tableinfo file under tableDir &lt;br&gt;<a name="line.1417"></a>
-<span class="sourceLineNo">1418</span>   * 1. if TableInfo is cached, to recover the .tableinfo accordingly &lt;br&gt;<a name="line.1418"></a>
-<span class="sourceLineNo">1419</span>   * 2. else create a default .tableinfo file with following items&lt;br&gt;<a name="line.1419"></a>
-<span class="sourceLineNo">1420</span>   * &amp;nbsp;2.1 the correct tablename &lt;br&gt;<a name="line.1420"></a>
-<span class="sourceLineNo">1421</span>   * &amp;nbsp;2.2 the correct colfamily list&lt;br&gt;<a name="line.1421"></a>
-<span class="sourceLineNo">1422</span>   * &amp;nbsp;2.3 the default properties for both {@link TableDescriptor} and {@link ColumnFamilyDescriptor}&lt;br&gt;<a name="line.1422"></a>
-<span class="sourceLineNo">1423</span>   * @throws IOException<a name="line.1423"></a>
-<span class="sourceLineNo">1424</span>   */<a name="line.1424"></a>
-<span class="sourceLineNo">1425</span>  public void fixOrphanTables() throws IOException {<a name="line.1425"></a>
-<span class="sourceLineNo">1426</span>    if (shouldFixTableOrphans() &amp;&amp; !orphanTableDirs.isEmpty()) {<a name="line.1426"></a>
-<span class="sourceLineNo">1427</span><a name="line.1427"></a>
-<span class="sourceLineNo">1428</span>      List&lt;TableName&gt; tmpList = new ArrayList&lt;&gt;(orphanTableDirs.keySet().size());<a name="line.1428"></a>
-<span class="sourceLineNo">1429</span>      tmpList.addAll(orphanTableDirs.keySet());<a name="line.1429"></a>
-<span class="sourceLineNo">1430</span>      TableDescriptor[] htds = getTableDescriptors(tmpList);<a name="line.1430"></a>
-<span class="sourceLineNo">1431</span>      Iterator&lt;Entry&lt;TableName, Set&lt;String&gt;&gt;&gt; iter =<a name="line.1431"></a>
-<span class="sourceLineNo">1432</span>          orphanTableDirs.entrySet().iterator();<a name="line.1432"></a>
-<span class="sourceLineNo">1433</span>      int j = 0;<a name="line.1433"></a>
-<span class="sourceLineNo">1434</span>      int numFailedCase = 0;<a name="line.1434"></a>
-<span class="sourceLineNo">1435</span>      FSTableDescriptors fstd = new FSTableDescriptors(getConf());<a name="line.1435"></a>
-<span class="sourceLineNo">1436</span>      while (iter.hasNext()) {<a name="line.1436"></a>
-<span class="sourceLineNo">1437</span>        Entry&lt;TableName, Set&lt;String&gt;&gt; entry =<a name="line.1437"></a>
-<span class="sourceLineNo">1438</span>            iter.next();<a name="line.1438"></a>
-<span class="sourceLineNo">1439</span>        TableName tableName = entry.getKey();<a name="line.1439"></a>
-<span class="sourceLineNo">1440</span>        LOG.info("Trying to fix orphan table error: " + tableName);<a name="line.1440"></a>
-<span class="sourceLineNo">1441</span>        if (j &lt; htds.length) {<a name="line.1441"></a>
-<span class="sourceLineNo">1442</span>          if (tableName.equals(htds[j].getTableName())) {<a name="line.1442"></a>
-<span class="sourceLineNo">1443</span>            TableDescriptor htd = htds[j];<a name="line.1443"></a>
-<span class="sourceLineNo">1444</span>            LOG.info("fixing orphan table: " + tableName + " from cache");<a name="line.1444"></a>
-<span class="sourceLineNo">1445</span>            fstd.createTableDescriptor(htd, true);<a name="line.1445"></a>
-<span class="sourceLineNo">1446</span>            j++;<a name="line.1446"></a>
-<span class="sourceLineNo">1447</span>            iter.remove();<a name="line.1447"></a>
-<span class="sourceLineNo">1448</span>          }<a name="line.1448"></a>
-<span class="sourceLineNo">1449</span>        } else {<a name="line.1449"></a>
-<span class="sourceLineNo">1450</span>          if (fabricateTableInfo(fstd, tableName, entry.getValue())) {<a name="line.1450"></a>
-<span class="sourceLineNo">1451</span>            LOG.warn("fixing orphan table: " + tableName + " with a default .tableinfo file");<a name="line.1451"></a>
-<span class="sourceLineNo">1452</span>            LOG.warn("Strongly recommend to modify the TableDescriptor if necessary for: " + tableName);<a name="line.1452"></a>
-<span class="sourceLineNo">1453</span>            iter.remove();<a name="line.1453"></a>
-<span class="sourceLineNo">1454</span>          } else {<a name="line.1454"></a>
-<span class="sourceLineNo">1455</span>            LOG.error("Unable to create default .tableinfo for " + tableName + " while missing column family information");<a name="line.1455"></a>
-<span class="sourceLineNo">1456</span>            numFailedCase++;<a name="line.1456"></a>
-<span class="sourceLineNo">1457</span>          }<a name="line.1457"></a>
-<span class="sourceLineNo">1458</span>        }<a name="line.1458"></a>
-<span class="sourceLineNo">1459</span>        fixes++;<a name="line.1459"></a>
-<span class="sourceLineNo">1460</span>      }<a name="line.1460"></a>
-<span class="sourceLineNo">1461</span><a name="line.1461"></a>
-<span class="sourceLineNo">1462</span>      if (orphanTableDirs.isEmpty()) {<a name="line.1462"></a>
-<span class="sourceLineNo">1463</span>        // all orphanTableDirs are luckily recovered<a name="line.1463"></a>
-<span class="sourceLineNo">1464</span>        // re-run doFsck after recovering the .tableinfo file<a name="line.1464"></a>
-<span class="sourceLineNo">1465</span>        setShouldRerun();<a name="line.1465"></a>
-<span class="sourceLineNo">1466</span>        LOG.warn("Strongly recommend to re-run manually hfsck after all orphanTableDirs being fixed");<a name="line.1466"></a>
-<span class="sourceLineNo">1467</span>      } else if (numFailedCase &gt; 0) {<a name="line.1467"></a>
-<span class="sourceLineNo">1468</span>        LOG.error("Failed to fix " + numFailedCase<a name="line.1468"></a>
-<span class="sourceLineNo">1469</span>            + " OrphanTables with default .tableinfo files");<a name="line.1469"></a>
-<span class="sourceLineNo">1470</span>      }<a name="line.1470"></a>
-<span class="sourceLineNo">1471</span><a name="line.1471"></a>
-<span class="sourceLineNo">1472</span>    }<a name="line.1472"></a>
-<span class="sourceLineNo">1473</span>    //cleanup the list<a name="line.1473"></a>
-<span class="sourceLineNo">1474</span>    orphanTableDirs.clear();<a name="line.1474"></a>
-<span class="sourceLineNo">1475</span><a name="line.1475"></a>
-<span class="sourceLineNo">1476</span>  }<a name="line.1476"></a>
-<span class="sourceLineNo">1477</span><a name="line.1477"></a>
-<span class="sourceLineNo">1478</span>  /**<a name="line.1478"></a>
-<span class="sourceLineNo">1479</span>   * Log an appropriate message about whether or not overlapping merges are computed in parallel.<a name="line.1479"></a>
-<span class="sourceLineNo">1480</span>   */<a name="line.1480"></a>
-<span class="sourceLineNo">1481</span>  private void logParallelMerge() {<a name="line.1481"></a>
-<span class="sourceLineNo">1482</span>    if (getConf().getBoolean("hbasefsck.overlap.merge.parallel", true)) {<a name="line.1482"></a>
-<span class="sourceLineNo">1483</span>      LOG.info("Handling overlap merges in parallel. set hbasefsck.overlap.merge.parallel to" +<a name="line.1483"></a>
-<span class="sourceLineNo">1484</span>          " false to run serially.");<a name="line.1484"></a>
-<span class="sourceLineNo">1485</span>    } else {<a name="line.1485"></a>
-<span class="sourceLineNo">1486</span>      LOG.info("Handling overlap merges serially.  set hbasefsck.overlap.merge.parallel to" +<a name="line.1486"></a>
-<span class="sourceLineNo">1487</span>          " true to run in parallel.");<a name="line.1487"></a>
-<span class="sourceLineNo">1488</span>    }<a name="line.1488"></a>
-<span class="sourceLineNo">1489</span>  }<a name="line.1489"></a>
-<span class="sourceLineNo">1490</span><a name="line.1490"></a>
-<span class="sourceLineNo">1491</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; checkHdfsIntegrity(boolean fixHoles,<a name="line.1491"></a>
-<span class="sourceLineNo">1492</span>      boolean fixOverlaps) throws IOException {<a name="line.1492"></a>
-<span class="sourceLineNo">1493</span>    LOG.info("Checking HBase region split map from HDFS data...");<a name="line.1493"></a>
-<span class="sourceLineNo">1494</span>    logParallelMerge();<a name="line.1494"></a>
-<span class="sourceLineNo">1495</span>    for (HbckTableInfo tInfo : tablesInfo.values()) {<a name="line.1495"></a>
-<span class="sourceLineNo">1496</span>      TableIntegrityErrorHandler handler;<a name="line.1496"></a>
-<span class="sourceLineNo">1497</span>      if (fixHoles || fixOverlaps) {<a name="line.1497"></a>
-<span class="sourceLineNo">1498</span>        handler = tInfo.new HDFSIntegrityFixer(tInfo, errors, getConf(),<a name="line.1498"></a>
-<span class="sourceLineNo">1499</span>          fixHoles, fixOverlaps);<a name="line.1499"></a>
-<span class="sourceLineNo">1500</span>      } else {<a name="line.1500"></a>
-<span class="sourceLineNo">1501</span>        handler = tInfo.new IntegrityFixSuggester(tInfo, errors);<a name="line.1501"></a>
-<span class="sourceLineNo">1502</span>      }<a name="line.1502"></a>
-<span class="sourceLineNo">1503</span>      if (!tInfo.checkRegionChain(handler)) {<a name="line.1503"></a>
-<span class="sourceLineNo">1504</span>        // should dump info as well.<a name="line.1504"></a>
-<span class="sourceLineNo">1505</span>        errors.report("Found inconsistency in table " + tInfo.getName());<a name="line.1505"></a>
-<span class="sourceLineNo">1506</span>      }<a name="line.1506"></a>
-<span class="sourceLineNo">1507</span>    }<a name="line.1507"></a>
-<span class="sourceLineNo">1508</span>    return tablesInfo;<a name="line.1508"></a>
-<span class="sourceLineNo">1509</span>  }<a name="line.1509"></a>
-<span class="sourceLineNo">1510</span><a name="line.1510"></a>
-<span class="sourceLineNo">1511</span>  Path getSidelineDir() throws IOException {<a name="line.1511"></a>
-<span class="sourceLineNo">1512</span>    if (sidelineDir == null) {<a name="line.1512"></a>
-<span class="sourceLineNo">1513</span>      Path hbaseDir = FSUtils.getRootDir(getConf());<a name="line.1513"></a>
-<span class="sourceLineNo">1514</span>      Path hbckDir = new Path(hbaseDir, HConstants.HBCK_SIDELINEDIR_NAME);<a name="line.1514"></a>
-<span class="sourceLineNo">1515</span>      sidelineDir = new Path(hbckDir, hbaseDir.getName() + "-"<a name="line.1515"></a>
-<span class="sourceLineNo">1516</span>          + startMillis);<a name="line.1516"></a>
-<span class="sourceLineNo">1517</span>    }<a name="line.1517"></a>
-<span class="sourceLineNo">1518</span>    return sidelineDir;<a name="line.1518"></a>
-<span class="sourceLineNo">1519</span>  }<a name="line.1519"></a>
-<span class="sourceLineNo">1520</span><a name="line.1520"></a>
-<span class="sourceLineNo">1521</span>  /**<a name="line.1521"></a>
-<span class="sourceLineNo">1522</span>   * Sideline a region dir (instead of deleting it)<a name="line.1522"></a>
-<span class="sourceLineNo">1523</span>   */<a name="line.1523"></a>
-<span class="sourceLineNo">1524</span>  Path sidelineRegionDir(FileSystem fs, HbckRegionInfo hi) throws IOException {<a name="line.1524"></a>
-<span class="sourceLineNo">1525</span>    return sidelineRegionDir(fs, null, hi);<a name="line.1525"></a>
-<span class="sourceLineNo">1526</span>  }<a name="line.1526"></a>
-<span class="sourceLineNo">1527</span><a name="line.1527"></a>
-<span class="sourceLineNo">1528</span>  /**<a name="line.1528"></a>
-<span class="sourceLineNo">1529</span>   * Sideline a region dir (instead of deleting it)<a name="line.1529"></a>
-<span class="sourceLineNo">1530</span>   *<a name="line.1530"></a>
-<span class="sourceLineNo">1531</span>   * @param parentDir if specified, the region will be sidelined to folder like<a name="line.1531"></a>
-<span class="sourceLineNo">1532</span>   *     {@literal .../parentDir/&lt;table name&gt;/&lt;region name&gt;}. The purpose is to group together<a name="line.1532"></a>
-<span class="sourceLineNo">1533</span>   *     similar regions sidelined, for example, those regions should be bulk loaded back later<a name="line.1533"></a>
-<span class="sourceLineNo">1534</span>   *     on. If NULL, it is ignored.<a name="line.1534"></a>
-<span class="sourceLineNo">1535</span>   */<a name="line.1535"></a>
-<span class="sourceLineNo">1536</span>  Path sidelineRegionDir(FileSystem fs,<a name="line.1536"></a>
-<span class="sourceLineNo">1537</span>      String parentDir, HbckRegionInfo hi) throws IOException {<a name="line.1537"></a>
-<span class="sourceLineNo">1538</span>    TableName tableName = hi.getTableName();<a name="line.1538"></a>
-<span class="sourceLineNo">1539</span>    Path regionDir = hi.getHdfsRegionDir();<a name="line.1539"></a>
-<span class="sourceLineNo">1540</span><a name="line.1540"></a>
-<span class="sourceLineNo">1541</span>    if (!fs.exists(regionDir)) {<a name="line.1541"></a>
-<span class="sourceLineNo">1542</span>      LOG.warn("No previous " + regionDir + " exists.  Continuing.");<a name="line.1542"></a>
-<span class="sourceLineNo">1543</span>      return null;<a name="line.1543"></a>
-<span class="sourceLineNo">1544</span>    }<a name="line.1544"></a>
-<span class="sourceLineNo">1545</span><a name="line.1545"></a>
-<span class="sourceLineNo">1546</span>    Path rootDir = getSidelineDir();<a name="line.1546"></a>
-<span class="sourceLineNo">1547</span>    if (parentDir != null) {<a name="line.1547"></a>
-<span class="sourceLineNo">1548</span>      rootDir = new Path(rootDir, parentDir);<a name="line.1548"></a>
-<span class="sourceLineNo">1549</span>    }<a name="line.1549"></a>
-<span class="sourceLineNo">1550</span>    Path sidelineTableDir= FSUtils.getTableDir(rootDir, tableName);<a name="line.1550"></a>
-<span class="sourceLineNo">1551</span>    Path sidelineRegionDir = new Path(sidelineTableDir, regionDir.getName());<a name="line.1551"></a>
-<span class="sourceLineNo">1552</span>    fs.mkdirs(sidelineRegionDir);<a name="line.1552"></a>
-<span class="sourceLineNo">1553</span>    boolean success = false;<a name="line.1553"></a>
-<span class="sourceLineNo">1554</span>    FileStatus[] cfs =  fs.listStatus(regionDir);<a name="line.1554"></a>
-<span class="sourceLineNo">1555</span>    if (cfs == null) {<a name="line.1555"></a>
-<span class="sourceLineNo">1556</span>      LOG.info("Region dir is empty: " + regionDir);<a name="line.1556"></a>
-<span class="sourceLineNo">1557</span>    } else {<a name="line.1557"></a>
-<span class="sourceLineNo">1558</span>      for (FileStatus cf : cfs) {<a name="line.1558"></a>
-<span class="sourceLineNo">1559</span>        Path src = cf.getPath();<a name="line.1559"></a>
-<span class="sourceLineNo">1560</span>        Path dst =  new Path(sidelineRegionDir, src.getName());<a name="line.1560"></a>
-<span class="sourceLineNo">1561</span>        if (fs.isFile(src)) {<a name="line.1561"></a>
-<span class="sourceLineNo">1562</span>          // simple file<a name="line.1562"></a>
-<span class="sourceLineNo">1563</span>          success = fs.rename(src, dst);<a name="line.1563"></a>
-<span class="sourceLineNo">1564</span>          if (!success) {<a name="line.1564"></a>
-<span class="sourceLineNo">1565</span>            String msg = "Unable to rename file " + src +  " to " + dst;<a name="line.1565"></a>
-<span class="sourceLineNo">1566</span>            LOG.error(msg);<a name="line.1566"></a>
-<span class="sourceLineNo">1567</span>            throw new IOException(msg);<a name="line.1567"></a>
-<span class="sourceLineNo">1568</span>          }<a name="line.1568"></a>
-<span class="sourceLineNo">1569</span>          continue;<a name="line.1569"></a>
-<span class="sourceLineNo">1570</span>        }<a name="line.1570"></a>
-<span class="sourceLineNo">1571</span><a name="line.1571"></a>
-<span class="sourceLineNo">1572</span>        // is a directory.<a name="line.1572"></a>
-<span class="sourceLineNo">1573</span>        fs.mkdirs(dst);<a name="line.1573"></a>
-<span class="sourceLineNo">1574</span><a name="line.1574"></a>
-<span class="sourceLineNo">1575</span>        LOG.info("Sidelining files from " + src + " into containing region " + dst);<a name="line.1575"></a>
-<span class="sourceLineNo">1576</span>        // FileSystem.rename is inconsistent with directories -- if the<a name="line.1576"></a>
-<span class="sourceLineNo">1577</span>        // dst (foo/a) exists and is a dir, and the src (foo/b) is a dir,<a name="line.1577"></a>
-<span class="sourceLineNo">1578</span>        // it moves the src into the dst dir resulting in (foo/a/b).  If<a name="line.1578"></a>
-<span class="sourceLineNo">1579</span>        // the dst does not exist, and the src a dir, src becomes dst. (foo/b)<a name="line.1579"></a>
-<span class="sourceLineNo">1580</span>        FileStatus[] hfiles = fs.listStatus(src);<a name="line.1580"></a>
-<span class="sourceLineNo">1581</span>        if (hfiles != null &amp;&amp; hfiles.length &gt; 0) {<a name="line.1581"></a>
-<span class="sourceLineNo">1582</span>          for (FileStatus hfile : hfiles) {<a name="line.1582"></a>
-<span class="sourceLineNo">1583</span>            success = fs.rename(hfile.getPath(), dst);<a name="line.1583"></a>
-<span class="sourceLineNo">1584</span>            if (!success) {<a name="line.1584"></a>
-<span class="sourceLineNo">1585</span>              String msg = "Unable to rename file " + src +  " to " + dst;<a name="line.1585"></a>
-<span class="sourceLineNo">1586</span>              LOG.error(msg);<a name="line.1586"></a>
-<span class="sourceLineNo">1587</span>              throw new IOException(msg);<a name="line.1587"></a>
-<span class="sourceLineNo">1588</span>            }<a name="line.1588"></a>
-<span class="sourceLineNo">1589</span>          }<a name="line.1589"></a>
-<span class="sourceLineNo">1590</span>        }<a name="line.1590"></a>
-<span class="sourceLineNo">1591</span>        LOG.debug("Sideline directory contents:");<a name="line.1591"></a>
-<span class="sourceLineNo">1592</span>        debugLsr(sidelineRegionDir);<a name="line.1592"></a>
-<span class="sourceLineNo">1593</span>      }<a name="line.1593"></a>
-<span class="sourceLineNo">1594</span>    }<a name="line.1594"></a>
-<span class="sourceLineNo">1595</span><a name="line.1595"></a>
-<span class="sourceLineNo">1596</span>    LOG.info("Removing old region dir: " + regionDir);<a name="line.1596"></a>
-<span class="sourceLineNo">1597</span>    success = fs.delete(regionDir, true);<a name="line.1597"></a>
-<span class="sourceLineNo">1598</span>    if (!success) {<a name="line.1598"></a>
-<span class="sourceLineNo">1599</span>      String msg = "Unable to delete dir " + regionDir;<a name="line.1599"></a>
-<span class="sourceLineNo">1600</span>      LOG.error(msg);<a name="line.1600"></a>
-<span class="sourceLineNo">1601</span>      throw new IOException(msg);<a name="line.1601"></a>
-<span class="sourceLineNo">1602</span>    }<a name="line.1602"></a>
-<span class="sourceLineNo">1603</span>    return sidelineRegionDir;<a name="line.1603"></a>
-<span class="sourceLineNo">1604</span>  }<a name="line.1604"></a>
-<span class="sourceLineNo">1605</span><a name="line.1605"></a>
-<span class="sourceLineNo">1606</span>  /**<a name="line.1606"></a>
-<span class="sourceLineNo">1607</span>   * Load the list of disabled tables in ZK into local set.<a name="line.1607"></a>
-<span class="sourceLineNo">1608</span>   * @throws ZooKeeperConnectionException<a name="line.1608"></a>
-<span class="sourceLineNo">1609</span>   * @throws IOException<a name="line.1609"></a>
-<span class="sourceLineNo">1610</span>   */<a name="line.1610"></a>
-<span class="sourceLineNo">1611</span>  private void loadTableStates()<a name="line.1611"></a>
-<span class="sourceLineNo">1612</span>  throws IOException {<a name="line.1612"></a>
-<span class="sourceLineNo">1613</span>    tableStates = MetaTableAccessor.getTableStates(connection);<a name="line.1613"></a>
-<span class="sourceLineNo">1614</span>    // Add hbase:meta so this tool keeps working. In hbase2, meta is always enabled though it<a name="line.1614"></a>
-<span class="sourceLineNo">1615</span>    // has no entry in the table states. HBCK doesn't work right w/ hbase2 but just do this in<a name="line.1615"></a>
-<span class="sourceLineNo">1616</span>    // meantime.<a name="line.1616"></a>
-<span class="sourceLineNo">1617</span>    this.tableStates.put(TableName.META_TABLE_NAME,<a name="line.1617"></a>
-<span class="sourceLineNo">1618</span>        new TableState(TableName.META_TABLE_NAME, TableState.State.ENABLED));<a name="line.1618"></a>
-<span class="sourceLineNo">1619</span>  }<a name="line.1619"></a>
-<span class="sourceLineNo">1620</span><a name="line.1620"></a>
-<span class="sourceLineNo">1621</span>  /**<a name="line.1621"></a>
-<span class="sourceLineNo">1622</span>   * Check if the specified region's table is disabled.<a name="line.1622"></a>
-<span class="sourceLineNo">1623</span>   * @param tableName table to check status of<a name="line.1623"></a>
-<span class="sourceLineNo">1624</span>   */<a name="line.1624"></a>
-<span class="sourceLineNo">1625</span>  boolean isTableDisabled(TableName tableName) {<a name="line.1625"></a>
-<span class="sourceLineNo">1626</span>    return tableStates.containsKey(tableName)<a name="line.1626"></a>
-<span class="sourceLineNo">1627</span>        &amp;&amp; tableStates.get(tableName)<a name="line.1627"></a>
-<span class="sourceLineNo">1628</span>        .inStates(TableState.State.DISABLED, TableState.State.DISABLING);<a name="line.1628"></a>
-<span class="sourceLineNo">1629</span>  }<a name="line.1629"></a>
-<span class="sourceLineNo">1630</span><a name="line.1630"></a>
-<span class="sourceLineNo">1631</span>  /**<a name="line.1631"></a>
-<span class="sourceLineNo">1632</span>   * Scan HDFS for all regions, recording their information into<a name="line.1632"></a>
-<span class="sourceLineNo">1633</span>   * regionInfoMap<a name="line.1633"></a>
-<span class="sourceLineNo">1634</span>   */<a name="line.1634"></a>
-<span class="sourceLineNo">1635</span>  public void loadHdfsRegionDirs() throws IOException, InterruptedException {<a name="line.1635"></a>
-<span class="sourceLineNo">1636</span>    Path rootDir = FSUtils.getRootDir(getConf());<a name="line.1636"></a>
-<span class="sourceLineNo">1637</span>    FileSystem fs = rootDir.getFileSystem(getConf());<a name="line.1637"></a>
-<span class="sourceLineNo">1638</span><a name="line.1638"></a>
-<span class="sourceLineNo">1639</span>    // list all tables from HDFS<a name="line.1639"></a>
-<span class="sourceLineNo">1640</span>    List&lt;FileStatus&gt; tableDirs = Lists.newArrayList();<a name="line.1640"></a>
-<span class="sourceLineNo">1641</span><a name="line.1641"></a>
-<span class="sourceLineNo">1642</span>    boolean foundVersionFile = fs.exists(new Path(rootDir, HConstants.VERSION_FILE_NAME));<a name="line.1642"></a>
-<span class="sourceLineNo">1643</span><a name="line.1643"></a>
-<span class="sourceLineNo">1644</span>    List&lt;Path&gt; paths = FSUtils.getTableDirs(fs, rootDir);<a name="line.1644"></a>
-<span class="sourceLineNo">1645</span>    for (Path path : paths) {<a name="line.1645"></a>
-<span class="sourceLineNo">1646</span>      TableName tableName = FSUtils.getTableName(path);<a name="line.1646"></a>
-<span class="sourceLineNo">1647</span>       if ((!checkMetaOnly &amp;&amp;<a name="line.1647"></a>
-<span class="sourceLineNo">1648</span>           isTableIncluded(tableName)) ||<a name="line.1648"></a>
-<span class="sourceLineNo">1649</span>           tableName.equals(TableName.META_TABLE_NAME)) {<a name="line.1649"></a>
-<span class="sourceLineNo">1650</span>         tableDirs.add(fs.getFileStatus(path));<a name="line.1650"></a>
-<span class="sourceLineNo">1651</span>       }<a name="line.1651"></a>
-<span class="sourceLineNo">1652</span>    }<a name="line.1652"></a>
-<span class="sourceLineNo">1653</span><a name="line.1653"></a>
-<span class="sourceLineNo">1654</span>    // verify that version file exists<a name="line.1654"></a>
-<span class="sourceLineNo">1655</span>    if (!foundVersionFile) {<a name="line.1655"></a>
-<span class="sourceLineNo">1656</span>      errors.reportError(ERROR_CODE.NO_VERSION_FILE,<a name="line.1656"></a>
-<span class="sourceLineNo">1657</span>          "Version file does not exist in root dir " + rootDir);<a name="line.1657"></a>
-<span class="sourceLineNo">1658</span>      if (shouldFixVersionFile()) {<a name="line.1658"></a>
-<span class="sourceLineNo">1659</span>        LOG.info("Trying to create a new " + HConstants.VERSION_FILE_NAME<a name="line.1659"></a>
-<span class="sourceLineNo">1660</span>            + " file.");<a name="line.1660"></a>
-<span class="sourceLineNo">1661</span>        setShouldRerun();<a name="line.1661"></a>
-<span class="sourceLineNo">1662</span>        FSUtils.setVersion(fs, rootDir, getConf().getInt(<a name="line.1662"></a>
-<span class="sourceLineNo">1663</span>            HConstants.THREAD_WAKE_FREQUENCY, 10 * 1000), getConf().getInt(<a name="line.1663"></a>
-<span class="sourceLineNo">1664</span>            HConstants.VERSION_FILE_WRITE_ATTEMPTS,<a name="line.1664"></a>
-<span class="sourceLineNo">1665</span>            HConstants.DEFAULT_VERSION_FILE_WRITE_ATTEMPTS));<a name="line.1665"></a>
-<span class="sourceLineNo">1666</span>      }<a name="line.1666"></a>
-<span class="sourceLineNo">1667</span>    }<a name="line.1667"></a>
-<span class="sourceLineNo">1668</span><a name="line.1668"></a>
-<span class="sourceLineNo">1669</span>    // Avoid multithreading at table-level because already multithreaded internally at<a name="line.1669"></a>
-<span class="sourceLineNo">1670</span>    // region-level.  Additionally multithreading at table-level can lead to deadlock<a name="line.1670"></a>
-<span class="sourceLineNo">1671</span>    // if there are many tables in the cluster.  Since there are a limited # of threads<a name="line.1671"></a>
-<span class="sourceLineNo">1672</span>    // in the executor's thread pool and if we multithread at the table-level by putting<a name="line.1672"></a>
-<span class="sourceLineNo">1673</span>    // WorkItemHdfsDir callables into the executor, then we will have some threads in the<a name="line.1673"></a>
-<span class="sourceLineNo">1674</span>    // executor tied up solely in waiting for the tables' region-level calls to complete.<a name="line.1674"></a>
-<span class="sourceLineNo">1675</span>    // If there are enough tables then there will be no actual threads in the pool left<a name="line.1675"></a>
-<span class="sourceLineNo">1676</span>    // for the region-level callables to be serviced.<a name="line.1676"></a>
-<span class="sourceLineNo">1677</span>    for (FileStatus tableDir : tableDirs) {<a name="line.1677"></a>
-<span class="sourceLineNo">1678</span>      LOG.debug("Loading region dirs from " +tableDir.getPath());<a name="line.1678"></a>
-<span class="sourceLineNo">1679</span>      WorkItemHdfsDir item = new WorkItemHdfsDir(fs, errors, tableDir);<a name="line.1679"></a>
-<span class="sourceLineNo">1680</span>      try {<a name="line.1680"></a>
-<span class="sourceLineNo">1681</span>        item.call();<a name="line.1681"></a>
-<span class="sourceLineNo">1682</span>      } catch (ExecutionException e) {<a name="line.1682"></a>
-<span class="sourceLineNo">1683</span>        LOG.warn("Could not completely load table dir " +<a name="line.1683"></a>
-<span class="sourceLineNo">1684</span>            tableDir.getPath(), e.getCause());<a name="line.1684"></a>
-<span class="sourceLineNo">1685</span>      }<a name="line.1685"></a>
-<span class="sourceLineNo">1686</span>    }<a name="line.1686"></a>
-<span class="sourceLineNo">1687</span>    errors.print("");<a name="line.1687"></a>
-<span class="sourceLineNo">1688</span>  }<a name="line.1688"></a>
-<span class="sourceLineNo">1689</span><a name="line.1689"></a>
-<span class="sourceLineNo">1690</span>  /**<a name="line.1690"></a>
-<span class="sourceLineNo">1691</span>   * Record the location of the hbase:meta region as found in ZooKeeper.<a name="line.1691"></a>
-<span class="sourceLineNo">1692</span>   */<a name="line.1692"></a>
-<span class="sourceLineNo">1693</span>  private boolean recordMetaRegion() throws IOException {<a name="line.1693"></a>
-<span class="sourceLineNo">1694</span>    List&lt;HRegionLocation&gt; locs;<a name="line.1694"></a>
-<span class="sourceLineNo">1695</span>    try (RegionLocator locator = connection.getRegionLocator(TableName.META_TABLE_NAME)) {<a name="line.1695"></a>
-<span class="sourceLineNo">1696</span>      locs = locator.getRegionLocations(HConstants.EMPTY_START_ROW, true);<a name="line.1696"></a>
-<span class="sourceLineNo">1697</span>    }<a name="line.1697"></a>
-<span class="sourceLineNo">1698</span>    if (locs == null || locs.isEmpty()) {<a name="line.1698"></a>
-<span class="sourceLineNo">1699</span>      errors.reportError(ERROR_CODE.NULL_META_REGION, "META region was not found in ZooKeeper");<a name="line.1699"></a>
-<span class="sourceLineNo">1700</span>      return false;<a name="line.1700"></a>
-<span class="sourceLineNo">1701</span>    }<a name="line.1701"></a>
-<span class="sourceLineNo">1702</span>    for (HRegionLocation metaLocation : locs) {<a name="line.1702"></a>
-<span class="sourceLineNo">1703</span>      // Check if Meta region is valid and existing<a name="line.1703"></a>
-<span class="sourceLineNo">1704</span>      if (metaLocation == null) {<a name="line.1704"></a>
-<span class="sourceLineNo">1705</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META region location is null");<a name="line.1705"></a>
-<span class="sourceLineNo">1706</span>        return false;<a name="line.1706"></a>
-<span class="sourceLineNo">1707</span>      }<a name="line.1707"></a>
-<span class="sourceLineNo">1708</span>      if (metaLocation.getRegion() == null) {<a name="line.1708"></a>
-<span class="sourceLineNo">1709</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META location regionInfo is null");<a name="line.1709"></a>
-<span class="sourceLineNo">1710</span>        return false;<a name="line.1710"></a>
-<span class="sourceLineNo">1711</span>      }<a name="line.1711"></a>
-<span class="sourceLineNo">1712</span>      if (metaLocation.getHostname() == null) {<a name="line.1712"></a>
-<span class="sourceLineNo">1713</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META location hostName is null");<a name="line.1713"></a>
-<span class="sourceLineNo">1714</span>        return false;<a name="line.1714"></a>
-<span class="sourceLineNo">1715</span>      }<a name="line.1715"></a>
-<span class="sourceLineNo">1716</span>      ServerName sn = metaLocation.getServerName();<a name="line.1716"></a>
-<span class="sourceLineNo">1717</span>      HbckRegionInfo.MetaEntry m = new HbckRegionInfo.MetaEntry(metaLocation.getRegion(), sn,<a name="line.1717"></a>
-<span class="sourceLineNo">1718</span>          EnvironmentEdgeManager.currentTime());<a name="line.1718"></a>
-<span class="sourceLineNo">1719</span>      HbckRegionInfo hbckRegionInfo = regionInfoMap.get(metaLocation.getRegion().getEncodedName());<a name="line.1719"></a>
-<span class="sourceLineNo">1720</span>      if (hbckRegionInfo == null) {<a name="line.1720"></a>
-<span class="sourceLineNo">1721</span>        regionInfoMap.put(metaLocation.getRegion().getEncodedName(), new HbckRegionInfo(m));<a name="line.1721"></a>
-<span class="sourceLineNo">1722</span>      } else {<a name="line.1722"></a>
-<span class="sourceLineNo">1723</span>        hbckRegionInfo.setMetaEntry(m);<a name="line.1723"></a>
-<span class="sourceLineNo">1724</span>      }<a name="line.1724"></a>
-<span class="sourceLineNo">1725</span>    }<a name="line.1725"></a>
-<span class="sourceLineNo">1726</span>    return true;<a name="line.1726"></a>
-<span class="sourceLineNo">1727</span>  }<a name="line.1727"></a>
-<span class="sourceLineNo">1728</span><a name="line.1728"></a>
-<span class="sourceLineNo">1729</span>  private ZKWatcher createZooKeeperWatcher() throws IOException {<a name="line.1729"></a>
-<span class="sourceLineNo">1730</span>    return new ZKWatcher(getConf(), "hbase Fsck", new Abortable() {<a name="line.1730"></a>
-<span class="sourceLineNo">1731</span>      @Override<a name="line.1731"></a>
-<span class="sourceLineNo">1732</span>      public void abort(String why, Throwable e) {<a name="line.1732"></a>
-<span class="sourceLineNo">1733</span>        LOG.error(why, e);<a name="line.1733"></a>
-<span class="sourceLineNo">1734</span>        System.exit(1);<a name="line.1734"></a>
-<span class="sourceLineNo">1735</span>      }<a name="line.1735"></a>
-<span class="sourceLineNo">1736</span><a name="line.1736"></a>
-<span class="sourceLineNo">1737</span>      @Override<a name="line.1737"></a>
-<span class="sourceLineNo">1738</span>      public boolean isAborted() {<a name="line.1738"></a>
-<span class="sourceLineNo">1739</span>        return false;<a name="line.1739"></a>
-<span class="sourceLineNo">1740</span>      }<a name="line.1740"></a>
-<span class="sourceLineNo">1741</span><a name="line.1741"></a>
-<span class="sourceLineNo">1742</span>    });<a name="line.1742"></a>
-<span class="sourceLineNo">1743</span>  }<a name="line.1743"></a>
-<span class="sourceLineNo">1744</span><a name="line.1744"></a>
-<span class="sourceLineNo">1745</span>  /**<a name="line.1745"></a>
-<span class="sourceLineNo">1746</span>   * Contacts each regionserver and fetches metadata about regions.<a name="line.1746"></a>
-<span class="sourceLineNo">1747</span>   * @param regionServerList - the list of region servers to connect to<a name="line.1747"></a>
-<span class="sourceLineNo">1748</span>   * @throws IOException if a remote or network exception occurs<a name="line.1748"></a>
-<span class="sourceLineNo">1749</span>   */<a name="line.1749"></a>
-<span class="sourceLineNo">1750</span>  void processRegionServers(Collection&lt;ServerName&gt; regionServerList)<a name="line.1750"></a>
-<span class="sourceLineNo">1751</span>    throws IOException, InterruptedException {<a name="line.1751"></a>
-<span class="sourceLineNo">1752</span><a name="line.1752"></a>
-<span class="sourceLineNo">1753</span>    List&lt;WorkItemRegion&gt; workItems = new ArrayList&lt;&gt;(regionServerList.size());<a name="line.1753"></a>
-<span class="sourceLineNo">1754</span>    List&lt;Future&lt;Void&gt;&gt; workFutures;<a name="line.1754"></a>
-<span class="sourceLineNo">1755</span><a name="line.1755"></a>
-<span class="sourceLineNo">1756</span>    // loop to contact each region server in parallel<a name="line.1756"></a>
-<span class="sourceLineNo">1757</span>    for (ServerName rsinfo: regionServerList) {<a name="line.1757"></a>
-<span class="sourceLineNo">1758</span>      workItems.add(new WorkItemRegion(this, rsinfo, errors, connection));<a name="line.1758"></a>
-<span class="sourceLineNo">1759</span>    }<a name="line.1759"></a>
-<span class="sourceLineNo">1760</span><a name="line.1760"></a>
-<span class="sourceLineNo">1761</span>    workFutures = executor.invokeAll(workItems);<a name="line.1761"></a>
-<span class="sourceLineNo">1762</span><a name="line.1762"></a>
-<span class="sourceLineNo">1763</span>    for(int i=0; i&lt;workFutures.size(); i++) {<a name="line.1763"></a>
-<span class="sourceLineNo">1764</span>      WorkItemRegion item = workItems.get(i);<a name="line.1764"></a>
-<span class="sourceLineNo">1765</span>      Future&lt;Void&gt; f = workFutures.get(i);<a name="line.1765"></a>
-<span class="sourceLineNo">1766</span>      try {<a name="line.1766"></a>
-<span class="sourceLineNo">1767</span>        f.get();<a name="line.1767"></a>
-<span class="sourceLineNo">1768</span>      } catch(ExecutionException e) {<a name="line.1768"></a>
-<span class="sourceLineNo">1769</span>        LOG.warn("Could not process regionserver " + item.rsinfo.getHostAndPort(),<a name="line.1769"></a>
-<span class="sourceLineNo">1770</span>            e.getCause());<a name="line.1770"></a>
-<span class="sourceLineNo">1771</span>      }<a name="line.1771"></a>
-<span class="sourceLineNo">1772</span>    }<a name="line.1772"></a>
-<span class="sourceLineNo">1773</span>  }<a name="line.1773"></a>
-<span class="sourceLineNo">1774</span><a name="line.1774"></a>
-<span class="sourceLineNo">1775</span>  /**<a name="line.1775"></a>
-<span class="sourceLineNo">1776</span>   * Check consistency of all regions that have been found in previous phases.<a name="line.1776"></a>
-<span class="sourceLineNo">1777</span>   */<a name="line.1777"></a>
-<span class="sourceLineNo">1778</span>  private void checkAndFixConsistency()<a name="line.1778"></a>
-<span class="sourceLineNo">1779</span>  throws IOException, KeeperException, InterruptedException {<a name="line.1779"></a>
-<span class="sourceLineNo">1780</span>    // Divide the checks in two phases. One for default/primary replicas and another<a name="line.1780"></a>
-<span class="sourceLineNo">1781</span>    // for the non-primary ones. Keeps code cleaner this way.<a name="line.1781"></a>
-<span class="sourceLineNo">1782</span><a name="line.1782"></a>
-<span class="sourceLineNo">1783</span>    List&lt;CheckRegionConsistencyWorkItem&gt; workItems = new ArrayList&lt;&gt;(regionInfoMap.size());<a name="line.1783"></a>
-<span class="sourceLineNo">1784</span>    for (java.util.Map.Entry&lt;String, HbckRegionInfo&gt; e: regionInfoMap.entrySet()) {<a name="line.1784"></a>
-<span class="sourceLineNo">1785</span>      if (e.getValue().getReplicaId() == RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.1785"></a>
-<span class="sourceLineNo">1786</span>        workItems.add(new CheckRegionConsistencyWorkItem(e.getKey(), e.getValue()));<a name="line.1786"></a>
-<span class="sourceLineNo">1787</span>      }<a name="line.1787"></a>
-<span class="sourceLineNo">1788</span>    }<a name="line.1788"></a>
-<span class="sourceLineNo">1789</span>    checkRegionConsistencyConcurrently(workItems);<a name="line.1789"></a>
-<span class="sourceLineNo">1790</span><a name="line.1790"></a>
-<span class="sourceLineNo">1791</span>    boolean prevHdfsCheck = shouldCheckHdfs();<a name="line.1791"></a>
-<span class="sourceLineNo">1792</span>    setCheckHdfs(false); //replicas don't have any hdfs data<a name="line.1792"></a>
-<span class="sourceLineNo">1793</span>    // Run a pass over the replicas and fix any assignment issues that exist on the currently<a name="line.1793"></a>
-<span class="sourceLineNo">1794</span>    // deployed/undeployed replicas.<a name="line.1794"></a>
-<span class="sourceLineNo">1795</span>    List&lt;CheckRegionConsistencyWorkItem&gt; replicaWorkItems = new ArrayList&lt;&gt;(regionInfoMap.size());<a name="line.1795"></a>
-<span class="sourceLineNo">1796</span>    for (java.util.Map.Entry&lt;String, HbckRegionInfo&gt; e: regionInfoMap.entrySet()) {<a name="line.1796"></a>
-<span class="sourceLineNo">1797</span>      if (e.getValue().getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.1797"></a>
-<span class="sourceLineNo">1798</span>        replicaWorkItems.add(new CheckRegionConsistencyWorkItem(e.getKey(), e.getValue()));<a name="line.1798"></a>
-<span class="sourceLineNo">1799</span>      }<a name="line.1799"></a>
-<span class="sourceLineNo">1800</span>    }<a name="line.1800"></a>
-<span class="sourceLineNo">1801</span>    checkRegionConsistencyConcurrently(replicaWorkItems);<a name="line.1801"></a>
-<span class="sourceLineNo">1802</span>    setCheckHdfs(prevHdfsCheck);<a name="line.1802"></a>
-<span class="sourceLineNo">1803</span><a name="line.1803"></a>
-<span class="sourceLineNo">1804</span>    // If some regions is skipped during checkRegionConsistencyConcurrently() phase, we might<a name="line.1804"></a>
-<span class="sourceLineNo">1805</span>    // not get accurate state of the hbase if continuing. The config here allows users to tune<a name="line.1805"></a>
-<span class="sourceLineNo">1806</span>    // the tolerance of number of skipped region.<a name="line.1806"></a>
-<span class="sourceLineNo">1807</span>    // TODO: evaluate the consequence to continue the hbck operation without config.<a name="line.1807"></a>
-<span class="sourceLineNo">1808</span>    int terminateThreshold =  getConf().getInt("hbase.hbck.skipped.regions.limit", 0);<a name="line.1808"></a>
-<span class="sourceLineNo">1809</span>    int numOfSkippedRegions = skippedRegions.size();<a name="line.1809"></a>
-<span class="sourceLineNo">1810</span>    if (numOfSkippedRegions &gt; 0 &amp;&amp; numOfSkippedRegions &gt; terminateThreshold) {<a name="line.1810"></a>
-<span class="sourceLineNo">1811</span>      throw new IOException(numOfSkippedRegions<a name="line.1811"></a>
-<span class="sourceLineNo">1812</span>        + " region(s) could not be checked or repaired.  See logs for detail.");<a name="line.1812"></a>
-<span class="sourceLineNo">1813</span>    }<a name="line.1813"></a>
-<span class="sourceLineNo">1814</span><a name="line.1814"></a>
-<span class="sourceLineNo">1815</span>    if (shouldCheckHdfs()) {<a name="line.1815"></a>
-<span class="sourceLineNo">1816</span>      checkAndFixTableStates();<a name="line.1816"></a>
-<span class="sourceLineNo">1817</span>    }<a name="line.1817"></a>
-<span class="sourceLineNo">1818</span>  }<a name="line.1818"></a>
-<span class="sourceLineNo">1819</span><a name="line.1819"></a>
-<span class="sourceLineNo">1820</span>  /**<a name="line.1820"></a>
-<span class="sourceLineNo">1821</span>   * Check consistency of all regions using mulitple threads concurrently.<a name="line.1821"></a>
-<span class="sourceLineNo">1822</span>   */<a name="line.1822"></a>
-<span class="sourceLineNo">1823</span>  private void checkRegionConsistencyConcurrently(<a name="line.1823"></a>
-<span class="sourceLineNo">1824</span>    final List&lt;CheckRegionConsistencyWorkItem&gt; workItems)<a name="line.1824"></a>
-<span class="sourceLineNo">1825</span>    throws IOException, KeeperException, InterruptedException {<a name="line.1825"></a>
-<span class="sourceLineNo">1826</span>    if (workItems.isEmpty()) {<a name="line.1826"></a>
-<span class="sourceLineNo">1827</span>      return;  // nothing to check<a name="line.1827"></a>
-<span class="sourceLineNo">1828</span>    }<a name="line.1828"></a>
-<span class="sourceLineNo">1829</span><a name="line.1829"></a>
-<span class="sourceLineNo">1830</span>    List&lt;Future&lt;Void&gt;&gt; workFutures = executor.invokeAll(workItems);<a name="line.1830"></a>
-<span class="sourceLineNo">1831</span>    for(Future&lt;Void&gt; f: workFutures) {<a name="line.1831"></a>
-<span class="sourceLineNo">1832</span>      try {<a name="line.1832"></a>
-<span class="sourceLineNo">1833</span>        f.get();<a name="line.1833"></a>
-<span class="sourceLineNo">1834</span>      } catch(ExecutionException e1) {<a name="line.1834"></a>
-<span class="sourceLineNo">1835</span>        LOG.warn("Could not check region consistency " , e1.getCause());<a name="line.1835"></a>
-<span class="sourceLineNo">1836</span>        if (e1.getCause() instanceof IOException) {<a name="line.1836"></a>
-<span class="sourceLineNo">1837</span>          throw (IOException)e1.getCause();<a name="line.1837"></a>
-<span class="sourceLineNo">1838</span>        } else if (e1.getCause() instanceof KeeperException) {<a name="line.1838"></a>
-<span class="sourceLineNo">1839</span>          throw (KeeperException)e1.getCause();<a name="line.1839"></a>
-<span class="sourceLineNo">1840</span>        } else if (e1.getCause() instanceof InterruptedException) {<a name="line.1840"></a>
-<span class="sourceLineNo">1841</span>          throw (InterruptedException)e1.getCause();<a name="line.1841"></a>
-<span class="sourceLineNo">1842</span>        } else {<a name="line.1842"></a>
-<span class="sourceLineNo">1843</span>          throw new IOException(e1.getCause());<a name="line.1843"></a>
-<span class="sourceLineNo">1844</span>        }<a name="line.1844"></a>
-<span class="sourceLineNo">1845</span>      }<a name="line.1845"></a>
-<span class="sourceLineNo">1846</span>    }<a name="line.1846"></a>
-<span class="sourceLineNo">1847</span>  }<a name="line.1847"></a>
-<span class="sourceLineNo">1848</span><a name="line.1848"></a>
-<span class="sourceLineNo">1849</span>  class CheckRegionConsistencyWorkItem implements Callable&lt;Void&gt; {<a name="line.1849"></a>
-<span class="sourceLineNo">1850</span>    private final String key;<a name="line.1850"></a>
-<span class="sourceLineNo">1851</span>    private final HbckRegionInfo hbi;<a name="line.1851"></a>
-<span class="sourceLineNo">1852</span><a name="line.1852"></a>
-<span class="sourceLineNo">1853</span>    CheckRegionConsistencyWorkItem(String key, HbckRegionInfo hbi) {<a name="line.1853"></a>
-<span class="sourceLineNo">1854</span>      this.key = key;<a name="line.1854"></a>
-<span class="sourceLineNo">1855</span>      this.hbi = hbi;<a name="line.1855"></a>
-<span class="sourceLineNo">1856</span>    }<a name="line.1856"></a>
-<span class="sourceLineNo">1857</span><a name="line.1857"></a>
-<span class="sourceLineNo">1858</span>    @Override<a name="line.1858"></a>
-<span class="sourceLineNo">1859</span>    public synchronized Void call() throws Exception {<a name="line.1859"></a>
-<span class="sourceLineNo">1860</span>      try {<a name="line.1860"></a>
-<span class="sourceLineNo">1861</span>        checkRegionConsistency(key, hbi);<a name="line.1861"></a>
-<span class="sourceLineNo">1862</span>      } catch (Exception e) {<a name="line.1862"></a>
-<span class="sourceLineNo">1863</span>        // If the region is non-META region, skip this region and send warning/error message; if<a name="line.1863"></a>
-<span class="sourceLineNo">1864</span>        // the region is META region, we should not continue.<a name="line.1864"></a>
-<span class="sourceLineNo">1865</span>        LOG.warn("Unable to complete check or repair the region '" + hbi.getRegionNameAsString()<a name="line.1865"></a>
-<span class="sourceLineNo">1866</span>          + "'.", e);<a name="line.1866"></a>
-<span class="sourceLineNo">1867</span>        if (hbi.getHdfsHRI().isMetaRegion()) {<a name="line.1867"></a>
-<span class="sourceLineNo">1868</span>          throw e;<a name="line.1868"></a>
-<span class="sourceLineNo">1869</span>        }<a name="line.1869"></a>
-<span class="sourceLineNo">1870</span>        LOG.warn("Skip region '" + hbi.getRegionNameAsString() + "'");<a name="line.1870"></a>
-<span class="sourceLineNo">1871</span>        addSkippedRegion(hbi);<a name="line.1871"></a>
-<span class="sourceLineNo">1872</span>      }<a name="line.1872"></a>
-<span class="sourceLineNo">1873</span>      return null;<a name="line.1873"></a>
-<span class="sourceLineNo">1874</span>    }<a name="line.1874"></a>
-<span class="sourceLineNo">1875</span>  }<a name="line.1875"></a>
-<span class="sourceLineNo">1876</span><a name="line.1876"></a>
-<span class="sourceLineNo">1877</span>  private void addSkippedRegion(final HbckRegionInfo hbi) {<a name="line.1877"></a>
-<span class="sourceLineNo">1878</span>    Set&lt;String&gt; skippedRegionNames = skippedRegions.get(hbi.getTableName());<a name="line.1878"></a>
-<span class="sourceLineNo">1879</span>    if (skippedRegionNames == null) {<a name="line.1879"></a>
-<span class="sourceLineNo">1880</span>      skippedRegionNames = new HashSet&lt;&gt;();<a name="line.1880"></a>
-<span class="sourceLineNo">1881</span>    }<a name="line.1881"></a>
-<span class="sourceLineNo">1882</span>    skippedRegionNames.add(hbi.getRegionNameAsString());<a name="line.1882"></a>
-<span class="sourceLineNo">1883</span>    skippedRegions.put(hbi.getTableName(), skippedRegionNames);<a name="line.1883"></a>
-<span class="sourceLineNo">1884</span>  }<a name="line.1884"></a>
-<span class="sourceLineNo">1885</span><a name="line.1885"></a>
-<span class="sourceLineNo">1886</span>  /**<a name="line.1886"></a>
-<span class="sourceLineNo">1887</span>   * Check and fix table states, assumes full info available:<a name="line.1887"></a>
-<span class="sourceLineNo">1888</span>   * - tableInfos<a name="line.1888"></a>
-<span class="sourceLineNo">1889</span>   * - empty tables loaded<a name="line.1889"></a>
-<span class="sourceLineNo">1890</span>   */<a name="line.1890"></a>
-<span class="sourceLineNo">1891</span>  private void checkAndFixTableStates() throws IOException {<a name="line.1891"></a>
-<span class="sourceLineNo">1892</span>    // first check dangling states<a name="line.1892"></a>
-<span class="sourceLineNo">1893</span>    for (Entry&lt;TableName, TableState&gt; entry : tableStates.entrySet()) {<a name="line.1893"></a>
-<span class="sourceLineNo">1894</span>      TableName tableName = entry.getKey();<a name="line.1894"></a>
-<span class="sourceLineNo">1895</span>      TableState tableState = entry.getValue();<a name="line.1895"></a>
-<span class="sourceLineNo">1896</span>      HbckTableInfo tableInfo = tablesInfo.get(tableName);<a name="line.1896"></a>
-<span class="sourceLineNo">1897</span>      if (isTableIncluded(tableName)<a name="line.1897"></a>
-<span class="sourceLineNo">1898</span>          &amp;&amp; !tableName.isSystemTable()<a name="line.1898"></a>
-<span class="sourceLineNo">1899</span>          &amp;&amp; tableInfo == null) {<a name="line.1899"></a>
-<span class="sourceLineNo">1900</span>        if (fixMeta) {<a name="line.1900"></a>
-<span class="sourceLineNo">1901</span>          MetaTableAccessor.deleteTableState(connection, tableName);<a name="line.1901"></a>
-<span class="sourceLineNo">1902</span>          TableState state = MetaTableAccessor.getTableState(connection, tableName);<a name="line.1902"></a>
-<span class="sourceLineNo">1903</span>          if (state != null) {<a name="line.1903"></a>
-<span class="sourceLineNo">1904</span>            errors.reportError(ERROR_CODE.ORPHAN_TABLE_STATE,<a name="line.1904"></a>
-<span class="sourceLineNo">1905</span>                tableName + " unable to delete dangling table state " + tableState);<a name="line.1905"></a>
-<span class="sourceLineNo">1906</span>          }<a name="line.1906"></a>
-<span class="sourceLineNo">1907</span>        } else if (!checkMetaOnly) {<a name="line.1907"></a>
-<span class="sourceLineNo">1908</span>          // dangling table state in meta if checkMetaOnly is false. If checkMetaOnly is<a name="line.1908"></a>
-<span class="sourceLineNo">1909</span>          // true, tableInfo will be null as tablesInfo are not polulated for all tables from hdfs<a name="line.1909"></a>
-<span class="sourceLineNo">1910</span>          errors.reportError(ERROR_CODE.ORPHAN_TABLE_STATE,<a name="line.1910"></a>
-<span class="sourceLineNo">1911</span>              tableName + " has dangling table state " + tableState);<a name="line.1911"></a>
-<span class="sourceLineNo">1912</span>        }<a name="line.1912"></a>
-<span class="sourceLineNo">1913</span>      }<a name="line.1913"></a>
-<span class="sourceLineNo">1914</span>    }<a name="line.1914"></a>
-<span class="sourceLineNo">1915</span>    // check that all tables have states<a name="line.1915"></a>
-<span class="sourceLineNo">1916</span>    for (TableName tableName : tablesInfo.keySet()) {<a name="line.1916"></a>
-<span class="sourceLineNo">1917</span>      if (isTableIncluded(tableName) &amp;&amp; !tableStates.containsKey(tableName)) {<a name="line.1917"></a>
-<span class="sourceLineNo">1918</span>        if (fixMeta) {<a name="line.1918"></a>
-<span class="sourceLineNo">1919</span>          MetaTableAccessor.updateTableState(connection, tableName, TableState.State.ENABLED);<a name="line.1919"></a>
-<span class="sourceLineNo">1920</span>          TableState newState = MetaTableAccessor.getTableState(connection, tableName);<a name="line.1920"></a>
-<span class="sourceLineNo">1921</span>          if (newState == null) {<a name="line.1921"></a>
-<span class="sourceLineNo">1922</span>            errors.reportError(ERROR_CODE.NO_TABLE_STATE,<a name="line.1922"></a>
-<span class="sourceLineNo">1923</span>                "Unable to change state for table " + tableName + " in meta ");<a name="line.1923"></a>
-<span class="sourceLineNo">1924</span>          }<a name="line.1924"></a>
-<span class="sourceLineNo">1925</span>        } else {<a name="line.1925"></a>
-<span class="sourceLineNo">1926</span>          errors.reportError(ERROR_CODE.NO_TABLE_STATE,<a name="line.1926"></a>
-<span class="sourceLineNo">1927</span>              tableName + " has no state in meta ");<a name="line.1927"></a>
-<span class="sourceLineNo">1928</span>        }<a name="line.1928"></a>
-<span class="sourceLineNo">1929</span>      }<a name="line.1929"></a>
-<span class="sourceLineNo">1930</span>    }<a name="line.1930"></a>
-<span class="sourceLineNo">1931</span>  }<a name="line.1931"></a>
-<span class="sourceLineNo">1932</span><a name="line.1932"></a>
-<span class="sourceLineNo">1933</span>  private void preCheckPermission() throws IOException, AccessDeniedException {<a name="line.1933"></a>
-<span class="sourceLineNo">1934</span>    if (shouldIgnorePreCheckPermission()) {<a name="line.1934"></a>
-<span class="sourceLineNo">1935</span>      return;<a name="line.1935"></a>
-<span class="sourceLineNo">1936</span>    }<a name="line.1936"></a>
-<span class="sourceLineNo">1937</span><a name="line.1937"></a>
-<span class="sourceLineNo">1938</span>    Path hbaseDir = FSUtils.getRootDir(getConf());<a name="line.1938"></a>
-<span class="sourceLineNo">1939</span>    FileSystem fs = hbaseDir.getFileSystem(getConf());<a name="line.1939"></a>
-<span class="sourceLineNo">1940</span>    UserProvider userProvider = UserProvider.instantiate(getConf());<a name="line.1940"></a>
-<span class="sourceLineNo">1941</span>    UserGroupInformation ugi = userProvider.getCurrent().getUGI();<a name="line.1941"></a>
-<span class="sourceLineNo">1942</span>    FileStatus[] files = fs.listStatus(hbaseDir);<a name="line.1942"></a>
-<span class="sourceLineNo">1943</span>    for (FileStatus file : files) {<a name="line.1943"></a>
-<span class="sourceLineNo">1944</span>      try {<a name="line.1944"></a>
-<span class="sourceLineNo">1945</span>        FSUtils.checkAccess(ugi, file, FsAction.WRITE);<a name="line.1945"></a>
-<span class="sourceLineNo">1946</span>      } catch (AccessDeniedException ace) {<a name="line.1946"></a>
-<span class="sourceLineNo">1947</span>        LOG.warn("Got AccessDeniedException when preCheckPermission ", ace);<a name="line.1947"></a>
-<span class="sourceLineNo">1948</span>        errors.reportError(ERROR_CODE.WRONG_USAGE, "Current user " + ugi.getUserName()<a name="line.1948"></a>
-<span class="sourceLineNo">1949</span>          + " does not have write perms to " + file.getPath()<a name="line.1949"></a>
-<span class="sourceLineNo">1950</span>          + ". Please rerun hbck as hdfs user " + file.getOwner());<a name="line.1950"></a>
-<span class="sourceLineNo">1951</span>        throw ace;<a name="line.1951"></a>
-<span class="sourceLineNo">1952</span>      }<a name="line.1952"></a>
-<span class="sourceLineNo">1953</span>    }<a name="line.1953"></a>
-<span class="sourceLineNo">1954</span>  }<a name="line.1954"></a>
-<span class="sourceLineNo">1955</span><a name="line.1955"></a>
-<span class="sourceLineNo">1956</span>  /**<a name="line.1956"></a>
-<span class="sourceLineNo">1957</span>   * Deletes region from meta table<a name="line.1957"></a>
-<span class="sourceLineNo">1958</span>   */<a name="line.1958"></a>
-<span class="sourceLineNo">1959</span>  private void deleteMetaRegion(HbckRegionInfo hi) throws IOException {<a name="line.1959"></a>
-<span class="sourceLineNo">1960</span>    deleteMetaRegion(hi.getMetaEntry().getRegionName());<a name="line.1960"></a>
-<span class="sourceLineNo">1961</span>  }<a name="line.1961"></a>
-<span class="sourceLineNo">1962</span><a name="line.1962"></a>
-<span class="sourceLineNo">1963</span>  /**<a name="line.1963"></a>
-<span class="sourceLineNo">1964</span>   * Deletes region from meta table<a name="line.1964"></a>
-<span class="sourceLineNo">1965</span>   */<a name="line.1965"></a>
-<span class="sourceLineNo">1966</span>  private void deleteMetaRegion(byte[] metaKey) throws IOException {<a name="line.1966"></a>
-<span class="sourceLineNo">1967</span>    Delete d = new Delete(metaKey);<a name="line.1967"></a>
-<span class="sourceLineNo">1968</span>    meta.delete(d);<a name="line.1968"></a>
-<span class="sourceLineNo">1969</span>    LOG.info("Deleted " + Bytes.toString(metaKey) + " from META" );<a name="line.1969"></a>
-<span class="sourceLineNo">1970</span>  }<a name="line.1970"></a>
-<span class="sourceLineNo">1971</span><a name="line.1971"></a>
-<span class="sourceLineNo">1972</span>  /**<a name="line.1972"></a>
-<span class="sourceLineNo">1973</span>   * Reset the split parent region info in meta table<a name="line.1973"></a>
-<span class="sourceLineNo">1974</span>   */<a name="line.1974"></a>
-<span class="sourceLineNo">1975</span>  private void resetSplitParent(HbckRegionInfo hi) throws IOException {<a name="line.1975"></a>
-<span class="sourceLineNo">1976</span>    RowMutations mutations = new RowMutations(hi.getMetaEntry().getRegionName());<a name="line.1976"></a>
-<span class="sourceLineNo">1977</span>    Delete d = new Delete(hi.getMetaEntry().getRegionName());<a name="line.1977"></a>
-<span class="sourceLineNo">1978</span>    d.addColumn(HConstants.CATALOG_FAMILY, HConstants.SPLITA_QUALIFIER);<a name="line.1978"></a>
-<span class="sourceLineNo">1979</span>    d.addColumn(HConstants.CATALOG_FAMILY, HConstants.SPLITB_QUALIFIER);<a name="line.1979"></a>
-<span class="sourceLineNo">1980</span>    mutations.add(d);<a name="line.1980"></a>
-<span class="sourceLineNo">1981</span><a name="line.1981"></a>
-<span class="sourceLineNo">1982</span>    RegionInfo hri = RegionInfoBuilder.newBuilder(hi.getMetaEntry())<a name="line.1982"></a>
-<span class="sourceLineNo">1983</span>        .setOffline(false)<a name="line.1983"></a>
-<span class="sourceLineNo">1984</span>        .setSplit(false)<a name="line.1984"></a>
-<span class="sourceLineNo">1985</span>        .build();<a name="line.1985"></a>
-<span class="sourceLineNo">1986</span>    Put p = MetaTableAccessor.makePutFromRegionInfo(hri, EnvironmentEdgeManager.currentTime());<a name="line.1986"></a>
-<span class="sourceLineNo">1987</span>    mutations.add(p);<a name="line.1987"></a>
-<span class="sourceLineNo">1988</span><a name="line.1988"></a>
-<span class="sourceLineNo">1989</span>    meta.mutateRow(mutations);<a name="line.1989"></a>
-<span class="sourceLineNo">1990</span>    LOG.info("Reset split parent " + hi.getMetaEntry().getRegionNameAsString() + " in META");<a name="line.1990"></a>
-<span class="sourceLineNo">1991</span>  }<a name="line.1991"></a>
-<span class="sourceLineNo">1992</span><a name="line.1992"></a>
-<span class="sourceLineNo">1993</span>  /**<a name="line.1993"></a>
-<span class="sourceLineNo">1994</span>   * This backwards-compatibility wrapper for permanently offlining a region<a name="line.1994"></a>
-<span class="sourceLineNo">1995</span>   * that should not be alive.  If the region server does not support the<a name="line.1995"></a>
-<span class="sourceLineNo">1996</span>   * "offline" method, it will use the closest unassign method instead.  This<a name="line.1996"></a>
-<span class="sourceLineNo">1997</span>   * will basically work until one attempts to disable or delete the affected<a name="line.1997"></a>
-<span class="sourceLineNo">1998</span>   * table.  The problem has to do with in-memory only master state, so<a name="line.1998"></a>
-<span class="sourceLineNo">1999</span>   * restarting the HMaster or failing over to another should fix this.<a name="line.1999"></a>
-<span class="sourceLineNo">2000</span>   */<a name="line.2000"></a>
-<span class="sourceLineNo">2001</span>  void offline(byte[] regionName) throws IOException {<a name="line.2001"></a>
-<span class="sourceLineNo">2002</span>    String regionString = Bytes.toStringBinary(regionName);<a name="line.2002"></a>
-<span class="sourceLineNo">2003</span>    if (!rsSupportsOffline) {<a name="line.2003"></a>
-<span class="sourceLineNo">2004</span>      LOG.warn(<a name="line.2004"></a>
-<span class="sourceLineNo">2005</span>          "Using unassign region " + regionString + " instead of using offline method, you should" +<a name="line.2005"></a>
-<span class="sourceLineNo">2006</span>              " restart HMaster after these repairs");<a name="line.2006"></a>
-<span class="sourceLineNo">2007</span>      admin.unassign(regionName, true);<a name="line.2007"></a>
-<span class="sourceLineNo">2008</span>      return;<a name="line.2008"></a>
-<span class="sourceLineNo">2009</span>    }<a name="line.2009"></a>
-<span class="sourceLineNo">2010</span><a name="line.2010"></a>
-<span class="sourceLineNo">2011</span>    // first time we assume the rs's supports #offline.<a name="line.2011"></a>
-<span class="sourceLineNo">2012</span>    try {<a name="line.2012"></a>
-<span class="sourceLineNo">2013</span>      LOG.info("Offlining region " + regionString);<a name="line.2013"></a>
-<span class="sourceLineNo">2014</span>      admin.offline(regionName);<a name="line.2014"></a>
-<span class="sourceLineNo">2015</span>    } catch (IOException ioe) {<a name="line.2015"></a>
-<span class="sourceLineNo">2016</span>      String notFoundMsg = "java.lang.NoSuchMethodException: " +<a name="line.2016"></a>
-<span class="sourceLineNo">2017</span>          "org.apache.hadoop.hbase.master.HMaster.offline([B)";<a name="line.2017"></a>
-<span class="sourceLineNo">2018</span>      if (ioe.getMessage().contains(notFoundMsg)) {<a name="line.2018"></a>
-<span class="sourceLineNo">2019</span>        LOG.warn("Using unassign region " + regionString +<a name="line.2019"></a>
-<span class="sourceLineNo">2020</span>            " instead of using offline method, you should" +<a name="line.2020"></a>
-<span class="sourceLineNo">2021</span>            " restart HMaster after these repairs");<a name="line.2021"></a>
-<span class="sourceLineNo">2022</span>        rsSupportsOffline = false; // in the future just use unassign<a name="line.2022"></a>
-<span class="sourceLineNo">2023</span>        admin.unassign(regionName, true);<a name="line.2023"></a>
-<span class="sourceLineNo">2024</span>        return;<a name="line.2024"></a>
-<span class="sourceLineNo">2025</span>      }<a name="line.2025"></a>
-<span class="sourceLineNo">2026</span>      throw ioe;<a name="line.2026"></a>
-<span class="sourceLineNo">2027</span>    }<a name="line.2027"></a>
-<span class="sourceLineNo">2028</span>  }<a name="line.2028"></a>
-<span class="sourceLineNo">2029</span><a name="line.2029"></a>
-<span class="sourceLineNo">2030</span>  /**<a name="line.2030"></a>
-<span class="sourceLineNo">2031</span>   * Attempts to undeploy a region from a region server based in information in<a name="line.2031"></a>
-<span class="sourceLineNo">2032</span>   * META.  Any operations that modify the file system should make sure that<a name="line.2032"></a>
-<span class="sourceLineNo">2033</span>   * its corresponding region is not deployed to prevent data races.<a name="line.2033"></a>
-<span class="sourceLineNo">2034</span>   *<a name="line.2034"></a>
-<span class="sourceLineNo">2035</span>   * A separate call is required to update the master in-memory region state<a name="line.2035"></a>
-<span class="sourceLineNo">2036</span>   * kept in the AssignementManager.  Because disable uses this state instead of<a name="line.2036"></a>
-<span class="sourceLineNo">2037</span>   * that found in META, we can't seem to cleanly disable/delete tables that<a name="line.2037"></a>
-<span class="sourceLineNo">2038</span>   * have been hbck fixed.  When used on a version of HBase that does not have<a name="line.2038"></a>
-<span class="sourceLineNo">2039</span>   * the offline ipc call exposed on the master (&amp;lt;0.90.5, &amp;lt;0.92.0) a master<a name="line.2039"></a>
-<span class="sourceLineNo">2040</span>   * restart or failover may be required.<a name="line.2040"></a>
-<span class="sourceLineNo">2041</span>   */<a name="line.2041"></a>
-<span class="sourceLineNo">2042</span>  void closeRegion(HbckRegionInfo hi) throws IOException, InterruptedException {<a name="line.2042"></a>
-<span class="sourceLineNo">2043</span>    if (hi.getMetaEntry() == null &amp;&amp; hi.getHdfsEntry() == null) {<a name="line.2043"></a>
-<span class="sourceLineNo">2044</span>      undeployRegions(hi);<a name="line.2044"></a>
-<span class="sourceLineNo">2045</span>      return;<a name="line.2045"></a>
-<span class="sourceLineNo">2046</span>    }<a name="line.2046"></a>
-<span class="sourceLineNo">2047</span><a name="line.2047"></a>
-<span class="sourceLineNo">2048</span>    // get assignment info and hregioninfo from meta.<a name="line.2048"></a>
-<span class="sourceLineNo">2049</span>    Get get = new Get(hi.getRegionName());<a name="line.2049"></a>
-<span class="sourceLineNo">2050</span>    get.addColumn(HConstants.CATALOG_FAMILY, HConstants.REGIONINFO_QUALIFIER);<a name="line.2050"></a>
-<span class="sourceLineNo">2051</span>    get.addColumn(HConstants.CATALOG_FAMILY, HConstants.SERVER_QUALIFIER);<a name="line.2051"></a>
-<span class="sourceLineNo">2052</span>    get.addColumn(HConstants.CATALOG_FAMILY, HConstants.STARTCODE_QUALIFIER);<a name="line.2052"></a>
-<span class="sourceLineNo">2053</span>    // also get the locations of the replicas to close if the primary region is being closed<a name="line.2053"></a>
-<span class="sourceLineNo">2054</span>    if (hi.getReplicaId() == RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.2054"></a>
-<span class="sourceLineNo">2055</span>      int numReplicas = admin.getDescriptor(hi.getTableName()).getRegionReplication();<a name="line.2055"></a>
-<span class="sourceLineNo">2056</span>      for (int i = 0; i &lt; numReplicas; i++) {<a name="line.2056"></a>
-<span class="sourceLineNo">2057</span>        get.addColumn(HConstants.CATALOG_FAMILY, MetaTableAccessor.getServerColumn(i));<a name="line.2057"></a>
-<span class="sourceLineNo">2058</span>        get.addColumn(HConstants.CATALOG_FAMILY, MetaTableAccessor.getStartCodeColumn(i));<a name="line.2058"></a>
-<span class="sourceLineNo">2059</span>      }<a name="line.2059"></a>
-<span class="sourceLineNo">2060</span>    }<a name="line.2060"></a>
-<span class="sourceLineNo">2061</span>    Result r = meta.get(get);<a name="line.2061"></a>
-<span class="sourceLineNo">2062</span>    RegionLocations rl = MetaTableAccessor.getRegionLocations(r);<a name="line.2062"></a>
-<span class="sourceLineNo">2063</span>    if (rl == null) {<a name="line.2063"></a>
-<span class="sourceLineNo">2064</span>      LOG.warn("Unable to close region " + hi.getRegionNameAsString() +<a name="line.2064"></a>
-<span class="sourceLineNo">2065</span>          " since meta does not have handle to reach it");<a name="line.2065"></a>
-<span class="sourceLineNo">2066</span>      return;<a name="line.2066"></a>
-<span class="sourceLineNo">2067</span>    }<a name="line.2067"></a>
-<span class="sourceLineNo">2068</span>    for (HRegionLocation h : rl.getRegionLocations()) {<a name="line.2068"></a>
-<span class="sourceLineNo">2069</span>      ServerName serverName = h.getServerName();<a name="line.2069"></a>
-<span class="sourceLineNo">2070</span>      if (serverName == null) {<a name="line.2070"></a>
-<span class="sourceLineNo">2071</span>        errors.reportError("Unable to close region "<a name="line.2071"></a>
-<span class="sourceLineNo">2072</span>            + hi.getRegionNameAsString() +  " because meta does not "<a name="line.2072"></a>
-<span class="sourceLineNo">2073</span>            + "have handle to reach it.");<a name="line.2073"></a>
-<span class="sourceLineNo">2074</span>        continue;<a name="line.2074"></a>
-<span class="sourceLineNo">2075</span>      }<a name="line.2075"></a>
-<span class="sourceLineNo">2076</span>      RegionInfo hri = h.getRegion();<a name="line.2076"></a>
-<span class="sourceLineNo">2077</span>      if (hri == null) {<a name="line.2077"></a>
-<span class="sourceLineNo">2078</span>        LOG.warn("Unable to close region " + hi.getRegionNameAsString()<a name="line.2078"></a>
-<span class="sourceLineNo">2079</span>            + " because hbase:meta had invalid or missing "<a name="line.2079"></a>
-<span class="sourceLineNo">2080</span>            + HConstants.CATALOG_FAMILY_STR + ":"<a name="line.2080"></a>
-<span class="sourceLineNo">2081</span>            + Bytes.toString(HConstants.REGIONINFO_QUALIFIER)<a name="line.2081"></a>
-<span class="sourceLineNo">2082</span>            + " qualifier value.");<a name="line.2082"></a>
-<span class="sourceLineNo">2083</span>        continue;<a name="line.2083"></a>
-<span class="sourceLineNo">2084</span>      }<a name="line.2084"></a>
-<span class="sourceLineNo">2085</span>      // close the region -- close files and remove assignment<a name="line.2085"></a>
-<span class="sourceLineNo">2086</span>      HBaseFsckRepair.closeRegionSilentlyAndWait(connection, serverName, hri);<a name="line.2086"></a>
-<span class="sourceLineNo">2087</span>    }<a name="line.2087"></a>
-<span class="sourceLineNo">2088</span>  }<a name="line.2088"></a>
-<span class="sourceLineNo">2089</span><a name="line.2089"></a>
-<span class="sourceLineNo">2090</span>  private void undeployRegions(HbckRegionInfo hi) throws IOException, InterruptedException {<a name="line.2090"></a>
-<span class="sourceLineNo">2091</span>    undeployRegionsForHbi(hi);<a name="line.2091"></a>
-<span class="sourceLineNo">2092</span>    // undeploy replicas of the region (but only if the method is invoked for the primary)<a name="line.2092"></a>
-<span class="sourceLineNo">2093</span>    if (hi.getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.2093"></a>
-<span class="sourceLineNo">2094</span>      return;<a name="line.2094"></a>
-<span class="sourceLineNo">2095</span>    }<a name="line.2095"></a>
-<span class="sourceLineNo">2096</span>    int numReplicas = admin.getDescriptor(hi.getTableName()).getRegionReplication();<a name="line.2096"></a>
-<span class="sourceLineNo">2097</span>    for (int i = 1; i &lt; numReplicas; i++) {<a name="line.2097"></a>
-<span class="sourceLineNo">2098</span>      if (hi.getPrimaryHRIForDeployedReplica() == null) continue;<a name="line.2098"></a>
-<span class="sourceLineNo">2099</span>      RegionInfo hri = RegionReplicaUtil.getRegionInfoForReplica(<a name="line.2099"></a>
-<span class="sourceLineNo">2100</span>          hi.getPrimaryHRIForDeployedReplica(), i);<a name="line.2100"></a>
-<span class="sourceLineNo">2101</span>      HbckRegionInfo h = regionInfoMap.get(hri.getEncodedName());<a name="line.2101"></a>
-<span class="sourceLineNo">2102</span>      if (h != null) {<a name="line.2102"></a>
-<span class="sourceLineNo">2103</span>        undeployRegionsForHbi(h);<a name="line.2103"></a>
-<span class="sourceLineNo">2104</span>        //set skip checks; we undeployed it, and we don't want to evaluate this anymore<a name="line.2104"></a>
-<span class="sourceLineNo">2105</span>        //in consistency checks<a name="line.2105"></a>
-<span class="sourceLineNo">2106</span>        h.setSkipChecks(true);<a name="line.2106"></a>
-<span class="sourceLineNo">2107</span>      }<a name="line.2107"></a>
-<span class="sourceLineNo">2108</span>    }<a name="line.2108"></a>
-<span class="sourceLineNo">2109</span>  }<a name="line.2109"></a>
-<span class="sourceLineNo">2110</span><a name="line.2110"></a>
-<span class="sourceLineNo">2111</span>  private void undeployRegionsForHbi(HbckRegionInfo hi) throws IOException, InterruptedException {<a name="line.2111"></a>
-<span class="sourceLineNo">2112</span>    for (HbckRegionInfo.OnlineEntry rse : hi.getOnlineEntries()) {<a name="line.2112"></a>
-<span class="sourceLineNo">2113</span>      LOG.debug("Undeploy region "  + rse.getRegionInfo() + " from " + rse.getServerName());<a name="line.2113"></a>
-<span class="sourceLineNo">2114</span>      try {<a name="line.2114"></a>
-<span class="sourceLineNo">2115</span>        HBaseFsckRepair<a name="line.2115"></a>
-<span class="sourceLineNo">2116</span>            .closeRegionSilentlyAndWait(connection, rse.getServerName(), rse.getRegionInfo());<a name="line.2116"></a>
-<span class="sourceLineNo">2117</span>        offline(rse.getRegionInfo().getRegionName());<a name="line.2117"></a>
-<span class="sourceLineNo">2118</span>      } catch (IOException ioe) {<a name="line.2118"></a>
-<span class="sourceLineNo">2119</span>        LOG.warn("Got exception when attempting to offline region "<a name="line.2119"></a>
-<span class="sourceLineNo">2120</span>            + Bytes.toString(rse.getRegionInfo().getRegionName()), ioe);<a name="line.2120"></a>
-<span class="sourceLineNo">2121</span>      }<a name="line.2121"></a>
-<span class="sourceLineNo">2122</span>    }<a name="line.2122"></a>
-<span class="sourceLineNo">2123</span>  }<a name="line.2123"></a>
-<span class="sourceLineNo">2124</span><a name="line.2124"></a>
-<span class="sourceLineNo">2125</span>  private void tryAssignmentRepair(HbckRegionInfo hbi, String msg) throws IOException,<a name="line.2125"></a>
-<span class="sourceLineNo">2126</span>    KeeperException, InterruptedException {<a name="line.2126"></a>
-<span class="sourceLineNo">2127</span>    // If we are trying to fix the errors<a name="line.2127"></a>
-<span class="sourceLineNo">2128</span>    if (shouldFixAssignments()) {<a name="line.2128"></a>
-<span class="sourceLineNo">2129</span>      errors.print(msg);<a name="line.2129"></a>
-<span class="sourceLineNo">2130</span>      undeployRegions(hbi);<a name="line.2130"></a>
-<span class="sourceLineNo">2131</span>      setShouldRerun();<a name="line.2131"></a>
-<span class="sourceLineNo">2132</span>      RegionInfo hri = hbi.getHdfsHRI();<a name="line.2132"></a>
-<span class="sourceLineNo">2133</span>      if (hri == null) {<a name="line.2133"></a>
-<span class="sourceLineNo">2134</span>        hri = hbi.getMetaEntry();<a name="line.2134"></a>
-<span class="sourceLineNo">2135</span>      }<a name="line.2135"></a>
-<span class="sourceLineNo">2136</span>      HBaseFsckRepair.fixUnassigned(admin, hri);<a name="line.2136"></a>
-<span class="sourceLineNo">2137</span>      HBaseFsckRepair.waitUntilAssigned(admin, hri);<a name="line.2137"></a>
-<span class="sourceLineNo">2138</span><a name="line.2138"></a>
-<span class="sourceLineNo">2139</span>      // also assign replicas if needed (do it only when this call operates on a primary replica)<a name="line.2139"></a>
-<span class="sourceLineNo">2140</span>      if (hbi.getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) return;<a name="line.2140"></a>
-<span class="sourceLineNo">2141</span>      int replicationCount = admin.getDescriptor(hri.getTable()).getRegionReplication();<a name="line.2141"></a>
-<span class="sourceLineNo">2142</span>      for (int i = 1; i &lt; replicationCount; i++) {<a name="line.2142"></a>
-<span class="sourceLineNo">2143</span>        hri = RegionReplicaUtil.getRegionInfoForReplica(hri, i);<a name="line.2143"></a>
-<span class="sourceLineNo">2144</span>        HbckRegionInfo h = regionInfoMap.get(hri.getEncodedName());<a name="line.2144"></a>
-<span class="sourceLineNo">2145</span>        if (h != null) {<a name="line.2145"></a>
-<span class="sourceLineNo">2146</span>          undeployRegions(h);<a name="line.2146"></a>
-<span class="sourceLineNo">2147</span>          //set skip checks; we undeploy &amp; deploy it; we don't want to evaluate this hbi anymore<a name="line.2147"></a>
-<span class="sourceLineNo">2148</span>          //in consistency checks<a name="line.2148"></a>
-<span class="sourceLineNo">2149</span>          h.setSkipChecks(true);<a name="line.2149"></a>
-<span class="sourceLineNo">2150</span>        }<a name="line.2150"></a>
-<span class="sourceLineNo">2151</span>        HBaseFsckRepair.fixUnassigned(admin, hri);<a name="line.2151"></a>
-<span class="sourceLineNo">2152</span>        HBaseFsckRepair.waitUntilAssigned(admin, hri);<a name="line.2152"></a>
-<span class="sourceLineNo">2153</span>      }<a name="line.2153"></a>
-<span class="sourceLineNo">2154</span><a name="line.2154"></a>
-<span class="sourceLineNo">2155</span>    }<a name="line.2155"></a>
-<span class="sourceLineNo">2156</span>  }<a name="line.2156"></a>
-<span class="sourceLineNo">2157</span><a name="line.2157"></a>
-<span class="sourceLineNo">2158</span>  /**<a name="line.2158"></a>
-<span class="sourceLineNo">2159</span>   * Check a single region for consistency and correct deployment.<a name="line.2159"></a>
-<span class="sourceLineNo">2160</span>   */<a name="line.2160"></a>
-<span class="sourceLineNo">2161</span>  private void checkRegionConsistency(final String key, final HbckRegionInfo hbi)<a name="line.2161"></a>
-<span class="sourceLineNo">2162</span>      throws IOException, KeeperException, InterruptedException {<a name="line.2162"></a>
-<span class="sourceLineNo">2163</span><a name="line.2163"></a>
-<span class="sourceLineNo">2164</span>    if (hbi.isSkipChecks()) return;<a name="line.2164"></a>
-<span class="sourceLineNo">2165</span>    String descriptiveName = hbi.toString();<a name="line.2165"></a>
-<span class="sourceLineNo">2166</span>    boolean inMeta = hbi.getMetaEntry() != null;<a name="line.2166"></a>
-<span class="sourceLineNo">2167</span>    // In case not checking HDFS, assume the region is on HDFS<a name="line.2167"></a>
-<span class="sourceLineNo">2168</span>    boolean inHdfs = !shouldCheckHdfs() || hbi.getHdfsRegionDir() != null;<a name="line.2168"></a>
-<span class="sourceLineNo">2169</span>    boolean hasMetaAssignment = inMeta &amp;&amp; hbi.getMetaEntry().regionServer != null;<a name="line.2169"></a>
-<span class="sourceLineNo">2170</span>    boolean isDeployed = !hbi.getDeployedOn().isEmpty();<a name="line.2170"></a>
-<span class="sourceLineNo">2171</span>    boolean isMultiplyDeployed = hbi.getDeployedOn().size() &gt; 1;<a name="line.2171"></a>
-<span class="sourceLineNo">2172</span>    boolean deploymentMatchesMeta =<a name="line.2172"></a>
-<span class="sourceLineNo">2173</span>      hasMetaAssignment &amp;&amp; isDeployed &amp;&amp; !isMultiplyDeployed &amp;&amp;<a name="line.2173"></a>
-<span class="sourceLineNo">2174</span>      hbi.getMetaEntry().regionServer.equals(hbi.getDeployedOn().get(0));<a name="line.2174"></a>
-<span class="sourceLineNo">2175</span>    boolean splitParent =<a name="line.2175"></a>
-<span class="sourceLineNo">2176</span>        inMeta &amp;&amp; hbi.getMetaEntry().isSplit() &amp;&amp; hbi.getMetaEntry().isOffline();<a name="line.2176"></a>
-<span class="sourceLineNo">2177</span>    boolean shouldBeDeployed = inMeta &amp;&amp; !isTableDisabled(hbi.getMetaEntry().getTable());<a name="line.2177"></a>
-<span class="sourceLineNo">2178</span>    boolean recentlyModified = inHdfs &amp;&amp;<a name="line.2178"></a>
-<span class="sourceLineNo">2179</span>      hbi.getModTime() + timelag &gt; EnvironmentEdgeManager.currentTime();<a name="line.2179"></a>
-<span class="sourceLineNo">2180</span><a name="line.2180"></a>
-<span class="sourceLineNo">2181</span>    // ========== First the healthy cases =============<a name="line.2181"></a>
-<span class="sourceLineNo">2182</span>    if (hbi.containsOnlyHdfsEdits()) {<a name="line.2182"></a>
-<span class="sourceLineNo">2183</span>      return;<a name="line.2183"></a>
-<span class="sourceLineNo">2184</span>    }<a name="line.2184"></a>
-<span class="sourceLineNo">2185</span>    if (inMeta &amp;&amp; inHdfs &amp;&amp; isDeployed &amp;&amp; deploymentMatchesMeta &amp;&amp; shouldBeDeployed) {<a name="line.2185"></a>
-<span class="sourceLineNo">2186</span>      return;<a name="line.2186"></a>
-<span class="sourceLineNo">2187</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; !shouldBeDeployed &amp;&amp; !isDeployed) {<a name="line.2187"></a>
-<span class="sourceLineNo">2188</span>      LOG.info("Region " + descriptiveName + " is in META, and in a disabled " +<a name="line.2188"></a>
-<span class="sourceLineNo">2189</span>        "tabled that is not deployed");<a name="line.2189"></a>
-<span class="sourceLineNo">2190</span>      return;<a name="line.2190"></a>
-<span class="sourceLineNo">2191</span>    } else if (recentlyModified) {<a name="line.2191"></a>
-<span class="sourceLineNo">2192</span>      LOG.warn("Region " + descriptiveName + " was recently modified -- skipping");<a name="line.2192"></a>
-<span class="sourceLineNo">2193</span>      return;<a name="line.2193"></a>
-<span class="sourceLineNo">2194</span>    }<a name="line.2194"></a>
-<span class="sourceLineNo">2195</span>    // ========== Cases where the region is not in hbase:meta =============<a name="line.2195"></a>
-<span class="sourceLineNo">2196</span>    else if (!inMeta &amp;&amp; !inHdfs &amp;&amp; !isDeployed) {<a name="line.2196"></a>
-<span class="sourceLineNo">2197</span>      // We shouldn't have record of this region at all then!<a name="line.2197"></a>
-<span class="sourceLineNo">2198</span>      assert false : "Entry for region with no data";<a name="line.2198"></a>
-<span class="sourceLineNo">2199</span>    } else if (!inMeta &amp;&amp; !inHdfs &amp;&amp; isDeployed) {<a name="line.2199"></a>
-<span class="sourceLineNo">2200</span>      errors.reportError(ERROR_CODE.NOT_IN_META_HDFS, "Region "<a name="line.2200"></a>
-<span class="sourceLineNo">2201</span>          + descriptiveName + ", key=" + key + ", not on HDFS or in hbase:meta but " +<a name="line.2201"></a>
-<span class="sourceLineNo">2202</span>          "deployed on " + Joiner.on(", ").join(hbi.getDeployedOn()));<a name="line.2202"></a>
-<span class="sourceLineNo">2203</span>      if (shouldFixAssignments()) {<a name="line.2203"></a>
-<span class="sourceLineNo">2204</span>        undeployRegions(hbi);<a name="line.2204"></a>
-<span class="sourceLineNo">2205</span>      }<a name="line.2205"></a>
-<span class="sourceLineNo">2206</span><a name="line.2206"></a>
-<span class="sourceLineNo">2207</span>    } else if (!inMeta &amp;&amp; inHdfs &amp;&amp; !isDeployed) {<a name="line.2207"></a>
-<span class="sourceLineNo">2208</span>      if (hbi.isMerged()) {<a name="line.2208"></a>
-<span class="sourceLineNo">2209</span>        // This region has already been merged, the remaining hdfs file will be<a name="line.2209"></a>
-<span class="sourceLineNo">2210</span>        // cleaned by CatalogJanitor later<a name="line.2210"></a>
-<span class="sourceLineNo">2211</span>        hbi.setSkipChecks(true);<a name="line.2211"></a>
-<span class="sourceLineNo">2212</span>        LOG.info("Region " + descriptiveName<a name="line.2212"></a>
-<span class="sourceLineNo">2213</span>            + " got merge recently, its file(s) will be cleaned by CatalogJanitor later");<a name="line.2213"></a>
-<span class="sourceLineNo">2214</span>        return;<a name="line.2214"></a>
-<span class="sourceLineNo">2215</span>      }<a name="line.2215"></a>
-<span class="sourceLineNo">2216</span>      errors.reportError(ERROR_CODE.NOT_IN_META_OR_DEPLOYED, "Region "<a name="line.2216"></a>
-<span class="sourceLineNo">2217</span>          + descriptiveName + " on HDFS, but not listed in hbase:meta " +<a name="line.2217"></a>
-<span class="sourceLineNo">2218</span>          "or deployed on any region server");<a name="line.2218"></a>
-<span class="sourceLineNo">2219</span>      // restore region consistency of an adopted orphan<a name="line.2219"></a>
-<span class="sourceLineNo">2220</span>      if (shouldFixMeta()) {<a name="line.2220"></a>
-<span class="sourceLineNo">2221</span>        if (!hbi.isHdfsRegioninfoPresent()) {<a name="line.2221"></a>
-<span class="sourceLineNo">2222</span>          LOG.error("Region " + hbi.getHdfsHRI() + " could have been repaired"<a name="line.2222"></a>
-<span class="sourceLineNo">2223</span>              +  " in table integrity repair phase if -fixHdfsOrphans was" +<a name="line.2223"></a>
-<span class="sourceLineNo">2224</span>              " used.");<a name="line.2224"></a>
-<span class="sourceLineNo">2225</span>          return;<a name="line.2225"></a>
-<span class="sourceLineNo">2226</span>        }<a name="line.2226"></a>
-<span class="sourceLineNo">2227</span><a name="line.2227"></a>
-<span class="sourceLineNo">2228</span>        RegionInfo hri = hbi.getHdfsHRI();<a name="line.2228"></a>
-<span class="sourceLineNo">2229</span>        HbckTableInfo tableInfo = tablesInfo.get(hri.getTable());<a name="line.2229"></a>
-<span class="sourceLineNo">2230</span><a name="line.2230"></a>
-<span class="sourceLineNo">2231</span>        for (RegionInfo region : tableInfo.getRegionsFromMeta(this.regionInfoMap)) {<a name="line.2231"></a>
-<span class="sourceLineNo">2232</span>          if (Bytes.compareTo(region.getStartKey(), hri.getStartKey()) &lt;= 0<a name="line.2232"></a>
-<span class="sourceLineNo">2233</span>              &amp;&amp; (region.getEndKey().length == 0 || Bytes.compareTo(region.getEndKey(),<a name="line.2233"></a>
-<span class="sourceLineNo">2234</span>                hri.getEndKey()) &gt;= 0)<a name="line.2234"></a>
-<span class="sourceLineNo">2235</span>              &amp;&amp; Bytes.compareTo(region.getStartKey(), hri.getEndKey()) &lt;= 0) {<a name="line.2235"></a>
-<span class="sourceLineNo">2236</span>            if(region.isSplit() || region.isOffline()) continue;<a name="line.2236"></a>
-<span class="sourceLineNo">2237</span>            Path regionDir = hbi.getHdfsRegionDir();<a name="line.2237"></a>
-<span class="sourceLineNo">2238</span>            FileSystem fs = regionDir.getFileSystem(getConf());<a name="line.2238"></a>
-<span class="sourceLineNo">2239</span>            List&lt;Path&gt; familyDirs = FSUtils.getFamilyDirs(fs, regionDir);<a name="line.2239"></a>
-<span class="sourceLineNo">2240</span>            for (Path familyDir : familyDirs) {<a name="line.2240"></a>
-<span class="sourceLineNo">2241</span>              List&lt;Path&gt; referenceFilePaths = FSUtils.getReferenceFilePaths(fs, familyDir);<a name="line.2241"></a>
-<span class="sourceLineNo">2242</span>              for (Path referenceFilePath : referenceFilePaths) {<a name="line.2242"></a>
-<span class="sourceLineNo">2243</span>                Path parentRegionDir =<a name="line.2243"></a>
-<span class="sourceLineNo">2244</span>                    StoreFileInfo.getReferredToFile(referenceFilePath).getParent().getParent();<a name="line.2244"></a>
-<span class="sourceLineNo">2245</span>                if (parentRegionDir.toString().endsWith(region.getEncodedName())) {<a name="line.2245"></a>
-<span class="sourceLineNo">2246</span>                  LOG.warn(hri + " start and stop keys are in the range of " + region<a name="line.2246"></a>
-<span class="sourceLineNo">2247</span>                      + ". The region might not be cleaned up from hdfs when region " + region<a name="line.2247"></a>
-<span class="sourceLineNo">2248</span>                      + " split failed. Hence deleting from hdfs.");<a name="line.2248"></a>
-<span class="sourceLineNo">2249</span>                  HRegionFileSystem.deleteRegionFromFileSystem(getConf(), fs,<a name="line.2249"></a>
-<span class="sourceLineNo">2250</span>                    regionDir.getParent(), hri);<a name="line.2250"></a>
-<span class="sourceLineNo">2251</span>                  return;<a name="line.2251"></a>
-<span class="sourceLineNo">2252</span>                }<a name="line.2252"></a>
-<span class="sourceLineNo">2253</span>              }<a name="line.2253"></a>
-<span class="sourceLineNo">2254</span>            }<a name="line.2254"></a>
-<span class="sourceLineNo">2255</span>          }<a name="line.2255"></a>
-<span class="sourceLineNo">2256</span>        }<a name="line.2256"></a>
-<span class="sourceLineNo">2257</span>        LOG.info("Patching hbase:meta with .regioninfo: " + hbi.getHdfsHRI());<a name="line.2257"></a>
-<span class="sourceLineNo">2258</span>        int numReplicas = admin.getDescriptor(hbi.getTableName()).getRegionReplication();<a name="line.2258"></a>
-<span class="sourceLineNo">2259</span>        HBaseFsckRepair.fixMetaHoleOnlineAndAddReplicas(getConf(), hbi.getHdfsHRI(),<a name="line.2259"></a>
-<span class="sourceLineNo">2260</span>            admin.getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.2260"></a>
-<span class="sourceLineNo">2261</span>              .getLiveServerMetrics().keySet(), numReplicas);<a name="line.2261"></a>
-<span class="sourceLineNo">2262</span><a name="line.2262"></a>
-<span class="sourceLineNo">2263</span>        tryAssignmentRepair(hbi, "Trying to reassign region...");<a name="line.2263"></a>
-<span class="sourceLineNo">2264</span>      }<a name="line.2264"></a>
-<span class="sourceLineNo">2265</span><a name="line.2265"></a>
-<span class="sourceLineNo">2266</span>    } else if (!inMeta &amp;&amp; inHdfs &amp;&amp; isDeployed) {<a name="line.2266"></a>
-<span class="sourceLineNo">2267</span>      errors.reportError(ERROR_CODE.NOT_IN_META, "Region " + descriptiveName<a name="line.2267"></a>
-<span class="sourceLineNo">2268</span>          + " not in META, but deployed on " + Joiner.on(", ").join(hbi.getDeployedOn()));<a name="line.2268"></a>
-<span class="sourceLineNo">2269</span>      debugLsr(hbi.getHdfsRegionDir());<a name="line.2269"></a>
-<span class="sourceLineNo">2270</span>      if (hbi.getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.2270"></a>
-<span class="sourceLineNo">2271</span>        // for replicas, this means that we should undeploy the region (we would have<a name="line.2271"></a>
-<span class="sourceLineNo">2272</span>        // gone over the primaries and fixed meta holes in first phase under<a name="line.2272"></a>
-<span class="sourceLineNo">2273</span>        // checkAndFixConsistency; we shouldn't get the condition !inMeta at<a name="line.2273"></a>
-<span class="sourceLineNo">2274</span>        // this stage unless unwanted replica)<a name="line.2274"></a>
-<span class="sourceLineNo">2275</span>        if (shouldFixAssignments()) {<a name="line.2275"></a>
-<span class="sourceLineNo">2276</span>          undeployRegionsForHbi(hbi);<a name="line.2276"></a>
-<span class="sourceLineNo">2277</span>        }<a name="line.2277"></a>
-<span class="sourceLineNo">2278</span>      }<a name="line.2278"></a>
-<span class="sourceLineNo">2279</span>      if (shouldFixMeta() &amp;&amp; hbi.getReplicaId() == RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.2279"></a>
-<span class="sourceLineNo">2280</span>        if (!hbi.isHdfsRegioninfoPresent()) {<a name="line.2280"></a>
-<span class="sourceLineNo">2281</span>          LOG.error("This should have been repaired in table integrity repair phase");<a name="line.2281"></a>
-<span class="sourceLineNo">2282</span>          return;<a name="line.2282"></a>
-<span class="sourceLineNo">2283</span>        }<a name="line.2283"></a>
-<span class="sourceLineNo">2284</span><a name="line.2284"></a>
-<span class="sourceLineNo">2285</span>        LOG.info("Patching hbase:meta with with .regioninfo: " + hbi.getHdfsHRI());<a name="line.2285"></a>
-<span class="sourceLineNo">2286</span>        int numReplicas = admin.getDescriptor(hbi.getTableName()).getRegionReplication();<a name="line.2286"></a>
-<span class="sourceLineNo">2287</span>        HBaseFsckRepair.fixMetaHoleOnlineAndAddReplicas(getConf(), hbi.getHdfsHRI(),<a name="line.2287"></a>
-<span class="sourceLineNo">2288</span>            admin.getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.2288"></a>
-<span class="sourceLineNo">2289</span>              .getLiveServerMetrics().keySet(), numReplicas);<a name="line.2289"></a>
-<span class="sourceLineNo">2290</span>        tryAssignmentRepair(hbi, "Trying to fix unassigned region...");<a name="line.2290"></a>
-<span class="sourceLineNo">2291</span>      }<a name="line.2291"></a>
-<span class="sourceLineNo">2292</span><a name="line.2292"></a>
-<span class="sourceLineNo">2293</span>    // ========== Cases where the region is in hbase:meta =============<a name="line.2293"></a>
-<span class="sourceLineNo">2294</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; !isDeployed &amp;&amp; splitParent) {<a name="line.2294"></a>
-<span class="sourceLineNo">2295</span>      // check whether this is an actual error, or just transient state where parent<a name="line.2295"></a>
-<span class="sourceLineNo">2296</span>      // is not cleaned<a name="line.2296"></a>
-<span class="sourceLineNo">2297</span>      if (hbi.getMetaEntry().splitA != null &amp;&amp; hbi.getMetaEntry().splitB != null) {<a name="line.2297"></a>
-<span class="sourceLineNo">2298</span>        // check that split daughters are there<a name="line.2298"></a>
-<span class="sourceLineNo">2299</span>        HbckRegionInfo infoA = this.regionInfoMap.get(hbi.getMetaEntry().splitA.getEncodedName());<a name="line.2299"></a>
-<span class="sourceLineNo">2300</span>        HbckRegionInfo infoB = this.regionInfoMap.get(hbi.getMetaEntry().splitB.getEncodedName());<a name="line.2300"></a>
-<span class="sourceLineNo">2301</span>        if (infoA != null &amp;&amp; infoB != null) {<a name="line.2301"></a>
-<span class="sourceLineNo">2302</span>          // we already processed or will process daughters. Move on, nothing to see here.<a name="line.2302"></a>
-<span class="sourceLineNo">2303</span>          hbi.setSkipChecks(true);<a name="line.2303"></a>
-<span class="sourceLineNo">2304</span>          return;<a name="line.2304"></a>
-<span class="sourceLineNo">2305</span>        }<a name="line.2305"></a>
-<span class="sourceLineNo">2306</span>      }<a name="line.2306"></a>
-<span class="sourceLineNo">2307</span><a name="line.2307"></a>
-<span class="sourceLineNo">2308</span>      // For Replica region, we need to do a similar check. If replica is not split successfully,<a name="line.2308"></a>
-<span class="sourceLineNo">2309</span>      // error is going to be reported against primary daughter region.<a name="line.2309"></a>
-<span class="sourceLineNo">2310</span>      if (hbi.getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.2310"></a>
-<span class="sourceLineNo">2311</span>        LOG.info("Region " + descriptiveName + " is a split parent in META, in HDFS, "<a name="line.2311"></a>
-<span class="sourceLineNo">2312</span>            + "and not deployed on any region server. This may be transient.");<a name="line.2312"></a>
-<span class="sourceLineNo">2313</span>        hbi.setSkipChecks(true);<a name="line.2313"></a>
-<span class="sourceLineNo">2314</span>        return;<a name="line.2314"></a>
-<span class="sourceLineNo">2315</span>      }<a name="line.2315"></a>
-<span class="sourceLineNo">2316</span><a name="line.2316"></a>
-<span class="sourceLineNo">2317</span>      errors.reportError(ERROR_CODE.LINGERING_SPLIT_PARENT, "Region "<a name="line.2317"></a>
-<span class="sourceLineNo">2318</span>          + descriptiveName + " is a split parent in META, in HDFS, "<a name="line.2318"></a>
-<span class="sourceLineNo">2319</span>          + "and not deployed on any region server. This could be transient, "<a name="line.2319"></a>
-<span class="sourceLineNo">2320</span>          + "consider to run the catalog janitor first!");<a name="line.2320"></a>
-<span class="sourceLineNo">2321</span>      if (shouldFixSplitParents()) {<a name="line.2321"></a>
-<span class="sourceLineNo">2322</span>        setShouldRerun();<a name="line.2322"></a>
-<span class="sourceLineNo">2323</span>        resetSplitParent(hbi);<a name="line.2323"></a>
-<span class="sourceLineNo">2324</span>      }<a name="line.2324"></a>
-<span class="sourceLineNo">2325</span>    } else if (inMeta &amp;&amp; !inHdfs &amp;&amp; !isDeployed) {<a name="line.2325"></a>
-<span class="sourceLineNo">2326</span>      errors.reportError(ERROR_CODE.NOT_IN_HDFS_OR_DEPLOYED, "Region "<a name="line.2326"></a>
-<span class="sourceLineNo">2327</span>          + descriptiveName + " found in META, but not in HDFS "<a name="line.2327"></a>
-<span class="sourceLineNo">2328</span>          + "or deployed on any region server.");<a name="line.2328"></a>
-<span class="sourceLineNo">2329</span>      if (shouldFixMeta()) {<a name="line.2329"></a>
-<span class="sourceLineNo">2330</span>        deleteMetaRegion(hbi);<a name="line.2330"></a>
-<span class="sourceLineNo">2331</span>      }<a name="line.2331"></a>
-<span class="sourceLineNo">2332</span>    } else if (inMeta &amp;&amp; !inHdfs &amp;&amp; isDeployed) {<a name="line.2332"></a>
-<span class="sourceLineNo">2333</span>      errors.reportError(ERROR_CODE.NOT_IN_HDFS, "Region " + descriptiveName<a name="line.2333"></a>
-<span class="sourceLineNo">2334</span>          + " found in META, but not in HDFS, " +<a name="line.2334"></a>
-<span class="sourceLineNo">2335</span>          "and deployed on " + Joiner.on(", ").join(hbi.getDeployedOn()));<a name="line.2335"></a>
-<span class="sourceLineNo">2336</span>      // We treat HDFS as ground truth.  Any information in meta is transient<a name="line.2336"></a>
-<span class="sourceLineNo">2337</span>      // and equivalent data can be regenerated.  So, lets unassign and remove<a name="line.2337"></a>
-<span class="sourceLineNo">2338</span>      // these problems from META.<a name="line.2338"></a>
-<span class="sourceLineNo">2339</span>      if (shouldFixAssignments()) {<a name="line.2339"></a>
-<span class="sourceLineNo">2340</span>        errors.print("Trying to fix unassigned region...");<a name="line.2340"></a>
-<span class="sourceLineNo">2341</span>        undeployRegions(hbi);<a name="line.2341"></a>
-<span class="sourceLineNo">2342</span>      }<a name="line.2342"></a>
-<span class="sourceLineNo">2343</span>      if (shouldFixMeta()) {<a name="line.2343"></a>
-<span class="sourceLineNo">2344</span>        // wait for it to complete<a name="line.2344"></a>
-<span class="sourceLineNo">2345</span>        deleteMetaRegion(hbi);<a name="line.2345"></a>
-<span class="sourceLineNo">2346</span>      }<a name="line.2346"></a>
-<span class="sourceLineNo">2347</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; !isDeployed &amp;&amp; shouldBeDeployed) {<a name="line.2347"></a>
-<span class="sourceLineNo">2348</span>      errors.reportError(ERROR_CODE.NOT_DEPLOYED, "Region " + descriptiveName<a name="line.2348"></a>
-<span class="sourceLineNo">2349</span>          + " not deployed on any region server.");<a name="line.2349"></a>
-<span class="sourceLineNo">2350</span>      tryAssignmentRepair(hbi, "Trying to fix unassigned region...");<a name="line.2350"></a>
-<span class="sourceLineNo">2351</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; isDeployed &amp;&amp; !shouldBeDeployed) {<a name="line.2351"></a>
-<span class="sourceLineNo">2352</span>      errors.reportError(ERROR_CODE.SHOULD_NOT_BE_DEPLOYED,<a name="line.2352"></a>
-<span class="sourceLineNo">2353</span>          "Region " + descriptiveName + " should not be deployed according " +<a name="line.2353"></a>
-<span class="sourceLineNo">2354</span>          "to META, but is deployed on " + Joiner.on(", ").join(hbi.getDeployedOn()));<a name="line.2354"></a>
-<span class="sourceLineNo">2355</span>      if (shouldFixAssignments()) {<a name="line.2355"></a>
-<span class="sourceLineNo">2356</span>        errors.print("Trying to close the region " + descriptiveName);<a name="line.2356"></a>
-<span class="sourceLineNo">2357</span>        setShouldRerun();<a name="line.2357"></a>
-<span class="sourceLineNo">2358</span>        HBaseFsckRepair.fixMultiAssignment(connection, hbi.getMetaEntry(), hbi.getDeployedOn());<a name="line.2358"></a>
-<span class="sourceLineNo">2359</span>      }<a name="line.2359"></a>
-<span class="sourceLineNo">2360</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; isMultiplyDeployed) {<a name="line.2360"></a>
-<span class="sourceLineNo">2361</span>      errors.reportError(ERROR_CODE.MULTI_DEPLOYED, "Region " + descriptiveName<a name="line.2361"></a>
-<span class="sourceLineNo">2362</span>          + " is listed in hbase:meta on region server " + hbi.getMetaEntry().regionServer<a name="line.2362"></a>
-<span class="sourceLineNo">2363</span>          + " but is multiply assigned to region servers " +<a name="line.2363"></a>
-<span class="sourceLineNo">2364</span>          Joiner.on(", ").join(hbi.getDeployedOn()));<a name="line.2364"></a>
-<span class="sourceLineNo">2365</span>      // If we are trying to fix the errors<a name="line.2365"></a>
-<span class="sourceLineNo">2366</span>      if (shouldFixAssignments()) {<a name="line.2366"></a>
-<span class="sourceLineNo">2367</span>        errors.print("Trying to fix assignment error...");<a name="line.2367"></a>
-<span class="sourceLineNo">2368</span>        setShouldRerun();<a name="line.2368"></a>
-<span class="sourceLineNo">2369</span>        HBaseFsckRepair.fixMultiAssignment(connection, hbi.getMetaEntry(), hbi.getDeployedOn());<a name="line.2369"></a>
-<span class="sourceLineNo">2370</span>      }<a name="line.2370"></a>
-<span class="sourceLineNo">2371</span>    } else if (inMeta &amp;&amp; inHdfs &amp;&amp; isDeployed &amp;&amp; !deploymentMatchesMeta) {<a name="line.2371"></a>
-<span class="sourceLineNo">2372</span>      errors.reportError(ERROR_CODE.SERVER_DOES_NOT_MATCH_META, "Region "<a name="line.2372"></a>
-<span class="sourceLineNo">2373</span>          + descriptiveName + " listed in hbase:meta on region server " +<a name="line.2373"></a>
-<span class="sourceLineNo">2374</span>          hbi.getMetaEntry().regionServer + " but found on region server " +<a name="line.2374"></a>
-<span class="sourceLineNo">2375</span>          hbi.getDeployedOn().get(0));<a name="line.2375"></a>
-<span class="sourceLineNo">2376</span>      // If we are trying to fix the errors<a name="line.2376"></a>
-<span class="sourceLineNo">2377</span>      if (shouldFixAssignments()) {<a name="line.2377"></a>
-<span class="sourceLineNo">2378</span>        errors.print("Trying to fix assignment error...");<a name="line.2378"></a>
-<span class="sourceLineNo">2379</span>        setShouldRerun();<a name="line.2379"></a>
-<span class="sourceLineNo">2380</span>        HBaseFsckRepair.fixMultiAssignment(connection, hbi.getMetaEntry(), hbi.getDeployedOn());<a name="line.2380"></a>
-<span class="sourceLineNo">2381</span>        HBaseFsckRepair.waitUntilAssigned(admin, hbi.getHdfsHRI());<a name="line.2381"></a>
-<span class="sourceLineNo">2382</span>      }<a name="line.2382"></a>
-<span class="sourceLineNo">2383</span>    } else {<a name="line.2383"></a>
-<span class="sourceLineNo">2384</span>      errors.reportError(ERROR_CODE.UNKNOWN, "Region " + descriptiveName +<a name="line.2384"></a>
-<span class="sourceLineNo">2385</span>          " is in an unforeseen state:" +<a name="line.2385"></a>
-<span class="sourceLineNo">2386</span>          " inMeta=" + inMeta +<a name="line.2386"></a>
-<span class="sourceLineNo">2387</span>          " inHdfs=" + inHdfs +<a name="line.2387"></a>
-<span class="sourceLineNo">2388</span>          " isDeployed=" + isDeployed +<a name="line.2388"></a>
-<span class="sourceLineNo">2389</span>          " isMultiplyDeployed=" + isMultiplyDeployed +<a name="line.2389"></a>
-<span class="sourceLineNo">2390</span>          " deploymentMatchesMeta=" + deploymentMatchesMeta +<a name="line.2390"></a>
-<span class="sourceLineNo">2391</span>          " shouldBeDeployed=" + shouldBeDeployed);<a name="line.2391"></a>
-<span class="sourceLineNo">2392</span>    }<a name="line.2392"></a>
-<span class="sourceLineNo">2393</span>  }<a name="line.2393"></a>
-<span class="sourceLineNo">2394</span><a name="line.2394"></a>
-<span class="sourceLineNo">2395</span>  /**<a name="line.2395"></a>
-<span class="sourceLineNo">2396</span>   * Checks tables integrity. Goes over all regions and scans the tables.<a name="line.2396"></a>
-<span class="sourceLineNo">2397</span>   * Collects all the pieces for each table and checks if there are missing,<a name="line.2397"></a>
-<span class="sourceLineNo">2398</span>   * repeated or overlapping ones.<a name="line.2398"></a>
-<span class="sourceLineNo">2399</span>   * @throws IOException<a name="line.2399"></a>
-<span class="sourceLineNo">2400</span>   */<a name="line.2400"></a>
-<span class="sourceLineNo">2401</span>  SortedMap&lt;TableName, HbckTableInfo&gt; checkIntegrity() throws IOException {<a name="line.2401"></a>
-<span class="sourceLineNo">2402</span>    tablesInfo = new TreeMap&lt;&gt;();<a name="line.2402"></a>
-<span class="sourceLineNo">2403</span>    LOG.debug("There are " + regionInfoMap.size() + " region info entries");<a name="line.2403"></a>
-<span class="sourceLineNo">2404</span>    for (HbckRegionInfo hbi : regionInfoMap.values()) {<a name="line.2404"></a>
-<span class="sourceLineNo">2405</span>      // Check only valid, working regions<a name="line.2405"></a>
-<span class="sourceLineNo">2406</span>      if (hbi.getMetaEntry() == null) {<a name="line.2406"></a>
-<span class="sourceLineNo">2407</span>        // this assumes that consistency check has run loadMetaEntry<a name="line.2407"></a>
-<span class="sourceLineNo">2408</span>        Path p = hbi.getHdfsRegionDir();<a name="line.2408"></a>
-<span class="sourceLineNo">2409</span>        if (p == null) {<a name="line.2409"></a>
-<span class="sourceLineNo">2410</span>          errors.report("No regioninfo in Meta or HDFS. " + hbi);<a name="line.2410"></a>
-<span class="sourceLineNo">2411</span>        }<a name="line.2411"></a>
-<span class="sourceLineNo">2412</span><a name="line.2412"></a>
-<span class="sourceLineNo">2413</span>        // TODO test.<a name="line.2413"></a>
-<span class="sourceLineNo">2414</span>        continue;<a name="line.2414"></a>
-<span class="sourceLineNo">2415</span>      }<a name="line.2415"></a>
-<span class="sourceLineNo">2416</span>      if (hbi.getMetaEntry().regionServer == null) {<a name="line.2416"></a>
-<span class="sourceLineNo">2417</span>        errors.detail("Skipping region because no region server: " + hbi);<a name="line.2417"></a>
-<span class="sourceLineNo">2418</span>        continue;<a name="line.2418"></a>
-<span class="sourceLineNo">2419</span>      }<a name="line.2419"></a>
-<span class="sourceLineNo">2420</span>      if (hbi.getMetaEntry().isOffline()) {<a name="line.2420"></a>
-<span class="sourceLineNo">2421</span>        errors.detail("Skipping region because it is offline: " + hbi);<a name="line.2421"></a>
-<span class="sourceLineNo">2422</span>        continue;<a name="line.2422"></a>
-<span class="sourceLineNo">2423</span>      }<a name="line.2423"></a>
-<span class="sourceLineNo">2424</span>      if (hbi.containsOnlyHdfsEdits()) {<a name="line.2424"></a>
-<span class="sourceLineNo">2425</span>        errors.detail("Skipping region because it only contains edits" + hbi);<a name="line.2425"></a>
-<span class="sourceLineNo">2426</span>        continue;<a name="line.2426"></a>
-<span class="sourceLineNo">2427</span>      }<a name="line.2427"></a>
-<span class="sourceLineNo">2428</span><a name="line.2428"></a>
-<span class="sourceLineNo">2429</span>      // Missing regionDir or over-deployment is checked elsewhere. Include<a name="line.2429"></a>
-<span class="sourceLineNo">2430</span>      // these cases in modTInfo, so we can evaluate those regions as part of<a name="line.2430"></a>
-<span class="sourceLineNo">2431</span>      // the region chain in META<a name="line.2431"></a>
-<span class="sourceLineNo">2432</span>      //if (hbi.foundRegionDir == null) continue;<a name="line.2432"></a>
-<span class="sourceLineNo">2433</span>      //if (hbi.deployedOn.size() != 1) continue;<a name="line.2433"></a>
-<span class="sourceLineNo">2434</span>      if (hbi.getDeployedOn().isEmpty()) {<a name="line.2434"></a>
-<span class="sourceLineNo">2435</span>        continue;<a name="line.2435"></a>
-<span class="sourceLineNo">2436</span>      }<a name="line.2436"></a>
-<span class="sourceLineNo">2437</span><a name="line.2437"></a>
-<span class="sourceLineNo">2438</span>      // We should be safe here<a name="line.2438"></a>
-<span class="sourceLineNo">2439</span>      TableName tableName = hbi.getMetaEntry().getTable();<a name="line.2439"></a>
-<span class="sourceLineNo">2440</span>      HbckTableInfo modTInfo = tablesInfo.get(tableName);<a name="line.2440"></a>
-<span class="sourceLineNo">2441</span>      if (modTInfo == null) {<a name="line.2441"></a>
-<span class="sourceLineNo">2442</span>        modTInfo = new HbckTableInfo(tableName, this);<a name="line.2442"></a>
-<span class="sourceLineNo">2443</span>      }<a name="line.2443"></a>
-<span class="sourceLineNo">2444</span>      for (ServerName server : hbi.getDeployedOn()) {<a name="line.2444"></a>
-<span class="sourceLineNo">2445</span>        modTInfo.addServer(server);<a name="line.2445"></a>
-<span class="sourceLineNo">2446</span>      }<a name="line.2446"></a>
-<span class="sourceLineNo">2447</span><a name="line.2447"></a>
-<span class="sourceLineNo">2448</span>      if (!hbi.isSkipChecks()) {<a name="line.2448"></a>
-<span class="sourceLineNo">2449</span>        modTInfo.addRegionInfo(hbi);<a name="line.2449"></a>
-<span class="sourceLineNo">2450</span>      }<a name="line.2450"></a>
-<span class="sourceLineNo">2451</span><a name="line.2451"></a>
-<span class="sourceLineNo">2452</span>      tablesInfo.put(tableName, modTInfo);<a name="line.2452"></a>
-<span class="sourceLineNo">2453</span>    }<a name="line.2453"></a>
-<span class="sourceLineNo">2454</span><a name="line.2454"></a>
-<span class="sourceLineNo">2455</span>    loadTableInfosForTablesWithNoRegion();<a name="line.2455"></a>
-<span class="sourceLineNo">2456</span><a name="line.2456"></a>
-<span class="sourceLineNo">2457</span>    logParallelMerge();<a name="line.2457"></a>
-<span class="sourceLineNo">2458</span>    for (HbckTableInfo tInfo : tablesInfo.values()) {<a name="line.2458"></a>
-<span class="sourceLineNo">2459</span>      TableIntegrityErrorHandler handler = tInfo.new IntegrityFixSuggester(tInfo, errors);<a name="line.2459"></a>
-<span class="sourceLineNo">2460</span>      if (!tInfo.checkRegionChain(handler)) {<a name="line.2460"></a>
-<span class="sourceLineNo">2461</span>        errors.report("Found inconsistency in table " + tInfo.getName());<a name="line.2461"></a>
-<span class="sourceLineNo">2462</span>      }<a name="line.2462"></a>
-<span class="sourceLineNo">2463</span>    }<a name="line.2463"></a>
-<span class="sourceLineNo">2464</span>    return tablesInfo;<a name="line.2464"></a>
-<span class="sourceLineNo">2465</span>  }<a name="line.2465"></a>
-<span class="sourceLineNo">2466</span><a name="line.2466"></a>
-<span class="sourceLineNo">2467</span>  /** Loads table info's for tables that may not have been included, since there are no<a name="line.2467"></a>
-<span class="sourceLineNo">2468</span>   * regions reported for the table, but table dir is there in hdfs<a name="line.2468"></a>
-<span class="sourceLineNo">2469</span>   */<a name="line.2469"></a>
-<span class="sourceLineNo">2470</span>  private void loadTableInfosForTablesWithNoRegion() throws IOException {<a name="line.2470"></a>
-<span class="sourceLineNo">2471</span>    Map&lt;String, TableDescriptor&gt; allTables = new FSTableDescriptors(getConf()).getAll();<a name="line.2471"></a>
-<span class="sourceLineNo">2472</span>    for (TableDescriptor htd : allTables.values()) {<a name="line.2472"></a>
-<span class="sourceLineNo">2473</span>      if (checkMetaOnly &amp;&amp; !htd.isMetaTable()) {<a name="line.2473"></a>
-<span class="sourceLineNo">2474</span>        continue;<a name="line.2474"></a>
-<span class="sourceLineNo">2475</span>      }<a name="line.2475"></a>
-<span class="sourceLineNo">2476</span><a name="line.2476"></a>
-<span class="sourceLineNo">2477</span>      TableName tableName = htd.getTableName();<a name="line.2477"></a>
-<span class="sourceLineNo">2478</span>      if (isTableIncluded(tableName) &amp;&amp; !tablesInfo.containsKey(tableName)) {<a name="line.2478"></a>
-<span class="sourceLineNo">2479</span>        HbckTableInfo tableInfo = new HbckTableInfo(tableName, this);<a name="line.2479"></a>
-<span class="sourceLineNo">2480</span>        tableInfo.htds.add(htd);<a name="line.2480"></a>
-<span class="sourceLineNo">2481</span>        tablesInfo.put(htd.getTableName(), tableInfo);<a name="line.2481"></a>
-<span class="sourceLineNo">2482</span>      }<a name="line.2482"></a>
-<span class="sourceLineNo">2483</span>    }<a name="line.2483"></a>
-<span class="sourceLineNo">2484</span>  }<a name="line.2484"></a>
-<span class="sourceLineNo">2485</span><a name="line.2485"></a>
-<span class="sourceLineNo">2486</span>  /**<a name="line.2486"></a>
-<span class="sourceLineNo">2487</span>   * Merge hdfs data by moving from contained HbckRegionInfo into targetRegionDir.<a name="line.2487"></a>
-<span class="sourceLineNo">2488</span>   * @return number of file move fixes done to merge regions.<a name="line.2488"></a>
-<span class="sourceLineNo">2489</span>   */<a name="line.2489"></a>
-<span class="sourceLineNo">2490</span>  public int mergeRegionDirs(Path targetRegionDir, HbckRegionInfo contained) throws IOException {<a name="line.2490"></a>
-<span class="sourceLineNo">2491</span>    int fileMoves = 0;<a name="line.2491"></a>
-<span class="sourceLineNo">2492</span>    String thread = Thread.currentThread().getName();<a name="line.2492"></a>
-<span class="sourceLineNo">2493</span>    LOG.debug("[" + thread + "] Contained region dir after close and pause");<a name="line.2493"></a>
-<span class="sourceLineNo">2494</span>    debugLsr(contained.getHdfsRegionDir());<a name="line.2494"></a>
-<span class="sourceLineNo">2495</span><a name="line.2495"></a>
-<span class="sourceLineNo">2496</span>    // rename the contained into the container.<a name="line.2496"></a>
-<span class="sourceLineNo">2497</span>    FileSystem fs = targetRegionDir.getFileSystem(getConf());<a name="line.2497"></a>
-<span class="sourceLineNo">2498</span>    FileStatus[] dirs = null;<a name="line.2498"></a>
-<span class="sourceLineNo">2499</span>    try {<a name="line.2499"></a>
-<span class="sourceLineNo">2500</span>      dirs = fs.listStatus(contained.getHdfsRegionDir());<a name="line.2500"></a>
-<span class="sourceLineNo">2501</span>    } catch (FileNotFoundException fnfe) {<a name="line.2501"></a>
-<span class="sourceLineNo">2502</span>      // region we are attempting to merge in is not present!  Since this is a merge, there is<a name="line.2502"></a>
-<span class="sourceLineNo">2503</span>      // no harm skipping this region if it does not exist.<a name="line.2503"></a>
-<span class="sourceLineNo">2504</span>      if (!fs.exists(contained.getHdfsRegionDir())) {<a name="line.2504"></a>
-<span class="sourceLineNo">2505</span>        LOG.warn("[" + thread + "] HDFS region dir " + contained.getHdfsRegionDir()<a name="line.2505"></a>
-<span class="sourceLineNo">2506</span>            + " is missing. Assuming already sidelined or moved.");<a name="line.2506"></a>
-<span class="sourceLineNo">2507</span>      } else {<a name="line.2507"></a>
-<span class="sourceLineNo">2508</span>        sidelineRegionDir(fs, contained);<a name="line.2508"></a>
-<span class="sourceLineNo">2509</span>      }<a name="line.2509"></a>
-<span class="sourceLineNo">2510</span>      return fileMoves;<a name="line.2510"></a>
-<span class="sourceLineNo">2511</span>    }<a name="line.2511"></a>
-<span class="sourceLineNo">2512</span><a name="line.2512"></a>
-<span class="sourceLineNo">2513</span>    if (dirs == null) {<a name="line.2513"></a>
-<span class="sourceLineNo">2514</span>      if (!fs.exists(contained.getHdfsRegionDir())) {<a name="line.2514"></a>
-<span class="sourceLineNo">2515</span>        LOG.warn("[" + thread + "] HDFS region dir " + contained.getHdfsRegionDir()<a name="line.2515"></a>
-<span class="sourceLineNo">2516</span>            + " already sidelined.");<a name="line.2516"></a>
-<span class="sourceLineNo">2517</span>      } else {<a name="line.2517"></a>
-<span class="sourceLineNo">2518</span>        sidelineRegionDir(fs, contained);<a name="line.2518"></a>
-<span class="sourceLineNo">2519</span>      }<a name="line.2519"></a>
-<span class="sourceLineNo">2520</span>      return fileMoves;<a name="line.2520"></a>
-<span class="sourceLineNo">2521</span>    }<a name="line.2521"></a>
-<span class="sourceLineNo">2522</span><a name="line.2522"></a>
-<span class="sourceLineNo">2523</span>    for (FileStatus cf : dirs) {<a name="line.2523"></a>
-<span class="sourceLineNo">2524</span>      Path src = cf.getPath();<a name="line.2524"></a>
-<span class="sourceLineNo">2525</span>      Path dst =  new Path(targetRegionDir, src.getName());<a name="line.2525"></a>
-<span class="sourceLineNo">2526</span><a name="line.2526"></a>
-<span class="sourceLineNo">2527</span>      if (src.getName().equals(HRegionFileSystem.REGION_INFO_FILE)) {<a name="line.2527"></a>
-<span class="sourceLineNo">2528</span>        // do not copy the old .regioninfo file.<a name="line.2528"></a>
-<span class="sourceLineNo">2529</span>        continue;<a name="line.2529"></a>
-<span class="sourceLineNo">2530</span>      }<a name="line.2530"></a>
-<span class="sourceLineNo">2531</span><a name="line.2531"></a>
-<span class="sourceLineNo">2532</span>      if (src.getName().equals(HConstants.HREGION_OLDLOGDIR_NAME)) {<a name="line.2532"></a>
-<span class="sourceLineNo">2533</span>        // do not copy the .oldlogs files<a name="line.2533"></a>
-<span class="sourceLineNo">2534</span>        continue;<a name="line.2534"></a>
-<span class="sourceLineNo">2535</span>      }<a name="line.2535"></a>
-<span class="sourceLineNo">2536</span><a name="line.2536"></a>
-<span class="sourceLineNo">2537</span>      LOG.info("[" + thread + "] Moving files from " + src + " into containing region " + dst);<a name="line.2537"></a>
-<span class="sourceLineNo">2538</span>      // FileSystem.rename is inconsistent with directories -- if the<a name="line.2538"></a>
-<span class="sourceLineNo">2539</span>      // dst (foo/a) exists and is a dir, and the src (foo/b) is a dir,<a name="line.2539"></a>
-<span class="sourceLineNo">2540</span>      // it moves the src into the dst dir resulting in (foo/a/b).  If<a name="line.2540"></a>
-<span class="sourceLineNo">2541</span>      // the dst does not exist, and the src a dir, src becomes dst. (foo/b)<a name="line.2541"></a>
-<span class="sourceLineNo">2542</span>      for (FileStatus hfile : fs.listStatus(src)) {<a name="line.2542"></a>
-<span class="sourceLineNo">2543</span>        boolean success = fs.rename(hfile.getPath(), dst);<a name="line.2543"></a>
-<span class="sourceLineNo">2544</span>        if (success) {<a name="line.2544"></a>
-<span class="sourceLineNo">2545</span>          fileMoves++;<a name="line.2545"></a>
-<span class="sourceLineNo">2546</span>        }<a name="line.2546"></a>
-<span class="sourceLineNo">2547</span>      }<a name="line.2547"></a>
-<span class="sourceLineNo">2548</span>      LOG.debug("[" + thread + "] Sideline directory contents:");<a name="line.2548"></a>
-<span class="sourceLineNo">2549</span>      debugLsr(targetRegionDir);<a name="line.2549"></a>
-<span class="sourceLineNo">2550</span>    }<a name="line.2550"></a>
-<span class="sourceLineNo">2551</span><a name="line.2551"></a>
-<span class="sourceLineNo">2552</span>    // if all success.<a name="line.2552"></a>
-<span class="sourceLineNo">2553</span>    sidelineRegionDir(fs, contained);<a name="line.2553"></a>
-<span class="sourceLineNo">2554</span>    LOG.info("[" + thread + "] Sidelined region dir "+ contained.getHdfsRegionDir() + " into " +<a name="line.2554"></a>
-<span class="sourceLineNo">2555</span>        getSidelineDir());<a name="line.2555"></a>
-<span class="sourceLineNo">2556</span>    debugLsr(contained.getHdfsRegionDir());<a name="line.2556"></a>
-<span class="sourceLineNo">2557</span><a name="line.2557"></a>
-<span class="sourceLineNo">2558</span>    return fileMoves;<a name="line.2558"></a>
-<span class="sourceLineNo">2559</span>  }<a name="line.2559"></a>
+<span class="sourceLineNo">1324</span>      // get table name from hdfs, populate various HBaseFsck tables.<a name="line.1324"></a>
+<span class="sourceLineNo">1325</span>      TableName tableName = hbi.getTableName();<a name="line.1325"></a>
+<span class="sourceLineNo">1326</span>      if (tableName == null) {<a name="line.1326"></a>
+<span class="sourceLineNo">1327</span>        // There was an entry in hbase:meta not in the HDFS?<a name="line.1327"></a>
+<span class="sourceLineNo">1328</span>        LOG.warn("tableName was null for: " + hbi);<a name="line.1328"></a>
+<span class="sourceLineNo">1329</span>        continue;<a name="line.1329"></a>
+<span class="sourceLineNo">1330</span>      }<a name="line.1330"></a>
+<span class="sourceLineNo">1331</span><a name="line.1331"></a>
+<span class="sourceLineNo">1332</span>      HbckTableInfo modTInfo = tablesInfo.get(tableName);<a name="line.1332"></a>
+<span class="sourceLineNo">1333</span>      if (modTInfo == null) {<a name="line.1333"></a>
+<span class="sourceLineNo">1334</span>        // only executed once per table.<a name="line.1334"></a>
+<span class="sourceLineNo">1335</span>        modTInfo = new HbckTableInfo(tableName, this);<a name="line.1335"></a>
+<span class="sourceLineNo">1336</span>        tablesInfo.put(tableName, modTInfo);<a name="line.1336"></a>
+<span class="sourceLineNo">1337</span>        try {<a name="line.1337"></a>
+<span class="sourceLineNo">1338</span>          TableDescriptor htd =<a name="line.1338"></a>
+<span class="sourceLineNo">1339</span>              FSTableDescriptors.getTableDescriptorFromFs(fs, hbaseRoot, tableName);<a name="line.1339"></a>
+<span class="sourceLineNo">1340</span>          modTInfo.htds.add(htd);<a name="line.1340"></a>
+<span class="sourceLineNo">1341</span>        } catch (IOException ioe) {<a name="line.1341"></a>
+<span class="sourceLineNo">1342</span>          if (!orphanTableDirs.containsKey(tableName)) {<a name="line.1342"></a>
+<span class="sourceLineNo">1343</span>            LOG.warn("Unable to read .tableinfo from " + hbaseRoot, ioe);<a name="line.1343"></a>
+<span class="sourceLineNo">1344</span>            //should only report once for each table<a name="line.1344"></a>
+<span class="sourceLineNo">1345</span>            errors.reportError(ERROR_CODE.NO_TABLEINFO_FILE,<a name="line.1345"></a>
+<span class="sourceLineNo">1346</span>                "Unable to read .tableinfo from " + hbaseRoot + "/" + tableName);<a name="line.1346"></a>
+<span class="sourceLineNo">1347</span>            Set&lt;String&gt; columns = new HashSet&lt;&gt;();<a name="line.1347"></a>
+<span class="sourceLineNo">1348</span>            orphanTableDirs.put(tableName, getColumnFamilyList(columns, hbi));<a name="line.1348"></a>
+<span class="sourceLineNo">1349</span>          }<a name="line.1349"></a>
+<span class="sourceLineNo">1350</span>        }<a name="line.1350"></a>
+<span class="sourceLineNo">1351</span>      }<a name="line.1351"></a>
+<span class="sourceLineNo">1352</span>      if (!hbi.isSkipChecks()) {<a name="line.1352"></a>
+<span class="sourceLineNo">1353</span>        modTInfo.addRegionInfo(hbi);<a name="line.1353"></a>
+<span class="sourceLineNo">1354</span>      }<a name="line.1354"></a>
+<span class="sourceLineNo">1355</span>    }<a name="line.1355"></a>
+<span class="sourceLineNo">1356</span><a name="line.1356"></a>
+<span class="sourceLineNo">1357</span>    loadTableInfosForTablesWithNoRegion();<a name="line.1357"></a>
+<span class="sourceLineNo">1358</span>    errors.print("");<a name="line.1358"></a>
+<span class="sourceLineNo">1359</span><a name="line.1359"></a>
+<span class="sourceLineNo">1360</span>    return tablesInfo;<a name="line.1360"></a>
+<span class="sourceLineNo">1361</span>  }<a name="line.1361"></a>
+<span class="sourceLineNo">1362</span><a name="line.1362"></a>
+<span class="sourceLineNo">1363</span>  /**<a name="line.1363"></a>
+<span class="sourceLineNo">1364</span>   * To get the column family list according to the column family dirs<a name="line.1364"></a>
+<span class="sourceLineNo">1365</span>   * @param columns<a name="line.1365"></a>
+<span class="sourceLineNo">1366</span>   * @param hbi<a name="line.1366"></a>
+<span class="sourceLineNo">1367</span>   * @return a set of column families<a name="line.1367"></a>
+<span class="sourceLineNo">1368</span>   * @throws IOException<a name="line.1368"></a>
+<span class="sourceLineNo">1369</span>   */<a name="line.1369"></a>
+<span class="sourceLineNo">1370</span>  private Set&lt;String&gt; getColumnFamilyList(Set&lt;String&gt; columns, HbckRegionInfo hbi)<a name="line.1370"></a>
+<span class="sourceLineNo">1371</span>      throws IOException {<a name="line.1371"></a>
+<span class="sourceLineNo">1372</span>    Path regionDir = hbi.getHdfsRegionDir();<a name="line.1372"></a>
+<span class="sourceLineNo">1373</span>    FileSystem fs = regionDir.getFileSystem(getConf());<a name="line.1373"></a>
+<span class="sourceLineNo">1374</span>    FileStatus[] subDirs = fs.listStatus(regionDir, new FSUtils.FamilyDirFilter(fs));<a name="line.1374"></a>
+<span class="sourceLineNo">1375</span>    for (FileStatus subdir : subDirs) {<a name="line.1375"></a>
+<span class="sourceLineNo">1376</span>      String columnfamily = subdir.getPath().getName();<a name="line.1376"></a>
+<span class="sourceLineNo">1377</span>      columns.add(columnfamily);<a name="line.1377"></a>
+<span class="sourceLineNo">1378</span>    }<a name="line.1378"></a>
+<span class="sourceLineNo">1379</span>    return columns;<a name="line.1379"></a>
+<span class="sourceLineNo">1380</span>  }<a name="line.1380"></a>
+<span class="sourceLineNo">1381</span><a name="line.1381"></a>
+<span class="sourceLineNo">1382</span>  /**<a name="line.1382"></a>
+<span class="sourceLineNo">1383</span>   * To fabricate a .tableinfo file with following contents&lt;br&gt;<a name="line.1383"></a>
+<span class="sourceLineNo">1384</span>   * 1. the correct tablename &lt;br&gt;<a name="line.1384"></a>
+<span class="sourceLineNo">1385</span>   * 2. the correct colfamily list&lt;br&gt;<a name="line.1385"></a>
+<span class="sourceLineNo">1386</span>   * 3. the default properties for both {@link TableDescriptor} and {@link ColumnFamilyDescriptor}&lt;br&gt;<a name="line.1386"></a>
+<span class="sourceLineNo">1387</span>   * @throws IOException<a name="line.1387"></a>
+<span class="sourceLineNo">1388</span>   */<a name="line.1388"></a>
+<span class="sourceLineNo">1389</span>  private boolean fabricateTableInfo(FSTableDescriptors fstd, TableName tableName,<a name="line.1389"></a>
+<span class="sourceLineNo">1390</span>      Set&lt;String&gt; columns) throws IOException {<a name="line.1390"></a>
+<span class="sourceLineNo">1391</span>    if (columns ==null || columns.isEmpty()) return false;<a name="line.1391"></a>
+<span class="sourceLineNo">1392</span>    TableDescriptorBuilder builder = TableDescriptorBuilder.newBuilder(tableName);<a name="line.1392"></a>
+<span class="sourceLineNo">1393</span>    for (String columnfamimly : columns) {<a name="line.1393"></a>
+<span class="sourceLineNo">1394</span>      builder.setColumnFamily(ColumnFamilyDescriptorBuilder.of(columnfamimly));<a name="line.1394"></a>
+<span class="sourceLineNo">1395</span>    }<a name="line.1395"></a>
+<span class="sourceLineNo">1396</span>    fstd.createTableDescriptor(builder.build(), true);<a name="line.1396"></a>
+<span class="sourceLineNo">1397</span>    return true;<a name="line.1397"></a>
+<span class="sourceLineNo">1398</span>  }<a name="line.1398"></a>
+<span class="sourceLineNo">1399</span><a name="line.1399"></a>
+<span class="sourceLineNo">1400</span>  /**<a name="line.1400"></a>
+<span class="sourceLineNo">1401</span>   * To fix the empty REGIONINFO_QUALIFIER rows from hbase:meta &lt;br&gt;<a name="line.1401"></a>
+<span class="sourceLineNo">1402</span>   * @throws IOException<a name="line.1402"></a>
+<span class="sourceLineNo">1403</span>   */<a name="line.1403"></a>
+<span class="sourceLineNo">1404</span>  public void fixEmptyMetaCells() throws IOException {<a name="line.1404"></a>
+<span class="sourceLineNo">1405</span>    if (shouldFixEmptyMetaCells() &amp;&amp; !emptyRegionInfoQualifiers.isEmpty()) {<a name="line.1405"></a>
+<span class="sourceLineNo">1406</span>      LOG.info("Trying to fix empty REGIONINFO_QUALIFIER hbase:meta rows.");<a name="line.1406"></a>
+<span class="sourceLineNo">1407</span>      for (Result region : emptyRegionInfoQualifiers) {<a name="line.1407"></a>
+<span class="sourceLineNo">1408</span>        deleteMetaRegion(region.getRow());<a name="line.1408"></a>
+<span class="sourceLineNo">1409</span>        errors.getErrorList().remove(ERROR_CODE.EMPTY_META_CELL);<a name="line.1409"></a>
+<span class="sourceLineNo">1410</span>      }<a name="line.1410"></a>
+<span class="sourceLineNo">1411</span>      emptyRegionInfoQualifiers.clear();<a name="line.1411"></a>
+<span class="sourceLineNo">1412</span>    }<a name="line.1412"></a>
+<span class="sourceLineNo">1413</span>  }<a name="line.1413"></a>
+<span class="sourceLineNo">1414</span><a name="line.1414"></a>
+<span class="sourceLineNo">1415</span>  /**<a name="line.1415"></a>
+<span class="sourceLineNo">1416</span>   * To fix orphan table by creating a .tableinfo file under tableDir &lt;br&gt;<a name="line.1416"></a>
+<span class="sourceLineNo">1417</span>   * 1. if TableInfo is cached, to recover the .tableinfo accordingly &lt;br&gt;<a name="line.1417"></a>
+<span class="sourceLineNo">1418</span>   * 2. else create a default .tableinfo file with following items&lt;br&gt;<a name="line.1418"></a>
+<span class="sourceLineNo">1419</span>   * &amp;nbsp;2.1 the correct tablename &lt;br&gt;<a name="line.1419"></a>
+<span class="sourceLineNo">1420</span>   * &amp;nbsp;2.2 the correct colfamily list&lt;br&gt;<a name="line.1420"></a>
+<span class="sourceLineNo">1421</span>   * &amp;nbsp;2.3 the default properties for both {@link TableDescriptor} and {@link ColumnFamilyDescriptor}&lt;br&gt;<a name="line.1421"></a>
+<span class="sourceLineNo">1422</span>   * @throws IOException<a name="line.1422"></a>
+<span class="sourceLineNo">1423</span>   */<a name="line.1423"></a>
+<span class="sourceLineNo">1424</span>  public void fixOrphanTables() throws IOException {<a name="line.1424"></a>
+<span class="sourceLineNo">1425</span>    if (shouldFixTableOrphans() &amp;&amp; !orphanTableDirs.isEmpty()) {<a name="line.1425"></a>
+<span class="sourceLineNo">1426</span><a name="line.1426"></a>
+<span class="sourceLineNo">1427</span>      List&lt;TableName&gt; tmpList = new ArrayList&lt;&gt;(orphanTableDirs.keySet().size());<a name="line.1427"></a>
+<span class="sourceLineNo">1428</span>      tmpList.addAll(orphanTableDirs.keySet());<a name="line.1428"></a>
+<span class="sourceLineNo">1429</span>      TableDescriptor[] htds = getTableDescriptors(tmpList);<a name="line.1429"></a>
+<span class="sourceLineNo">1430</span>      Iterator&lt;Entry&lt;TableName, Set&lt;String&gt;&gt;&gt; iter =<a name="line.1430"></a>
+<span class="sourceLineNo">1431</span>          orphanTableDirs.entrySet().iterator();<a name="line.1431"></a>
+<span class="sourceLineNo">1432</span>      int j = 0;<a name="line.1432"></a>
+<span class="sourceLineNo">1433</span>      int numFailedCase = 0;<a name="line.1433"></a>
+<span class="sourceLineNo">1434</span>      FSTableDescriptors fstd = new FSTableDescriptors(getConf());<a name="line.1434"></a>
+<span class="sourceLineNo">1435</span>      while (iter.hasNext()) {<a name="line.1435"></a>
+<span class="sourceLineNo">1436</span>        Entry&lt;TableName, Set&lt;String&gt;&gt; entry =<a name="line.1436"></a>
+<span class="sourceLineNo">1437</span>            iter.next();<a name="line.1437"></a>
+<span class="sourceLineNo">1438</span>        TableName tableName = entry.getKey();<a name="line.1438"></a>
+<span class="sourceLineNo">1439</span>        LOG.info("Trying to fix orphan table error: " + tableName);<a name="line.1439"></a>
+<span class="sourceLineNo">1440</span>        if (j &lt; htds.length) {<a name="line.1440"></a>
+<span class="sourceLineNo">1441</span>          if (tableName.equals(htds[j].getTableName())) {<a name="line.1441"></a>
+<span class="sourceLineNo">1442</span>            TableDescriptor htd = htds[j];<a name="line.1442"></a>
+<span class="sourceLineNo">1443</span>            LOG.info("fixing orphan table: " + tableName + " from cache");<a name="line.1443"></a>
+<span class="sourceLineNo">1444</span>            fstd.createTableDescriptor(htd, true);<a name="line.1444"></a>
+<span class="sourceLineNo">1445</span>            j++;<a name="line.1445"></a>
+<span class="sourceLineNo">1446</span>            iter.remove();<a name="line.1446"></a>
+<span class="sourceLineNo">1447</span>          }<a name="line.1447"></a>
+<span class="sourceLineNo">1448</span>        } else {<a name="line.1448"></a>
+<span class="sourceLineNo">1449</span>          if (fabricateTableInfo(fstd, tableName, entry.getValue())) {<a name="line.1449"></a>
+<span class="sourceLineNo">1450</span>            LOG.warn("fixing orphan table: " + tableName + " with a default .tableinfo file");<a name="line.1450"></a>
+<span class="sourceLineNo">1451</span>            LOG.warn("Strongly recommend to modify the TableDescriptor if necessary for: " + tableName);<a name="line.1451"></a>
+<span class="sourceLineNo">1452</span>            iter.remove();<a name="line.1452"></a>
+<span class="sourceLineNo">1453</span>          } else {<a name="line.1453"></a>
+<span class="sourceLineNo">1454</span>            LOG.error("Unable to create default .tableinfo for " + tableName + " while missing column family information");<a name="line.1454"></a>
+<span class="sourceLineNo">1455</span>            numFailedCase++;<a name="line.1455"></a>
+<span class="sourceLineNo">1456</span>          }<a name="line.1456"></a>
+<span class="sourceLineNo">1457</span>        }<a name="line.1457"></a>
+<span class="sourceLineNo">1458</span>        fixes++;<a name="line.1458"></a>
+<span class="sourceLineNo">1459</span>      }<a name="line.1459"></a>
+<span class="sourceLineNo">1460</span><a name="line.1460"></a>
+<span class="sourceLineNo">1461</span>      if (orphanTableDirs.isEmpty()) {<a name="line.1461"></a>
+<span class="sourceLineNo">1462</span>        // all orphanTableDirs are luckily recovered<a name="line.1462"></a>
+<span class="sourceLineNo">1463</span>        // re-run doFsck after recovering the .tableinfo file<a name="line.1463"></a>
+<span class="sourceLineNo">1464</span>        setShouldRerun();<a name="line.1464"></a>
+<span class="sourceLineNo">1465</span>        LOG.warn("Strongly recommend to re-run manually hfsck after all orphanTableDirs being fixed");<a name="line.1465"></a>
+<span class="sourceLineNo">1466</span>      } else if (numFailedCase &gt; 0) {<a name="line.1466"></a>
+<span class="sourceLineNo">1467</span>        LOG.error("Failed to fix " + numFailedCase<a name="line.1467"></a>
+<span class="sourceLineNo">1468</span>            + " OrphanTables with default .tableinfo files");<a name="line.1468"></a>
+<span class="sourceLineNo">1469</span>      }<a name="line.1469"></a>
+<span class="sourceLineNo">1470</span><a name="line.1470"></a>
+<span class="sourceLineNo">1471</span>    }<a name="line.1471"></a>
+<span class="sourceLineNo">1472</span>    //cleanup the list<a name="line.1472"></a>
+<span class="sourceLineNo">1473</span>    orphanTableDirs.clear();<a name="line.1473"></a>
+<span class="sourceLineNo">1474</span><a name="line.1474"></a>
+<span class="sourceLineNo">1475</span>  }<a name="line.1475"></a>
+<span class="sourceLineNo">1476</span><a name="line.1476"></a>
+<span class="sourceLineNo">1477</span>  /**<a name="line.1477"></a>
+<span class="sourceLineNo">1478</span>   * Log an appropriate message about whether or not overlapping merges are computed in parallel.<a name="line.1478"></a>
+<span class="sourceLineNo">1479</span>   */<a name="line.1479"></a>
+<span class="sourceLineNo">1480</span>  private void logParallelMerge() {<a name="line.1480"></a>
+<span class="sourceLineNo">1481</span>    if (getConf().getBoolean("hbasefsck.overlap.merge.parallel", true)) {<a name="line.1481"></a>
+<span class="sourceLineNo">1482</span>      LOG.info("Handling overlap merges in parallel. set hbasefsck.overlap.merge.parallel to" +<a name="line.1482"></a>
+<span class="sourceLineNo">1483</span>          " false to run serially.");<a name="line.1483"></a>
+<span class="sourceLineNo">1484</span>    } else {<a name="line.1484"></a>
+<span class="sourceLineNo">1485</span>      LOG.info("Handling overlap merges serially.  set hbasefsck.overlap.merge.parallel to" +<a name="line.1485"></a>
+<span class="sourceLineNo">1486</span>          " true to run in parallel.");<a name="line.1486"></a>
+<span class="sourceLineNo">1487</span>    }<a name="line.1487"></a>
+<span class="sourceLineNo">1488</span>  }<a name="line.1488"></a>
+<span class="sourceLineNo">1489</span><a name="line.1489"></a>
+<span class="sourceLineNo">1490</span>  private SortedMap&lt;TableName, HbckTableInfo&gt; checkHdfsIntegrity(boolean fixHoles,<a name="line.1490"></a>
+<span class="sourceLineNo">1491</span>      boolean fixOverlaps) throws IOException {<a name="line.1491"></a>
+<span class="sourceLineNo">1492</span>    LOG.info("Checking HBase region split map from HDFS data...");<a name="line.1492"></a>
+<span class="sourceLineNo">1493</span>    logParallelMerge();<a name="line.1493"></a>
+<span class="sourceLineNo">1494</span>    for (HbckTableInfo tInfo : tablesInfo.values()) {<a name="line.1494"></a>
+<span class="sourceLineNo">1495</span>      TableIntegrityErrorHandler handler;<a name="line.1495"></a>
+<span class="sourceLineNo">1496</span>      if (fixHoles || fixOverlaps) {<a name="line.1496"></a>
+<span class="sourceLineNo">1497</span>        handler = tInfo.new HDFSIntegrityFixer(tInfo, errors, getConf(),<a name="line.1497"></a>
+<span class="sourceLineNo">1498</span>          fixHoles, fixOverlaps);<a name="line.1498"></a>
+<span class="sourceLineNo">1499</span>      } else {<a name="line.1499"></a>
+<span class="sourceLineNo">1500</span>        handler = tInfo.new IntegrityFixSuggester(tInfo, errors);<a name="line.1500"></a>
+<span class="sourceLineNo">1501</span>      }<a name="line.1501"></a>
+<span class="sourceLineNo">1502</span>      if (!tInfo.checkRegionChain(handler)) {<a name="line.1502"></a>
+<span class="sourceLineNo">1503</span>        // should dump info as well.<a name="line.1503"></a>
+<span class="sourceLineNo">1504</span>        errors.report("Found inconsistency in table " + tInfo.getName());<a name="line.1504"></a>
+<span class="sourceLineNo">1505</span>      }<a name="line.1505"></a>
+<span class="sourceLineNo">1506</span>    }<a name="line.1506"></a>
+<span class="sourceLineNo">1507</span>    return tablesInfo;<a name="line.1507"></a>
+<span class="sourceLineNo">1508</span>  }<a name="line.1508"></a>
+<span class="sourceLineNo">1509</span><a name="line.1509"></a>
+<span class="sourceLineNo">1510</span>  Path getSidelineDir() throws IOException {<a name="line.1510"></a>
+<span class="sourceLineNo">1511</span>    if (sidelineDir == null) {<a name="line.1511"></a>
+<span class="sourceLineNo">1512</span>      Path hbaseDir = FSUtils.getRootDir(getConf());<a name="line.1512"></a>
+<span class="sourceLineNo">1513</span>      Path hbckDir = new Path(hbaseDir, HConstants.HBCK_SIDELINEDIR_NAME);<a name="line.1513"></a>
+<span class="sourceLineNo">1514</span>      sidelineDir = new Path(hbckDir, hbaseDir.getName() + "-"<a name="line.1514"></a>
+<span class="sourceLineNo">1515</span>          + startMillis);<a name="line.1515"></a>
+<span class="sourceLineNo">1516</span>    }<a name="line.1516"></a>
+<span class="sourceLineNo">1517</span>    return sidelineDir;<a name="line.1517"></a>
+<span class="sourceLineNo">1518</span>  }<a name="line.1518"></a>
+<span class="sourceLineNo">1519</span><a name="line.1519"></a>
+<span class="sourceLineNo">1520</span>  /**<a name="line.1520"></a>
+<span class="sourceLineNo">1521</span>   * Sideline a region dir (instead of deleting it)<a name="line.1521"></a>
+<span class="sourceLineNo">1522</span>   */<a name="line.1522"></a>
+<span class="sourceLineNo">1523</span>  Path sidelineRegionDir(FileSystem fs, HbckRegionInfo hi) throws IOException {<a name="line.1523"></a>
+<span class="sourceLineNo">1524</span>    return sidelineRegionDir(fs, null, hi);<a name="line.1524"></a>
+<span class="sourceLineNo">1525</span>  }<a name="line.1525"></a>
+<span class="sourceLineNo">1526</span><a name="line.1526"></a>
+<span class="sourceLineNo">1527</span>  /**<a name="line.1527"></a>
+<span class="sourceLineNo">1528</span>   * Sideline a region dir (instead of deleting it)<a name="line.1528"></a>
+<span class="sourceLineNo">1529</span>   *<a name="line.1529"></a>
+<span class="sourceLineNo">1530</span>   * @param parentDir if specified, the region will be sidelined to folder like<a name="line.1530"></a>
+<span class="sourceLineNo">1531</span>   *     {@literal .../parentDir/&lt;table name&gt;/&lt;region name&gt;}. The purpose is to group together<a name="line.1531"></a>
+<span class="sourceLineNo">1532</span>   *     similar regions sidelined, for example, those regions should be bulk loaded back later<a name="line.1532"></a>
+<span class="sourceLineNo">1533</span>   *     on. If NULL, it is ignored.<a name="line.1533"></a>
+<span class="sourceLineNo">1534</span>   */<a name="line.1534"></a>
+<span class="sourceLineNo">1535</span>  Path sidelineRegionDir(FileSystem fs,<a name="line.1535"></a>
+<span class="sourceLineNo">1536</span>      String parentDir, HbckRegionInfo hi) throws IOException {<a name="line.1536"></a>
+<span class="sourceLineNo">1537</span>    TableName tableName = hi.getTableName();<a name="line.1537"></a>
+<span class="sourceLineNo">1538</span>    Path regionDir = hi.getHdfsRegionDir();<a name="line.1538"></a>
+<span class="sourceLineNo">1539</span><a name="line.1539"></a>
+<span class="sourceLineNo">1540</span>    if (!fs.exists(regionDir)) {<a name="line.1540"></a>
+<span class="sourceLineNo">1541</span>      LOG.warn("No previous " + regionDir + " exists.  Continuing.");<a name="line.1541"></a>
+<span class="sourceLineNo">1542</span>      return null;<a name="line.1542"></a>
+<span class="sourceLineNo">1543</span>    }<a name="line.1543"></a>
+<span class="sourceLineNo">1544</span><a name="line.1544"></a>
+<span class="sourceLineNo">1545</span>    Path rootDir = getSidelineDir();<a name="line.1545"></a>
+<span class="sourceLineNo">1546</span>    if (parentDir != null) {<a name="line.1546"></a>
+<span class="sourceLineNo">1547</span>      rootDir = new Path(rootDir, parentDir);<a name="line.1547"></a>
+<span class="sourceLineNo">1548</span>    }<a name="line.1548"></a>
+<span class="sourceLineNo">1549</span>    Path sidelineTableDir= FSUtils.getTableDir(rootDir, tableName);<a name="line.1549"></a>
+<span class="sourceLineNo">1550</span>    Path sidelineRegionDir = new Path(sidelineTableDir, regionDir.getName());<a name="line.1550"></a>
+<span class="sourceLineNo">1551</span>    fs.mkdirs(sidelineRegionDir);<a name="line.1551"></a>
+<span class="sourceLineNo">1552</span>    boolean success = false;<a name="line.1552"></a>
+<span class="sourceLineNo">1553</span>    FileStatus[] cfs =  fs.listStatus(regionDir);<a name="line.1553"></a>
+<span class="sourceLineNo">1554</span>    if (cfs == null) {<a name="line.1554"></a>
+<span class="sourceLineNo">1555</span>      LOG.info("Region dir is empty: " + regionDir);<a name="line.1555"></a>
+<span class="sourceLineNo">1556</span>    } else {<a name="line.1556"></a>
+<span class="sourceLineNo">1557</span>      for (FileStatus cf : cfs) {<a name="line.1557"></a>
+<span class="sourceLineNo">1558</span>        Path src = cf.getPath();<a name="line.1558"></a>
+<span class="sourceLineNo">1559</span>        Path dst =  new Path(sidelineRegionDir, src.getName());<a name="line.1559"></a>
+<span class="sourceLineNo">1560</span>        if (fs.isFile(src)) {<a name="line.1560"></a>
+<span class="sourceLineNo">1561</span>          // simple file<a name="line.1561"></a>
+<span class="sourceLineNo">1562</span>          success = fs.rename(src, dst);<a name="line.1562"></a>
+<span class="sourceLineNo">1563</span>          if (!success) {<a name="line.1563"></a>
+<span class="sourceLineNo">1564</span>            String msg = "Unable to rename file " + src +  " to " + dst;<a name="line.1564"></a>
+<span class="sourceLineNo">1565</span>            LOG.error(msg);<a name="line.1565"></a>
+<span class="sourceLineNo">1566</span>            throw new IOException(msg);<a name="line.1566"></a>
+<span class="sourceLineNo">1567</span>          }<a name="line.1567"></a>
+<span class="sourceLineNo">1568</span>          continue;<a name="line.1568"></a>
+<span class="sourceLineNo">1569</span>        }<a name="line.1569"></a>
+<span class="sourceLineNo">1570</span><a name="line.1570"></a>
+<span class="sourceLineNo">1571</span>        // is a directory.<a name="line.1571"></a>
+<span class="sourceLineNo">1572</span>        fs.mkdirs(dst);<a name="line.1572"></a>
+<span class="sourceLineNo">1573</span><a name="line.1573"></a>
+<span class="sourceLineNo">1574</span>        LOG.info("Sidelining files from " + src + " into containing region " + dst);<a name="line.1574"></a>
+<span class="sourceLineNo">1575</span>        // FileSystem.rename is inconsistent with directories -- if the<a name="line.1575"></a>
+<span class="sourceLineNo">1576</span>        // dst (foo/a) exists and is a dir, and the src (foo/b) is a dir,<a name="line.1576"></a>
+<span class="sourceLineNo">1577</span>        // it moves the src into the dst dir resulting in (foo/a/b).  If<a name="line.1577"></a>
+<span class="sourceLineNo">1578</span>        // the dst does not exist, and the src a dir, src becomes dst. (foo/b)<a name="line.1578"></a>
+<span class="sourceLineNo">1579</span>        FileStatus[] hfiles = fs.listStatus(src);<a name="line.1579"></a>
+<span class="sourceLineNo">1580</span>        if (hfiles != null &amp;&amp; hfiles.length &gt; 0) {<a name="line.1580"></a>
+<span class="sourceLineNo">1581</span>          for (FileStatus hfile : hfiles) {<a name="line.1581"></a>
+<span class="sourceLineNo">1582</span>            success = fs.rename(hfile.getPath(), dst);<a name="line.1582"></a>
+<span class="sourceLineNo">1583</span>            if (!success) {<a name="line.1583"></a>
+<span class="sourceLineNo">1584</span>              String msg = "Unable to rename file " + src +  " to " + dst;<a name="line.1584"></a>
+<span class="sourceLineNo">1585</span>              LOG.error(msg);<a name="line.1585"></a>
+<span class="sourceLineNo">1586</span>              throw new IOException(msg);<a name="line.1586"></a>
+<span class="sourceLineNo">1587</span>            }<a name="line.1587"></a>
+<span class="sourceLineNo">1588</span>          }<a name="line.1588"></a>
+<span class="sourceLineNo">1589</span>        }<a name="line.1589"></a>
+<span class="sourceLineNo">1590</span>        LOG.debug("Sideline directory contents:");<a name="line.1590"></a>
+<span class="sourceLineNo">1591</span>        debugLsr(sidelineRegionDir);<a name="line.1591"></a>
+<span class="sourceLineNo">1592</span>      }<a name="line.1592"></a>
+<span class="sourceLineNo">1593</span>    }<a name="line.1593"></a>
+<span class="sourceLineNo">1594</span><a name="line.1594"></a>
+<span class="sourceLineNo">1595</span>    LOG.info("Removing old region dir: " + regionDir);<a name="line.1595"></a>
+<span class="sourceLineNo">1596</span>    success = fs.delete(regionDir, true);<a name="line.1596"></a>
+<span class="sourceLineNo">1597</span>    if (!success) {<a name="line.1597"></a>
+<span class="sourceLineNo">1598</span>      String msg = "Unable to delete dir " + regionDir;<a name="line.1598"></a>
+<span class="sourceLineNo">1599</span>      LOG.error(msg);<a name="line.1599"></a>
+<span class="sourceLineNo">1600</span>      throw new IOException(msg);<a name="line.1600"></a>
+<span class="sourceLineNo">1601</span>    }<a name="line.1601"></a>
+<span class="sourceLineNo">1602</span>    return sidelineRegionDir;<a name="line.1602"></a>
+<span class="sourceLineNo">1603</span>  }<a name="line.1603"></a>
+<span class="sourceLineNo">1604</span><a name="line.1604"></a>
+<span class="sourceLineNo">1605</span>  /**<a name="line.1605"></a>
+<span class="sourceLineNo">1606</span>   * Load the list of disabled tables in ZK into local set.<a name="line.1606"></a>
+<span class="sourceLineNo">1607</span>   * @throws ZooKeeperConnectionException<a name="line.1607"></a>
+<span class="sourceLineNo">1608</span>   * @throws IOException<a name="line.1608"></a>
+<span class="sourceLineNo">1609</span>   */<a name="line.1609"></a>
+<span class="sourceLineNo">1610</span>  private void loadTableStates()<a name="line.1610"></a>
+<span class="sourceLineNo">1611</span>  throws IOException {<a name="line.1611"></a>
+<span class="sourceLineNo">1612</span>    tableStates = MetaTableAccessor.getTableStates(connection);<a name="line.1612"></a>
+<span class="sourceLineNo">1613</span>    // Add hbase:meta so this tool keeps working. In hbase2, meta is always enabled though it<a name="line.1613"></a>
+<span class="sourceLineNo">1614</span>    // has no entry in the table states. HBCK doesn't work right w/ hbase2 but just do this in<a name="line.1614"></a>
+<span class="sourceLineNo">1615</span>    // meantime.<a name="line.1615"></a>
+<span class="sourceLineNo">1616</span>    this.tableStates.put(TableName.META_TABLE_NAME,<a name="line.1616"></a>
+<span class="sourceLineNo">1617</span>        new TableState(TableName.META_TABLE_NAME, TableState.State.ENABLED));<a name="line.1617"></a>
+<span class="sourceLineNo">1618</span>  }<a name="line.1618"></a>
+<span class="sourceLineNo">1619</span><a name="line.1619"></a>
+<span class="sourceLineNo">1620</span>  /**<a name="line.1620"></a>
+<span class="sourceLineNo">1621</span>   * Check if the specified region's table is disabled.<a name="line.1621"></a>
+<span class="sourceLineNo">1622</span>   * @param tableName table to check status of<a name="line.1622"></a>
+<span class="sourceLineNo">1623</span>   */<a name="line.1623"></a>
+<span class="sourceLineNo">1624</span>  boolean isTableDisabled(TableName tableName) {<a name="line.1624"></a>
+<span class="sourceLineNo">1625</span>    return tableStates.containsKey(tableName)<a name="line.1625"></a>
+<span class="sourceLineNo">1626</span>        &amp;&amp; tableStates.get(tableName)<a name="line.1626"></a>
+<span class="sourceLineNo">1627</span>        .inStates(TableState.State.DISABLED, TableState.State.DISABLING);<a name="line.1627"></a>
+<span class="sourceLineNo">1628</span>  }<a name="line.1628"></a>
+<span class="sourceLineNo">1629</span><a name="line.1629"></a>
+<span class="sourceLineNo">1630</span>  /**<a name="line.1630"></a>
+<span class="sourceLineNo">1631</span>   * Scan HDFS for all regions, recording their information into<a name="line.1631"></a>
+<span class="sourceLineNo">1632</span>   * regionInfoMap<a name="line.1632"></a>
+<span class="sourceLineNo">1633</span>   */<a name="line.1633"></a>
+<span class="sourceLineNo">1634</span>  public void loadHdfsRegionDirs() throws IOException, InterruptedException {<a name="line.1634"></a>
+<span class="sourceLineNo">1635</span>    Path rootDir = FSUtils.getRootDir(getConf());<a name="line.1635"></a>
+<span class="sourceLineNo">1636</span>    FileSystem fs = rootDir.getFileSystem(getConf());<a name="line.1636"></a>
+<span class="sourceLineNo">1637</span><a name="line.1637"></a>
+<span class="sourceLineNo">1638</span>    // list all tables from HDFS<a name="line.1638"></a>
+<span class="sourceLineNo">1639</span>    List&lt;FileStatus&gt; tableDirs = Lists.newArrayList();<a name="line.1639"></a>
+<span class="sourceLineNo">1640</span><a name="line.1640"></a>
+<span class="sourceLineNo">1641</span>    boolean foundVersionFile = fs.exists(new Path(rootDir, HConstants.VERSION_FILE_NAME));<a name="line.1641"></a>
+<span class="sourceLineNo">1642</span><a name="line.1642"></a>
+<span class="sourceLineNo">1643</span>    List&lt;Path&gt; paths = FSUtils.getTableDirs(fs, rootDir);<a name="line.1643"></a>
+<span class="sourceLineNo">1644</span>    for (Path path : paths) {<a name="line.1644"></a>
+<span class="sourceLineNo">1645</span>      TableName tableName = FSUtils.getTableName(path);<a name="line.1645"></a>
+<span class="sourceLineNo">1646</span>       if ((!checkMetaOnly &amp;&amp;<a name="line.1646"></a>
+<span class="sourceLineNo">1647</span>           isTableIncluded(tableName)) ||<a name="line.1647"></a>
+<span class="sourceLineNo">1648</span>           tableName.equals(TableName.META_TABLE_NAME)) {<a name="line.1648"></a>
+<span class="sourceLineNo">1649</span>         tableDirs.add(fs.getFileStatus(path));<a name="line.1649"></a>
+<span class="sourceLineNo">1650</span>       }<a name="line.1650"></a>
+<span class="sourceLineNo">1651</span>    }<a name="line.1651"></a>
+<span class="sourceLineNo">1652</span><a name="line.1652"></a>
+<span class="sourceLineNo">1653</span>    // verify that version file exists<a name="line.1653"></a>
+<span class="sourceLineNo">1654</span>    if (!foundVersionFile) {<a name="line.1654"></a>
+<span class="sourceLineNo">1655</span>      errors.reportError(ERROR_CODE.NO_VERSION_FILE,<a name="line.1655"></a>
+<span class="sourceLineNo">1656</span>          "Version file does not exist in root dir " + rootDir);<a name="line.1656"></a>
+<span class="sourceLineNo">1657</span>      if (shouldFixVersionFile()) {<a name="line.1657"></a>
+<span class="sourceLineNo">1658</span>        LOG.info("Trying to create a new " + HConstants.VERSION_FILE_NAME<a name="line.1658"></a>
+<span class="sourceLineNo">1659</span>            + " file.");<a name="line.1659"></a>
+<span class="sourceLineNo">1660</span>        setShouldRerun();<a name="line.1660"></a>
+<span class="sourceLineNo">1661</span>        FSUtils.setVersion(fs, rootDir, getConf().getInt(<a name="line.1661"></a>
+<span class="sourceLineNo">1662</span>            HConstants.THREAD_WAKE_FREQUENCY, 10 * 1000), getConf().getInt(<a name="line.1662"></a>
+<span class="sourceLineNo">1663</span>            HConstants.VERSION_FILE_WRITE_ATTEMPTS,<a name="line.1663"></a>
+<span class="sourceLineNo">1664</span>            HConstants.DEFAULT_VERSION_FILE_WRITE_ATTEMPTS));<a name="line.1664"></a>
+<span class="sourceLineNo">1665</span>      }<a name="line.1665"></a>
+<span class="sourceLineNo">1666</span>    }<a name="line.1666"></a>
+<span class="sourceLineNo">1667</span><a name="line.1667"></a>
+<span class="sourceLineNo">1668</span>    // Avoid multithreading at table-level because already multithreaded internally at<a name="line.1668"></a>
+<span class="sourceLineNo">1669</span>    // region-level.  Additionally multithreading at table-level can lead to deadlock<a name="line.1669"></a>
+<span class="sourceLineNo">1670</span>    // if there are many tables in the cluster.  Since there are a limited # of threads<a name="line.1670"></a>
+<span class="sourceLineNo">1671</span>    // in the executor's thread pool and if we multithread at the table-level by putting<a name="line.1671"></a>
+<span class="sourceLineNo">1672</span>    // WorkItemHdfsDir callables into the executor, then we will have some threads in the<a name="line.1672"></a>
+<span class="sourceLineNo">1673</span>    // executor tied up solely in waiting for the tables' region-level calls to complete.<a name="line.1673"></a>
+<span class="sourceLineNo">1674</span>    // If there are enough tables then there will be no actual threads in the pool left<a name="line.1674"></a>
+<span class="sourceLineNo">1675</span>    // for the region-level callables to be serviced.<a name="line.1675"></a>
+<span class="sourceLineNo">1676</span>    for (FileStatus tableDir : tableDirs) {<a name="line.1676"></a>
+<span class="sourceLineNo">1677</span>      LOG.debug("Loading region dirs from " +tableDir.getPath());<a name="line.1677"></a>
+<span class="sourceLineNo">1678</span>      WorkItemHdfsDir item = new WorkItemHdfsDir(fs, errors, tableDir);<a name="line.1678"></a>
+<span class="sourceLineNo">1679</span>      try {<a name="line.1679"></a>
+<span class="sourceLineNo">1680</span>        item.call();<a name="line.1680"></a>
+<span class="sourceLineNo">1681</span>      } catch (ExecutionException e) {<a name="line.1681"></a>
+<span class="sourceLineNo">1682</span>        LOG.warn("Could not completely load table dir " +<a name="line.1682"></a>
+<span class="sourceLineNo">1683</span>            tableDir.getPath(), e.getCause());<a name="line.1683"></a>
+<span class="sourceLineNo">1684</span>      }<a name="line.1684"></a>
+<span class="sourceLineNo">1685</span>    }<a name="line.1685"></a>
+<span class="sourceLineNo">1686</span>    errors.print("");<a name="line.1686"></a>
+<span class="sourceLineNo">1687</span>  }<a name="line.1687"></a>
+<span class="sourceLineNo">1688</span><a name="line.1688"></a>
+<span class="sourceLineNo">1689</span>  /**<a name="line.1689"></a>
+<span class="sourceLineNo">1690</span>   * Record the location of the hbase:meta region as found in ZooKeeper.<a name="line.1690"></a>
+<span class="sourceLineNo">1691</span>   */<a name="line.1691"></a>
+<span class="sourceLineNo">1692</span>  private boolean recordMetaRegion() throws IOException {<a name="line.1692"></a>
+<span class="sourceLineNo">1693</span>    List&lt;HRegionLocation&gt; locs;<a name="line.1693"></a>
+<span class="sourceLineNo">1694</span>    try (RegionLocator locator = connection.getRegionLocator(TableName.META_TABLE_NAME)) {<a name="line.1694"></a>
+<span class="sourceLineNo">1695</span>      locs = locator.getRegionLocations(HConstants.EMPTY_START_ROW, true);<a name="line.1695"></a>
+<span class="sourceLineNo">1696</span>    }<a name="line.1696"></a>
+<span class="sourceLineNo">1697</span>    if (locs == null || locs.isEmpty()) {<a name="line.1697"></a>
+<span class="sourceLineNo">1698</span>      errors.reportError(ERROR_CODE.NULL_META_REGION, "META region was not found in ZooKeeper");<a name="line.1698"></a>
+<span class="sourceLineNo">1699</span>      return false;<a name="line.1699"></a>
+<span class="sourceLineNo">1700</span>    }<a name="line.1700"></a>
+<span class="sourceLineNo">1701</span>    for (HRegionLocation metaLocation : locs) {<a name="line.1701"></a>
+<span class="sourceLineNo">1702</span>      // Check if Meta region is valid and existing<a name="line.1702"></a>
+<span class="sourceLineNo">1703</span>      if (metaLocation == null) {<a name="line.1703"></a>
+<span class="sourceLineNo">1704</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META region location is null");<a name="line.1704"></a>
+<span class="sourceLineNo">1705</span>        return false;<a name="line.1705"></a>
+<span class="sourceLineNo">1706</span>      }<a name="line.1706"></a>
+<span class="sourceLineNo">1707</span>      if (metaLocation.getRegion() == null) {<a name="line.1707"></a>
+<span class="sourceLineNo">1708</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META location regionInfo is null");<a name="line.1708"></a>
+<span class="sourceLineNo">1709</span>        return false;<a name="line.1709"></a>
+<span class="sourceLineNo">1710</span>      }<a name="line.1710"></a>
+<span class="sourceLineNo">1711</span>      if (metaLocation.getHostname() == null) {<a name="line.1711"></a>
+<span class="sourceLineNo">1712</span>        errors.reportError(ERROR_CODE.NULL_META_REGION, "META location hostName is null");<a name="line.1712"></a>
+<span class="sourceLineNo">1713</span>        return false;<a name="line.1713"></a>
+<span class="sourceLineNo">1714</span>      }<a name="line.1714"></a>
+<span class="sourceLineNo">1715</span>      ServerName sn = metaLocation.getServerName();<a name="line.1715"></a>
+<span class="sourceLineNo">1716</span>      HbckRegionInfo.MetaEntry m = new HbckRegionInfo.MetaEntry(metaLocation.getRegion(), sn,<a name="line.1716"></a>
+<span class="sourceLineNo">1717</span>          EnvironmentEdgeManager.currentTime());<a name="line.1717"></a>
+<span class="sourceLineNo">1718</span>      HbckRegionInfo hbckRegionInfo = regionInfoMap.get(metaLocation.getRegion().getEncodedName());<a name="line.1718"></a>
+<span class="sourceLineNo">1719</span>      if (hbckRegionInfo == null) {<a name="line.1719"></a>
+<span class="sourceLineNo">1720</span>        regionInfoMap.put(metaLocation.getRegion().getEncodedName(), new HbckRegionInfo(m));<a name="line.1720"></a>
+<span class="sourceLineNo">1721</span>      } else {<a name="line.1721"></a>
+<span class="sourceLineNo">1722</span>        hbckRegionInfo.setMetaEntry(m);<a name="line.1722"></a>
+<span class="sourceLineNo">1723</span>      }<a name="line.1723"></a>
+<span class="sourceLineNo">1724</span>    }<a name="line.1724"></a>
+<span class="sourceLineNo">1725</span>    return true;<a name="line.1725"></a>
+<span class="sourceLineNo">1726</span>  }<a name="line.1726"></a>
+<span class="sourceLineNo">1727</span><a name="line.1727"></a>
+<span class="sourceLineNo">1728</span>  private ZKWatcher createZooKeeperWatcher() throws IOException {<a name="line.1728"></a>
+<span class="sourceLineNo">1729</span>    return new ZKWatcher(getConf(), "hbase Fsck", new Abortable() {<a name="line.1729"></a>
+<span class="sourceLineNo">1730</span>      @Override<a name="line.1730"></a>
+<span class="sourceLineNo">1731</span>      public void abort(String why, Throwable e) {<a name="line.1731"></a>
+<span class="sourceLineNo">1732</span>        LOG.error(why, e);<a name="line.1732"></a>
+<span class="sourceLineNo">1733</span>        System.exit(1);<a name="line.1733"></a>
+<span class="sourceLineNo">1734</span>      }<a name="line.1734"></a>
+<span class="sourceLineNo">1735</span><a name="line.1735"></a>
+<span class="sourceLineNo">1736</span>      @Override<a name="line.1736"></a>
+<span class="sourceLineNo">1737</span>      public boolean isAborted() {<a name="line.1737"></a>
+<span class="sourceLineNo">1738</span>        return false;<a name="line.1738"></a>
+<span class="sourceLineNo">1739</span>      }<a name="line.1739"></a>
+<span class="sourceLineNo">1740</span><a name="line.1740"></a>
+<span class="sourceLineNo">1741</span>    });<a name="line.1741"></a>
+<span class="sourceLineNo">1742</span>  }<a name="line.1742"></a>
+<span class="sourceLineNo">1743</span><a name="line.1743"></a>
+<span class="sourceLineNo">1744</span>  /**<a name="line.1744"></a>
+<span class="sourceLineNo">1745</span>   * Contacts each regionserver and fetches metadata about regions.<a name="line.1745"></a>
+<span class="sourceLineNo">1746</span>   * @param regionServerList - the list of region servers to connect to<a name="line.1746"></a>
+<span class="sourceLineNo">1747</span>   * @throws IOException if a remote or network exception occurs<a name="line.1747"></a>
+<span class="sourceLineNo">1748</span>   */<a name="line.1748"></a>
+<span class="sourceLineNo">1749</span>  void processRegionServers(Collection&lt;ServerName&gt; regionServerList)<a name="line.1749"></a>
+<span class="sourceLineNo">1750</span>    throws IOException, InterruptedException {<a name="line.1750"></a>
+<span class="sourceLineNo">1751</span><a name="line.1751"></a>
+<span class="sourceLineNo">1752</span>    List&lt;WorkItemRegion&gt; workItems = new ArrayList&lt;&gt;(regionServerList.size());<a name="line.1752"></a>
+<span class="sourceLineNo">1753</span>    List&lt;Future&lt;Void&gt;&gt; workFutures;<a name="line.1753"></a>
+<span class="sourceLineNo">1754</span><a name="line.1754"></a>
+<span class="sourceLineNo">1755</span>    // loop to contact each region server in parallel<a name="line.1755"></a>
+<span class="sourceLineNo">1756</span>    for (ServerName rsinfo: regionServerList) {<a name="line.1756"></a>
+<span class="sourceLineNo">1757</span>      workItems.add(new WorkItemRegion(this, rsinfo, errors, connection));<a name="line.1757"></a>
+<span class="sourceLineNo">1758</span>    }<a name="line.1758"></a>
+<span class="sourceLineNo">1759</span><a name="line.1759"></a>
+<span class="sourceLineNo">1760</span>    workFutures = executor.invokeAll(workItems);<a name="line.1760"></a>
+<span class="sourceLineNo">1761</span><a name="line.1761"></a>
+<span class="sourceLineNo">1762</span>    for(int i=0; i&lt;workFutures.size(); i++) {<a name="line.1762"></a>
+<span class="sourceLineNo">1763</span>      WorkItemRegion item = workItems.get(i);<a name="line.1763"></a>
+<span class="sourceLineNo">1764</span>      Future&lt;Void&gt; f = workFutures.get(i);<a name="line.1764"></a>
+<span class="sourceLineNo">1765</span>      try {<a name="line.1765"></a>
+<span class="sourceLineNo">1766</span>        f.get();<a name="line.1766"></a>
+<span class="sourceLineNo">1767</span>      } catch(ExecutionException e) {<a name="line.1767"></a>
+<span class="sourceLineNo">1768</span>        LOG.warn("Could not process regionserver " + item.rsinfo.getHostAndPort(),<a name="line.1768"></a>
+<span class="sourceLineNo">1769</span>            e.getCause());<a name="line.1769"></a>
+<span class="sourceLineNo">1770</span>      }<a name="line.1770"></a>
+<span class="sourceLineNo">1771</span>    }<a name="line.1771"></a>
+<span class="sourceLineNo">1772</span>  }<a name="line.1772"></a>
+<span class="sourceLineNo">1773</span><a name="line.1773"></a>
+<span class="sourceLineNo">1774</span>  /**<a name="line.1774"></a>
+<span class="sourceLineNo">1775</span>   * Check consistency of all regions that have been found in previous phases.<a name="line.1775"></a>
+<span class="sourceLineNo">1776</span>   */<a name="line.1776"></a>
+<span class="sourceLineNo">1777</span>  private void checkAndFixConsistency()<a name="line.1777"></a>
+<span class="sourceLineNo">1778</span>  throws IOException, KeeperException, InterruptedException {<a name="line.1778"></a>
+<span class="sourceLineNo">1779</span>    // Divide the checks in two phases. One for default/primary replicas and another<a name="line.1779"></a>
+<span class="sourceLineNo">1780</span>    // for the non-primary ones. Keeps code cleaner this way.<a name="line.1780"></a>
+<span class="sourceLineNo">1781</span><a name="line.1781"></a>
+<span class="sourceLineNo">1782</span>    List&lt;CheckRegionConsistencyWorkItem&gt; workItems = new ArrayList&lt;&gt;(regionInfoMap.size());<a name="line.1782"></a>
+<span class="sourceLineNo">1783</span>    for (java.util.Map.Entry&lt;String, HbckRegionInfo&gt; e: regionInfoMap.entrySet()) {<a name="line.1783"></a>
+<span class="sourceLineNo">1784</span>      if (e.getValue().getReplicaId() == RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.1784"></a>
+<span class="sourceLineNo">1785</span>        workItems.add(new CheckRegionConsistencyWorkItem(e.getKey(), e.getValue()));<a name="line.1785"></a>
+<span class="sourceLineNo">1786</span>      }<a name="line.1786"></a>
+<span class="sourceLineNo">1787</span>    }<a name="line.1787"></a>
+<span class="sourceLineNo">1788</span>    checkRegionConsistencyConcurrently(workItems);<a name="line.1788"></a>
+<span class="sourceLineNo">1789</span><a name="line.1789"></a>
+<span class="sourceLineNo">1790</span>    boolean prevHdfsCheck = shouldCheckHdfs();<a name="line.1790"></a>
+<span class="sourceLineNo">1791</span>    setCheckHdfs(false); //replicas don't have any hdfs data<a name="line.1791"></a>
+<span class="sourceLineNo">1792</span>    // Run a pass over the replicas and fix any assignment issues that exist on the currently<a name="line.1792"></a>
+<span class="sourceLineNo">1793</span>    // deployed/undeployed replicas.<a name="line.1793"></a>
+<span class="sourceLineNo">1794</span>    List&lt;CheckRegionConsistencyWorkItem&gt; replicaWorkItems = new ArrayList&lt;&gt;(regionInfoMap.size());<a name="line.1794"></a>
+<span class="sourceLineNo">1795</span>    for (java.util.Map.Entry&lt;String, HbckRegionInfo&gt; e: regionInfoMap.entrySet()) {<a name="line.1795"></a>
+<span class="sourceLineNo">1796</span>      if (e.getValue().getReplicaId() != RegionInfo.DEFAULT_REPLICA_ID) {<a name="line.1796"></a>
+<span class="sourceLineNo">1797</span>        replicaWorkItems.add(new CheckRegionConsistencyWorkItem(e.getKey(), e.getValue()));<a name="line.1797"></a>
+<span class="sourceLineNo">1798</span>      }<a name="line.1798"></a>
+<span class="sourceLineNo">1799</span>    }<a name="line.1799"></a>
+<span class="sourceLineNo">1800</span>    checkRegionConsistencyConcurrently(replicaWorkItems);<a name="line.1800"></a>
+<span class="sourceLineNo">1801</span>    setCheckHdfs(prevHdfsCheck);<a name="line.1801"></a>
+<span class="sourceLineNo">1802</span><a name="line.1802"></a>
+<span class="sourceLineNo">1803</span>    // If some regions is skipped during checkRegionConsistencyConcurrently() phase, we might<a name="line.1803"></a>
+<span class="sourceLineNo">1804</span>    // not get accurate state of the hbase if continuing. The config here allows users to tune<a name="line.1804"></a>
+<span class="sourceLineNo">1805</span>    // the tolerance of number of skipped region.<a name="line.1805"></a>
+<span class="sourceLineNo">1806</span>    // TODO: evaluate the consequence to continue the hbck operation without config.<a name="line.1806"></a>
+<span class="sourceLineNo">1807</span>    int terminateThreshold =  getConf().getInt("hbase.hbck.skipped.regions.limit", 0);<a name="line.1807"></a>
+<span class="sourceLineNo">1808</span>    int numOfSkippedRegions = skippedRegions.size();<a name="line.1808"></a>
+<span class="sourceLineNo">1809</span>    if (numOfSkippedRegions &gt; 0 &amp;&amp; numOfSkippedRegions &gt; terminateThreshold) {<a name="line.1809"></a>
+<span class="sourceLineNo">1810</span>      throw new IOException(numOfSkippedRegions<a name="line.1810"></a>
+<span class="sourceLineNo">1811</span>        + " region(s) could not be checked or repaired.  See logs for detail.");<a name="line.1811"></a>
+<span class="sourceLineNo">1812</span>    }<a name="line.1812"></a>
+<span class="sourceLineNo">1813</span><a name="line.1813"></a>
+<span class="sourceLineNo">1814</span>    if (shouldCheckHdfs()) {<a name="line.1814"></a>
+<span class="sourceLineNo">1815</span>      checkAndFixTableStates();<a name="line.1815"></a>
+<span class="sourceLineNo">1816</span>    }<a name="line.1816"></a>
+<span class="sourceLineNo">1817</span>  }<a name="line.1817"></a>
+<span class="sourceLineNo">1818</span><a name="line.1818"></a>
+<span class="sourceLineNo">1819</span>  /**<a name="line.1819"></a>
+<span class="sourceLineNo">1820</span>   * Check consistency of all regions using mulitple threads concurrently.<a name="line.1820"></a>
+<span class="sourceLineNo">1821</span>   */<a name="line.1821"></a>
+<span class="sourceLineNo">1822</span>  private void checkRegionConsistencyConcurrently(<a name="line.1822"></a>
+<span class="sourceLineNo">1823</span>    final List&lt;CheckRegionConsistencyWorkItem&gt; workItems)<a name="line.1823"></a>
+<span class="sourceLineNo">1824</span>    throws IOException, KeeperException, InterruptedException {<a name="line.1824"></a>
+<span class="sourceLineNo">1825</span>    if (workItems.isEmpty()) {<a name="line.1825"></a>
+<span class="sourceLineNo">1826</span>      return;  // nothing to check<a name="line.1826"></a>
+<span class="sourceLineNo">1827</span>    }<a name="line.1827"></a>
+<span class="sourceLineNo">1828</span><a name="line.1828"></a>
+<span class="sourceLineNo">1829</span>    List&lt;Future&lt;Void&gt;&gt; workFutures = executor.invokeAll(workItems);<a name="line.1829"></a>
+<span class="sourceLineNo">1830</span>    for(Future&lt;Void&gt; f: workFutures) {<a name="line.1830"></a>
+<span class="sourceLineNo">1831</span>      try {<a name="line.1831"></a>
+<span class="sourceLineNo">1832</span>        f.get();<a name="line.1832"></a>
+<span class="sourceLineNo">1833</span>      } catch(ExecutionException e1) {<a name="line.1833"></a>
+<span class="sourceLineNo">1834</span>        LOG.warn("Could not check region consistency " , e1.getCause());<a name="line.1834"></a>
+<span class="sourceLineNo">1835</span>        if (e1.getCause() instanceof IOException) {<a name="line.1835"></a>
+<span class="sourceLineNo">1836</span>          throw (IOException)e1.getCause();<a name="line.1836"></a>
+<span class="sourceLineNo">1837</span>        } else if (e1.getCause() instanceof KeeperException) {<a name="line.1837"></a>
+<span class="sourceLineNo">1838</span>          throw (KeeperException)e1.getCause();<a name="line.1838"></a>
+<span class="sourceLineNo">1839</span>        } else if (e1.getCause() instanceof InterruptedException) {<a name="line.1839"></a>
+<span class="sourceLineNo">1840</span>          throw (InterruptedException)e1.getCause();<a name="line.1840"></a>
+<span class="sourceLineNo">1841</span>        } else {<a name="line.1841"></a>
+<span class="sourceLineNo">1842</span>          throw new IOException(e1.getCause());<a name="line.1842"></a>
+<span class="sourceLineNo">1843</span>        }<a name="line.1843"></a>
+<span class="sourceLineNo">1844</span>      }<a name="line.1844"></a>
+<span class="sourceLineNo">1845</span>    }<a name="line.1845"></a>
+<span class="sourceLineNo">1846</span>  }<a name="line.1846"></a>
+<span class="sourceLineNo">1847</span><a name="line.1847"></a>
+<span class="sourceLineNo">1848</span>  class CheckRegionConsistencyWorkItem implements Callable&lt;Void&gt; {<a name="line.1848"></a>
+<span class="sourceLineNo">1849</span>    private final String key;<a name="line.1849"></a>
+<span class="sourceLineNo">1850</span>    private final HbckRegionInfo hbi;<a name="line.1850"></a>
+<span class="sourceLineNo">1851</span><a name="line.1851"></a>
+<span class="sourceLineNo">1852</span>    CheckRegionConsistencyWorkItem(String key, HbckRegionInfo hbi) {<a name="line.1852"></a>
+<span class="sourceLineNo">1853</span>      this.key = key;<a name="line.1853"></a>
+<span class="sourceLineNo">1854</span>      this.hbi = hbi;<a name="line.1854"></a>
+<span class="sourceLineNo">1855</span>    }<a name="line.1855"></a>
+<span class="sourceLineNo">1856</span><a name="line.1856"></a>
+<span class="sourceLineNo">1857</span>    @Override<a name="line.1857"></a>
+<span class="sourceLineNo">1858</span>    public synchronized Void call() throws Exception {<a name="line.1858"></a>
+<span class="sourceLineNo">1859</span>      try {<a name="line.1859"></a>
+<span class="sourceLineNo">1860</span>        checkRegionConsistency(key, hbi);<a name="line.1860"></a>
+<span class="sourceLineNo">1861</span>      } catch (Exception e) {<a name="line.1861"></a>
+<span class="sourceLineNo">1862</span>        // If the region is non-META region, skip this region and send warning/error message; if<a name="line.1862"></a>
+<span class="sourceLineNo">1863</span>        // the region is META region, we should not continue.<a name="line.1863"></a>
+<span class="sourceLineNo">1864</span>        LOG.warn("Unable to complete check or repair the region '" + hbi.getRegionNameAsString()<a name="line.1864"></a>
+<span class="sourceLineNo">1865</span>          + "'.", e);<a name="line.1865"></a>
+<span class="sourceLineNo">1866</span>        if (hbi.getHdfsHRI().isMetaRegion()) {<a name="line.1866"></a>
+<span class="sourceLineNo">1867</span>          throw e;<a name="line.1867"></a>
+<span class="sourceLineNo">1868</span>        }<a name="line.1868"></a>
+<span class="sourceLineNo">1869</span>        LOG.warn("Skip region '" + hbi.getRegionNameAsString() + "'");<a name="line.1869"></a>
+<span class="sourceLineNo">1870</span>        addSkippedRegion(hbi);<a name="line.1870"></a>
+<span class="sourceLineNo">1871</span>      }<a name="line.1871"></a>
+<span class="sourceLineNo">1872</span>      return null;<a name="line.1872"></a>
+<span class="sourceLineNo">1873</span>    }<a name="line.1873"></a>
+<span class="sourceLineNo">1874</span>  }<a name="line.1874"></a>
+<span class="sourceLineNo">1875</span><a name="line.1875"></a>
+<span class="sourceLineNo">1876</span>  private void addSkippedRegion(final HbckRegionInfo hbi) {<a name="line.1876"></a>
+<span class="sourceLineNo">1877</span>    Set&lt;String&gt; skippedRegionNames = skippedRegions.get(hbi.getTableName());<a name="line.1877"></a>
+<span class="sourceLineNo">1878</span>    if (skippedRegionNames == null) {<a name="line.1878"></a>
+<span class="sourceLineNo">1879</span>      skippedRegionNames = new HashSet&lt;&gt;();<a name="line.1879"></a>
+<span class="sourceLineNo">1880</span>    }<a name="line.1880"></a>
+<span class="sourceLineNo">1881</span>    skippedRegionNames.add(hbi.getRegionNameAsString());<a name="line.1881"></a>
+<span class="sourceLineNo">1882</span>    skippedRegions.put(hbi.getTableName(), skippedRegionNames);<a name="line.1882"></a>
+<span class="sourceLineNo">1883</span>  }<a name="line.1883"></a>
+<span class="sourceLineNo">1884</span><a name="line.1884"></a>
+<span class="sourceLineNo">1885</span>  /**<a name="line.1885"></a>
+<span class="sourceLineNo">1886</span>   * Check and fix table states, assumes full info available:<a name="line.1886"></a>
+<span class="sourceLineNo">1887</span>   * - tableInfos<a name="line.1887"></a>
+<span class="sourceLineNo">1888</span>   * - empty tables loaded<a name="line.1888"></a>
+<span class="sourceLineNo">1889</span>   */<a name="line.1889"></a>
+<span class="sourceLineNo">1890</span>  private void checkAndFixTableStates() throws IOException {<a name="line.1890"></a>
+<span class="sourceLineNo">1891</span>    // first check dangling states<a name="line.1891"></a>
+<span class="sourceLineNo">1892</span>    for (Entry&lt;TableName, TableState&gt; entry : tableStates.entrySet()) {<a name="line.1892"></a>
+<span class="sourceLineNo">1893</span>      TableName tableName = entry.getKey();<a name="line.1893"></a>
+<span class="sourceLineNo">1894</span>      TableState tableState = entry.getValue();<a name="line.1894"></a>
+<span class="sourceLineNo">1895</span>      HbckTableInfo tableInfo = tablesInfo.get(tableName);<a name="line.1895"></a>
+<span class="sourceLineNo">1896</span>      if (isTableIncluded(tableName)<a name="line.1896"></a>
+<span class="sourceLineNo">1897</span>          &amp;&amp; !tableName.isSystemTable()<a name="line.1897"></a>
+<span class="sourceLineNo">1898</span>          &amp;&amp; tableInfo == null) {<a name="line.1898"></a>
+<span class="sourceLineNo">1899</span>        if (fixMeta) {<a name="line.1899"></a>
+<span class="sourceLineNo">1900</span>          MetaTableAccessor.deleteTableState(connection, tableName);<a name="line.1900"></a>
+<span class="sourceLineNo">1901</span>          TableState state = MetaTableAccessor.getTableState(connection, tableName);<a name="line.1901"></a>
+<span class="sourceLineNo">1902</span>          if (state != null) {<a name="line.1902"></a>
+<span class="sourceLineNo">1903</span>            errors.reportError(ERROR_CODE.ORPHAN_TABLE_STATE,<a name="line.1903"></a>
+<span class="sourceLineNo">1904</span>                tableName + " unable to delete dangling table state " + tableState);<a name="line.1904"></a>
+<span class="sourceLineNo">1905</span>          }<a name="line.1905"></a>
+<span class="sourceLineNo">1906</span>        } else if (!checkMetaOnly) {<a name="line.1906"></a>
+<span class="sourceLineNo">1907</span>          // dangling table state in meta if checkMetaOnly is false. If checkMetaOnly is<a name="line.1907"></a>
+<span class="sourceLineNo">1908</span>          // true, tableInfo will be null as tablesInfo are not polulated for all tables from hdfs<a name="line.1908"></a>
+<span class="sourceLineNo">1909</span>          errors.reportError(ERROR_CODE.ORPHAN_TABLE_STATE,<a name="line.1909"></a>
+<span class="sourceLineNo">1910</span>              tableName + " has dangling table state " + tableState);<a name="line.1910"></a>
+<span class="sourceLineNo">1911</span>        }<a name="line.1911"></a>
+<span class="sourceLineNo">1912</span>      }<a name="line.1912"></a>
+<span class="sourceLineNo">1913</span>    }<a name="line.1913"></a>
+<span class="sourceLineNo">1914</span>    // check that all tables have states<a name="line.1914"></a>
+<span class="sourceLineNo">1915</span>    for (TableName tableName : tablesInfo.keySet()) {<a name="line.1915"></a>
+<span class="sourceLineNo">1916</span>      if (isTableIncluded(tableName) &amp;&amp; !tableStates.containsKey(tableName)) {<a name="line.1916"></a>
+<span class="sourceLineNo">1917</span>        if (fixMeta) {<a name="line.1917"></a>
+<span class="sourceLineNo">1918</span>          MetaTableAccessor.updateTableState(connection, tableName, TableState.State.ENABLED);<a name="line.1918"></a>
+<span class="sourceLineNo">1919</span>          TableState newState = MetaTableAccessor.getTableState(connection, tableName);<a name="line.1919"></a>
+<span class="sourceLineNo">1920</span>          if (newState == null) {<a name="line.1920"></a>
+<span class="sourceLineNo">1921</span>            errors.reportError(ERROR_CODE.NO_TABLE_STATE,<a name="line.1921"></a>
+<span class="sourceLineNo">1922</span>                "Unable to change state for table " + tableName + " in meta ");<a name="line.1922"></a>
+<span class="sourceLineNo">1923</span>          }<a name="line.1923"></a>
+<span class="sourceLineNo">1924</span>        } else {<a name="line.1924"></a>
+<span class="sourceLineNo">1925</span>          errors.reportError(ERROR_CODE.NO_TABLE_STATE,<a name="line.1925"></a>
+<span class="sourceLineNo">1926</span>              tableName + " has no state in meta ");<a name="line.1926"></a>
+<span class="sourceLineNo">1927</span>        }<a name="line.1927"></a>
+<span class="sourceLineNo">1928</span>      }<a name="line.1928"></a>
+<span class="sourceLineNo">1929</span>    }<a name="line.1929"></a>
+<span class="sourceLineNo">1930</span>  }<a name="line.1930"></a>
+<span class="sourceLineNo">1931</span><a name="line.1931"></a>
+<span class="sourceLineNo">1932</span>  private void preCheckPermission() throws IOException, AccessDeniedException {<a name="line.1932"></a>
+<span class="sourceLineNo">1933</span>    if (shouldIgnorePreCheckPermission()) {<a name="line.1933"></a>
+<span class="sourceLineNo">1934</span>      return;<a name="line.1934"></a>
+<span class="sourceLineNo">1935</span>    }<a name="line.1935"></a>
+<span class="sourceLineNo">1936</span><a name="line.1936"></a>
+<span class="sourceLineNo">1937</span>    Path hbaseDir = FSUtils.getRootDir(getConf());<a name="line.1937"></a>
+<span class="sourceLineNo">1938</span>    FileSystem fs = hbaseDir.getFileSystem(getConf());<a name="line.1938"></a>
+<span class="sourceLineNo">1939</span>    UserProvider userProvider = UserProvider.instantiate(getConf());<a name="line.1939"></a>
+<span class="sourceLineNo">1940</span>    UserGroupInformation ugi = userProvider.getCurrent().getUGI();<a name="line.1940"></a>
+<span class="sourceLineNo">1941</span>    FileStatus[] files = fs.listStatus(hbaseDir);<a name="line.1941"></a>
+<span class="sourceLineNo">1942</span>    for (FileStatus file : files) {<a name="line.1942"></a>
+<span class="sourceLineNo">1943</span>      try {<a name="line.1943"></a>
+<span class="sourceLineNo">1944</span>        FSUtils.checkAccess(ugi, file, FsAction.WRITE);<a name="line.1944"></a>
+<span class="sourceLineNo">1945</span>      } catch (AccessDeniedException ace) {<a name="line.1945"></a>
+<span class="sourceLineNo">1946</span>        LOG.warn("Got AccessDeniedException when preCheckPermission ", ace);<a name="line.1946"></a>
+<span class="sourceLineNo">1947</span>        errors.reportError(ERROR_CODE.WRONG_USAGE, "Current user " + ugi.getUserName()<a name="line.1947"></a>
+<span class="sourceLineNo">1948</span>          + " does not have write perms to " + file.getPath()<a name="line.1948"></a>
+<span class="sourceLineNo">1949</span>          + ". Please rerun hbck as hdfs user " + file.getOwner());<a name="line.1949"></a>
+<span class="sourceLineNo">1950</span>        throw ace;<a name="line.1950"></a>
+<span class="sourceLineNo">1951</span>      }<a name="line.1951"></a>
+<span class="sourceLineNo">1952</span>    }<a name="line.1952"></a>
+<span class="sourceLineNo">1953</span>  }<a name="line.1953"></a>
+<span class="sourceLineNo">1954</span><a name="line.1954"></a>
+<span class="sourceLineNo">1955</span>  /**<a name="line.1955"></a>
+<span class="sourceLineNo">1956</span>   * Deletes region from meta table<a name="line.1956"></a>
+<span class="sourceLineNo">1957</span>   */<a name="line.1957"></a>
+<span class="sourceLineNo">1958</span>  private void deleteMetaRegion(HbckRegionInfo hi) throws IOException {<a name="line.1958"></a>
+<span class="sourceLineNo">1959</span>    deleteMetaRegion(hi.getMetaEntry().getRegionName());<a name="line.1959"></a>
+<span class="sourceLineNo">1960</span>  }<a name="line.1960"></a>
+<span class="sourceLineNo">1961</span><a name="line.1961"></a>
+<span class="sourceLineNo">1962</span>  /**<a name="line.1962"></a>
+<span class="sourceLineNo">1963</span>   * Deletes region from meta table<a name="line.1963"></a>
+<span class="sourceLineNo">1964</span>   */<a name="line.1964"></a>
+<span class="sourceLineNo">1965</span>  private void deleteMetaRegion(byte[] metaKey) throws IOException {<a name="line.1965"></a>
+<span class="sourceLineNo">1966</span>    Delete d = new Delete(metaKey);<a name="line.1966"></a>
+<span class="sourceLineNo">1967</span>    meta.delete(d);<a name="line.1967"></a>
+<span class="sourceLineNo">1968</span>    LOG.info("Deleted " + Bytes.toString(metaKey) + " from META" );<a name="line.1968"></a>
+<span class="sourceLineNo">1969</span>  }<a name="line.1969"></a>
+<span class="sourceLineNo">1970</span><a name="line.1970"></a>
+<span class="sourceLineNo">1971</span>  /**<a name="line.1971"></a>
+<span class="sourceLineNo">1972</span>   * Reset the split parent region info in meta table<a name="line.1972"></a>
+<span class="sourceLineNo">1973</span>   */<a name="line.1973"></a>
+<span class="sourceLineNo">1974</span>  private void resetSplitParent(HbckRegionInfo hi) throws IOException {<a name="line.1974"></a>
+<span class="sourceLineNo">1975</span>    RowMutations mutations = new RowMutations(hi.getMetaEntry().getRegionName());<a name="line.1975"></a>
+<span class="sourceLineNo">1976</span>    Delete d = new Delete(hi.getMetaEntry().getRegionName());<a name="line.1976"></a>
+<span class="sourceLineNo">1977</span>    d.addColumn(HConstants.CATALOG_FAMILY, HConstants.SPLITA_QUALIFIER);<a name="line.1977"></a>
+<span class="sourceLineNo">1978</span>    d.addColumn(HConstants.CATALOG_FAMILY, HConstants.SPLITB_QUALIFIER);<a name="line.1978"></a>
+<span class="sourceLineNo">1979</span>    mutations.add(d);<a name="line.1979"></a>
+<span class="sourceLineNo">1980</span><a name="line.1980"></a>
+<span class="sourceLineNo">1981</span>    RegionInfo hri = RegionInfoBuilder.newBuilder(hi.getMetaEntry())<a name="line.1981"></a>
+<span class="sourceLineNo">1982</span>        .setOffline(false)<a name="line.1982"></a>
+<span class="sourceLineNo">1983</span>        .setSplit(false)<a name="line.1983"></a>
+<span class="sourceLineNo">1984</span>        .build();<a name="line.1984"></a>
+<span class="sourceLineNo">1985</span>    Put p = MetaTableAccessor.makePutFromRegionInfo(hri, EnvironmentEdgeManager.currentTime());<a name="line.1985"></a>
+<span class="sourceLineNo">1986</span>    mutations.add(p);<a name="line.1986"></a>
+<span class="sourceLineNo">1987</span><a name="line.1987"></a>
+<span class="sourceLineNo">1988</span>    meta.mutateRow(mutations);<a name="line.1988"></a>
+<span class="sourceLineNo">1989</span>    LOG.info("Reset split parent " + hi.getMetaEntry().getRegionNameAsString() + " in META");<a name="line.1989"></a>
+<span class="sourceLineNo">1990</span>  }<a name="line.1990"></a>
+<span class="sourceLineNo">1991</span><a name="line.1991"></a>
+<span class="sourceLineNo">1992</span>  /**<a name="line.1992"></a>
+<span class="sourceLineNo">1993</span>   * This backwards-compatibility wrapper for permanently offlining a region<a name="line.1993"></a>
+<span class="sourceLineNo">1994</span>   * that should not be alive.  If the region server does not support the<a name="line.1994"></a>
+<span class="sourceLineNo">1995</span>   * "offline" method, it will use the closest unassign method instead.  This<a name="line.1995"></a>
+<span class="sourceLineNo">1996</span>   * will basically work until one attempts to disable or delete the affected<a name="line.1996"></a>
+<span class="sourceLineNo">1997</span>   * table.  The problem has to do with in-memory only master state, so<a name="line.1997"></a>
+<span class="sourceLineNo">1998</span>   * restarting the HMaster or failing over to another should fix this.<a name="line.1998"></a>
+<span class="sourceLineNo">1999</span>   */<a name="line.1999"></a>
+<span class="sourceLineNo">2000</span>  void offline(byte[] regionName) throws IOException {<a name="line.2000"></a>
+<span class="sourceLineNo">2001</span>    String regionString = Bytes.toStringBinary(regionName);<a name="line.2001"></a>
+<span class="sourceLineNo">2002</span>    if (!rsSupportsOffline) {<a name="line.2002"></a>
+<span class="sourceLineNo">2003</span>      LOG.warn(<a name="line.2003"></a>
+<span class="sourceLineNo">2004</span>          "Using unassign region " + regionString + " instead of using offline method, you should" +<a name="line.2004"></a>
+<span class="sourceLineNo">2005</span>              " restart HMaster after these repairs");<a name="line.2005"></a>
+<span class="sourceLineNo">2006</span>      admin.unassign(regionName, true);<a name="line.2006"></a>
+<span class="sourceLineNo">2007</span>      return;<a name="line.2007"></a>
+<span class="sourceLineNo">2008</span>    }<a name="line.2008"></a>
+<span class="sourceLineNo">2009</span><a name="line.2009"></a>
+<span class="sourceLineNo">2010</span>    // first time we assume the rs's supports #offline.<a name="line.2010"></a>
+<span class="sourceLineNo">2011</span>    try {<a name="line.2011"></a>
+<span class="sourceLineNo">2012</span>      LOG.info("Offlining region " + regionString);<a name="line.2012"></a>
+<span class="sourceLineNo">2013</span>      admin.offline(regionName);<a name="line.2013"></a>
+<span class="sourceLineNo">2014</span>    } catch (IOException ioe) {<a name="line.2014"></a>
+<span class="sourceLineNo">2015</span>      String notFoundMsg = "java.lang.NoSuchMethodException: " +<a name="line.2015"></a>
+<span class="sourceLineNo">2016</span>          "org.apache.hadoop.hbase.master.HMaster.offline([B)";<a name="line.2016"></a>
+<span class="sourceLineNo">2017</span>      if (ioe.getMessage().contains(notFoundMsg)) {<a name="line.2017"></a>
+<span class="sourceLineNo">2018</span>        LOG.warn("Using unassign region " + regionString +<a name="line.2018"></a>
+<span class="sourceLineNo">2019</span>            " instead of using offline method, you should" +<a name="line.2019"></a>
+<span class="sourceLineNo">2020</span>            " restart HMaster after these repairs");<a name="line.2020"></a>
+<span class="sourceLineNo">2021</span>        rsSupportsOffline = false; // in the future just use unassign<a name="line.2021"></a>
+<span class="sourceLineNo">2022</span>        admin.unassign(regionName, true);<a name="line.2022"></a>
+<span class="sourceLineNo">2023</span>        return;<a name="line.2023"></a>
+<span class="sourceLineNo">2024</span>      }<a name="line.2024"></a>
+<span class="sourceLineNo">2025</span>      throw ioe;<a name="line.2025"></a>
+<span class="sourceLineNo">2026</span>    }<a name="line.2026"></a>
+<span class="sourceLineNo">2027</span>  }<a name="line.2027"></a>
+<span class="sourceLineNo">2028</span><a name="line.2028"></a>
+<span class="sourceLineNo">2029</span>  /**<a name="line.2029"></a>
+<span class="sourceLineNo">2030</span>   * Attempts to undeploy a region from a region server based in information in<a name="line.2030"></a>
+<span class="sourceLineNo">2031</span>   * META.  Any operations that modify the file system should make sure that<a name="line.2031"></a>
+<span class="sourceLineNo">2032</span>   * its corresponding region is not deployed to prevent data races.<a name="line.2032"></a>
+<span class="sourceLineNo">2033</span>   *<a name="line.2033"></a>
+<span class="sourceLineNo">2034</span>   * A separate call is required to update the master in-memory region state<a name="line.2034"></a>
+<span class="sourceLineNo">2035</span>   * kept in the AssignementManager.  Because disable uses this state instead of<a name="line.2035"></a>
+<span class="sourceLineNo">2036</span>   * that found in META, we can't seem to cleanly disable/delete tables that<a name="line.2036"></a>
+<span class="sourceLineNo">2037</span>   * have been hbck fixed.  When used on a version of HBase that does not have<a name="line.2037"></a>
+<span class="sourceLineNo">2038</span>   * the offline ipc call exposed on the master (&amp;lt;0.90.5, &amp;lt;0.92.0) a master<a name="line.2038"></a>
... 75775 lines suppressed ...