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 2021/09/03 20:17:40 UTC

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

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 6e3ac3d  Published site at dd293c8ba97248f292667c52d7e95420611e3e22.
6e3ac3d is described below

commit 6e3ac3d8e1aa06bc997df5621807d69f6ebf83c2
Author: jenkins <bu...@apache.org>
AuthorDate: Fri Sep 3 20:17:30 2021 +0000

    Published site at dd293c8ba97248f292667c52d7e95420611e3e22.
---
 acid-semantics.html                                |    2 +-
 apache_hbase_reference_guide.pdf                   |    4 +-
 book.html                                          |    2 +-
 bulk-loads.html                                    |    2 +-
 checkstyle-aggregate.html                          |  200 +-
 coc.html                                           |    2 +-
 dependencies.html                                  |    2 +-
 dependency-convergence.html                        |    2 +-
 dependency-info.html                               |    2 +-
 dependency-management.html                         |    2 +-
 devapidocs/index-all.html                          |    2 +
 .../apache/hadoop/hbase/backup/package-tree.html   |    4 +-
 .../apache/hadoop/hbase/chaos/package-tree.html    |    2 +-
 .../apache/hadoop/hbase/client/package-tree.html   |   24 +-
 .../apache/hadoop/hbase/filter/package-tree.html   |    6 +-
 .../hadoop/hbase/hbtop/field/package-tree.html     |    2 +-
 .../hadoop/hbase/hbtop/terminal/package-tree.html  |    2 +-
 .../org/apache/hadoop/hbase/http/package-tree.html |    2 +-
 .../apache/hadoop/hbase/io/hfile/package-tree.html |    4 +-
 .../org/apache/hadoop/hbase/ipc/package-tree.html  |    2 +-
 .../hadoop/hbase/mapreduce/package-tree.html       |    4 +-
 .../master/HMaster.TableDescriptorGetter.html      |    4 +-
 .../org/apache/hadoop/hbase/master/HMaster.html    |  601 +-
 .../ServerManager.FlushedSequenceIdFlusher.html    |    6 +-
 .../master/ServerManager.ServerLiveState.html      |    8 +-
 .../apache/hadoop/hbase/master/ServerManager.html  |   50 +-
 .../hbase/master/assignment/package-tree.html      |    2 +-
 .../apache/hadoop/hbase/master/package-tree.html   |    6 +-
 .../org/apache/hadoop/hbase/package-tree.html      |   12 +-
 .../hadoop/hbase/procedure2/package-tree.html      |    4 +-
 .../hbase/procedure2/store/wal/package-tree.html   |    2 +-
 .../apache/hadoop/hbase/quotas/package-tree.html   |    4 +-
 .../hadoop/hbase/regionserver/package-tree.html    |   18 +-
 .../regionserver/querymatcher/package-tree.html    |    2 +-
 .../hbase/regionserver/wal/package-tree.html       |    4 +-
 .../replication/regionserver/package-tree.html     |    2 +-
 .../hadoop/hbase/rest/model/package-tree.html      |    2 +-
 .../hadoop/hbase/security/access/package-tree.html |    6 +-
 .../apache/hadoop/hbase/thrift/package-tree.html   |    2 +-
 .../JVMClusterUtil.RegionServerThread.html         |   13 +
 .../org/apache/hadoop/hbase/util/package-tree.html |   12 +-
 .../master/HMaster.TableDescriptorGetter.html      | 7278 ++++++++++----------
 .../org/apache/hadoop/hbase/master/HMaster.html    | 7278 ++++++++++----------
 .../ServerManager.FlushedSequenceIdFlusher.html    |  909 +--
 .../master/ServerManager.ServerLiveState.html      |  909 +--
 .../apache/hadoop/hbase/master/ServerManager.html  |  909 +--
 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 +-
 .../hadoop/hbase/master/TestMasterNoCluster.html   |    2 +-
 67 files changed, 9197 insertions(+), 9162 deletions(-)

diff --git a/acid-semantics.html b/acid-semantics.html
index 292299d..6afd0c9 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -456,7 +456,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 da0bbb8..16feb2e 100644
--- a/apache_hbase_reference_guide.pdf
+++ b/apache_hbase_reference_guide.pdf
@@ -5,8 +5,8 @@
 /Author (Apache HBase Team)
 /Creator (Asciidoctor PDF 1.5.3, based on Prawn 2.2.2)
 /Producer (Apache HBase Team)
-/ModDate (D:20210902200503+00'00')
-/CreationDate (D:20210902201507+00'00')
+/ModDate (D:20210903200524+00'00')
+/CreationDate (D:20210903201522+00'00')
 >>
 endobj
 2 0 obj
diff --git a/book.html b/book.html
index 5e0a87a..432ea6a 100644
--- a/book.html
+++ b/book.html
@@ -46227,7 +46227,7 @@ org/apache/hadoop/hbase/security/access/AccessControlClient.revoke:(Lorg/apache/
 <div id="footer">
 <div id="footer-text">
 Version 3.0.0-alpha-2-SNAPSHOT<br>
-Last updated 2021-09-02 20:05:03 UTC
+Last updated 2021-09-03 20:05:24 UTC
 </div>
 </div>
 <link rel="stylesheet" href="./coderay-asciidoctor.css">
diff --git a/bulk-loads.html b/bulk-loads.html
index 905eedf..f1072ec 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -161,7 +161,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 38f0eb2..2db7bc4 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -7288,7 +7288,7 @@
 <tr class="a">
 <td>annotation</td>
 <td><a class="externalLink" href="http://checkstyle.sourceforge.net/config_annotation.html#MissingDeprecated">MissingDeprecated</a></td>
-<td>8</td>
+<td>6</td>
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td></tr>
 <tr class="b">
 <td>blocks</td>
@@ -7392,7 +7392,7 @@
 <tr class="b">
 <td></td>
 <td><a class="externalLink" href="http://checkstyle.sourceforge.net/config_javadoc.html#NonEmptyAtclauseDescription">NonEmptyAtclauseDescription</a></td>
-<td>2247</td>
+<td>2249</td>
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td></tr>
 <tr class="a">
 <td>misc</td>
@@ -35333,8 +35333,8 @@
 <th>Line</th></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
-<td>annotation</td>
-<td>MissingDeprecated</td>
+<td>javadoc</td>
+<td>NonEmptyAtclauseDescription</td>
 <td>Javadoc comment at column 14 has parse error. Details: mismatched input ':' expecting &lt;EOF&gt; while parsing JAVADOC</td>
 <td>46</td></tr></table></div>
 <div class="section">
@@ -38177,535 +38177,535 @@
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 114).</td>
-<td>596</td></tr>
+<td>600</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>752</td></tr>
+<td>750</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
-<td>Method length is 358 lines (max allowed is 150).</td>
-<td>853</td></tr>
+<td>Method length is 363 lines (max allowed is 150).</td>
+<td>851</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>1494</td></tr>
+<td>1497</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>1601</td></tr>
+<td>1606</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>1773</td></tr>
+<td>1778</td></tr>
 <tr class="a">
 <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>2040</td></tr>
+<td>2045</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 modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2051</td></tr>
+<td>2056</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2053</td></tr>
+<td>2058</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2054</td></tr>
+<td>2059</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2057</td></tr>
+<td>2062</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2058</td></tr>
+<td>2063</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2060</td></tr>
+<td>2065</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2062</td></tr>
+<td>2067</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2063</td></tr>
+<td>2068</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2064</td></tr>
+<td>2069</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>2092</td></tr>
+<td>2097</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 105).</td>
-<td>2094</td></tr>
+<td>2099</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2303</td></tr>
+<td>2308</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2305</td></tr>
+<td>2310</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2307</td></tr>
+<td>2312</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2313</td></tr>
+<td>2318</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2314</td></tr>
+<td>2319</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2316</td></tr>
+<td>2321</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2318</td></tr>
+<td>2323</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2319</td></tr>
+<td>2324</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2321</td></tr>
+<td>2326</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2323</td></tr>
+<td>2328</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2324</td></tr>
+<td>2329</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2325</td></tr>
+<td>2330</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2338</td></tr>
+<td>2343</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2340</td></tr>
+<td>2345</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2342</td></tr>
+<td>2347</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2343</td></tr>
+<td>2348</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2344</td></tr>
+<td>2349</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2346</td></tr>
+<td>2351</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2348</td></tr>
+<td>2353</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2349</td></tr>
+<td>2354</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2351</td></tr>
+<td>2356</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2353</td></tr>
+<td>2358</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2354</td></tr>
+<td>2359</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2355</td></tr>
+<td>2360</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2438</td></tr>
+<td>2443</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2440</td></tr>
+<td>2445</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2446</td></tr>
+<td>2451</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' has incorrect indentation level 8, expected level should be one of the following: 10, 12.</td>
-<td>2447</td></tr>
+<td>2452</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2448</td></tr>
+<td>2453</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 16, expected level should be one of the following: 18, 20.</td>
-<td>2455</td></tr>
+<td>2460</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 14, expected level should be one of the following: 16, 18.</td>
-<td>2457</td></tr>
+<td>2462</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 rcurly' has incorrect indentation level 12, expected level should be one of the following: 14, 16.</td>
-<td>2458</td></tr>
+<td>2463</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2459</td></tr>
+<td>2464</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 12, expected level should be one of the following: 14, 16.</td>
-<td>2460</td></tr>
+<td>2465</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2461</td></tr>
+<td>2466</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 rcurly' has incorrect indentation level 8, expected level should be one of the following: 10, 12.</td>
-<td>2462</td></tr>
+<td>2467</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2464</td></tr>
+<td>2469</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2471</td></tr>
+<td>2476</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2472</td></tr>
+<td>2477</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2474</td></tr>
+<td>2479</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2476</td></tr>
+<td>2481</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2477</td></tr>
+<td>2482</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2479</td></tr>
+<td>2484</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2481</td></tr>
+<td>2486</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2482</td></tr>
+<td>2487</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2483</td></tr>
+<td>2488</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2493</td></tr>
+<td>2498</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2495</td></tr>
+<td>2500</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2497</td></tr>
+<td>2502</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2507</td></tr>
+<td>2512</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2508</td></tr>
+<td>2513</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2510</td></tr>
+<td>2515</td></tr>
 <tr class="a">
 <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 8, expected level should be one of the following: 10, 12.</td>
-<td>2512</td></tr>
+<td>2517</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2513</td></tr>
+<td>2518</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2515</td></tr>
+<td>2520</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2517</td></tr>
+<td>2522</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2518</td></tr>
+<td>2523</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2519</td></tr>
+<td>2524</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2582</td></tr>
+<td>2587</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2586</td></tr>
+<td>2591</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def modifier' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2588</td></tr>
+<td>2593</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2590</td></tr>
+<td>2595</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'method def rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2591</td></tr>
+<td>2596</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>indentation</td>
 <td>Indentation</td>
 <td>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2592</td></tr>
+<td>2597</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>3052</td></tr>
+<td>3057</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>3228</td></tr>
+<td>3233</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>3230</td></tr>
+<td>3235</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>3342</td></tr>
+<td>3347</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>blocks</td>
 <td>NeedBraces</td>
 <td>'for' construct must use '{}'s.</td>
-<td>3372</td></tr>
+<td>3377</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>3384</td></tr>
+<td>3389</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>3413</td></tr></table></div>
+<td>3418</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.master.HMasterCommandLine.java">org/apache/hadoop/hbase/master/HMasterCommandLine.java</h3>
 <table border="0" class="table table-striped">
@@ -39659,19 +39659,19 @@
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>759</td></tr>
+<td>760</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>788</td></tr>
+<td>789</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 103).</td>
-<td>825</td></tr></table></div>
+<td>826</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.master.SnapshotOfRegionAssignmentFromMeta.java">org/apache/hadoop/hbase/master/SnapshotOfRegionAssignmentFromMeta.java</h3>
 <table border="0" class="table table-striped">
@@ -50231,8 +50231,8 @@
 <th>Line</th></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
-<td>annotation</td>
-<td>MissingDeprecated</td>
+<td>javadoc</td>
+<td>NonEmptyAtclauseDescription</td>
 <td>Javadoc comment at column 54 has parse error. Details: no viable alternative at input '(' while parsing JAVADOC_INLINE_TAG</td>
 <td>59</td></tr>
 <tr class="b">
@@ -73532,7 +73532,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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/coc.html b/coc.html
index 3a2ab92..19c5815 100644
--- a/coc.html
+++ b/coc.html
@@ -230,7 +230,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 a4a1fee..5620ae5 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -302,7 +302,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 588ccec..ef5be80 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -866,7 +866,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 6cc948e..e21ac4c 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -183,7 +183,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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 a4abb15..a840630 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -1190,7 +1190,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2021
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-02</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2021-09-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/index-all.html b/devapidocs/index-all.html
index 555b751..4ebbf41 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -76907,6 +76907,8 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/HMaster.html#maintenanceMode">maintenanceMode</a></span> - Variable in class org.apache.hadoop.hbase.master.<a href="org/apache/hadoop/hbase/master/HMaster.html" title="class in org.apache.hadoop.hbase.master">HMaster</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/HMaster.html#maintenanceRegionServer">maintenanceRegionServer</a></span> - Variable in class org.apache.hadoop.hbase.master.<a href="org/apache/hadoop/hbase/master/HMaster.html" title="class in org.apache.hadoop.hbase.master">HMaster</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/CompactionTool.CompactionMapper.html#major">major</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/CompactionTool.CompactionMapper.html" title="class in org.apache.hadoop.hbase.regionserver">CompactionTool.CompactionMapper</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html#MAJOR_COMPACTED_CELLS">MAJOR_COMPACTED_CELLS</a></span> - Static variable in interface org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/MetricsRegionServerSource.html" title="interface in org.apache.hadoop.hbase.regionserver">MetricsRegionServerSource</a></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
index 8f6dbe9..4b5bc4d 100644
--- a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
@@ -166,10 +166,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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/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.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/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/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/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
index 12a24fd..9e8dcb9 100644
--- a/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/chaos/package-tree.html
@@ -103,8 +103,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ExecutorAction.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ExecutorAction</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.chaos.<a href="../../../../../org/apache/hadoop/hbase/chaos/ChaosService.ChaosServiceName.html" title="enum in org.apache.hadoop.hbase.chaos"><span class="typeNameLink">ChaosService.ChaosServiceName</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
index 847b1ea..2be3876 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -466,25 +466,25 @@
 <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.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/LogQueryFilter.Type.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/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/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/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/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/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/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CatalogReplicaMode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CatalogReplicaMode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/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/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/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/ServerType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ServerType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/LogQueryFilter.Type.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/LogQueryFilter.FilterByOperator.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">LogQueryFilter.FilterByOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/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/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/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</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 112335a..f728297 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/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/Filter.ReturnCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">Filter.ReturnCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
+<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/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/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>
+<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>
 </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 4245577..96318e7 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/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>
+<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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
index 85ba9c8..5a984ee 100644
--- a/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/hbtop/terminal/package-tree.html
@@ -107,8 +107,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/Color.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">Color</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/KeyPress.Type.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">KeyPress.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.hbtop.terminal.<a href="../../../../../../org/apache/hadoop/hbase/hbtop/terminal/Color.html" title="enum in org.apache.hadoop.hbase.hbtop.terminal"><span class="typeNameLink">Color</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
index f4fcd97..30f215e 100644
--- a/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/http/package-tree.html
@@ -140,9 +140,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/HttpConfig.Policy.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">HttpConfig.Policy</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Event.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Event</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.http.<a href="../../../../../org/apache/hadoop/hbase/http/ProfileServlet.Output.html" title="enum in org.apache.hadoop.hbase.http"><span class="typeNameLink">ProfileServlet.Output</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
index 6daca3a..7859440 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/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/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/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/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/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/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/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/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</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 3ce9ea6..2baee7c 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -363,9 +363,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.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/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
index c08f65a..52775e9 100644
--- a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
@@ -301,10 +301,10 @@
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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/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/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/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/WALPlayer.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">WALPlayer.Counter</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html b/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
index cd010b2..46598a7 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
@@ -105,7 +105,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>protected static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2382">HMaster.TableDescriptorGetter</a></pre>
+<pre>protected static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2387">HMaster.TableDescriptorGetter</a></pre>
 <div class="block">Implement to return TableDescriptor after pre-checks</div>
 </li>
 </ul>
@@ -150,7 +150,7 @@ var activeTableTab = "activeTableTab";
 <ul class="blockListLast">
 <li class="blockList">
 <h4>get</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/master/HMaster.TableDescriptorGetter.html#line.2383">get</a>()
+<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/master/HMaster.TableDescriptorGetter.html#line.2388">get</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="throwsLabel">Throws:</span></dt>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/HMaster.html b/devapidocs/org/apache/hadoop/hbase/master/HMaster.html
index f36b23b..da396f7 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/HMaster.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/HMaster.html
@@ -128,7 +128,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.LimitedPrivate(value="Tools")
-public class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.269">HMaster</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.270">HMaster</a>
 extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a>
 implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></pre>
 <div class="block">HMaster is the "master server" for HBase. An HBase cluster has one active master. If many masters
@@ -311,164 +311,168 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#maintenanceMode">maintenanceMode</a></span></code>&nbsp;</td>
 </tr>
 <tr class="altColor">
+<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#maintenanceRegionServer">maintenanceRegionServer</a></span></code>&nbsp;</td>
+</tr>
+<tr class="rowColor">
 <td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#MASTER">MASTER</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private long</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#masterActiveTime">masterActiveTime</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) <a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MasterAddressSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MasterAddressSyncer</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#masterAddressSyncer">masterAddressSyncer</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private long</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#masterFinishedInitializationTime">masterFinishedInitializationTime</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#masterJettyServer">masterJettyServer</a></span></code>
 <div class="block">jetty server for master to redirect requests to regionserver infoServer</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#masterRegion">masterRegion</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private int</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#maxBalancingTime">maxBalancingTime</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private double</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#maxRitPercent">maxRitPercent</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MetaLocationSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MetaLocationSyncer</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#metaLocationSyncer">metaLocationSyncer</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>(package private) <a href="../../../../../org/apache/hadoop/hbase/master/MetricsMaster.html" title="class in org.apache.hadoop.hbase.master">MetricsMaster</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#metricsMaster">metricsMaster</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/util/IdLock.html" title="class in org.apache.hadoop.hbase.util">IdLock</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#mobCompactionLock">mobCompactionLock</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a>&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/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a>&gt;</co [...]
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#mobCompactionStates">mobCompactionStates</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCleanerChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCleanerChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#mobFileCleanerChore">mobFileCleanerChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCompactionChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCompactionChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#mobFileCompactionChore">mobFileCompactionChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/procedure/MasterProcedureManagerHost.html" title="class in org.apache.hadoop.hbase.procedure">MasterProcedureManagerHost</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#mpmHost">mpmHost</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#preLoadTableDescriptors">preLoadTableDescriptors</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureExecutor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&gt;</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#procedureExecutor">procedureExecutor</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/procedure2/store/ProcedureStore.html" title="interface in org.apache.hadoop.hbase.procedure2.store">ProcedureStore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#procedureStore">procedureStore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/MasterQuotaManager.html" title="class in org.apache.hadoop.hbase.quotas">MasterQuotaManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#quotaManager">quotaManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">QuotaObserverChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#quotaObserverChore">quotaObserverChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/normalizer/RegionNormalizerManager.html" title="class in org.apache.hadoop.hbase.master.normalizer">RegionNormalizerManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#regionNormalizerManager">regionNormalizerManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/RegionServerTracker.html" title="class in org.apache.hadoop.hbase.master">RegionServerTracker</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#regionServerTracker">regionServerTracker</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryChore.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#regionsRecoveryChore">regionsRecoveryChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryConfigManager.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryConfigManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#regionsRecoveryConfigManager">regionsRecoveryConfigManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/cleaner/ReplicationBarrierCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">ReplicationBarrierCleaner</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#replicationBarrierCleaner">replicationBarrierCleaner</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication">ReplicationPeerManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#replicationPeerManager">replicationPeerManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) <a href="../../../../../org/apache/hadoop/hbase/monitoring/MemoryBoundedLogMessageBuffer.html" title="class in org.apache.hadoop.hbase.monitoring">MemoryBoundedLogMessageBuffer</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#rsFatals">rsFatals</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupInfoManager.html" title="interface in org.apache.hadoop.hbase.rsgroup">RSGroupInfoManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#rsGroupInfoManager">rsGroupInfoManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#serverManager">serverManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>(package private) boolean</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#serviceStarted">serviceStarted</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/cleaner/SnapshotCleanerChore.html" title="class in org.apache.hadoop.hbase.master.cleaner">SnapshotCleanerChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#snapshotCleanerChore">snapshotCleanerChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>(package private) <a href="../../../../../org/apache/hadoop/hbase/zookeeper/SnapshotCleanupTracker.html" title="class in org.apache.hadoop.hbase.zookeeper">SnapshotCleanupTracker</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#snapshotCleanupTracker">snapshotCleanupTracker</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) <a href="../../../../../org/apache/hadoop/hbase/master/snapshot/SnapshotManager.html" title="class in org.apache.hadoop.hbase.master.snapshot">SnapshotManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#snapshotManager">snapshotManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">SnapshotQuotaObserverChore</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#snapshotQuotaChore">snapshotQuotaChore</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#spaceQuotaSnapshotNotifier">spaceQuotaSnapshotNotifier</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master">SplitOrMergeTracker</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#splitOrMergeTracker">splitOrMergeTracker</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/SplitWALManager.html" title="class in org.apache.hadoop.hbase.master">SplitWALManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#splitWALManager">splitWALManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication">SyncReplicationReplayWALManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#syncReplicationReplayWALManager">syncReplicationReplayWALManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#tableStateManager">tableStateManager</a></span></code>&nbsp;</td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/master/MasterWalManager.html" title="class in org.apache.hadoop.hbase.master">MasterWalManager</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html#walManager">walManager</a></span></code>&nbsp;</td>
 </tr>
@@ -1588,7 +1592,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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/HMaster.html#line.271">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.272">LOG</a></pre>
 </li>
 </ul>
 <a name="MASTER">
@@ -1597,7 +1601,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>MASTER</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/master/HMaster.html#line.275">MASTER</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/master/HMaster.html#line.276">MASTER</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.MASTER">Constant Field Values</a></dd>
@@ -1610,7 +1614,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>activeMasterManager</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ActiveMasterManager.html" title="class in org.apache.hadoop.hbase.master">ActiveMasterManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.278">activeMasterManager</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ActiveMasterManager.html" title="class in org.apache.hadoop.hbase.master">ActiveMasterManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.279">activeMasterManager</a></pre>
 </li>
 </ul>
 <a name="regionServerTracker">
@@ -1619,7 +1623,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>regionServerTracker</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionServerTracker.html" title="class in org.apache.hadoop.hbase.master">RegionServerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.280">regionServerTracker</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionServerTracker.html" title="class in org.apache.hadoop.hbase.master">RegionServerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.281">regionServerTracker</a></pre>
 </li>
 </ul>
 <a name="drainingServerTracker">
@@ -1628,7 +1632,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>drainingServerTracker</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/DrainingServerTracker.html" title="class in org.apache.hadoop.hbase.master">DrainingServerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.282">drainingServerTracker</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/DrainingServerTracker.html" title="class in org.apache.hadoop.hbase.master">DrainingServerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.283">drainingServerTracker</a></pre>
 </li>
 </ul>
 <a name="loadBalancerTracker">
@@ -1637,7 +1641,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>loadBalancerTracker</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/zookeeper/LoadBalancerTracker.html" title="class in org.apache.hadoop.hbase.zookeeper">LoadBalancerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.284">loadBalancerTracker</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/zookeeper/LoadBalancerTracker.html" title="class in org.apache.hadoop.hbase.zookeeper">LoadBalancerTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.285">loadBalancerTracker</a></pre>
 </li>
 </ul>
 <a name="metaLocationSyncer">
@@ -1646,7 +1650,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>metaLocationSyncer</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MetaLocationSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MetaLocationSyncer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.286">metaLocationSyncer</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MetaLocationSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MetaLocationSyncer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.287">metaLocationSyncer</a></pre>
 </li>
 </ul>
 <a name="masterAddressSyncer">
@@ -1656,7 +1660,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <li class="blockList">
 <h4>masterAddressSyncer</h4>
 <pre>@InterfaceAudience.Private
-<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MasterAddressSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MasterAddressSyncer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.289">masterAddressSyncer</a></pre>
+<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MasterAddressSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MasterAddressSyncer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.290">masterAddressSyncer</a></pre>
 </li>
 </ul>
 <a name="snapshotCleanupTracker">
@@ -1665,7 +1669,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>snapshotCleanupTracker</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/zookeeper/SnapshotCleanupTracker.html" title="class in org.apache.hadoop.hbase.zookeeper">SnapshotCleanupTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.291">snapshotCleanupTracker</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/zookeeper/SnapshotCleanupTracker.html" title="class in org.apache.hadoop.hbase.zookeeper">SnapshotCleanupTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.292">snapshotCleanupTracker</a></pre>
 </li>
 </ul>
 <a name="splitOrMergeTracker">
@@ -1674,7 +1678,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>splitOrMergeTracker</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master">SplitOrMergeTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.294">splitOrMergeTracker</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master">SplitOrMergeTracker</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.295">splitOrMergeTracker</a></pre>
 </li>
 </ul>
 <a name="clusterSchemaService">
@@ -1683,7 +1687,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>clusterSchemaService</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterSchemaService.html" title="interface in org.apache.hadoop.hbase.master">ClusterSchemaService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.296">clusterSchemaService</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterSchemaService.html" title="interface in org.apache.hadoop.hbase.master">ClusterSchemaService</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.297">clusterSchemaService</a></pre>
 </li>
 </ul>
 <a name="HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS">
@@ -1692,7 +1696,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</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/master/HMaster.html#line.298">HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</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/master/HMaster.html#line.299">HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS">Constant Field Values</a></dd>
@@ -1705,7 +1709,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</h4>
-<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.300">DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</a></pre>
+<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.301">DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS">Constant Field Values</a></dd>
@@ -1718,7 +1722,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>HBASE_MASTER_CLEANER_INTERVAL</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/master/HMaster.html#line.302">HBASE_MASTER_CLEANER_INTERVAL</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/master/HMaster.html#line.303">HBASE_MASTER_CLEANER_INTERVAL</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.HBASE_MASTER_CLEANER_INTERVAL">Constant Field Values</a></dd>
@@ -1731,7 +1735,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_HBASE_MASTER_CLEANER_INTERVAL</h4>
-<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.304">DEFAULT_HBASE_MASTER_CLEANER_INTERVAL</a></pre>
+<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.305">DEFAULT_HBASE_MASTER_CLEANER_INTERVAL</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.DEFAULT_HBASE_MASTER_CLEANER_INTERVAL">Constant Field Values</a></dd>
@@ -1744,7 +1748,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>metricsMaster</h4>
-<pre>final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMaster.html" title="class in org.apache.hadoop.hbase.master">MetricsMaster</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.307">metricsMaster</a></pre>
+<pre>final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMaster.html" title="class in org.apache.hadoop.hbase.master">MetricsMaster</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.308">metricsMaster</a></pre>
 </li>
 </ul>
 <a name="fileSystemManager">
@@ -1753,7 +1757,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>fileSystemManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterFileSystem.html" title="class in org.apache.hadoop.hbase.master">MasterFileSystem</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.309">fileSystemManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterFileSystem.html" title="class in org.apache.hadoop.hbase.master">MasterFileSystem</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.310">fileSystemManager</a></pre>
 </li>
 </ul>
 <a name="walManager">
@@ -1762,7 +1766,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>walManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterWalManager.html" title="class in org.apache.hadoop.hbase.master">MasterWalManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.310">walManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterWalManager.html" title="class in org.apache.hadoop.hbase.master">MasterWalManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.311">walManager</a></pre>
 </li>
 </ul>
 <a name="splitWALManager">
@@ -1771,7 +1775,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>splitWALManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitWALManager.html" title="class in org.apache.hadoop.hbase.master">SplitWALManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.317">splitWALManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitWALManager.html" title="class in org.apache.hadoop.hbase.master">SplitWALManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.318">splitWALManager</a></pre>
 </li>
 </ul>
 <a name="serverManager">
@@ -1780,7 +1784,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>serverManager</h4>
-<pre>private volatile&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.320">serverManager</a></pre>
+<pre>private volatile&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.321">serverManager</a></pre>
 </li>
 </ul>
 <a name="assignmentManager">
@@ -1789,7 +1793,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>assignmentManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.323">assignmentManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.324">assignmentManager</a></pre>
 </li>
 </ul>
 <a name="rsGroupInfoManager">
@@ -1798,7 +1802,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>rsGroupInfoManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupInfoManager.html" title="interface in org.apache.hadoop.hbase.rsgroup">RSGroupInfoManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.325">rsGroupInfoManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupInfoManager.html" title="interface in org.apache.hadoop.hbase.rsgroup">RSGroupInfoManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.326">rsGroupInfoManager</a></pre>
 </li>
 </ul>
 <a name="replicationPeerManager">
@@ -1807,7 +1811,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>replicationPeerManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication">ReplicationPeerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.328">replicationPeerManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication">ReplicationPeerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.329">replicationPeerManager</a></pre>
 </li>
 </ul>
 <a name="syncReplicationReplayWALManager">
@@ -1816,7 +1820,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>syncReplicationReplayWALManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication">SyncReplicationReplayWALManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.330">syncReplicationReplayWALManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication">SyncReplicationReplayWALManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.331">syncReplicationReplayWALManager</a></pre>
 </li>
 </ul>
 <a name="rsFatals">
@@ -1825,7 +1829,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>rsFatals</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/monitoring/MemoryBoundedLogMessageBuffer.html" title="class in org.apache.hadoop.hbase.monitoring">MemoryBoundedLogMessageBuffer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.335">rsFatals</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/monitoring/MemoryBoundedLogMessageBuffer.html" title="class in org.apache.hadoop.hbase.monitoring">MemoryBoundedLogMessageBuffer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.336">rsFatals</a></pre>
 </li>
 </ul>
 <a name="activeMaster">
@@ -1834,7 +1838,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>activeMaster</h4>
-<pre>private volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.338">activeMaster</a></pre>
+<pre>private volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.339">activeMaster</a></pre>
 </li>
 </ul>
 <a name="initialized">
@@ -1843,7 +1847,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>initialized</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureEvent.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureEvent</a>&lt;?&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.341">initialized</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureEvent.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureEvent</a>&lt;?&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.342">initialized</a></pre>
 </li>
 </ul>
 <a name="serviceStarted">
@@ -1852,7 +1856,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>serviceStarted</h4>
-<pre>volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.345">serviceStarted</a></pre>
+<pre>volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.346">serviceStarted</a></pre>
 </li>
 </ul>
 <a name="maxBalancingTime">
@@ -1861,7 +1865,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>maxBalancingTime</h4>
-<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.348">maxBalancingTime</a></pre>
+<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.349">maxBalancingTime</a></pre>
 </li>
 </ul>
 <a name="maxRitPercent">
@@ -1870,7 +1874,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>maxRitPercent</h4>
-<pre>private final&nbsp;double <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.350">maxRitPercent</a></pre>
+<pre>private final&nbsp;double <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.351">maxRitPercent</a></pre>
 </li>
 </ul>
 <a name="lockManager">
@@ -1879,7 +1883,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>lockManager</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/locking/LockManager.html" title="class in org.apache.hadoop.hbase.master.locking">LockManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.352">lockManager</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/locking/LockManager.html" title="class in org.apache.hadoop.hbase.master.locking">LockManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.353">lockManager</a></pre>
 </li>
 </ul>
 <a name="balancer">
@@ -1888,7 +1892,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>balancer</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupBasedLoadBalancer.html" title="class in org.apache.hadoop.hbase.rsgroup">RSGroupBasedLoadBalancer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.354">balancer</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupBasedLoadBalancer.html" title="class in org.apache.hadoop.hbase.rsgroup">RSGroupBasedLoadBalancer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.355">balancer</a></pre>
 </li>
 </ul>
 <a name="balancerChore">
@@ -1897,7 +1901,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>balancerChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/balancer/BalancerChore.html" title="class in org.apache.hadoop.hbase.master.balancer">BalancerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.355">balancerChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/balancer/BalancerChore.html" title="class in org.apache.hadoop.hbase.master.balancer">BalancerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.356">balancerChore</a></pre>
 </li>
 </ul>
 <a name="regionNormalizerManager">
@@ -1906,7 +1910,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>regionNormalizerManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/normalizer/RegionNormalizerManager.html" title="class in org.apache.hadoop.hbase.master.normalizer">RegionNormalizerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.356">regionNormalizerManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/normalizer/RegionNormalizerManager.html" title="class in org.apache.hadoop.hbase.master.normalizer">RegionNormalizerManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.357">regionNormalizerManager</a></pre>
 </li>
 </ul>
 <a name="clusterStatusChore">
@@ -1915,7 +1919,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>clusterStatusChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/balancer/ClusterStatusChore.html" title="class in org.apache.hadoop.hbase.master.balancer">ClusterStatusChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.357">clusterStatusChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/balancer/ClusterStatusChore.html" title="class in org.apache.hadoop.hbase.master.balancer">ClusterStatusChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.358">clusterStatusChore</a></pre>
 </li>
 </ul>
 <a name="clusterStatusPublisherChore">
@@ -1924,7 +1928,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>clusterStatusPublisherChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterStatusPublisher.html" title="class in org.apache.hadoop.hbase.master">ClusterStatusPublisher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.358">clusterStatusPublisherChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterStatusPublisher.html" title="class in org.apache.hadoop.hbase.master">ClusterStatusPublisher</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.359">clusterStatusPublisherChore</a></pre>
 </li>
 </ul>
 <a name="snapshotCleanerChore">
@@ -1933,7 +1937,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>snapshotCleanerChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/SnapshotCleanerChore.html" title="class in org.apache.hadoop.hbase.master.cleaner">SnapshotCleanerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.359">snapshotCleanerChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/SnapshotCleanerChore.html" title="class in org.apache.hadoop.hbase.master.cleaner">SnapshotCleanerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.360">snapshotCleanerChore</a></pre>
 </li>
 </ul>
 <a name="hbckChore">
@@ -1942,7 +1946,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>hbckChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HbckChore.html" title="class in org.apache.hadoop.hbase.master">HbckChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.361">hbckChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HbckChore.html" title="class in org.apache.hadoop.hbase.master">HbckChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.362">hbckChore</a></pre>
 </li>
 </ul>
 <a name="catalogJanitorChore">
@@ -1951,7 +1955,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>catalogJanitorChore</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/master/janitor/CatalogJanitor.html" title="class in org.apache.hadoop.hbase.master.janitor">CatalogJanitor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.362">catalogJanitorChore</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/master/janitor/CatalogJanitor.html" title="class in org.apache.hadoop.hbase.master.janitor">CatalogJanitor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.363">catalogJanitorChore</a></pre>
 </li>
 </ul>
 <a name="cleanerPool">
@@ -1960,7 +1964,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>cleanerPool</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/DirScanPool.html" title="class in org.apache.hadoop.hbase.master.cleaner">DirScanPool</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.363">cleanerPool</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/DirScanPool.html" title="class in org.apache.hadoop.hbase.master.cleaner">DirScanPool</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.364">cleanerPool</a></pre>
 </li>
 </ul>
 <a name="logCleaner">
@@ -1969,7 +1973,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>logCleaner</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/LogCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">LogCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.364">logCleaner</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/LogCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">LogCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.365">logCleaner</a></pre>
 </li>
 </ul>
 <a name="hfileCleaner">
@@ -1978,7 +1982,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>hfileCleaner</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">HFileCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.365">hfileCleaner</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">HFileCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.366">hfileCleaner</a></pre>
 </li>
 </ul>
 <a name="replicationBarrierCleaner">
@@ -1987,7 +1991,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>replicationBarrierCleaner</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/ReplicationBarrierCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">ReplicationBarrierCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.366">replicationBarrierCleaner</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/ReplicationBarrierCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">ReplicationBarrierCleaner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.367">replicationBarrierCleaner</a></pre>
 </li>
 </ul>
 <a name="mobFileCleanerChore">
@@ -1996,7 +2000,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>mobFileCleanerChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCleanerChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCleanerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.367">mobFileCleanerChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCleanerChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCleanerChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.368">mobFileCleanerChore</a></pre>
 </li>
 </ul>
 <a name="mobFileCompactionChore">
@@ -2005,7 +2009,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>mobFileCompactionChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCompactionChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCompactionChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.368">mobFileCompactionChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/mob/MobFileCompactionChore.html" title="class in org.apache.hadoop.hbase.mob">MobFileCompactionChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.369">mobFileCompactionChore</a></pre>
 </li>
 </ul>
 <a name="mobCompactionLock">
@@ -2014,7 +2018,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>mobCompactionLock</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/IdLock.html" title="class in org.apache.hadoop.hbase.util">IdLock</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.370">mobCompactionLock</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/IdLock.html" title="class in org.apache.hadoop.hbase.util">IdLock</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.371">mobCompactionLock</a></pre>
 </li>
 </ul>
 <a name="mobCompactionStates">
@@ -2023,7 +2027,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>mobCompactionStates</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/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a>&gt; <a href="../../../.. [...]
+<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/concurrent/atomic/AtomicInteger.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicInteger</a>&gt; <a href="../../../.. [...]
 </li>
 </ul>
 <a name="cpHost">
@@ -2032,7 +2036,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>cpHost</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/master/MasterCoprocessorHost.html" title="class in org.apache.hadoop.hbase.master">MasterCoprocessorHost</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.375">cpHost</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/master/MasterCoprocessorHost.html" title="class in org.apache.hadoop.hbase.master">MasterCoprocessorHost</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.376">cpHost</a></pre>
 </li>
 </ul>
 <a name="preLoadTableDescriptors">
@@ -2041,7 +2045,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>preLoadTableDescriptors</h4>
-<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.377">preLoadTableDescriptors</a></pre>
+<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.378">preLoadTableDescriptors</a></pre>
 </li>
 </ul>
 <a name="masterActiveTime">
@@ -2050,7 +2054,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>masterActiveTime</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.380">masterActiveTime</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.381">masterActiveTime</a></pre>
 </li>
 </ul>
 <a name="masterFinishedInitializationTime">
@@ -2059,7 +2063,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>masterFinishedInitializationTime</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.383">masterFinishedInitializationTime</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.384">masterFinishedInitializationTime</a></pre>
 </li>
 </ul>
 <a name="coprocessorServiceHandlers">
@@ -2068,7 +2072,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>coprocessorServiceHandlers</h4>
-<pre><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>,org.apache.hbase.thirdparty.com.google.protobuf.Service&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.385">coprocessorServiceHandlers</a></pre>
+<pre><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>,org.apache.hbase.thirdparty.com.google.protobuf.Service&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.386">coprocessorServiceHandlers</a></pre>
 </li>
 </ul>
 <a name="snapshotManager">
@@ -2077,7 +2081,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>snapshotManager</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/master/snapshot/SnapshotManager.html" title="class in org.apache.hadoop.hbase.master.snapshot">SnapshotManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.388">snapshotManager</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/master/snapshot/SnapshotManager.html" title="class in org.apache.hadoop.hbase.master.snapshot">SnapshotManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.389">snapshotManager</a></pre>
 </li>
 </ul>
 <a name="mpmHost">
@@ -2086,7 +2090,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>mpmHost</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure/MasterProcedureManagerHost.html" title="class in org.apache.hadoop.hbase.procedure">MasterProcedureManagerHost</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.390">mpmHost</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure/MasterProcedureManagerHost.html" title="class in org.apache.hadoop.hbase.procedure">MasterProcedureManagerHost</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.391">mpmHost</a></pre>
 </li>
 </ul>
 <a name="regionsRecoveryChore">
@@ -2095,7 +2099,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>regionsRecoveryChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryChore.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.392">regionsRecoveryChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryChore.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.393">regionsRecoveryChore</a></pre>
 </li>
 </ul>
 <a name="regionsRecoveryConfigManager">
@@ -2104,7 +2108,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>regionsRecoveryConfigManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryConfigManager.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryConfigManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.394">regionsRecoveryConfigManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/RegionsRecoveryConfigManager.html" title="class in org.apache.hadoop.hbase.master">RegionsRecoveryConfigManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.395">regionsRecoveryConfigManager</a></pre>
 </li>
 </ul>
 <a name="quotaManager">
@@ -2113,7 +2117,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>quotaManager</h4>
-<pre>private volatile&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/MasterQuotaManager.html" title="class in org.apache.hadoop.hbase.quotas">MasterQuotaManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.396">quotaManager</a></pre>
+<pre>private volatile&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/MasterQuotaManager.html" title="class in org.apache.hadoop.hbase.quotas">MasterQuotaManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.397">quotaManager</a></pre>
 </li>
 </ul>
 <a name="spaceQuotaSnapshotNotifier">
@@ -2122,7 +2126,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>spaceQuotaSnapshotNotifier</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.397">spaceQuotaSnapshotNotifier</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.398">spaceQuotaSnapshotNotifier</a></pre>
 </li>
 </ul>
 <a name="quotaObserverChore">
@@ -2131,7 +2135,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>quotaObserverChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">QuotaObserverChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.398">quotaObserverChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">QuotaObserverChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.399">quotaObserverChore</a></pre>
 </li>
 </ul>
 <a name="snapshotQuotaChore">
@@ -2140,7 +2144,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>snapshotQuotaChore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">SnapshotQuotaObserverChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.399">snapshotQuotaChore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">SnapshotQuotaObserverChore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.400">snapshotQuotaChore</a></pre>
 </li>
 </ul>
 <a name="procedureExecutor">
@@ -2149,7 +2153,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>procedureExecutor</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureExecutor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.401">procedureExecutor</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureExecutor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.402">procedureExecutor</a></pre>
 </li>
 </ul>
 <a name="procedureStore">
@@ -2158,7 +2162,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>procedureStore</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/store/ProcedureStore.html" title="interface in org.apache.hadoop.hbase.procedure2.store">ProcedureStore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.402">procedureStore</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/store/ProcedureStore.html" title="interface in org.apache.hadoop.hbase.procedure2.store">ProcedureStore</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.403">procedureStore</a></pre>
 </li>
 </ul>
 <a name="masterRegion">
@@ -2167,7 +2171,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>masterRegion</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.405">masterRegion</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.406">masterRegion</a></pre>
 </li>
 </ul>
 <a name="tableStateManager">
@@ -2176,7 +2180,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>tableStateManager</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.408">tableStateManager</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.409">tableStateManager</a></pre>
 </li>
 </ul>
 <a name="masterJettyServer">
@@ -2185,7 +2189,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>masterJettyServer</h4>
-<pre>private&nbsp;org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.411">masterJettyServer</a></pre>
+<pre>private&nbsp;org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.412">masterJettyServer</a></pre>
 <div class="block">jetty server for master to redirect requests to regionserver infoServer</div>
 </li>
 </ul>
@@ -2195,7 +2199,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>maintenanceMode</h4>
-<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.415">maintenanceMode</a></pre>
+<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.416">maintenanceMode</a></pre>
 </li>
 </ul>
 <a name="MAINTENANCE_MODE">
@@ -2204,20 +2208,29 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>MAINTENANCE_MODE</h4>
-<pre>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/master/HMaster.html#line.416">MAINTENANCE_MODE</a></pre>
+<pre>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/master/HMaster.html#line.417">MAINTENANCE_MODE</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.master.HMaster.MAINTENANCE_MODE">Constant Field Values</a></dd>
 </dl>
 </li>
 </ul>
+<a name="maintenanceRegionServer">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>maintenanceRegionServer</h4>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.420">maintenanceRegionServer</a></pre>
+</li>
+</ul>
 <a name="cachedClusterId">
 <!--   -->
 </a>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>cachedClusterId</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/CachedClusterId.html" title="class in org.apache.hadoop.hbase.master">CachedClusterId</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.419">cachedClusterId</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/CachedClusterId.html" title="class in org.apache.hadoop.hbase.master">CachedClusterId</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.423">cachedClusterId</a></pre>
 </li>
 </ul>
 </li>
@@ -2234,7 +2247,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HMaster</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.433">HMaster</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.437">HMaster</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">Initializes the HMaster. The steps are as follows:
  <p>
@@ -2266,7 +2279,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>createActiveMasterManager</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ActiveMasterManager.html" title="class in org.apache.hadoop.hbase.master">ActiveMasterManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.508">createActiveMasterManager</a>(<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;zk,
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ActiveMasterManager.html" title="class in org.apache.hadoop.hbase.master">ActiveMasterManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.512">createActiveMasterManager</a>(<a href="../../../../../org/apache/hadoop/hbase/zookeeper/ZKWatcher.html" title="class in org.apache.hadoop.hbase.zookeeper">ZKWatcher</a>&nbsp;zk,
                                                         <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn,
                                                         <a href="../../../../../org/apache/hadoop/hbase/Server.html" title="interface in org.apache.hadoop.hbase">Server</a>&nbsp;server)
                                                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/InterruptedIOException.html?is-external=true" title="class or interface in java.io">InterruptedIOException</a></pre>
@@ -2284,7 +2297,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>getUseThisHostnameInstead</h4>
-<pre>protected&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/master/HMaster.html#line.514">getUseThisHostnameInstead</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>protected&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/master/HMaster.html#line.518">getUseThisHostnameInstead</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#getUseThisHostnameInstead-org.apache.hadoop.conf.Configuration-">getUseThisHostnameInstead</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2297,7 +2310,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>run</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.521">run</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.525">run</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#run--">HRegionServer</a></code></span></div>
 <div class="block">The HRegionServer sticks in this loop until closed.</div>
 <dl>
@@ -2314,7 +2327,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>putUpJettyServer</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.557">putUpJettyServer</a>()
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.561">putUpJettyServer</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="throwsLabel">Throws:</span></dt>
@@ -2328,7 +2341,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>login</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.612">login</a>(<a href="../../../../../org/apache/hadoop/hbase/security/UserProvider.html" title="class in org.apache.hadoop.hbase.security">UserProvider</a>&nbsp;user,
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.616">login</a>(<a href="../../../../../org/apache/hadoop/hbase/security/UserProvider.html" title="class in org.apache.hadoop.hbase.security">UserProvider</a>&nbsp;user,
                      <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;host)
               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">For compatibility, if failed with regionserver credentials, try the master one</div>
@@ -2346,7 +2359,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>waitForMasterActive</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.625">waitForMasterActive</a>()</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.629">waitForMasterActive</a>()</pre>
 <div class="block">Loop till the server is stopped or aborted.</div>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
@@ -2361,7 +2374,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <li class="blockList">
 <h4>getMasterRpcServices</h4>
 <pre>@InterfaceAudience.Private
-public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.html" title="class in org.apache.hadoop.hbase.master">MasterRpcServices</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.635">getMasterRpcServices</a>()</pre>
+public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.html" title="class in org.apache.hadoop.hbase.master">MasterRpcServices</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.636">getMasterRpcServices</a>()</pre>
 </li>
 </ul>
 <a name="balanceSwitch-boolean-">
@@ -2370,7 +2383,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>balanceSwitch</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.639">balanceSwitch</a>(boolean&nbsp;b)
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.640">balanceSwitch</a>(boolean&nbsp;b)
                       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>
@@ -2384,7 +2397,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>getProcessName</h4>
-<pre>protected&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/master/HMaster.html#line.644">getProcessName</a>()</pre>
+<pre>protected&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/master/HMaster.html#line.645">getProcessName</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#getProcessName--">getProcessName</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2397,7 +2410,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>canCreateBaseZNode</h4>
-<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.649">canCreateBaseZNode</a>()</pre>
+<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.650">canCreateBaseZNode</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#canCreateBaseZNode--">canCreateBaseZNode</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2410,7 +2423,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>canUpdateTableDescriptor</h4>
-<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.654">canUpdateTableDescriptor</a>()</pre>
+<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.655">canUpdateTableDescriptor</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#canUpdateTableDescriptor--">canUpdateTableDescriptor</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2423,7 +2436,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>cacheTableDescriptor</h4>
-<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.659">cacheTableDescriptor</a>()</pre>
+<pre>protected&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.660">cacheTableDescriptor</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#cacheTableDescriptor--">cacheTableDescriptor</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2436,7 +2449,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>createRpcServices</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RSRpcServices.html" title="class in org.apache.hadoop.hbase.regionserver">RSRpcServices</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.664">createRpcServices</a>()
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RSRpcServices.html" title="class in org.apache.hadoop.hbase.regionserver">RSRpcServices</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.665">createRpcServices</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">Overrides:</span></dt>
@@ -2452,7 +2465,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>configureInfoServer</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.669">configureInfoServer</a>()</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.670">configureInfoServer</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#configureInfoServer--">configureInfoServer</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2465,7 +2478,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>getDumpServlet</h4>
-<pre>protected&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends javax.servlet.http.HttpServlet&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.678">getDumpServlet</a>()</pre>
+<pre>protected&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends javax.servlet.http.HttpServlet&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.676">getDumpServlet</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#getDumpServlet--">getDumpServlet</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -2478,7 +2491,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterMetrics</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMaster.html" title="class in org.apache.hadoop.hbase.master">MetricsMaster</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.683">getMasterMetrics</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMaster.html" title="class in org.apache.hadoop.hbase.master">MetricsMaster</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.681">getMasterMetrics</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterMetrics--">getMasterMetrics</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2493,7 +2506,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <ul class="blockList">
 <li class="blockList">
 <h4>initializeZKBasedSystemTrackers</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.691">initializeZKBasedSystemTrackers</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.689">initializeZKBasedSystemTrackers</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="../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a></pre>
@@ -2514,7 +2527,7 @@ public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServ
 <li class="blockList">
 <h4>createAssignmentManager</h4>
 <pre>@InterfaceAudience.Private
-protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.770">createAssignmentManager</a>(<a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a>&nbsp;master,
+protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.768">createAssignmentManager</a>(<a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a>&nbsp;master,
                                                                                <a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a>&nbsp;masterRegion)</pre>
 </li>
 </ul>
@@ -2524,7 +2537,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment
 <ul class="blockList">
 <li class="blockList">
 <h4>tryMigrateMetaLocationsFromZooKeeper</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.775">tryMigrateMetaLocationsFromZooKeeper</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.773">tryMigrateMetaLocationsFromZooKeeper</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</pre>
 <dl>
@@ -2540,7 +2553,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment
 <ul class="blockList">
 <li class="blockList">
 <h4>finishActiveMasterInitialization</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.853">finishActiveMasterInitialization</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.851">finishActiveMasterInitialization</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
                                        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,
@@ -2596,7 +2609,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment
 <ul class="blockList">
 <li class="blockList">
 <h4>createMissingCFsInMetaDuringUpgrade</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1213">createMissingCFsInMetaDuringUpgrade</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;metaDescriptor)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1216">createMissingCFsInMetaDuringUpgrade</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;metaDescriptor)
                                           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>
@@ -2611,7 +2624,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment
 <li class="blockList">
 <h4>waitForMetaOnline</h4>
 <pre>@InterfaceAudience.Private
-public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1251">waitForMetaOnline</a>()</pre>
+public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1254">waitForMetaOnline</a>()</pre>
 <div class="block">Check hbase:meta is up and ready for reading. For use during Master startup only.</div>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
@@ -2626,7 +2639,7 @@ public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isRegionOnline</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1259">isRegionOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;ri)</pre>
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1262">isRegionOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;ri)</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>True if region is online and scannable else false if an error or shutdown (Otherwise
@@ -2640,7 +2653,7 @@ public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>waitForNamespaceOnline</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1294">waitForNamespaceOnline</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1297">waitForNamespaceOnline</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">Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table
  <p/>
@@ -2662,7 +2675,7 @@ public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <li class="blockList">
 <h4>updateConfigurationForQuotasObserver</h4>
 <pre>@InterfaceAudience.Private
-public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1322">updateConfigurationForQuotasObserver</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1325">updateConfigurationForQuotasObserver</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block">Adds the <code>MasterQuotasObserver</code> to the list of configured Master observers to
  automatically remove quotas for a table when that table is deleted.</div>
 </li>
@@ -2673,7 +2686,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>initMobCleaner</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1339">initMobCleaner</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1342">initMobCleaner</a>()</pre>
 </li>
 </ul>
 <a name="createServerManager-org.apache.hadoop.hbase.master.MasterServices-">
@@ -2683,7 +2696,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <li class="blockList">
 <h4>createServerManager</h4>
 <pre>@InterfaceAudience.Private
-protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1355">createServerManager</a>(<a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a>&nbsp;master)
+protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1358">createServerManager</a>(<a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a>&nbsp;master)
                                                                 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"><p>
  Create a <a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master"><code>ServerManager</code></a> instance.
@@ -2703,7 +2716,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerMana
 <ul class="blockList">
 <li class="blockList">
 <h4>waitForRegionServers</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1362">waitForRegionServers</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1365">waitForRegionServers</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
                            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>
 <dl>
@@ -2720,7 +2733,7 @@ protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerMana
 <li class="blockList">
 <h4>initClusterSchemaService</h4>
 <pre>@InterfaceAudience.Private
-protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1369">initClusterSchemaService</a>()
+protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1372">initClusterSchemaService</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>
 <dl>
@@ -2736,7 +2749,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>initQuotaManager</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1381">initQuotaManager</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1384">initQuotaManager</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="throwsLabel">Throws:</span></dt>
@@ -2750,7 +2763,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>createQuotaSnapshotNotifier</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1387">createQuotaSnapshotNotifier</a>()</pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1390">createQuotaSnapshotNotifier</a>()</pre>
 </li>
 </ul>
 <a name="isCatalogJanitorEnabled--">
@@ -2759,7 +2772,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isCatalogJanitorEnabled</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1393">isCatalogJanitorEnabled</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1396">isCatalogJanitorEnabled</a>()</pre>
 </li>
 </ul>
 <a name="isCleanerChoreEnabled--">
@@ -2768,7 +2781,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isCleanerChoreEnabled</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1397">isCleanerChoreEnabled</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1400">isCleanerChoreEnabled</a>()</pre>
 </li>
 </ul>
 <a name="getServerManager--">
@@ -2777,7 +2790,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getServerManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1412">getServerManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html" title="class in org.apache.hadoop.hbase.master">ServerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1415">getServerManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getServerManager--">getServerManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2792,7 +2805,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterFileSystem</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterFileSystem.html" title="class in org.apache.hadoop.hbase.master">MasterFileSystem</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1417">getMasterFileSystem</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterFileSystem.html" title="class in org.apache.hadoop.hbase.master">MasterFileSystem</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1420">getMasterFileSystem</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterFileSystem--">getMasterFileSystem</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2807,7 +2820,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterWalManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterWalManager.html" title="class in org.apache.hadoop.hbase.master">MasterWalManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1422">getMasterWalManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterWalManager.html" title="class in org.apache.hadoop.hbase.master">MasterWalManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1425">getMasterWalManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterWalManager--">getMasterWalManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2822,7 +2835,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getSplitWALManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitWALManager.html" title="class in org.apache.hadoop.hbase.master">SplitWALManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1427">getSplitWALManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitWALManager.html" title="class in org.apache.hadoop.hbase.master">SplitWALManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1430">getSplitWALManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getSplitWALManager--">getSplitWALManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2837,7 +2850,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableStateManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1432">getTableStateManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/TableStateManager.html" title="class in org.apache.hadoop.hbase.master">TableStateManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1435">getTableStateManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getTableStateManager--">getTableStateManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -2852,7 +2865,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>startServiceThreads</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1443">startServiceThreads</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1446">startServiceThreads</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="throwsLabel">Throws:</span></dt>
@@ -2866,7 +2879,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>stopServiceThreads</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1540">stopServiceThreads</a>()</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1543">stopServiceThreads</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#stopServiceThreads--">HRegionServer</a></code></span></div>
 <div class="block">Wait on all threads to finish. Presumption is that all closes and stops
  have already been called.</div>
@@ -2882,7 +2895,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>createProcedureExecutor</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1598">createProcedureExecutor</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1603">createProcedureExecutor</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="throwsLabel">Throws:</span></dt>
@@ -2896,7 +2909,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>startProcedureExecutor</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1630">startProcedureExecutor</a>()
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1635">startProcedureExecutor</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="throwsLabel">Throws:</span></dt>
@@ -2910,7 +2923,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>switchSnapshotCleanup</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1639">switchSnapshotCleanup</a>(boolean&nbsp;on,
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1644">switchSnapshotCleanup</a>(boolean&nbsp;on,
                            boolean&nbsp;synchronous)</pre>
 <div class="block">Turn on/off Snapshot Cleanup Chore</div>
 <dl>
@@ -2925,7 +2938,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>switchSnapshotCleanup</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1649">switchSnapshotCleanup</a>(boolean&nbsp;on)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1654">switchSnapshotCleanup</a>(boolean&nbsp;on)</pre>
 </li>
 </ul>
 <a name="stopProcedureExecutor--">
@@ -2934,7 +2947,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>stopProcedureExecutor</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1663">stopProcedureExecutor</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1668">stopProcedureExecutor</a>()</pre>
 </li>
 </ul>
 <a name="stopChores--">
@@ -2943,7 +2956,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>stopChores</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1678">stopChores</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1683">stopChores</a>()</pre>
 </li>
 </ul>
 <a name="getRemoteInetAddress-int-long-">
@@ -2952,7 +2965,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getRemoteInetAddress</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/net/InetAddress.html?is-external=true" title="class or interface in java.net">InetAddress</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1702">getRemoteInetAddress</a>(int&nbsp;port,
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/net/InetAddress.html?is-external=true" title="class or interface in java.net">InetAddress</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1707">getRemoteInetAddress</a>(int&nbsp;port,
                                  long&nbsp;serverStartCode)
                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/net/UnknownHostException.html?is-external=true" title="class or interface in java.net">UnknownHostException</a></pre>
 <dl>
@@ -2969,7 +2982,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxBalancingTime</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1722">getMaxBalancingTime</a>()</pre>
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1727">getMaxBalancingTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>Maximum time we should run balancer for</dd>
@@ -2982,7 +2995,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getMaxRegionsInTransition</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1733">getMaxRegionsInTransition</a>()</pre>
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1738">getMaxRegionsInTransition</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>Maximum number of regions in transition</dd>
@@ -2995,7 +3008,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>balanceThrottling</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1745">balanceThrottling</a>(long&nbsp;nextBalanceStartTime,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1750">balanceThrottling</a>(long&nbsp;nextBalanceStartTime,
                                int&nbsp;maxRegionsInTransition,
                                long&nbsp;cutoffTime)</pre>
 <div class="block">It first sleep to the next balance plan start time. Meanwhile, throttling by the max
@@ -3014,7 +3027,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>balance</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/BalanceResponse.html" title="class in org.apache.hadoop.hbase.client">BalanceResponse</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1776">balance</a>()
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/BalanceResponse.html" title="class in org.apache.hadoop.hbase.client">BalanceResponse</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1781">balance</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="throwsLabel">Throws:</span></dt>
@@ -3028,7 +3041,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>skipRegionManagementAction</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1786">skipRegionManagementAction</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;action)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1791">skipRegionManagementAction</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;action)</pre>
 <div class="block">Checks master state before initiating action over region topology.</div>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -3046,7 +3059,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>balance</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/BalanceResponse.html" title="class in org.apache.hadoop.hbase.client">BalanceResponse</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1803">balance</a>(<a href="../../../../../org/apache/hadoop/hbase/client/BalanceRequest.html" title="class in org.apache.hadoop.hbase.client">BalanceRequest</a>&nbsp;request)
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/BalanceResponse.html" title="class in org.apache.hadoop.hbase.client">BalanceResponse</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1808">balance</a>(<a href="../../../../../org/apache/hadoop/hbase/client/BalanceRequest.html" title="class in org.apache.hadoop.hbase.client">BalanceRequest</a>&nbsp;request)
                         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>
@@ -3060,7 +3073,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>executeRegionPlansWithThrottling</h4>
-<pre>public&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/master/RegionPlan.html" title="class in org.apache.hadoop.hbase.master">RegionPlan</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1902">executeRegionPlansWithThrottling</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List [...]
+<pre>public&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/master/RegionPlan.html" title="class in org.apache.hadoop.hbase.master">RegionPlan</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1907">executeRegionPlansWithThrottling</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List [...]
 <div class="block">Execute region plans with throttling</div>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -3078,7 +3091,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionNormalizerManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/normalizer/RegionNormalizerManager.html" title="class in org.apache.hadoop.hbase.master.normalizer">RegionNormalizerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1950">getRegionNormalizerManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/normalizer/RegionNormalizerManager.html" title="class in org.apache.hadoop.hbase.master.normalizer">RegionNormalizerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1955">getRegionNormalizerManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getRegionNormalizerManager--">getRegionNormalizerManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3093,7 +3106,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>normalizeRegions</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1955">normalizeRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/client/NormalizeTableFilterParams.html" title="class in org.apache.hadoop.hbase.client">NormalizeTableFilterParams</a>&nbsp;ntfp,
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1960">normalizeRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/client/NormalizeTableFilterParams.html" title="class in org.apache.hadoop.hbase.client">NormalizeTableFilterParams</a>&nbsp;ntfp,
                                 boolean&nbsp;isHighPriority)
                          throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#normalizeRegions-org.apache.hadoop.hbase.client.NormalizeTableFilterParams-boolean-">MasterServices</a></code></span></div>
@@ -3118,7 +3131,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>getClientIdAuditPrefix</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/master/HMaster.html#line.1987">getClientIdAuditPrefix</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/master/HMaster.html#line.1992">getClientIdAuditPrefix</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getClientIdAuditPrefix--">getClientIdAuditPrefix</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3133,7 +3146,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>setCatalogJanitorEnabled</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1998">setCatalogJanitorEnabled</a>(boolean&nbsp;b)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2003">setCatalogJanitorEnabled</a>(boolean&nbsp;b)</pre>
 <div class="block">Switch for the background CatalogJanitor thread.
  Used for testing.  The thread will continue to run.  It will just be a noop
  if disabled.</div>
@@ -3149,7 +3162,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>mergeRegions</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2003">mergeRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>[]&nbsp;regionsToMerge,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2008">mergeRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>[]&nbsp;regionsToMerge,
                          boolean&nbsp;forcible,
                          long&nbsp;ng,
                          long&nbsp;nonce)
@@ -3177,7 +3190,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>splitRegion</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2038">splitRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;regionInfo,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2043">splitRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;regionInfo,
                         byte[]&nbsp;splitRow,
                         long&nbsp;nonceGroup,
                         long&nbsp;nonce)
@@ -3205,7 +3218,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>warmUpRegion</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2067">warmUpRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;server,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2072">warmUpRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;server,
                           <a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;region)</pre>
 </li>
 </ul>
@@ -3216,7 +3229,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <li class="blockList">
 <h4>move</h4>
 <pre>@InterfaceAudience.Private
-public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2080">move</a>(byte[]&nbsp;encodedRegionName,
+public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2085">move</a>(byte[]&nbsp;encodedRegionName,
                                             byte[]&nbsp;destServerName)
                                      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>
@@ -3231,7 +3244,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>createTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2172">createTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;tableDescriptor,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2177">createTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;tableDescriptor,
                         byte[][]&nbsp;splitKeys,
                         long&nbsp;nonceGroup,
                         long&nbsp;nonce)
@@ -3256,7 +3269,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>createSystemTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2214">createSystemTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;tableDescriptor)
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2219">createSystemTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;tableDescriptor)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#createSystemTable-org.apache.hadoop.hbase.client.TableDescriptor-">MasterServices</a></code></span></div>
 <div class="block">Create a system table using the given table definition.</div>
@@ -3277,7 +3290,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>startActiveMasterManager</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2237">startActiveMasterManager</a>(int&nbsp;infoPort)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2242">startActiveMasterManager</a>(int&nbsp;infoPort)
                                throws org.apache.zookeeper.KeeperException</pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -3291,7 +3304,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>isCatalogTable</h4>
-<pre>private static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2290">isCatalogTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>private static&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2295">isCatalogTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 </li>
 </ul>
 <a name="deleteTable-org.apache.hadoop.hbase.TableName-long-long-">
@@ -3300,7 +3313,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2295">deleteTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2300">deleteTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                         long&nbsp;nonceGroup,
                         long&nbsp;nonce)
                  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>
@@ -3322,7 +3335,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>truncateTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2329">truncateTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2334">truncateTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                           boolean&nbsp;preserveSplits,
                           long&nbsp;nonceGroup,
                           long&nbsp;nonce)
@@ -3346,7 +3359,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>addColumn</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2359">addColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2364">addColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                       <a href="../../../../../org/apache/hadoop/hbase/client/ColumnFamilyDescriptor.html" title="interface in org.apache.hadoop.hbase.client">ColumnFamilyDescriptor</a>&nbsp;column,
                       long&nbsp;nonceGroup,
                       long&nbsp;nonce)
@@ -3370,7 +3383,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>modifyColumn</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2387">modifyColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2392">modifyColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                          <a href="../../../../../org/apache/hadoop/hbase/client/ColumnFamilyDescriptor.html" title="interface in org.apache.hadoop.hbase.client">ColumnFamilyDescriptor</a>&nbsp;descriptor,
                          long&nbsp;nonceGroup,
                          long&nbsp;nonce)
@@ -3394,7 +3407,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteColumn</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2407">deleteColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2412">deleteColumn</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                          byte[]&nbsp;columnName,
                          long&nbsp;nonceGroup,
                          long&nbsp;nonce)
@@ -3418,7 +3431,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>enableTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2432">enableTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2437">enableTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                         long&nbsp;nonceGroup,
                         long&nbsp;nonce)
                  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>
@@ -3440,7 +3453,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>disableTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2487">disableTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2492">disableTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                          long&nbsp;nonceGroup,
                          long&nbsp;nonce)
                   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>
@@ -3462,7 +3475,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>modifyTable</h4>
-<pre>private&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2522">modifyTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>private&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2527">modifyTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                          <a href="../../../../../org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html" title="interface in org.apache.hadoop.hbase.master">HMaster.TableDescriptorGetter</a>&nbsp;newDescriptorGetter,
                          long&nbsp;nonceGroup,
                          long&nbsp;nonce,
@@ -3480,7 +3493,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>modifyTable</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2559">modifyTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2564">modifyTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
                         <a href="../../../../../org/apache/hadoop/hbase/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&nbsp;newDescriptor,
                         long&nbsp;nonceGroup,
                         long&nbsp;nonce)
@@ -3504,7 +3517,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>restoreSnapshot</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2571">restoreSnapshot</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription&nbsp;snapshotDesc,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2576">restoreSnapshot</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription&nbsp;snapshotDesc,
                             long&nbsp;nonceGroup,
                             long&nbsp;nonce,
                             boolean&nbsp;restoreAcl)
@@ -3521,7 +3534,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>checkTableExists</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2595">checkTableExists</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2600">checkTableExists</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
                        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/TableNotFoundException.html" title="class in org.apache.hadoop.hbase">TableNotFoundException</a></pre>
 <dl>
@@ -3537,7 +3550,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>checkTableModifiable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2603">checkTableModifiable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2608">checkTableModifiable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
                           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/TableNotFoundException.html" title="class in org.apache.hadoop.hbase">TableNotFoundException</a>,
                                  <a href="../../../../../org/apache/hadoop/hbase/TableNotDisabledException.html" title="class in org.apache.hadoop.hbase">TableNotDisabledException</a></pre>
@@ -3561,7 +3574,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterMetricsWithoutCoprocessor</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2615">getClusterMetricsWithoutCoprocessor</a>()
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2620">getClusterMetricsWithoutCoprocessor</a>()
                                                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/InterruptedIOException.html?is-external=true" title="class or interface in java.io">InterruptedIOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -3575,7 +3588,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterMetricsWithoutCoprocessor</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2619">getClusterMetricsWithoutCoprocessor</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/EnumSet.html?is-external=true" title="class or interface in java.util">EnumSet</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics [...]
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2624">getClusterMetricsWithoutCoprocessor</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/EnumSet.html?is-external=true" title="class or interface in java.util">EnumSet</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics [...]
                                                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/InterruptedIOException.html?is-external=true" title="class or interface in java.io">InterruptedIOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -3589,7 +3602,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterMetrics</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2705">getClusterMetrics</a>()
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2710">getClusterMetrics</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="returnLabel">Returns:</span></dt>
@@ -3605,7 +3618,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterMetrics</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2709">getClusterMetrics</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/EnumSet.html?is-external=true" title="class or interface in java.util">EnumSet</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" titl [...]
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.html" title="interface in org.apache.hadoop.hbase">ClusterMetrics</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2714">getClusterMetrics</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/EnumSet.html?is-external=true" title="class or interface in java.util">EnumSet</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" titl [...]
                                  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>
@@ -3619,7 +3632,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getActiveMaster</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2721">getActiveMaster</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Optional.html?is-external=true" title="class or interface in java.util">Optional</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2726">getActiveMaster</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/ConnectionRegistryEndpoint.html#getActiveMaster--">ConnectionRegistryEndpoint</a></code></span></div>
 <div class="block">Get active master address.</div>
 <dl>
@@ -3636,7 +3649,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getBackupMasters</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2726">getBackupMasters</a>()</pre>
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2731">getBackupMasters</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/ConnectionRegistryEndpoint.html#getBackupMasters--">ConnectionRegistryEndpoint</a></code></span></div>
 <div class="block">Get backup masters address.</div>
 <dl>
@@ -3653,7 +3666,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getActiveMasterInfoPort</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2733">getActiveMasterInfoPort</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2738">getActiveMasterInfoPort</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>info port of active master or 0 if any exception occurs.</dd>
@@ -3666,7 +3679,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getBackupMasterInfoPort</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2741">getBackupMasterInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2746">getBackupMasterInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</pre>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
 <dd><code>sn</code> - is ServerName of the backup master</dd>
@@ -3681,7 +3694,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServers</h4>
-<pre>public&nbsp;<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;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2746">getRegionServers</a>()</pre>
+<pre>public&nbsp;<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;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2751">getRegionServers</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/ConnectionRegistryEndpoint.html#getRegionServers--">ConnectionRegistryEndpoint</a></code></span></div>
 <div class="block">Get all the region servers address.</div>
 <dl>
@@ -3698,7 +3711,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLoadedCoprocessors</h4>
-<pre>public static&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/master/HMaster.html#line.2756">getLoadedCoprocessors</a>()</pre>
+<pre>public static&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/master/HMaster.html#line.2761">getLoadedCoprocessors</a>()</pre>
 <div class="block">The set of loaded coprocessors is stored in a static set. Since it's
  statically allocated, it does not require that HMaster's cpHost be
  initialized prior to accessing it.</div>
@@ -3714,7 +3727,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterStartTime</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2763">getMasterStartTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2768">getMasterStartTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster was started.</dd>
@@ -3727,7 +3740,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterActiveTime</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2770">getMasterActiveTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2775">getMasterActiveTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster became the active master.</dd>
@@ -3740,7 +3753,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterFinishedInitializationTime</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2777">getMasterFinishedInitializationTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2782">getMasterFinishedInitializationTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster finished becoming the active master</dd>
@@ -3753,7 +3766,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getNumWALFiles</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2781">getNumWALFiles</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2786">getNumWALFiles</a>()</pre>
 </li>
 </ul>
 <a name="getProcedureStore--">
@@ -3762,7 +3775,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getProcedureStore</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/store/ProcedureStore.html" title="interface in org.apache.hadoop.hbase.procedure2.store">ProcedureStore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2785">getProcedureStore</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/store/ProcedureStore.html" title="interface in org.apache.hadoop.hbase.procedure2.store">ProcedureStore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2790">getProcedureStore</a>()</pre>
 </li>
 </ul>
 <a name="getRegionServerInfoPort-org.apache.hadoop.hbase.ServerName-">
@@ -3771,7 +3784,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServerInfoPort</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2789">getRegionServerInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2794">getRegionServerInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</pre>
 </li>
 </ul>
 <a name="getRegionServerVersion-org.apache.hadoop.hbase.ServerName-">
@@ -3780,7 +3793,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServerVersion</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/master/HMaster.html#line.2796">getRegionServerVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</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/master/HMaster.html#line.2801">getRegionServerVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;sn)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getRegionServerVersion-org.apache.hadoop.hbase.ServerName-">getRegionServerVersion</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3793,7 +3806,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>checkIfShouldMoveSystemRegionAsync</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2803">checkIfShouldMoveSystemRegionAsync</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2808">checkIfShouldMoveSystemRegionAsync</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#checkIfShouldMoveSystemRegionAsync--">MasterServices</a></code></span></div>
 <div class="block">Called when a new RegionServer is added to the cluster.
  Checks if new server has a newer version than any existing server and will move system tables
@@ -3810,7 +3823,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterCoprocessors</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/master/HMaster.html#line.2810">getMasterCoprocessors</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/master/HMaster.html#line.2815">getMasterCoprocessors</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>array of coprocessor SimpleNames.</dd>
@@ -3823,7 +3836,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>abort</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2816">abort</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;reason,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2821">abort</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;reason,
                   <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html?is-external=true" title="class or interface in java.lang">Throwable</a>&nbsp;cause)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#abort-java.lang.String-java.lang.Throwable-">HRegionServer</a></code></span></div>
 <div class="block">Cause the server to exit without closing the regions it is serving, the log
@@ -3846,7 +3859,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getZooKeeper</h4>
-<pre>public&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/master/HMaster.html#line.2841">getZooKeeper</a>()</pre>
+<pre>public&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/master/HMaster.html#line.2846">getZooKeeper</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/Server.html#getZooKeeper--">Server</a></code></span></div>
 <div class="block">Gets the ZooKeeper instance for this server.</div>
 <dl>
@@ -3863,7 +3876,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterCoprocessorHost</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterCoprocessorHost.html" title="class in org.apache.hadoop.hbase.master">MasterCoprocessorHost</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2846">getMasterCoprocessorHost</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MasterCoprocessorHost.html" title="class in org.apache.hadoop.hbase.master">MasterCoprocessorHost</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2851">getMasterCoprocessorHost</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterCoprocessorHost--">getMasterCoprocessorHost</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3878,7 +3891,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterQuotaManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/MasterQuotaManager.html" title="class in org.apache.hadoop.hbase.quotas">MasterQuotaManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2851">getMasterQuotaManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/MasterQuotaManager.html" title="class in org.apache.hadoop.hbase.quotas">MasterQuotaManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2856">getMasterQuotaManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterQuotaManager--">getMasterQuotaManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3893,7 +3906,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterProcedureExecutor</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureExecutor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2856">getMasterProcedureExecutor</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureExecutor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2861">getMasterProcedureExecutor</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterProcedureExecutor--">getMasterProcedureExecutor</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3908,7 +3921,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getServerName</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2861">getServerName</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2866">getServerName</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/Server.html#getServerName--">getServerName</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/Server.html" title="interface in org.apache.hadoop.hbase">Server</a></code></dd>
@@ -3925,7 +3938,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getAssignmentManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2866">getAssignmentManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/assignment/AssignmentManager.html" title="class in org.apache.hadoop.hbase.master.assignment">AssignmentManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2871">getAssignmentManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getAssignmentManager--">getAssignmentManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3940,7 +3953,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getCatalogJanitor</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/janitor/CatalogJanitor.html" title="class in org.apache.hadoop.hbase.master.janitor">CatalogJanitor</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2871">getCatalogJanitor</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/janitor/CatalogJanitor.html" title="class in org.apache.hadoop.hbase.master.janitor">CatalogJanitor</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2876">getCatalogJanitor</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getCatalogJanitor--">getCatalogJanitor</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -3955,7 +3968,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionServerFatalLogBuffer</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/monitoring/MemoryBoundedLogMessageBuffer.html" title="class in org.apache.hadoop.hbase.monitoring">MemoryBoundedLogMessageBuffer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2875">getRegionServerFatalLogBuffer</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/monitoring/MemoryBoundedLogMessageBuffer.html" title="class in org.apache.hadoop.hbase.monitoring">MemoryBoundedLogMessageBuffer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2880">getRegionServerFatalLogBuffer</a>()</pre>
 </li>
 </ul>
 <a name="shutdown--">
@@ -3964,7 +3977,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>shutdown</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2883">shutdown</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2888">shutdown</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">Shutdown the cluster.
  Master runs a coordinated stop of all RegionServers and then itself.</div>
@@ -3980,7 +3993,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>stopMaster</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2916">stopMaster</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2921">stopMaster</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="throwsLabel">Throws:</span></dt>
@@ -3994,7 +4007,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>stop</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2924">stop</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>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2929">stop</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>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/Stoppable.html#stop-java.lang.String-">Stoppable</a></code></span></div>
 <div class="block">Stop this service.
  Implementers should favor logging errors over throwing RuntimeExceptions.</div>
@@ -4015,7 +4028,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <li class="blockList">
 <h4>checkServiceStarted</h4>
 <pre>@InterfaceAudience.Private
-protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2934">checkServiceStarted</a>()
+protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2939">checkServiceStarted</a>()
                                                        throws <a href="../../../../../org/apache/hadoop/hbase/ipc/ServerNotRunningYetException.html" title="class in org.apache.hadoop.hbase.ipc">ServerNotRunningYetException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -4029,7 +4042,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>checkInitialized</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2940">checkInitialized</a>()
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2945">checkInitialized</a>()
                throws <a href="../../../../../org/apache/hadoop/hbase/PleaseHoldException.html" title="class in org.apache.hadoop.hbase">PleaseHoldException</a>,
                       <a href="../../../../../org/apache/hadoop/hbase/ipc/ServerNotRunningYetException.html" title="class in org.apache.hadoop.hbase.ipc">ServerNotRunningYetException</a>,
                       <a href="../../../../../org/apache/hadoop/hbase/MasterNotRunningException.html" title="class in org.apache.hadoop.hbase">MasterNotRunningException</a>,
@@ -4049,7 +4062,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isActiveMaster</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2960">isActiveMaster</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2965">isActiveMaster</a>()</pre>
 <div class="block">Report whether this master is currently the active master or not.
  If not active master, we are parked on ZK waiting to become active.
 
@@ -4068,7 +4081,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isInitialized</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2974">isInitialized</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2979">isInitialized</a>()</pre>
 <div class="block">Report whether this master has completed with its initialization and is
  ready.  If ready, the master is also the active master.  A standby master
  is never ready.
@@ -4088,7 +4101,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isOnline</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2987">isOnline</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2992">isOnline</a>()</pre>
 <div class="block">Report whether this master is started
 
  This method is used for testing.</div>
@@ -4106,7 +4119,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <ul class="blockList">
 <li class="blockList">
 <h4>isInMaintenanceMode</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2997">isInMaintenanceMode</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3002">isInMaintenanceMode</a>()</pre>
 <div class="block">Report whether this master is in maintenance mode.</div>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -4123,7 +4136,7 @@ protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbas
 <li class="blockList">
 <h4>setInitialized</h4>
 <pre>@InterfaceAudience.Private
-public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3002">setInitialized</a>(boolean&nbsp;isInitialized)</pre>
+public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3007">setInitialized</a>(boolean&nbsp;isInitialized)</pre>
 </li>
 </ul>
 <a name="getInitializedEvent--">
@@ -4132,7 +4145,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getInitializedEvent</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureEvent.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureEvent</a>&lt;?&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3007">getInitializedEvent</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/ProcedureEvent.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureEvent</a>&lt;?&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3012">getInitializedEvent</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getInitializedEvent--">getInitializedEvent</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4147,7 +4160,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getAverageLoad</h4>
-<pre>public&nbsp;double&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3017">getAverageLoad</a>()</pre>
+<pre>public&nbsp;double&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3022">getAverageLoad</a>()</pre>
 <div class="block">Compute the average load across all region servers.
  Currently, this uses a very naive computation - just uses the number of
  regions being served, ignoring stats about number of requests.</div>
@@ -4163,7 +4176,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>registerService</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3030">registerService</a>(org.apache.hbase.thirdparty.com.google.protobuf.Service&nbsp;instance)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3035">registerService</a>(org.apache.hbase.thirdparty.com.google.protobuf.Service&nbsp;instance)</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionServerServices.html#registerService-org.apache.hbase.thirdparty.com.google.protobuf.Service-">RegionServerServices</a></code></span></div>
 <div class="block">Registers a new protocol buffer <code>Service</code> subclass as a coprocessor endpoint to be
  available for handling</div>
@@ -4187,7 +4200,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>constructMaster</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html" title="class in org.apache.hadoop.hbase.master">HMaster</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3055">constructMaster</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends <a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html" titl [...]
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html" title="class in org.apache.hadoop.hbase.master">HMaster</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3060">constructMaster</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends <a href="../../../../../org/apache/hadoop/hbase/master/HMaster.html" titl [...]
                                       org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block">Utility for constructing an instance of the passed HMaster class.</div>
 <dl>
@@ -4204,7 +4217,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>main</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3074">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>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3079">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>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../org/apache/hadoop/hbase/master/HMasterCommandLine.html" title="class in org.apache.hadoop.hbase.master"><code>HMasterCommandLine</code></a></dd>
@@ -4217,7 +4230,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getHFileCleaner</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">HFileCleaner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3080">getHFileCleaner</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">HFileCleaner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3085">getHFileCleaner</a>()</pre>
 </li>
 </ul>
 <a name="getLogCleaner--">
@@ -4226,7 +4239,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLogCleaner</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/LogCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">LogCleaner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3084">getLogCleaner</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/cleaner/LogCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">LogCleaner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3089">getLogCleaner</a>()</pre>
 </li>
 </ul>
 <a name="getSnapshotManager--">
@@ -4235,7 +4248,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getSnapshotManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/snapshot/SnapshotManager.html" title="class in org.apache.hadoop.hbase.master.snapshot">SnapshotManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3092">getSnapshotManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/snapshot/SnapshotManager.html" title="class in org.apache.hadoop.hbase.master.snapshot">SnapshotManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3097">getSnapshotManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getSnapshotManager--">getSnapshotManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4250,7 +4263,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMasterProcedureManagerHost</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure/MasterProcedureManagerHost.html" title="class in org.apache.hadoop.hbase.procedure">MasterProcedureManagerHost</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3100">getMasterProcedureManagerHost</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure/MasterProcedureManagerHost.html" title="class in org.apache.hadoop.hbase.procedure">MasterProcedureManagerHost</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3105">getMasterProcedureManagerHost</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMasterProcedureManagerHost--">getMasterProcedureManagerHost</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4265,7 +4278,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterSchema</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterSchema.html" title="interface in org.apache.hadoop.hbase.master">ClusterSchema</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3105">getClusterSchema</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ClusterSchema.html" title="interface in org.apache.hadoop.hbase.master">ClusterSchema</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3110">getClusterSchema</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getClusterSchema--">getClusterSchema</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4280,7 +4293,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>createNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3117">createNamespace</a>(<a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;namespaceDescriptor,
+<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3122">createNamespace</a>(<a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;namespaceDescriptor,
                      long&nbsp;nonceGroup,
                      long&nbsp;nonce)
               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>
@@ -4304,7 +4317,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>modifyNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3153">modifyNamespace</a>(<a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;newNsDescriptor,
+<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3158">modifyNamespace</a>(<a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;newNsDescriptor,
                      long&nbsp;nonceGroup,
                      long&nbsp;nonce)
               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>
@@ -4327,7 +4340,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3191">deleteNamespace</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>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3196">deleteNamespace</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,
                      long&nbsp;nonceGroup,
                      long&nbsp;nonce)
               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>
@@ -4350,7 +4363,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getNamespace</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3226">getNamespace</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><a href="../../../../../org/apache/hadoop/hbase/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3231">getNamespace</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)
                           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">Get a Namespace</div>
 <dl>
@@ -4369,7 +4382,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getNamespaces</h4>
-<pre><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/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3238">getNamespaces</a>()
+<pre><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/NamespaceDescriptor.html" title="class in org.apache.hadoop.hbase">NamespaceDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3243">getNamespaces</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">Get all Namespaces</div>
 <dl>
@@ -4386,7 +4399,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listNamespaces</h4>
-<pre>public&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="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/master/HMaster.html#line.3255">listNamespaces</a>()
+<pre>public&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="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/master/HMaster.html#line.3260">listNamespaces</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">List namespace names</div>
 <dl>
@@ -4403,7 +4416,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listTableNamesByNamespace</h4>
-<pre>public&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/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3271">listTableNamesByNamespace</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=tru [...]
+<pre>public&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/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3276">listTableNamesByNamespace</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=tru [...]
                                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#listTableNamesByNamespace-java.lang.String-">MasterServices</a></code></span></div>
 <div class="block">Get list of table names by namespace</div>
@@ -4425,7 +4438,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listTableDescriptorsByNamespace</h4>
-<pre>public&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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3277">listTableDescriptorsByNamespace</a>(<a href="https://docs.oracle.com/javase/8/docs/api/j [...]
+<pre>public&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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3282">listTableDescriptorsByNamespace</a>(<a href="https://docs.oracle.com/javase/8/docs/api/j [...]
                                                       throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#listTableDescriptorsByNamespace-java.lang.String-">MasterServices</a></code></span></div>
 <div class="block">Get list of table descriptors by namespace</div>
@@ -4447,7 +4460,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>abortProcedure</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3283">abortProcedure</a>(long&nbsp;procId,
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3288">abortProcedure</a>(long&nbsp;procId,
                               boolean&nbsp;mayInterruptIfRunning)
                        throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#abortProcedure-long-boolean-">MasterServices</a></code></span></div>
@@ -4471,7 +4484,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getProcedures</h4>
-<pre>public&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/procedure2/Procedure.html" title="class in org.apache.hadoop.hbase.procedure2">Procedure</a>&lt;?&gt;&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3299">getProcedures</a>()
+<pre>public&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/procedure2/Procedure.html" title="class in org.apache.hadoop.hbase.procedure2">Procedure</a>&lt;?&gt;&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3304">getProcedures</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="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getProcedures--">MasterServices</a></code></span></div>
 <div class="block">Get procedures</div>
@@ -4491,7 +4504,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLocks</h4>
-<pre>public&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/procedure2/LockedResource.html" title="class in org.apache.hadoop.hbase.procedure2">LockedResource</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3315">getLocks</a>()
+<pre>public&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/procedure2/LockedResource.html" title="class in org.apache.hadoop.hbase.procedure2">LockedResource</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3320">getLocks</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="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getLocks--">MasterServices</a></code></span></div>
 <div class="block">Get locks</div>
@@ -4511,7 +4524,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listTableDescriptors</h4>
-<pre>public&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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3340">listTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/St [...]
+<pre>public&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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3345">listTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/St [...]
                                                   <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;regex,
                                                   <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 in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;tableNameList,
                                                   boolean&nbsp;includeSysTables)
@@ -4536,7 +4549,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listTableNames</h4>
-<pre>public&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/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3361">listTableNames</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="c [...]
+<pre>public&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/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3366">listTableNames</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="c [...]
                                       <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;regex,
                                       boolean&nbsp;includeSysTables)
                                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>
@@ -4559,7 +4572,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableDescriptors</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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3381">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Li [...]
+<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/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3386">getTableDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/Li [...]
                                                   <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;namespace,
                                                   <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;regex,
                                                   <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 in org.apache.hadoop.hbase">TableName</a>&gt;&nbsp;tableNameList,
@@ -4580,7 +4593,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>filterTablesByRegex</h4>
-<pre>private static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3422">filterTablesByRegex</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/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;descriptors,
+<pre>private static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3427">filterTablesByRegex</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/client/TableDescriptor.html" title="interface in org.apache.hadoop.hbase.client">TableDescriptor</a>&gt;&nbsp;descriptors,
                                         <a href="https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html?is-external=true" title="class or interface in java.util.regex">Pattern</a>&nbsp;pattern)</pre>
 <div class="block">Removes the table descriptors that don't match the pattern.</div>
 <dl>
@@ -4596,7 +4609,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLastMajorCompactionTimestamp</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3440">getLastMajorCompactionTimestamp</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3445">getLastMajorCompactionTimestamp</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;table)
                                      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>
@@ -4617,7 +4630,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLastMajorCompactionTimestampForRegion</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3446">getLastMajorCompactionTimestampForRegion</a>(byte[]&nbsp;regionName)
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3451">getLastMajorCompactionTimestampForRegion</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>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -4636,7 +4649,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getMobCompactionState</h4>
-<pre>public&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.GetRegionInfoResponse.CompactionState&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3460">getMobCompactionState</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>public&nbsp;org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.GetRegionInfoResponse.CompactionState&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3465">getMobCompactionState</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block">Gets the mob file compaction state for a specific table.
  Whether all the mob files are selected is known during the compaction execution, but
  the statistic is done just before compaction starts, it is hard to know the compaction
@@ -4656,7 +4669,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>reportMobCompactionStart</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3468">reportMobCompactionStart</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3473">reportMobCompactionStart</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
                               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>
@@ -4670,7 +4683,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>reportMobCompactionEnd</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3485">reportMobCompactionEnd</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3490">reportMobCompactionEnd</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)
                             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>
@@ -4684,7 +4697,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>isBalancerOn</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3511">isBalancerOn</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3516">isBalancerOn</a>()</pre>
 <div class="block">Queries the state of the <a href="../../../../../org/apache/hadoop/hbase/zookeeper/LoadBalancerTracker.html" title="class in org.apache.hadoop.hbase.zookeeper"><code>LoadBalancerTracker</code></a>. If the balancer is not initialized,
  false is returned.</div>
 <dl>
@@ -4701,7 +4714,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>isNormalizerOn</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3521">isNormalizerOn</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3526">isNormalizerOn</a>()</pre>
 <div class="block">Queries the state of the <a href="../../../../../org/apache/hadoop/hbase/zookeeper/RegionNormalizerTracker.html" title="class in org.apache.hadoop.hbase.zookeeper"><code>RegionNormalizerTracker</code></a>. If it's not initialized,
  false is returned.</div>
 </li>
@@ -4712,7 +4725,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>isSplitOrMergeEnabled</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3533">isSplitOrMergeEnabled</a>(<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client">MasterSwitchType</a>&nbsp;switchType)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3538">isSplitOrMergeEnabled</a>(<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client">MasterSwitchType</a>&nbsp;switchType)</pre>
 <div class="block">Queries the state of the <a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master"><code>SplitOrMergeTracker</code></a>. If it is not initialized,
  false is returned. If switchType is illegal, false will return.</div>
 <dl>
@@ -4731,7 +4744,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLoadBalancerClassName</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/master/HMaster.html#line.3546">getLoadBalancerClassName</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/master/HMaster.html#line.3551">getLoadBalancerClassName</a>()</pre>
 <div class="block">Fetch the configured <a href="../../../../../org/apache/hadoop/hbase/master/LoadBalancer.html" title="interface in org.apache.hadoop.hbase.master"><code>LoadBalancer</code></a> class name. If none is set, a default is returned.
  <p/>
  Notice that, the base load balancer will always be <a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupBasedLoadBalancer.html" title="class in org.apache.hadoop.hbase.rsgroup"><code>RSGroupBasedLoadBalancer</code></a> now, so
@@ -4748,7 +4761,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getSplitOrMergeTracker</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master">SplitOrMergeTracker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3551">getSplitOrMergeTracker</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/SplitOrMergeTracker.html" title="class in org.apache.hadoop.hbase.master">SplitOrMergeTracker</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3556">getSplitOrMergeTracker</a>()</pre>
 </li>
 </ul>
 <a name="getLoadBalancer--">
@@ -4757,7 +4770,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLoadBalancer</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupBasedLoadBalancer.html" title="class in org.apache.hadoop.hbase.rsgroup">RSGroupBasedLoadBalancer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3556">getLoadBalancer</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupBasedLoadBalancer.html" title="class in org.apache.hadoop.hbase.rsgroup">RSGroupBasedLoadBalancer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3561">getLoadBalancer</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getLoadBalancer--">getLoadBalancer</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4772,7 +4785,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getFavoredNodesManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/favored/FavoredNodesManager.html" title="class in org.apache.hadoop.hbase.favored">FavoredNodesManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3561">getFavoredNodesManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/favored/FavoredNodesManager.html" title="class in org.apache.hadoop.hbase.favored">FavoredNodesManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3566">getFavoredNodesManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getFavoredNodesManager--">getFavoredNodesManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -4787,7 +4800,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>executePeerProcedure</h4>
-<pre>private&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3565">executePeerProcedure</a>(<a href="../../../../../org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html" title="class in org.apache.hadoop.hbase.master.replication">AbstractPeerProcedure</a>&lt;?&gt;&nbsp;procedure)
+<pre>private&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3570">executePeerProcedure</a>(<a href="../../../../../org/apache/hadoop/hbase/master/replication/AbstractPeerProcedure.html" title="class in org.apache.hadoop.hbase.master.replication">AbstractPeerProcedure</a>&lt;?&gt;&nbsp;procedure)
                            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>
@@ -4801,7 +4814,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>addReplicationPeer</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3572">addReplicationPeer</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3577">addReplicationPeer</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,
                                <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig,
                                boolean&nbsp;enabled)
                         throws <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationException.html" title="class in org.apache.hadoop.hbase.replication">ReplicationException</a>,
@@ -4827,7 +4840,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>removeReplicationPeer</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3580">removeReplicationPeer</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3585">removeReplicationPeer</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)
                            throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#removeReplicationPeer-java.lang.String-">MasterServices</a></code></span></div>
@@ -4849,7 +4862,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>enableReplicationPeer</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3586">enableReplicationPeer</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3591">enableReplicationPeer</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)
                            throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#enableReplicationPeer-java.lang.String-">MasterServices</a></code></span></div>
@@ -4871,7 +4884,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>disableReplicationPeer</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3592">disableReplicationPeer</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3597">disableReplicationPeer</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)
                             throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#disableReplicationPeer-java.lang.String-">MasterServices</a></code></span></div>
@@ -4893,7 +4906,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getReplicationPeerConfig</h4>
-<pre>public&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/HMaster.html#line.3598">getReplicationPeerConfig</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>public&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/HMaster.html#line.3603">getReplicationPeerConfig</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)
                                                throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getReplicationPeerConfig-java.lang.String-">MasterServices</a></code></span></div>
@@ -4917,7 +4930,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>updateReplicationPeerConfig</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3613">updateReplicationPeerConfig</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3618">updateReplicationPeerConfig</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,
                                         <a href="../../../../../org/apache/hadoop/hbase/replication/ReplicationPeerConfig.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerConfig</a>&nbsp;peerConfig)
                                  throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -4941,7 +4954,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listReplicationPeers</h4>
-<pre>public&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/replication/ReplicationPeerDescription.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerDescription</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3621">listReplicationPeers</a>(<a href="https://docs.oracle.com/ja [...]
+<pre>public&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/replication/ReplicationPeerDescription.html" title="class in org.apache.hadoop.hbase.replication">ReplicationPeerDescription</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3626">listReplicationPeers</a>(<a href="https://docs.oracle.com/ja [...]
                                                       throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#listReplicationPeers-java.lang.String-">MasterServices</a></code></span></div>
@@ -4965,7 +4978,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>transitReplicationPeerSyncReplicationState</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3637">transitReplicationPeerSyncReplicationState</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>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3642">transitReplicationPeerSyncReplicationState</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,
                                                        <a href="../../../../../org/apache/hadoop/hbase/replication/SyncReplicationState.html" title="enum in org.apache.hadoop.hbase.replication">SyncReplicationState</a>&nbsp;state)
                                                 throws <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/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
@@ -4989,7 +5002,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>decommissionRegionServers</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3651">decommissionRegionServers</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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;servers,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3656">decommissionRegionServers</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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;servers,
                                       boolean&nbsp;offload)
                                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">Mark region server(s) as decommissioned (previously called 'draining') to prevent additional
@@ -5008,7 +5021,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>listDecommissionedRegionServers</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3690">listDecommissionedRegionServers</a>()</pre>
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3695">listDecommissionedRegionServers</a>()</pre>
 <div class="block">List region servers marked as decommissioned (previously called 'draining') to not get regions
  assigned to them.</div>
 <dl>
@@ -5023,7 +5036,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>recommissionRegionServer</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3699">recommissionRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;server,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3704">recommissionRegionServer</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;server,
                                      <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;byte[]&gt;&nbsp;encodedRegionNames)
                               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">Remove decommission marker (previously called 'draining') from a region server to allow regions
@@ -5042,7 +5055,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getLockManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/locking/LockManager.html" title="class in org.apache.hadoop.hbase.master.locking">LockManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3738">getLockManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/locking/LockManager.html" title="class in org.apache.hadoop.hbase.master.locking">LockManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3743">getLockManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getLockManager--">getLockManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -5057,7 +5070,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getQuotaObserverChore</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">QuotaObserverChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3742">getQuotaObserverChore</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">QuotaObserverChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3747">getQuotaObserverChore</a>()</pre>
 </li>
 </ul>
 <a name="getSpaceQuotaSnapshotNotifier--">
@@ -5066,7 +5079,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getSpaceQuotaSnapshotNotifier</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3746">getSpaceQuotaSnapshotNotifier</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.html" title="interface in org.apache.hadoop.hbase.quotas">SpaceQuotaSnapshotNotifier</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3751">getSpaceQuotaSnapshotNotifier</a>()</pre>
 </li>
 </ul>
 <a name="getRemoteProcedure-long-">
@@ -5075,7 +5088,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getRemoteProcedure</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/RemoteProcedureDispatcher.RemoteProcedure.html" title="interface in org.apache.hadoop.hbase.procedure2">RemoteProcedureDispatcher.RemoteProcedure</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>,?&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#lin [...]
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/procedure2/RemoteProcedureDispatcher.RemoteProcedure.html" title="interface in org.apache.hadoop.hbase.procedure2">RemoteProcedureDispatcher.RemoteProcedure</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/procedure/MasterProcedureEnv.html" title="class in org.apache.hadoop.hbase.master.procedure">MasterProcedureEnv</a>,?&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#lin [...]
 </li>
 </ul>
 <a name="remoteProcedureCompleted-long-">
@@ -5084,7 +5097,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>remoteProcedureCompleted</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3760">remoteProcedureCompleted</a>(long&nbsp;procId)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3765">remoteProcedureCompleted</a>(long&nbsp;procId)</pre>
 </li>
 </ul>
 <a name="remoteProcedureFailed-long-org.apache.hadoop.hbase.procedure2.RemoteProcedureException-">
@@ -5093,7 +5106,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>remoteProcedureFailed</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3768">remoteProcedureFailed</a>(long&nbsp;procId,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3773">remoteProcedureFailed</a>(long&nbsp;procId,
                                   <a href="../../../../../org/apache/hadoop/hbase/procedure2/RemoteProcedureException.html" title="class in org.apache.hadoop.hbase.procedure2">RemoteProcedureException</a>&nbsp;error)</pre>
 </li>
 </ul>
@@ -5103,7 +5116,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>reopenRegions</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3787">reopenRegions</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName,
+<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3792">reopenRegions</a>(<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/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;byte[]&gt;&nbsp;regionNames,
                    long&nbsp;nonceGroup,
                    long&nbsp;nonce)
@@ -5129,7 +5142,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getReplicationPeerManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication">ReplicationPeerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3809">getReplicationPeerManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication">ReplicationPeerManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3814">getReplicationPeerManager</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getReplicationPeerManager--">MasterServices</a></code></span></div>
 <div class="block">Returns the <a href="../../../../../org/apache/hadoop/hbase/master/replication/ReplicationPeerManager.html" title="class in org.apache.hadoop.hbase.master.replication"><code>ReplicationPeerManager</code></a>.</div>
 <dl>
@@ -5144,7 +5157,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <ul class="blockList">
 <li class="blockList">
 <h4>getReplicationLoad</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/HashMap.html?is-external=true" title="class or interface in java.util">HashMap</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/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hba [...]
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/HashMap.html?is-external=true" title="class or interface in java.util">HashMap</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/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../../../org/apache/hadoop/hba [...]
 </li>
 </ul>
 <a name="decorateMasterConfiguration-org.apache.hadoop.conf.Configuration-">
@@ -5154,7 +5167,7 @@ public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/m
 <li class="blockList">
 <h4>decorateMasterConfiguration</h4>
 <pre>@InterfaceAudience.Private
-public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3850">decorateMasterConfiguration</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3855">decorateMasterConfiguration</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 <div class="block">This method modifies the master's configuration in order to inject replication-related features</div>
 </li>
 </ul>
@@ -5164,7 +5177,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getSnapshotQuotaObserverChore</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">SnapshotQuotaObserverChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3865">getSnapshotQuotaObserverChore</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.html" title="class in org.apache.hadoop.hbase.quotas">SnapshotQuotaObserverChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3870">getSnapshotQuotaObserverChore</a>()</pre>
 </li>
 </ul>
 <a name="getSyncReplicationReplayWALManager--">
@@ -5173,7 +5186,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getSyncReplicationReplayWALManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication">SyncReplicationReplayWALManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3870">getSyncReplicationReplayWALManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication">SyncReplicationReplayWALManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3875">getSyncReplicationReplayWALManager</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getSyncReplicationReplayWALManager--">MasterServices</a></code></span></div>
 <div class="block">Returns the <a href="../../../../../org/apache/hadoop/hbase/master/replication/SyncReplicationReplayWALManager.html" title="class in org.apache.hadoop.hbase.master.replication"><code>SyncReplicationReplayWALManager</code></a>.</div>
 <dl>
@@ -5188,7 +5201,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getWalGroupsReplicationStatus</h4>
-<pre>public&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="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/replication/regionserver/ReplicationStatus.html" title="class in org.apache.hadoop.hbase.replication.regionserver">ReplicationStatus</a>&gt;&nbsp; [...]
+<pre>public&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="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/replication/regionserver/ReplicationStatus.html" title="class in org.apache.hadoop.hbase.replication.regionserver">ReplicationStatus</a>&gt;&nbsp; [...]
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#getWalGroupsReplicationStatus--">getWalGroupsReplicationStatus</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html" title="class in org.apache.hadoop.hbase.regionserver">HRegionServer</a></code></dd>
@@ -5201,7 +5214,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getHbckChore</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HbckChore.html" title="class in org.apache.hadoop.hbase.master">HbckChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3882">getHbckChore</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/HbckChore.html" title="class in org.apache.hadoop.hbase.master">HbckChore</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3884">getHbckChore</a>()</pre>
 </li>
 </ul>
 <a name="getClusterId--">
@@ -5210,7 +5223,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getClusterId</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/master/HMaster.html#line.3887">getClusterId</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/master/HMaster.html#line.3889">getClusterId</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/client/ConnectionRegistryEndpoint.html#getClusterId--">ConnectionRegistryEndpoint</a></code></span></div>
 <div class="block">Get cluster id.</div>
 <dl>
@@ -5227,7 +5240,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>runReplicationBarrierCleaner</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3895">runReplicationBarrierCleaner</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3897">runReplicationBarrierCleaner</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#runReplicationBarrierCleaner--">MasterServices</a></code></span></div>
 <div class="block">Run the ReplicationBarrierChore.</div>
 <dl>
@@ -5242,7 +5255,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getRSGroupInfoManager</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupInfoManager.html" title="interface in org.apache.hadoop.hbase.rsgroup">RSGroupInfoManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3903">getRSGroupInfoManager</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/rsgroup/RSGroupInfoManager.html" title="interface in org.apache.hadoop.hbase.rsgroup">RSGroupInfoManager</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3905">getRSGroupInfoManager</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getRSGroupInfoManager--">getRSGroupInfoManager</a></code>&nbsp;in interface&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a></code></dd>
@@ -5257,7 +5270,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getCompactionState</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client">CompactionState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3913">getCompactionState</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client">CompactionState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3915">getCompactionState</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;tableName)</pre>
 <div class="block">Get the compaction state of the table</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -5273,7 +5286,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockList">
 <li class="blockList">
 <h4>getMetaLocationSyncer</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MetaLocationSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MetaLocationSyncer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3951">getMetaLocationSyncer</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/zksyncer/MetaLocationSyncer.html" title="class in org.apache.hadoop.hbase.master.zksyncer">MetaLocationSyncer</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3953">getMetaLocationSyncer</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html#getMetaLocationSyncer--">MasterServices</a></code></span></div>
 <div class="block">Get the meta location syncer.
  <p/>
@@ -5290,7 +5303,7 @@ public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/
 <ul class="blockListLast">
 <li class="blockList">
 <h4>getMasterRegion</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3957">getMasterRegion</a>()</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/master/region/MasterRegion.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegion</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3959">getMasterRegion</a>()</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html
index 4f6ec2c..f1a24ea 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>private class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1175">ServerManager.FlushedSequenceIdFlusher</a>
+<pre>private class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1176">ServerManager.FlushedSequenceIdFlusher</a>
 extends <a href="../../../../../org/apache/hadoop/hbase/ScheduledChore.html" title="class in org.apache.hadoop.hbase">ScheduledChore</a></pre>
 </li>
 </ul>
@@ -201,7 +201,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/ScheduledChore.html" tit
 <ul class="blockListLast">
 <li class="blockList">
 <h4>FlushedSequenceIdFlusher</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html#line.1177">FlushedSequenceIdFlusher</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>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html#line.1178">FlushedSequenceIdFlusher</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,
                                 int&nbsp;p)</pre>
 </li>
 </ul>
@@ -219,7 +219,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/ScheduledChore.html" tit
 <ul class="blockListLast">
 <li class="blockList">
 <h4>chore</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html#line.1182">chore</a>()</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.FlushedSequenceIdFlusher.html#line.1183">chore</a>()</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../org/apache/hadoop/hbase/ScheduledChore.html#chore--">ScheduledChore</a></code></span></div>
 <div class="block">The task to execute on each scheduled execution of the Chore</div>
 <dl>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html
index 9b7fa5c..d1235dc 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>public static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.874">ServerManager.ServerLiveState</a>
+<pre>public static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.875">ServerManager.ServerLiveState</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang">Enum</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a>&gt;</pre>
 </li>
 </ul>
@@ -213,7 +213,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>LIVE</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.875">LIVE</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.876">LIVE</a></pre>
 </li>
 </ul>
 <a name="DEAD">
@@ -222,7 +222,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>DEAD</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.876">DEAD</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.877">DEAD</a></pre>
 </li>
 </ul>
 <a name="UNKNOWN">
@@ -231,7 +231,7 @@ the order they are declared.</div>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>UNKNOWN</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.877">UNKNOWN</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html#line.878">UNKNOWN</a></pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.html b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.html
index 8662179..bf73701 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/ServerManager.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/ServerManager.html
@@ -1353,7 +1353,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>waitForRegionServers</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.761">waitForRegionServers</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.762">waitForRegionServers</a>(<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.html" title="interface in org.apache.hadoop.hbase.monitoring">MonitoredTask</a>&nbsp;status)
                           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></pre>
 <div class="block">Wait for the region servers to report in.
  We will wait until one of this condition is met:
@@ -1376,7 +1376,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getStrForMax</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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.829">getStrForMax</a>(int&nbsp;max)</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>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.830">getStrForMax</a>(int&nbsp;max)</pre>
 </li>
 </ul>
 <a name="getOnlineServersList--">
@@ -1385,7 +1385,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getOnlineServersList</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.836">getOnlineServersList</a>()</pre>
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.837">getOnlineServersList</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>A copy of the internal list of online servers.</dd>
@@ -1398,7 +1398,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getOnlineServersListWithPredicator</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.847">getOnlineServersListWithPredicator</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?i [...]
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.848">getOnlineServersListWithPredicator</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?i [...]
                                                            <a href="https://docs.oracle.com/javase/8/docs/api/java/util/function/Predicate.html?is-external=true" title="class or interface in java.util.function">Predicate</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/ServerMetrics.html" title="interface in org.apache.hadoop.hbase">ServerMetrics</a>&gt;&nbsp;idleServerPredicator)</pre>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -1415,7 +1415,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getDrainingServersList</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.866">getDrainingServersList</a>()</pre>
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.867">getDrainingServersList</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>A copy of the internal list of draining servers.</dd>
@@ -1428,7 +1428,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isServerOnline</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.870">isServerOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.871">isServerOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 </li>
 </ul>
 <a name="isServerKnownAndOnline-org.apache.hadoop.hbase.ServerName-">
@@ -1437,7 +1437,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isServerKnownAndOnline</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.883">isServerKnownAndOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master">ServerManager.ServerLiveState</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.884">isServerKnownAndOnline</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>whether the server is online, dead, or unknown.</dd>
@@ -1450,7 +1450,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isServerDead</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.894">isServerDead</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.895">isServerDead</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 <div class="block">Check if a server is known to be dead.  A server can be online,
  or known to be dead, or unknown to this manager (i.e, not online,
  not known to be dead either; it is simply not tracked by the
@@ -1463,7 +1463,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isServerUnknown</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.904">isServerUnknown</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.905">isServerUnknown</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 <div class="block">Check if a server is unknown.  A server can be online,
  or known to be dead, or unknown to this manager (i.e, not online,
  not known to be dead either; it is simply not tracked by the
@@ -1476,7 +1476,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>shutdownCluster</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.909">shutdownCluster</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.910">shutdownCluster</a>()</pre>
 </li>
 </ul>
 <a name="isClusterShutdown--">
@@ -1485,7 +1485,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isClusterShutdown</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.919">isClusterShutdown</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.920">isClusterShutdown</a>()</pre>
 </li>
 </ul>
 <a name="startChore--">
@@ -1494,7 +1494,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>startChore</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.926">startChore</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.927">startChore</a>()</pre>
 <div class="block">start chore in ServerManager</div>
 </li>
 </ul>
@@ -1504,7 +1504,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>stop</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.947">stop</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.948">stop</a>()</pre>
 <div class="block">Stop the ServerManager.</div>
 </li>
 </ul>
@@ -1514,7 +1514,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>createDestinationServersList</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.966">createDestinationServersList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-exte [...]
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.967">createDestinationServersList</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-exte [...]
 <div class="block">Creates a list of possible destinations for a region. It contains the online servers, but not
  the draining or dying servers.</div>
 <dl>
@@ -1529,7 +1529,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>createDestinationServersList</h4>
-<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.991">createDestinationServersList</a>()</pre>
+<pre>public&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/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.992">createDestinationServersList</a>()</pre>
 <div class="block">Calls <a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.html#createDestinationServersList-java.util.List-"><code>createDestinationServersList(java.util.List&lt;org.apache.hadoop.hbase.ServerName&gt;)</code></a> without server to exclude.</div>
 </li>
 </ul>
@@ -1539,7 +1539,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>clearDeadServersWithSameHostNameAndPortOfOnlineServer</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.998">clearDeadServersWithSameHostNameAndPortOfOnlineServer</a>()</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.999">clearDeadServersWithSameHostNameAndPortOfOnlineServer</a>()</pre>
 <div class="block">To clear any dead server with same host name and port of any online server</div>
 </li>
 </ul>
@@ -1549,7 +1549,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>removeRegion</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1007">removeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;regionInfo)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1008">removeRegion</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;regionInfo)</pre>
 <div class="block">Called by delete table and similar to notify the ServerManager that a region was removed.</div>
 </li>
 </ul>
@@ -1559,7 +1559,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isRegionInServerManagerStates</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1013">isRegionInServerManagerStates</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;hri)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1014">isRegionInServerManagerStates</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&nbsp;hri)</pre>
 </li>
 </ul>
 <a name="removeRegions-java.util.List-">
@@ -1568,7 +1568,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>removeRegions</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1022">removeRegions</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/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;regions)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1023">removeRegions</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/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a>&gt;&nbsp;regions)</pre>
 <div class="block">Called by delete table and similar to notify the ServerManager that a region was removed.</div>
 </li>
 </ul>
@@ -1578,7 +1578,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getVersionNumber</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1031">getVersionNumber</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1032">getVersionNumber</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 <div class="block">May return 0 when server is not online.</div>
 </li>
 </ul>
@@ -1588,7 +1588,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getVersion</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/master/ServerManager.html#line.1039">getVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</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/master/ServerManager.html#line.1040">getVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 <div class="block">May return "0.0.0" when server is not online</div>
 </li>
 </ul>
@@ -1598,7 +1598,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getInfoPort</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1044">getInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1045">getInfoPort</a>(<a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a>&nbsp;serverName)</pre>
 </li>
 </ul>
 <a name="persistRegionLastFlushedSequenceIds--">
@@ -1607,7 +1607,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>persistRegionLastFlushedSequenceIds</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1053">persistRegionLastFlushedSequenceIds</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1054">persistRegionLastFlushedSequenceIds</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">Persist last flushed sequence id of each region to HDFS</div>
 <dl>
@@ -1622,7 +1622,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>loadLastFlushedSequenceIds</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1110">loadLastFlushedSequenceIds</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1111">loadLastFlushedSequenceIds</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">Load last flushed sequence id of each region from HDFS, if persisted</div>
 <dl>
@@ -1637,7 +1637,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>removeDeletedRegionFromLoadedFlushedSequenceIds</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1163">removeDeletedRegionFromLoadedFlushedSequenceIds</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/ServerManager.html#line.1164">removeDeletedRegionFromLoadedFlushedSequenceIds</a>()</pre>
 <div class="block">Regions may have been removed between latest persist of FlushedSequenceIds
  and master abort. So after loading FlushedSequenceIds from file, and after
  meta loaded, we need to remove the deleted region according to RegionStates.</div>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
index 8bede26..ba98778 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/assignment/package-tree.html
@@ -151,8 +151,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/TransitRegionStateProcedure.TransitionType.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">TransitRegionStateProcedure.TransitionType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/ServerState.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">ServerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.assignment.<a href="../../../../../../org/apache/hadoop/hbase/master/assignment/TransitRegionStateProcedure.TransitionType.html" title="enum in org.apache.hadoop.hbase.master.assignment"><span class="typeNameLink">TransitRegionStateProcedure.TransitionType</span></a></li>
 </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 c1c8a99..953c42f 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -317,12 +317,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.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/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/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/ServerManager.ServerLiveState.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">ServerManager.ServerLiveState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/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.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</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 2608e78..1079134 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -459,20 +459,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.<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/MetaRegionLocationCache.ZNodeOpType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaRegionLocationCache.ZNodeOpType</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/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/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/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/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/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/MetaRegionLocationCache.ZNodeOpType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaRegionLocationCache.ZNodeOpType</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/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/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/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/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/ClientMetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClientMetaTableAccessor.QueryType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompatibilitySingletonFactory.SingletonStorage.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompatibilitySingletonFactory.SingletonStorage</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
 </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 219566c..0d161e1 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -217,11 +217,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/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/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/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>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
index a402ab9..d094b12 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/store/wal/package-tree.html
@@ -133,8 +133,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/ProcedureStoreTracker.DeleteState.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">ProcedureStoreTracker.DeleteState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.PushType.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">WALProcedureStore.PushType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.store.wal.<a href="../../../../../../../org/apache/hadoop/hbase/procedure2/store/wal/ProcedureStoreTracker.DeleteState.html" title="enum in org.apache.hadoop.hbase.procedure2.store.wal"><span class="typeNameLink">ProcedureStoreTracker.DeleteState</span></a></li>
 </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 7700e1d..abdf477 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
@@ -241,11 +241,11 @@
 <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/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/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/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/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/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/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 39f4db1..918e4ae 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -733,20 +733,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/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/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/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/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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/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/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/TimeRangeTracker.Type.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TimeRangeTracker.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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/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/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/HRegion.FlushResult.Result.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">HRegion.FlushResult.Result</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 c9a6517..25d73f8 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/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/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/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/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
index 61f3f12..cdffecf 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
@@ -249,10 +249,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.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/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/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/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>
 </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 069bc9b..cdee00f 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
@@ -224,8 +224,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 8703f65..90989fc 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.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>
+<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>
 </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 1cf29f2..d8bd52a 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/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Action.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Action</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/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.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/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.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/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
 </ul>
 </li>
 </ul>
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
index fba9877..efb292e 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/package-tree.html
@@ -211,8 +211,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.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ImplType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ImplType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.ThriftServerType.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">ThriftMetrics.ThriftServerType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.thrift.<a href="../../../../../org/apache/hadoop/hbase/thrift/MetricsThriftServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.thrift"><span class="typeNameLink">MetricsThriftServerSourceFactoryImpl.FactoryStorage</span></a></li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/class-use/JVMClusterUtil.RegionServerThread.html b/devapidocs/org/apache/hadoop/hbase/util/class-use/JVMClusterUtil.RegionServerThread.html
index d1b3863..f451b4a 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/class-use/JVMClusterUtil.RegionServerThread.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/class-use/JVMClusterUtil.RegionServerThread.html
@@ -238,6 +238,19 @@
 <!--   -->
 </a>
 <h3>Uses of <a href="../../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a> in <a href="../../../../../../org/apache/hadoop/hbase/master/package-summary.html">org.apache.hadoop.hbase.master</a></h3>
+<table class="useSummary" border="0" cellpadding="3" cellspacing="0" summary="Use table, listing fields, and an explanation">
+<caption><span>Fields in <a href="../../../../../../org/apache/hadoop/hbase/master/package-summary.html">org.apache.hadoop.hbase.master</a> declared as <a href="../../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a></span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Field and Description</th>
+</tr>
+<tbody>
+<tr class="altColor">
+<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a></code></td>
+<td class="colLast"><span class="typeNameLabel">HMaster.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/master/HMaster.html#maintenanceRegionServer">maintenanceRegionServer</a></span></code>&nbsp;</td>
+</tr>
+</tbody>
+</table>
 <table class="useSummary" border="0" cellpadding="3" cellspacing="0" summary="Use table, listing methods, and an explanation">
 <caption><span>Method parameters in <a href="../../../../../../org/apache/hadoop/hbase/master/package-summary.html">org.apache.hadoop.hbase.master</a> with type arguments of type <a href="../../../../../../org/apache/hadoop/hbase/util/JVMClusterUtil.RegionServerThread.html" title="class in org.apache.hadoop.hbase.util">JVMClusterUtil.RegionServerThread</a></span><span class="tabEnd">&nbsp;</span></caption>
 <tr>
diff --git a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
index c0d7cb9..2a37b8b 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -531,15 +531,15 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&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/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/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/DNS.ServerType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">DNS.ServerType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PrettyPrinter.Unit.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PrettyPrinter.Unit</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&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/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/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/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/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/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/DNS.ServerType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">DNS.ServerType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/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/master/HMaster.TableDescriptorGetter.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
index c770776..8fc2dd4 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
@@ -223,3749 +223,3751 @@
 <span class="sourceLineNo">215</span>import org.apache.hadoop.hbase.util.HBaseFsck;<a name="line.215"></a>
 <span class="sourceLineNo">216</span>import org.apache.hadoop.hbase.util.HFileArchiveUtil;<a name="line.216"></a>
 <span class="sourceLineNo">217</span>import org.apache.hadoop.hbase.util.IdLock;<a name="line.217"></a>
-<span class="sourceLineNo">218</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.219"></a>
-<span class="sourceLineNo">220</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.220"></a>
-<span class="sourceLineNo">221</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.222"></a>
-<span class="sourceLineNo">223</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.223"></a>
-<span class="sourceLineNo">224</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.224"></a>
-<span class="sourceLineNo">225</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.225"></a>
-<span class="sourceLineNo">226</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.226"></a>
-<span class="sourceLineNo">227</span>import org.apache.hadoop.hbase.zookeeper.MetaTableLocator;<a name="line.227"></a>
-<span class="sourceLineNo">228</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.228"></a>
-<span class="sourceLineNo">229</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.229"></a>
-<span class="sourceLineNo">230</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.230"></a>
-<span class="sourceLineNo">231</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.231"></a>
-<span class="sourceLineNo">232</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.232"></a>
-<span class="sourceLineNo">233</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.233"></a>
-<span class="sourceLineNo">234</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.234"></a>
-<span class="sourceLineNo">235</span>import org.apache.zookeeper.KeeperException;<a name="line.235"></a>
-<span class="sourceLineNo">236</span>import org.slf4j.Logger;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>import org.slf4j.LoggerFactory;<a name="line.237"></a>
-<span class="sourceLineNo">238</span><a name="line.238"></a>
-<span class="sourceLineNo">239</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.239"></a>
-<span class="sourceLineNo">240</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.240"></a>
-<span class="sourceLineNo">241</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.241"></a>
-<span class="sourceLineNo">242</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.242"></a>
-<span class="sourceLineNo">243</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.ServerConnector;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.servlet.ServletHolder;<a name="line.247"></a>
-<span class="sourceLineNo">248</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.webapp.WebAppContext;<a name="line.248"></a>
-<span class="sourceLineNo">249</span><a name="line.249"></a>
-<span class="sourceLineNo">250</span>import org.apache.hadoop.hbase.shaded.protobuf.RequestConverter;<a name="line.250"></a>
-<span class="sourceLineNo">251</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.GetRegionInfoResponse;<a name="line.251"></a>
-<span class="sourceLineNo">252</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription;<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> * HMaster is the "master server" for HBase. An HBase cluster has one active master. If many masters<a name="line.255"></a>
-<span class="sourceLineNo">256</span> * are started, all compete. Whichever wins goes on to run the cluster. All others park themselves<a name="line.256"></a>
-<span class="sourceLineNo">257</span> * in their constructor until master or cluster shutdown or until the active master loses its lease<a name="line.257"></a>
-<span class="sourceLineNo">258</span> * in zookeeper. Thereafter, all running master jostle to take over master role.<a name="line.258"></a>
-<span class="sourceLineNo">259</span> * &lt;p/&gt;<a name="line.259"></a>
-<span class="sourceLineNo">260</span> * The Master can be asked shutdown the cluster. See {@link #shutdown()}. In this case it will tell<a name="line.260"></a>
-<span class="sourceLineNo">261</span> * all regionservers to go down and then wait on them all reporting in that they are down. This<a name="line.261"></a>
-<span class="sourceLineNo">262</span> * master will then shut itself down.<a name="line.262"></a>
-<span class="sourceLineNo">263</span> * &lt;p/&gt;<a name="line.263"></a>
-<span class="sourceLineNo">264</span> * You can also shutdown just this master. Call {@link #stopMaster()}.<a name="line.264"></a>
-<span class="sourceLineNo">265</span> * @see org.apache.zookeeper.Watcher<a name="line.265"></a>
-<span class="sourceLineNo">266</span> */<a name="line.266"></a>
-<span class="sourceLineNo">267</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)<a name="line.267"></a>
-<span class="sourceLineNo">268</span>@SuppressWarnings("deprecation")<a name="line.268"></a>
-<span class="sourceLineNo">269</span>public class HMaster extends HRegionServer implements MasterServices {<a name="line.269"></a>
-<span class="sourceLineNo">270</span><a name="line.270"></a>
-<span class="sourceLineNo">271</span>  private static final Logger LOG = LoggerFactory.getLogger(HMaster.class);<a name="line.271"></a>
-<span class="sourceLineNo">272</span><a name="line.272"></a>
-<span class="sourceLineNo">273</span>  // MASTER is name of the webapp and the attribute name used stuffing this<a name="line.273"></a>
-<span class="sourceLineNo">274</span>  //instance into web context.<a name="line.274"></a>
-<span class="sourceLineNo">275</span>  public static final String MASTER = "master";<a name="line.275"></a>
-<span class="sourceLineNo">276</span><a name="line.276"></a>
-<span class="sourceLineNo">277</span>  // Manager and zk listener for master election<a name="line.277"></a>
-<span class="sourceLineNo">278</span>  private final ActiveMasterManager activeMasterManager;<a name="line.278"></a>
-<span class="sourceLineNo">279</span>  // Region server tracker<a name="line.279"></a>
-<span class="sourceLineNo">280</span>  private final RegionServerTracker regionServerTracker;<a name="line.280"></a>
-<span class="sourceLineNo">281</span>  // Draining region server tracker<a name="line.281"></a>
-<span class="sourceLineNo">282</span>  private DrainingServerTracker drainingServerTracker;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>  // Tracker for load balancer state<a name="line.283"></a>
-<span class="sourceLineNo">284</span>  LoadBalancerTracker loadBalancerTracker;<a name="line.284"></a>
-<span class="sourceLineNo">285</span>  // Tracker for meta location, if any client ZK quorum specified<a name="line.285"></a>
-<span class="sourceLineNo">286</span>  private MetaLocationSyncer metaLocationSyncer;<a name="line.286"></a>
-<span class="sourceLineNo">287</span>  // Tracker for active master location, if any client ZK quorum specified<a name="line.287"></a>
-<span class="sourceLineNo">288</span>  @InterfaceAudience.Private<a name="line.288"></a>
-<span class="sourceLineNo">289</span>  MasterAddressSyncer masterAddressSyncer;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>  // Tracker for auto snapshot cleanup state<a name="line.290"></a>
-<span class="sourceLineNo">291</span>  SnapshotCleanupTracker snapshotCleanupTracker;<a name="line.291"></a>
-<span class="sourceLineNo">292</span><a name="line.292"></a>
-<span class="sourceLineNo">293</span>  // Tracker for split and merge state<a name="line.293"></a>
-<span class="sourceLineNo">294</span>  private SplitOrMergeTracker splitOrMergeTracker;<a name="line.294"></a>
-<span class="sourceLineNo">295</span><a name="line.295"></a>
-<span class="sourceLineNo">296</span>  private ClusterSchemaService clusterSchemaService;<a name="line.296"></a>
-<span class="sourceLineNo">297</span><a name="line.297"></a>
-<span class="sourceLineNo">298</span>  public static final String HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS =<a name="line.298"></a>
-<span class="sourceLineNo">299</span>    "hbase.master.wait.on.service.seconds";<a name="line.299"></a>
-<span class="sourceLineNo">300</span>  public static final int DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS = 5 * 60;<a name="line.300"></a>
-<span class="sourceLineNo">301</span><a name="line.301"></a>
-<span class="sourceLineNo">302</span>  public static final String HBASE_MASTER_CLEANER_INTERVAL = "hbase.master.cleaner.interval";<a name="line.302"></a>
-<span class="sourceLineNo">303</span><a name="line.303"></a>
-<span class="sourceLineNo">304</span>  public static final int DEFAULT_HBASE_MASTER_CLEANER_INTERVAL = 600 * 1000;<a name="line.304"></a>
-<span class="sourceLineNo">305</span><a name="line.305"></a>
-<span class="sourceLineNo">306</span>  // Metrics for the HMaster<a name="line.306"></a>
-<span class="sourceLineNo">307</span>  final MetricsMaster metricsMaster;<a name="line.307"></a>
-<span class="sourceLineNo">308</span>  // file system manager for the master FS operations<a name="line.308"></a>
-<span class="sourceLineNo">309</span>  private MasterFileSystem fileSystemManager;<a name="line.309"></a>
-<span class="sourceLineNo">310</span>  private MasterWalManager walManager;<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>  // manager to manage procedure-based WAL splitting, can be null if current<a name="line.312"></a>
-<span class="sourceLineNo">313</span>  // is zk-based WAL splitting. SplitWALManager will replace SplitLogManager<a name="line.313"></a>
-<span class="sourceLineNo">314</span>  // and MasterWalManager, which means zk-based WAL splitting code will be<a name="line.314"></a>
-<span class="sourceLineNo">315</span>  // useless after we switch to the procedure-based one. our eventual goal<a name="line.315"></a>
-<span class="sourceLineNo">316</span>  // is to remove all the zk-based WAL splitting code.<a name="line.316"></a>
-<span class="sourceLineNo">317</span>  private SplitWALManager splitWALManager;<a name="line.317"></a>
-<span class="sourceLineNo">318</span><a name="line.318"></a>
-<span class="sourceLineNo">319</span>  // server manager to deal with region server info<a name="line.319"></a>
-<span class="sourceLineNo">320</span>  private volatile ServerManager serverManager;<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  // manager of assignment nodes in zookeeper<a name="line.322"></a>
-<span class="sourceLineNo">323</span>  private AssignmentManager assignmentManager;<a name="line.323"></a>
-<span class="sourceLineNo">324</span><a name="line.324"></a>
-<span class="sourceLineNo">325</span>  private RSGroupInfoManager rsGroupInfoManager;<a name="line.325"></a>
-<span class="sourceLineNo">326</span><a name="line.326"></a>
-<span class="sourceLineNo">327</span>  // manager of replication<a name="line.327"></a>
-<span class="sourceLineNo">328</span>  private ReplicationPeerManager replicationPeerManager;<a name="line.328"></a>
-<span class="sourceLineNo">329</span><a name="line.329"></a>
-<span class="sourceLineNo">330</span>  private SyncReplicationReplayWALManager syncReplicationReplayWALManager;<a name="line.330"></a>
-<span class="sourceLineNo">331</span><a name="line.331"></a>
-<span class="sourceLineNo">332</span>  // buffer for "fatal error" notices from region servers<a name="line.332"></a>
-<span class="sourceLineNo">333</span>  // in the cluster. This is only used for assisting<a name="line.333"></a>
-<span class="sourceLineNo">334</span>  // operations/debugging.<a name="line.334"></a>
-<span class="sourceLineNo">335</span>  MemoryBoundedLogMessageBuffer rsFatals;<a name="line.335"></a>
-<span class="sourceLineNo">336</span><a name="line.336"></a>
-<span class="sourceLineNo">337</span>  // flag set after we become the active master (used for testing)<a name="line.337"></a>
-<span class="sourceLineNo">338</span>  private volatile boolean activeMaster = false;<a name="line.338"></a>
-<span class="sourceLineNo">339</span><a name="line.339"></a>
-<span class="sourceLineNo">340</span>  // flag set after we complete initialization once active<a name="line.340"></a>
-<span class="sourceLineNo">341</span>  private final ProcedureEvent&lt;?&gt; initialized = new ProcedureEvent&lt;&gt;("master initialized");<a name="line.341"></a>
-<span class="sourceLineNo">342</span><a name="line.342"></a>
-<span class="sourceLineNo">343</span>  // flag set after master services are started,<a name="line.343"></a>
-<span class="sourceLineNo">344</span>  // initialization may have not completed yet.<a name="line.344"></a>
-<span class="sourceLineNo">345</span>  volatile boolean serviceStarted = false;<a name="line.345"></a>
-<span class="sourceLineNo">346</span><a name="line.346"></a>
-<span class="sourceLineNo">347</span>  // Maximum time we should run balancer for<a name="line.347"></a>
-<span class="sourceLineNo">348</span>  private final int maxBalancingTime;<a name="line.348"></a>
-<span class="sourceLineNo">349</span>  // Maximum percent of regions in transition when balancing<a name="line.349"></a>
-<span class="sourceLineNo">350</span>  private final double maxRitPercent;<a name="line.350"></a>
-<span class="sourceLineNo">351</span><a name="line.351"></a>
-<span class="sourceLineNo">352</span>  private final LockManager lockManager = new LockManager(this);<a name="line.352"></a>
-<span class="sourceLineNo">353</span><a name="line.353"></a>
-<span class="sourceLineNo">354</span>  private RSGroupBasedLoadBalancer balancer;<a name="line.354"></a>
-<span class="sourceLineNo">355</span>  private BalancerChore balancerChore;<a name="line.355"></a>
-<span class="sourceLineNo">356</span>  private RegionNormalizerManager regionNormalizerManager;<a name="line.356"></a>
-<span class="sourceLineNo">357</span>  private ClusterStatusChore clusterStatusChore;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>  private ClusterStatusPublisher clusterStatusPublisherChore = null;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>  private SnapshotCleanerChore snapshotCleanerChore = null;<a name="line.359"></a>
-<span class="sourceLineNo">360</span><a name="line.360"></a>
-<span class="sourceLineNo">361</span>  private HbckChore hbckChore;<a name="line.361"></a>
-<span class="sourceLineNo">362</span>  CatalogJanitor catalogJanitorChore;<a name="line.362"></a>
-<span class="sourceLineNo">363</span>  private DirScanPool cleanerPool;<a name="line.363"></a>
-<span class="sourceLineNo">364</span>  private LogCleaner logCleaner;<a name="line.364"></a>
-<span class="sourceLineNo">365</span>  private HFileCleaner hfileCleaner;<a name="line.365"></a>
-<span class="sourceLineNo">366</span>  private ReplicationBarrierCleaner replicationBarrierCleaner;<a name="line.366"></a>
-<span class="sourceLineNo">367</span>  private MobFileCleanerChore mobFileCleanerChore;<a name="line.367"></a>
-<span class="sourceLineNo">368</span>  private MobFileCompactionChore mobFileCompactionChore;<a name="line.368"></a>
-<span class="sourceLineNo">369</span>  // used to synchronize the mobCompactionStates<a name="line.369"></a>
-<span class="sourceLineNo">370</span>  private final IdLock mobCompactionLock = new IdLock();<a name="line.370"></a>
-<span class="sourceLineNo">371</span>  // save the information of mob compactions in tables.<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  // the key is table name, the value is the number of compactions in that table.<a name="line.372"></a>
-<span class="sourceLineNo">373</span>  private Map&lt;TableName, AtomicInteger&gt; mobCompactionStates = Maps.newConcurrentMap();<a name="line.373"></a>
-<span class="sourceLineNo">374</span><a name="line.374"></a>
-<span class="sourceLineNo">375</span>  MasterCoprocessorHost cpHost;<a name="line.375"></a>
-<span class="sourceLineNo">376</span><a name="line.376"></a>
-<span class="sourceLineNo">377</span>  private final boolean preLoadTableDescriptors;<a name="line.377"></a>
-<span class="sourceLineNo">378</span><a name="line.378"></a>
-<span class="sourceLineNo">379</span>  // Time stamps for when a hmaster became active<a name="line.379"></a>
-<span class="sourceLineNo">380</span>  private long masterActiveTime;<a name="line.380"></a>
-<span class="sourceLineNo">381</span><a name="line.381"></a>
-<span class="sourceLineNo">382</span>  // Time stamp for when HMaster finishes becoming Active Master<a name="line.382"></a>
-<span class="sourceLineNo">383</span>  private long masterFinishedInitializationTime;<a name="line.383"></a>
-<span class="sourceLineNo">384</span><a name="line.384"></a>
-<span class="sourceLineNo">385</span>  Map&lt;String, Service&gt; coprocessorServiceHandlers = Maps.newHashMap();<a name="line.385"></a>
-<span class="sourceLineNo">386</span><a name="line.386"></a>
-<span class="sourceLineNo">387</span>  // monitor for snapshot of hbase tables<a name="line.387"></a>
-<span class="sourceLineNo">388</span>  SnapshotManager snapshotManager;<a name="line.388"></a>
-<span class="sourceLineNo">389</span>  // monitor for distributed procedures<a name="line.389"></a>
-<span class="sourceLineNo">390</span>  private MasterProcedureManagerHost mpmHost;<a name="line.390"></a>
-<span class="sourceLineNo">391</span><a name="line.391"></a>
-<span class="sourceLineNo">392</span>  private RegionsRecoveryChore regionsRecoveryChore = null;<a name="line.392"></a>
-<span class="sourceLineNo">393</span><a name="line.393"></a>
-<span class="sourceLineNo">394</span>  private RegionsRecoveryConfigManager regionsRecoveryConfigManager = null;<a name="line.394"></a>
-<span class="sourceLineNo">395</span>  // it is assigned after 'initialized' guard set to true, so should be volatile<a name="line.395"></a>
-<span class="sourceLineNo">396</span>  private volatile MasterQuotaManager quotaManager;<a name="line.396"></a>
-<span class="sourceLineNo">397</span>  private SpaceQuotaSnapshotNotifier spaceQuotaSnapshotNotifier;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>  private QuotaObserverChore quotaObserverChore;<a name="line.398"></a>
-<span class="sourceLineNo">399</span>  private SnapshotQuotaObserverChore snapshotQuotaChore;<a name="line.399"></a>
-<span class="sourceLineNo">400</span><a name="line.400"></a>
-<span class="sourceLineNo">401</span>  private ProcedureExecutor&lt;MasterProcedureEnv&gt; procedureExecutor;<a name="line.401"></a>
-<span class="sourceLineNo">402</span>  private ProcedureStore procedureStore;<a name="line.402"></a>
-<span class="sourceLineNo">403</span><a name="line.403"></a>
-<span class="sourceLineNo">404</span>  // the master local storage to store procedure data, meta region locations, etc.<a name="line.404"></a>
-<span class="sourceLineNo">405</span>  private MasterRegion masterRegion;<a name="line.405"></a>
-<span class="sourceLineNo">406</span><a name="line.406"></a>
-<span class="sourceLineNo">407</span>  // handle table states<a name="line.407"></a>
-<span class="sourceLineNo">408</span>  private TableStateManager tableStateManager;<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  /** jetty server for master to redirect requests to regionserver infoServer */<a name="line.410"></a>
-<span class="sourceLineNo">411</span>  private Server masterJettyServer;<a name="line.411"></a>
-<span class="sourceLineNo">412</span><a name="line.412"></a>
-<span class="sourceLineNo">413</span>  // Determine if we should do normal startup or minimal "single-user" mode with no region<a name="line.413"></a>
-<span class="sourceLineNo">414</span>  // servers and no user tables. Useful for repair and recovery of hbase:meta<a name="line.414"></a>
-<span class="sourceLineNo">415</span>  private final boolean maintenanceMode;<a name="line.415"></a>
-<span class="sourceLineNo">416</span>  static final String MAINTENANCE_MODE = "hbase.master.maintenance_mode";<a name="line.416"></a>
-<span class="sourceLineNo">417</span><a name="line.417"></a>
-<span class="sourceLineNo">418</span>  // Cached clusterId on stand by masters to serve clusterID requests from clients.<a name="line.418"></a>
-<span class="sourceLineNo">419</span>  private final CachedClusterId cachedClusterId;<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>   * Initializes the HMaster. The steps are as follows:<a name="line.422"></a>
-<span class="sourceLineNo">423</span>   * &lt;p&gt;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>   * &lt;ol&gt;<a name="line.424"></a>
-<span class="sourceLineNo">425</span>   * &lt;li&gt;Initialize the local HRegionServer<a name="line.425"></a>
-<span class="sourceLineNo">426</span>   * &lt;li&gt;Start the ActiveMasterManager.<a name="line.426"></a>
-<span class="sourceLineNo">427</span>   * &lt;/ol&gt;<a name="line.427"></a>
-<span class="sourceLineNo">428</span>   * &lt;p&gt;<a name="line.428"></a>
-<span class="sourceLineNo">429</span>   * Remaining steps of initialization occur in<a name="line.429"></a>
-<span class="sourceLineNo">430</span>   * {@link #finishActiveMasterInitialization(MonitoredTask)} after the master becomes the<a name="line.430"></a>
-<span class="sourceLineNo">431</span>   * active one.<a name="line.431"></a>
-<span class="sourceLineNo">432</span>   */<a name="line.432"></a>
-<span class="sourceLineNo">433</span>  public HMaster(final Configuration conf) throws IOException {<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    super(conf);<a name="line.434"></a>
-<span class="sourceLineNo">435</span>    try {<a name="line.435"></a>
-<span class="sourceLineNo">436</span>      if (conf.getBoolean(MAINTENANCE_MODE, false)) {<a name="line.436"></a>
-<span class="sourceLineNo">437</span>        LOG.info("Detected {}=true via configuration.", MAINTENANCE_MODE);<a name="line.437"></a>
-<span class="sourceLineNo">438</span>        maintenanceMode = true;<a name="line.438"></a>
-<span class="sourceLineNo">439</span>      } else if (Boolean.getBoolean(MAINTENANCE_MODE)) {<a name="line.439"></a>
-<span class="sourceLineNo">440</span>        LOG.info("Detected {}=true via environment variables.", MAINTENANCE_MODE);<a name="line.440"></a>
-<span class="sourceLineNo">441</span>        maintenanceMode = true;<a name="line.441"></a>
-<span class="sourceLineNo">442</span>      } else {<a name="line.442"></a>
-<span class="sourceLineNo">443</span>        maintenanceMode = false;<a name="line.443"></a>
-<span class="sourceLineNo">444</span>      }<a name="line.444"></a>
-<span class="sourceLineNo">445</span>      this.rsFatals = new MemoryBoundedLogMessageBuffer(<a name="line.445"></a>
-<span class="sourceLineNo">446</span>          conf.getLong("hbase.master.buffer.for.rs.fatals", 1 * 1024 * 1024));<a name="line.446"></a>
-<span class="sourceLineNo">447</span>      LOG.info("hbase.rootdir={}, hbase.cluster.distributed={}", getDataRootDir(),<a name="line.447"></a>
-<span class="sourceLineNo">448</span>          this.conf.getBoolean(HConstants.CLUSTER_DISTRIBUTED, false));<a name="line.448"></a>
-<span class="sourceLineNo">449</span><a name="line.449"></a>
-<span class="sourceLineNo">450</span>      // Disable usage of meta replicas in the master<a name="line.450"></a>
-<span class="sourceLineNo">451</span>      this.conf.setBoolean(HConstants.USE_META_REPLICAS, false);<a name="line.451"></a>
-<span class="sourceLineNo">452</span><a name="line.452"></a>
-<span class="sourceLineNo">453</span>      decorateMasterConfiguration(this.conf);<a name="line.453"></a>
-<span class="sourceLineNo">454</span><a name="line.454"></a>
-<span class="sourceLineNo">455</span>      // Hack! Maps DFSClient =&gt; Master for logs.  HDFS made this<a name="line.455"></a>
-<span class="sourceLineNo">456</span>      // config param for task trackers, but we can piggyback off of it.<a name="line.456"></a>
-<span class="sourceLineNo">457</span>      if (this.conf.get("mapreduce.task.attempt.id") == null) {<a name="line.457"></a>
-<span class="sourceLineNo">458</span>        this.conf.set("mapreduce.task.attempt.id", "hb_m_" + this.serverName.toString());<a name="line.458"></a>
-<span class="sourceLineNo">459</span>      }<a name="line.459"></a>
-<span class="sourceLineNo">460</span><a name="line.460"></a>
-<span class="sourceLineNo">461</span>      this.metricsMaster = new MetricsMaster(new MetricsMasterWrapperImpl(this));<a name="line.461"></a>
-<span class="sourceLineNo">462</span><a name="line.462"></a>
-<span class="sourceLineNo">463</span>      // preload table descriptor at startup<a name="line.463"></a>
-<span class="sourceLineNo">464</span>      this.preLoadTableDescriptors = conf.getBoolean("hbase.master.preload.tabledescriptors", true);<a name="line.464"></a>
-<span class="sourceLineNo">465</span><a name="line.465"></a>
-<span class="sourceLineNo">466</span>      this.maxBalancingTime = getMaxBalancingTime();<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      this.maxRitPercent = conf.getDouble(HConstants.HBASE_MASTER_BALANCER_MAX_RIT_PERCENT,<a name="line.467"></a>
-<span class="sourceLineNo">468</span>          HConstants.DEFAULT_HBASE_MASTER_BALANCER_MAX_RIT_PERCENT);<a name="line.468"></a>
+<span class="sourceLineNo">218</span>import org.apache.hadoop.hbase.util.JVMClusterUtil;<a name="line.218"></a>
+<span class="sourceLineNo">219</span>import org.apache.hadoop.hbase.util.ModifyRegionUtils;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.220"></a>
+<span class="sourceLineNo">221</span>import org.apache.hadoop.hbase.util.RetryCounter;<a name="line.221"></a>
+<span class="sourceLineNo">222</span>import org.apache.hadoop.hbase.util.RetryCounterFactory;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>import org.apache.hadoop.hbase.util.TableDescriptorChecker;<a name="line.223"></a>
+<span class="sourceLineNo">224</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.224"></a>
+<span class="sourceLineNo">225</span>import org.apache.hadoop.hbase.util.VersionInfo;<a name="line.225"></a>
+<span class="sourceLineNo">226</span>import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;<a name="line.226"></a>
+<span class="sourceLineNo">227</span>import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;<a name="line.227"></a>
+<span class="sourceLineNo">228</span>import org.apache.hadoop.hbase.zookeeper.MetaTableLocator;<a name="line.228"></a>
+<span class="sourceLineNo">229</span>import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;<a name="line.229"></a>
+<span class="sourceLineNo">230</span>import org.apache.hadoop.hbase.zookeeper.SnapshotCleanupTracker;<a name="line.230"></a>
+<span class="sourceLineNo">231</span>import org.apache.hadoop.hbase.zookeeper.ZKClusterId;<a name="line.231"></a>
+<span class="sourceLineNo">232</span>import org.apache.hadoop.hbase.zookeeper.ZKUtil;<a name="line.232"></a>
+<span class="sourceLineNo">233</span>import org.apache.hadoop.hbase.zookeeper.ZKWatcher;<a name="line.233"></a>
+<span class="sourceLineNo">234</span>import org.apache.hadoop.hbase.zookeeper.ZNodePaths;<a name="line.234"></a>
+<span class="sourceLineNo">235</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.235"></a>
+<span class="sourceLineNo">236</span>import org.apache.zookeeper.KeeperException;<a name="line.236"></a>
+<span class="sourceLineNo">237</span>import org.slf4j.Logger;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>import org.slf4j.LoggerFactory;<a name="line.238"></a>
+<span class="sourceLineNo">239</span><a name="line.239"></a>
+<span class="sourceLineNo">240</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.240"></a>
+<span class="sourceLineNo">241</span>import org.apache.hbase.thirdparty.com.google.common.collect.Maps;<a name="line.241"></a>
+<span class="sourceLineNo">242</span>import org.apache.hbase.thirdparty.com.google.common.collect.Sets;<a name="line.242"></a>
+<span class="sourceLineNo">243</span>import org.apache.hbase.thirdparty.com.google.common.io.Closeables;<a name="line.243"></a>
+<span class="sourceLineNo">244</span>import org.apache.hbase.thirdparty.com.google.protobuf.Descriptors;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>import org.apache.hbase.thirdparty.com.google.protobuf.Service;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.Server;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.server.ServerConnector;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.servlet.ServletHolder;<a name="line.248"></a>
+<span class="sourceLineNo">249</span>import org.apache.hbase.thirdparty.org.eclipse.jetty.webapp.WebAppContext;<a name="line.249"></a>
+<span class="sourceLineNo">250</span><a name="line.250"></a>
+<span class="sourceLineNo">251</span>import org.apache.hadoop.hbase.shaded.protobuf.RequestConverter;<a name="line.251"></a>
+<span class="sourceLineNo">252</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.AdminProtos.GetRegionInfoResponse;<a name="line.252"></a>
+<span class="sourceLineNo">253</span>import org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription;<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> * HMaster is the "master server" for HBase. An HBase cluster has one active master. If many masters<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * are started, all compete. Whichever wins goes on to run the cluster. All others park themselves<a name="line.257"></a>
+<span class="sourceLineNo">258</span> * in their constructor until master or cluster shutdown or until the active master loses its lease<a name="line.258"></a>
+<span class="sourceLineNo">259</span> * in zookeeper. Thereafter, all running master jostle to take over master role.<a name="line.259"></a>
+<span class="sourceLineNo">260</span> * &lt;p/&gt;<a name="line.260"></a>
+<span class="sourceLineNo">261</span> * The Master can be asked shutdown the cluster. See {@link #shutdown()}. In this case it will tell<a name="line.261"></a>
+<span class="sourceLineNo">262</span> * all regionservers to go down and then wait on them all reporting in that they are down. This<a name="line.262"></a>
+<span class="sourceLineNo">263</span> * master will then shut itself down.<a name="line.263"></a>
+<span class="sourceLineNo">264</span> * &lt;p/&gt;<a name="line.264"></a>
+<span class="sourceLineNo">265</span> * You can also shutdown just this master. Call {@link #stopMaster()}.<a name="line.265"></a>
+<span class="sourceLineNo">266</span> * @see org.apache.zookeeper.Watcher<a name="line.266"></a>
+<span class="sourceLineNo">267</span> */<a name="line.267"></a>
+<span class="sourceLineNo">268</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.TOOLS)<a name="line.268"></a>
+<span class="sourceLineNo">269</span>@SuppressWarnings("deprecation")<a name="line.269"></a>
+<span class="sourceLineNo">270</span>public class HMaster extends HRegionServer implements MasterServices {<a name="line.270"></a>
+<span class="sourceLineNo">271</span><a name="line.271"></a>
+<span class="sourceLineNo">272</span>  private static final Logger LOG = LoggerFactory.getLogger(HMaster.class);<a name="line.272"></a>
+<span class="sourceLineNo">273</span><a name="line.273"></a>
+<span class="sourceLineNo">274</span>  // MASTER is name of the webapp and the attribute name used stuffing this<a name="line.274"></a>
+<span class="sourceLineNo">275</span>  //instance into web context.<a name="line.275"></a>
+<span class="sourceLineNo">276</span>  public static final String MASTER = "master";<a name="line.276"></a>
+<span class="sourceLineNo">277</span><a name="line.277"></a>
+<span class="sourceLineNo">278</span>  // Manager and zk listener for master election<a name="line.278"></a>
+<span class="sourceLineNo">279</span>  private final ActiveMasterManager activeMasterManager;<a name="line.279"></a>
+<span class="sourceLineNo">280</span>  // Region server tracker<a name="line.280"></a>
+<span class="sourceLineNo">281</span>  private final RegionServerTracker regionServerTracker;<a name="line.281"></a>
+<span class="sourceLineNo">282</span>  // Draining region server tracker<a name="line.282"></a>
+<span class="sourceLineNo">283</span>  private DrainingServerTracker drainingServerTracker;<a name="line.283"></a>
+<span class="sourceLineNo">284</span>  // Tracker for load balancer state<a name="line.284"></a>
+<span class="sourceLineNo">285</span>  LoadBalancerTracker loadBalancerTracker;<a name="line.285"></a>
+<span class="sourceLineNo">286</span>  // Tracker for meta location, if any client ZK quorum specified<a name="line.286"></a>
+<span class="sourceLineNo">287</span>  private MetaLocationSyncer metaLocationSyncer;<a name="line.287"></a>
+<span class="sourceLineNo">288</span>  // Tracker for active master location, if any client ZK quorum specified<a name="line.288"></a>
+<span class="sourceLineNo">289</span>  @InterfaceAudience.Private<a name="line.289"></a>
+<span class="sourceLineNo">290</span>  MasterAddressSyncer masterAddressSyncer;<a name="line.290"></a>
+<span class="sourceLineNo">291</span>  // Tracker for auto snapshot cleanup state<a name="line.291"></a>
+<span class="sourceLineNo">292</span>  SnapshotCleanupTracker snapshotCleanupTracker;<a name="line.292"></a>
+<span class="sourceLineNo">293</span><a name="line.293"></a>
+<span class="sourceLineNo">294</span>  // Tracker for split and merge state<a name="line.294"></a>
+<span class="sourceLineNo">295</span>  private SplitOrMergeTracker splitOrMergeTracker;<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>  private ClusterSchemaService clusterSchemaService;<a name="line.297"></a>
+<span class="sourceLineNo">298</span><a name="line.298"></a>
+<span class="sourceLineNo">299</span>  public static final String HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS =<a name="line.299"></a>
+<span class="sourceLineNo">300</span>    "hbase.master.wait.on.service.seconds";<a name="line.300"></a>
+<span class="sourceLineNo">301</span>  public static final int DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS = 5 * 60;<a name="line.301"></a>
+<span class="sourceLineNo">302</span><a name="line.302"></a>
+<span class="sourceLineNo">303</span>  public static final String HBASE_MASTER_CLEANER_INTERVAL = "hbase.master.cleaner.interval";<a name="line.303"></a>
+<span class="sourceLineNo">304</span><a name="line.304"></a>
+<span class="sourceLineNo">305</span>  public static final int DEFAULT_HBASE_MASTER_CLEANER_INTERVAL = 600 * 1000;<a name="line.305"></a>
+<span class="sourceLineNo">306</span><a name="line.306"></a>
+<span class="sourceLineNo">307</span>  // Metrics for the HMaster<a name="line.307"></a>
+<span class="sourceLineNo">308</span>  final MetricsMaster metricsMaster;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>  // file system manager for the master FS operations<a name="line.309"></a>
+<span class="sourceLineNo">310</span>  private MasterFileSystem fileSystemManager;<a name="line.310"></a>
+<span class="sourceLineNo">311</span>  private MasterWalManager walManager;<a name="line.311"></a>
+<span class="sourceLineNo">312</span><a name="line.312"></a>
+<span class="sourceLineNo">313</span>  // manager to manage procedure-based WAL splitting, can be null if current<a name="line.313"></a>
+<span class="sourceLineNo">314</span>  // is zk-based WAL splitting. SplitWALManager will replace SplitLogManager<a name="line.314"></a>
+<span class="sourceLineNo">315</span>  // and MasterWalManager, which means zk-based WAL splitting code will be<a name="line.315"></a>
+<span class="sourceLineNo">316</span>  // useless after we switch to the procedure-based one. our eventual goal<a name="line.316"></a>
+<span class="sourceLineNo">317</span>  // is to remove all the zk-based WAL splitting code.<a name="line.317"></a>
+<span class="sourceLineNo">318</span>  private SplitWALManager splitWALManager;<a name="line.318"></a>
+<span class="sourceLineNo">319</span><a name="line.319"></a>
+<span class="sourceLineNo">320</span>  // server manager to deal with region server info<a name="line.320"></a>
+<span class="sourceLineNo">321</span>  private volatile ServerManager serverManager;<a name="line.321"></a>
+<span class="sourceLineNo">322</span><a name="line.322"></a>
+<span class="sourceLineNo">323</span>  // manager of assignment nodes in zookeeper<a name="line.323"></a>
+<span class="sourceLineNo">324</span>  private AssignmentManager assignmentManager;<a name="line.324"></a>
+<span class="sourceLineNo">325</span><a name="line.325"></a>
+<span class="sourceLineNo">326</span>  private RSGroupInfoManager rsGroupInfoManager;<a name="line.326"></a>
+<span class="sourceLineNo">327</span><a name="line.327"></a>
+<span class="sourceLineNo">328</span>  // manager of replication<a name="line.328"></a>
+<span class="sourceLineNo">329</span>  private ReplicationPeerManager replicationPeerManager;<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  private SyncReplicationReplayWALManager syncReplicationReplayWALManager;<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  // buffer for "fatal error" notices from region servers<a name="line.333"></a>
+<span class="sourceLineNo">334</span>  // in the cluster. This is only used for assisting<a name="line.334"></a>
+<span class="sourceLineNo">335</span>  // operations/debugging.<a name="line.335"></a>
+<span class="sourceLineNo">336</span>  MemoryBoundedLogMessageBuffer rsFatals;<a name="line.336"></a>
+<span class="sourceLineNo">337</span><a name="line.337"></a>
+<span class="sourceLineNo">338</span>  // flag set after we become the active master (used for testing)<a name="line.338"></a>
+<span class="sourceLineNo">339</span>  private volatile boolean activeMaster = false;<a name="line.339"></a>
+<span class="sourceLineNo">340</span><a name="line.340"></a>
+<span class="sourceLineNo">341</span>  // flag set after we complete initialization once active<a name="line.341"></a>
+<span class="sourceLineNo">342</span>  private final ProcedureEvent&lt;?&gt; initialized = new ProcedureEvent&lt;&gt;("master initialized");<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span>  // flag set after master services are started,<a name="line.344"></a>
+<span class="sourceLineNo">345</span>  // initialization may have not completed yet.<a name="line.345"></a>
+<span class="sourceLineNo">346</span>  volatile boolean serviceStarted = false;<a name="line.346"></a>
+<span class="sourceLineNo">347</span><a name="line.347"></a>
+<span class="sourceLineNo">348</span>  // Maximum time we should run balancer for<a name="line.348"></a>
+<span class="sourceLineNo">349</span>  private final int maxBalancingTime;<a name="line.349"></a>
+<span class="sourceLineNo">350</span>  // Maximum percent of regions in transition when balancing<a name="line.350"></a>
+<span class="sourceLineNo">351</span>  private final double maxRitPercent;<a name="line.351"></a>
+<span class="sourceLineNo">352</span><a name="line.352"></a>
+<span class="sourceLineNo">353</span>  private final LockManager lockManager = new LockManager(this);<a name="line.353"></a>
+<span class="sourceLineNo">354</span><a name="line.354"></a>
+<span class="sourceLineNo">355</span>  private RSGroupBasedLoadBalancer balancer;<a name="line.355"></a>
+<span class="sourceLineNo">356</span>  private BalancerChore balancerChore;<a name="line.356"></a>
+<span class="sourceLineNo">357</span>  private RegionNormalizerManager regionNormalizerManager;<a name="line.357"></a>
+<span class="sourceLineNo">358</span>  private ClusterStatusChore clusterStatusChore;<a name="line.358"></a>
+<span class="sourceLineNo">359</span>  private ClusterStatusPublisher clusterStatusPublisherChore = null;<a name="line.359"></a>
+<span class="sourceLineNo">360</span>  private SnapshotCleanerChore snapshotCleanerChore = null;<a name="line.360"></a>
+<span class="sourceLineNo">361</span><a name="line.361"></a>
+<span class="sourceLineNo">362</span>  private HbckChore hbckChore;<a name="line.362"></a>
+<span class="sourceLineNo">363</span>  CatalogJanitor catalogJanitorChore;<a name="line.363"></a>
+<span class="sourceLineNo">364</span>  private DirScanPool cleanerPool;<a name="line.364"></a>
+<span class="sourceLineNo">365</span>  private LogCleaner logCleaner;<a name="line.365"></a>
+<span class="sourceLineNo">366</span>  private HFileCleaner hfileCleaner;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>  private ReplicationBarrierCleaner replicationBarrierCleaner;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>  private MobFileCleanerChore mobFileCleanerChore;<a name="line.368"></a>
+<span class="sourceLineNo">369</span>  private MobFileCompactionChore mobFileCompactionChore;<a name="line.369"></a>
+<span class="sourceLineNo">370</span>  // used to synchronize the mobCompactionStates<a name="line.370"></a>
+<span class="sourceLineNo">371</span>  private final IdLock mobCompactionLock = new IdLock();<a name="line.371"></a>
+<span class="sourceLineNo">372</span>  // save the information of mob compactions in tables.<a name="line.372"></a>
+<span class="sourceLineNo">373</span>  // the key is table name, the value is the number of compactions in that table.<a name="line.373"></a>
+<span class="sourceLineNo">374</span>  private Map&lt;TableName, AtomicInteger&gt; mobCompactionStates = Maps.newConcurrentMap();<a name="line.374"></a>
+<span class="sourceLineNo">375</span><a name="line.375"></a>
+<span class="sourceLineNo">376</span>  MasterCoprocessorHost cpHost;<a name="line.376"></a>
+<span class="sourceLineNo">377</span><a name="line.377"></a>
+<span class="sourceLineNo">378</span>  private final boolean preLoadTableDescriptors;<a name="line.378"></a>
+<span class="sourceLineNo">379</span><a name="line.379"></a>
+<span class="sourceLineNo">380</span>  // Time stamps for when a hmaster became active<a name="line.380"></a>
+<span class="sourceLineNo">381</span>  private long masterActiveTime;<a name="line.381"></a>
+<span class="sourceLineNo">382</span><a name="line.382"></a>
+<span class="sourceLineNo">383</span>  // Time stamp for when HMaster finishes becoming Active Master<a name="line.383"></a>
+<span class="sourceLineNo">384</span>  private long masterFinishedInitializationTime;<a name="line.384"></a>
+<span class="sourceLineNo">385</span><a name="line.385"></a>
+<span class="sourceLineNo">386</span>  Map&lt;String, Service&gt; coprocessorServiceHandlers = Maps.newHashMap();<a name="line.386"></a>
+<span class="sourceLineNo">387</span><a name="line.387"></a>
+<span class="sourceLineNo">388</span>  // monitor for snapshot of hbase tables<a name="line.388"></a>
+<span class="sourceLineNo">389</span>  SnapshotManager snapshotManager;<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  // monitor for distributed procedures<a name="line.390"></a>
+<span class="sourceLineNo">391</span>  private MasterProcedureManagerHost mpmHost;<a name="line.391"></a>
+<span class="sourceLineNo">392</span><a name="line.392"></a>
+<span class="sourceLineNo">393</span>  private RegionsRecoveryChore regionsRecoveryChore = null;<a name="line.393"></a>
+<span class="sourceLineNo">394</span><a name="line.394"></a>
+<span class="sourceLineNo">395</span>  private RegionsRecoveryConfigManager regionsRecoveryConfigManager = null;<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  // it is assigned after 'initialized' guard set to true, so should be volatile<a name="line.396"></a>
+<span class="sourceLineNo">397</span>  private volatile MasterQuotaManager quotaManager;<a name="line.397"></a>
+<span class="sourceLineNo">398</span>  private SpaceQuotaSnapshotNotifier spaceQuotaSnapshotNotifier;<a name="line.398"></a>
+<span class="sourceLineNo">399</span>  private QuotaObserverChore quotaObserverChore;<a name="line.399"></a>
+<span class="sourceLineNo">400</span>  private SnapshotQuotaObserverChore snapshotQuotaChore;<a name="line.400"></a>
+<span class="sourceLineNo">401</span><a name="line.401"></a>
+<span class="sourceLineNo">402</span>  private ProcedureExecutor&lt;MasterProcedureEnv&gt; procedureExecutor;<a name="line.402"></a>
+<span class="sourceLineNo">403</span>  private ProcedureStore procedureStore;<a name="line.403"></a>
+<span class="sourceLineNo">404</span><a name="line.404"></a>
+<span class="sourceLineNo">405</span>  // the master local storage to store procedure data, meta region locations, etc.<a name="line.405"></a>
+<span class="sourceLineNo">406</span>  private MasterRegion masterRegion;<a name="line.406"></a>
+<span class="sourceLineNo">407</span><a name="line.407"></a>
+<span class="sourceLineNo">408</span>  // handle table states<a name="line.408"></a>
+<span class="sourceLineNo">409</span>  private TableStateManager tableStateManager;<a name="line.409"></a>
+<span class="sourceLineNo">410</span><a name="line.410"></a>
+<span class="sourceLineNo">411</span>  /** jetty server for master to redirect requests to regionserver infoServer */<a name="line.411"></a>
+<span class="sourceLineNo">412</span>  private Server masterJettyServer;<a name="line.412"></a>
+<span class="sourceLineNo">413</span><a name="line.413"></a>
+<span class="sourceLineNo">414</span>  // Determine if we should do normal startup or minimal "single-user" mode with no region<a name="line.414"></a>
+<span class="sourceLineNo">415</span>  // servers and no user tables. Useful for repair and recovery of hbase:meta<a name="line.415"></a>
+<span class="sourceLineNo">416</span>  private final boolean maintenanceMode;<a name="line.416"></a>
+<span class="sourceLineNo">417</span>  static final String MAINTENANCE_MODE = "hbase.master.maintenance_mode";<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  // the in process region server for carry system regions in maintenanceMode<a name="line.419"></a>
+<span class="sourceLineNo">420</span>  private JVMClusterUtil.RegionServerThread maintenanceRegionServer;<a name="line.420"></a>
+<span class="sourceLineNo">421</span><a name="line.421"></a>
+<span class="sourceLineNo">422</span>  // Cached clusterId on stand by masters to serve clusterID requests from clients.<a name="line.422"></a>
+<span class="sourceLineNo">423</span>  private final CachedClusterId cachedClusterId;<a name="line.423"></a>
+<span class="sourceLineNo">424</span><a name="line.424"></a>
+<span class="sourceLineNo">425</span>  /**<a name="line.425"></a>
+<span class="sourceLineNo">426</span>   * Initializes the HMaster. The steps are as follows:<a name="line.426"></a>
+<span class="sourceLineNo">427</span>   * &lt;p&gt;<a name="line.427"></a>
+<span class="sourceLineNo">428</span>   * &lt;ol&gt;<a name="line.428"></a>
+<span class="sourceLineNo">429</span>   * &lt;li&gt;Initialize the local HRegionServer<a name="line.429"></a>
+<span class="sourceLineNo">430</span>   * &lt;li&gt;Start the ActiveMasterManager.<a name="line.430"></a>
+<span class="sourceLineNo">431</span>   * &lt;/ol&gt;<a name="line.431"></a>
+<span class="sourceLineNo">432</span>   * &lt;p&gt;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>   * Remaining steps of initialization occur in<a name="line.433"></a>
+<span class="sourceLineNo">434</span>   * {@link #finishActiveMasterInitialization(MonitoredTask)} after the master becomes the<a name="line.434"></a>
+<span class="sourceLineNo">435</span>   * active one.<a name="line.435"></a>
+<span class="sourceLineNo">436</span>   */<a name="line.436"></a>
+<span class="sourceLineNo">437</span>  public HMaster(final Configuration conf) throws IOException {<a name="line.437"></a>
+<span class="sourceLineNo">438</span>    super(conf);<a name="line.438"></a>
+<span class="sourceLineNo">439</span>    try {<a name="line.439"></a>
+<span class="sourceLineNo">440</span>      if (conf.getBoolean(MAINTENANCE_MODE, false)) {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>        LOG.info("Detected {}=true via configuration.", MAINTENANCE_MODE);<a name="line.441"></a>
+<span class="sourceLineNo">442</span>        maintenanceMode = true;<a name="line.442"></a>
+<span class="sourceLineNo">443</span>      } else if (Boolean.getBoolean(MAINTENANCE_MODE)) {<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        LOG.info("Detected {}=true via environment variables.", MAINTENANCE_MODE);<a name="line.444"></a>
+<span class="sourceLineNo">445</span>        maintenanceMode = true;<a name="line.445"></a>
+<span class="sourceLineNo">446</span>      } else {<a name="line.446"></a>
+<span class="sourceLineNo">447</span>        maintenanceMode = false;<a name="line.447"></a>
+<span class="sourceLineNo">448</span>      }<a name="line.448"></a>
+<span class="sourceLineNo">449</span>      this.rsFatals = new MemoryBoundedLogMessageBuffer(<a name="line.449"></a>
+<span class="sourceLineNo">450</span>          conf.getLong("hbase.master.buffer.for.rs.fatals", 1 * 1024 * 1024));<a name="line.450"></a>
+<span class="sourceLineNo">451</span>      LOG.info("hbase.rootdir={}, hbase.cluster.distributed={}", getDataRootDir(),<a name="line.451"></a>
+<span class="sourceLineNo">452</span>          this.conf.getBoolean(HConstants.CLUSTER_DISTRIBUTED, false));<a name="line.452"></a>
+<span class="sourceLineNo">453</span><a name="line.453"></a>
+<span class="sourceLineNo">454</span>      // Disable usage of meta replicas in the master<a name="line.454"></a>
+<span class="sourceLineNo">455</span>      this.conf.setBoolean(HConstants.USE_META_REPLICAS, false);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>      decorateMasterConfiguration(this.conf);<a name="line.457"></a>
+<span class="sourceLineNo">458</span><a name="line.458"></a>
+<span class="sourceLineNo">459</span>      // Hack! Maps DFSClient =&gt; Master for logs.  HDFS made this<a name="line.459"></a>
+<span class="sourceLineNo">460</span>      // config param for task trackers, but we can piggyback off of it.<a name="line.460"></a>
+<span class="sourceLineNo">461</span>      if (this.conf.get("mapreduce.task.attempt.id") == null) {<a name="line.461"></a>
+<span class="sourceLineNo">462</span>        this.conf.set("mapreduce.task.attempt.id", "hb_m_" + this.serverName.toString());<a name="line.462"></a>
+<span class="sourceLineNo">463</span>      }<a name="line.463"></a>
+<span class="sourceLineNo">464</span><a name="line.464"></a>
+<span class="sourceLineNo">465</span>      this.metricsMaster = new MetricsMaster(new MetricsMasterWrapperImpl(this));<a name="line.465"></a>
+<span class="sourceLineNo">466</span><a name="line.466"></a>
+<span class="sourceLineNo">467</span>      // preload table descriptor at startup<a name="line.467"></a>
+<span class="sourceLineNo">468</span>      this.preLoadTableDescriptors = conf.getBoolean("hbase.master.preload.tabledescriptors", true);<a name="line.468"></a>
 <span class="sourceLineNo">469</span><a name="line.469"></a>
-<span class="sourceLineNo">470</span>      // Do we publish the status?<a name="line.470"></a>
-<span class="sourceLineNo">471</span><a name="line.471"></a>
-<span class="sourceLineNo">472</span>      boolean shouldPublish = conf.getBoolean(HConstants.STATUS_PUBLISHED,<a name="line.472"></a>
-<span class="sourceLineNo">473</span>          HConstants.STATUS_PUBLISHED_DEFAULT);<a name="line.473"></a>
-<span class="sourceLineNo">474</span>      Class&lt;? extends ClusterStatusPublisher.Publisher&gt; publisherClass =<a name="line.474"></a>
-<span class="sourceLineNo">475</span>          conf.getClass(ClusterStatusPublisher.STATUS_PUBLISHER_CLASS,<a name="line.475"></a>
-<span class="sourceLineNo">476</span>              ClusterStatusPublisher.DEFAULT_STATUS_PUBLISHER_CLASS,<a name="line.476"></a>
-<span class="sourceLineNo">477</span>              ClusterStatusPublisher.Publisher.class);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      if (shouldPublish) {<a name="line.479"></a>
-<span class="sourceLineNo">480</span>        if (publisherClass == null) {<a name="line.480"></a>
-<span class="sourceLineNo">481</span>          LOG.warn(HConstants.STATUS_PUBLISHED + " is true, but " +<a name="line.481"></a>
-<span class="sourceLineNo">482</span>              ClusterStatusPublisher.DEFAULT_STATUS_PUBLISHER_CLASS +<a name="line.482"></a>
-<span class="sourceLineNo">483</span>              " is not set - not publishing status");<a name="line.483"></a>
-<span class="sourceLineNo">484</span>        } else {<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          clusterStatusPublisherChore = new ClusterStatusPublisher(this, conf, publisherClass);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>          LOG.debug("Created {}", this.clusterStatusPublisherChore);<a name="line.486"></a>
-<span class="sourceLineNo">487</span>          getChoreService().scheduleChore(clusterStatusPublisherChore);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>        }<a name="line.488"></a>
-<span class="sourceLineNo">489</span>      }<a name="line.489"></a>
-<span class="sourceLineNo">490</span><a name="line.490"></a>
-<span class="sourceLineNo">491</span>      this.activeMasterManager = createActiveMasterManager(zooKeeper, serverName, this);<a name="line.491"></a>
-<span class="sourceLineNo">492</span><a name="line.492"></a>
-<span class="sourceLineNo">493</span>      cachedClusterId = new CachedClusterId(this, conf);<a name="line.493"></a>
+<span class="sourceLineNo">470</span>      this.maxBalancingTime = getMaxBalancingTime();<a name="line.470"></a>
+<span class="sourceLineNo">471</span>      this.maxRitPercent = conf.getDouble(HConstants.HBASE_MASTER_BALANCER_MAX_RIT_PERCENT,<a name="line.471"></a>
+<span class="sourceLineNo">472</span>          HConstants.DEFAULT_HBASE_MASTER_BALANCER_MAX_RIT_PERCENT);<a name="line.472"></a>
+<span class="sourceLineNo">473</span><a name="line.473"></a>
+<span class="sourceLineNo">474</span>      // Do we publish the status?<a name="line.474"></a>
+<span class="sourceLineNo">475</span><a name="line.475"></a>
+<span class="sourceLineNo">476</span>      boolean shouldPublish = conf.getBoolean(HConstants.STATUS_PUBLISHED,<a name="line.476"></a>
+<span class="sourceLineNo">477</span>          HConstants.STATUS_PUBLISHED_DEFAULT);<a name="line.477"></a>
+<span class="sourceLineNo">478</span>      Class&lt;? extends ClusterStatusPublisher.Publisher&gt; publisherClass =<a name="line.478"></a>
+<span class="sourceLineNo">479</span>          conf.getClass(ClusterStatusPublisher.STATUS_PUBLISHER_CLASS,<a name="line.479"></a>
+<span class="sourceLineNo">480</span>              ClusterStatusPublisher.DEFAULT_STATUS_PUBLISHER_CLASS,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>              ClusterStatusPublisher.Publisher.class);<a name="line.481"></a>
+<span class="sourceLineNo">482</span><a name="line.482"></a>
+<span class="sourceLineNo">483</span>      if (shouldPublish) {<a name="line.483"></a>
+<span class="sourceLineNo">484</span>        if (publisherClass == null) {<a name="line.484"></a>
+<span class="sourceLineNo">485</span>          LOG.warn(HConstants.STATUS_PUBLISHED + " is true, but " +<a name="line.485"></a>
+<span class="sourceLineNo">486</span>              ClusterStatusPublisher.DEFAULT_STATUS_PUBLISHER_CLASS +<a name="line.486"></a>
+<span class="sourceLineNo">487</span>              " is not set - not publishing status");<a name="line.487"></a>
+<span class="sourceLineNo">488</span>        } else {<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          clusterStatusPublisherChore = new ClusterStatusPublisher(this, conf, publisherClass);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>          LOG.debug("Created {}", this.clusterStatusPublisherChore);<a name="line.490"></a>
+<span class="sourceLineNo">491</span>          getChoreService().scheduleChore(clusterStatusPublisherChore);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>        }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      }<a name="line.493"></a>
 <span class="sourceLineNo">494</span><a name="line.494"></a>
-<span class="sourceLineNo">495</span>      this.regionServerTracker = new RegionServerTracker(zooKeeper, this);<a name="line.495"></a>
-<span class="sourceLineNo">496</span>    } catch (Throwable t) {<a name="line.496"></a>
-<span class="sourceLineNo">497</span>      // Make sure we log the exception. HMaster is often started via reflection and the<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      // cause of failed startup is lost.<a name="line.498"></a>
-<span class="sourceLineNo">499</span>      LOG.error("Failed construction of Master", t);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      throw t;<a name="line.500"></a>
-<span class="sourceLineNo">501</span>    }<a name="line.501"></a>
-<span class="sourceLineNo">502</span>  }<a name="line.502"></a>
-<span class="sourceLineNo">503</span><a name="line.503"></a>
-<span class="sourceLineNo">504</span>  /**<a name="line.504"></a>
-<span class="sourceLineNo">505</span>   * Protected to have custom implementations in tests override the default ActiveMaster<a name="line.505"></a>
-<span class="sourceLineNo">506</span>   * implementation.<a name="line.506"></a>
-<span class="sourceLineNo">507</span>   */<a name="line.507"></a>
-<span class="sourceLineNo">508</span>  protected ActiveMasterManager createActiveMasterManager(ZKWatcher zk, ServerName sn,<a name="line.508"></a>
-<span class="sourceLineNo">509</span>      org.apache.hadoop.hbase.Server server) throws InterruptedIOException {<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    return new ActiveMasterManager(zk, sn, server);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>  }<a name="line.511"></a>
-<span class="sourceLineNo">512</span><a name="line.512"></a>
-<span class="sourceLineNo">513</span>  @Override<a name="line.513"></a>
-<span class="sourceLineNo">514</span>  protected String getUseThisHostnameInstead(Configuration conf) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>    return conf.get(MASTER_HOSTNAME_KEY);<a name="line.515"></a>
-<span class="sourceLineNo">516</span>  }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>  // Main run loop. Calls through to the regionserver run loop AFTER becoming active Master; will<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  // block in here until then.<a name="line.519"></a>
-<span class="sourceLineNo">520</span>  @Override<a name="line.520"></a>
-<span class="sourceLineNo">521</span>  public void run() {<a name="line.521"></a>
-<span class="sourceLineNo">522</span>    try {<a name="line.522"></a>
-<span class="sourceLineNo">523</span>      Threads.setDaemonThreadRunning(new Thread(() -&gt; {<a name="line.523"></a>
-<span class="sourceLineNo">524</span>        try {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>          int infoPort = putUpJettyServer();<a name="line.525"></a>
-<span class="sourceLineNo">526</span>          startActiveMasterManager(infoPort);<a name="line.526"></a>
-<span class="sourceLineNo">527</span>        } catch (Throwable t) {<a name="line.527"></a>
-<span class="sourceLineNo">528</span>          // Make sure we log the exception.<a name="line.528"></a>
-<span class="sourceLineNo">529</span>          String error = "Failed to become Active Master";<a name="line.529"></a>
-<span class="sourceLineNo">530</span>          LOG.error(error, t);<a name="line.530"></a>
-<span class="sourceLineNo">531</span>          // Abort should have been called already.<a name="line.531"></a>
-<span class="sourceLineNo">532</span>          if (!isAborted()) {<a name="line.532"></a>
-<span class="sourceLineNo">533</span>            abort(error, t);<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>      }), getName() + ":becomeActiveMaster");<a name="line.536"></a>
-<span class="sourceLineNo">537</span>      // Fall in here even if we have been aborted. Need to run the shutdown services and<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      // the super run call will do this for us.<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      super.run();<a name="line.539"></a>
-<span class="sourceLineNo">540</span>    } finally {<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      if (this.clusterSchemaService != null) {<a name="line.541"></a>
-<span class="sourceLineNo">542</span>        // If on way out, then we are no longer active master.<a name="line.542"></a>
-<span class="sourceLineNo">543</span>        this.clusterSchemaService.stopAsync();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>        try {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>          this.clusterSchemaService.awaitTerminated(<a name="line.545"></a>
-<span class="sourceLineNo">546</span>              getConfiguration().getInt(HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.546"></a>
-<span class="sourceLineNo">547</span>              DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.547"></a>
-<span class="sourceLineNo">548</span>        } catch (TimeoutException te) {<a name="line.548"></a>
-<span class="sourceLineNo">549</span>          LOG.warn("Failed shutdown of clusterSchemaService", te);<a name="line.549"></a>
-<span class="sourceLineNo">550</span>        }<a name="line.550"></a>
-<span class="sourceLineNo">551</span>      }<a name="line.551"></a>
-<span class="sourceLineNo">552</span>      this.activeMaster = false;<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><a name="line.555"></a>
-<span class="sourceLineNo">556</span>  // return the actual infoPort, -1 means disable info server.<a name="line.556"></a>
-<span class="sourceLineNo">557</span>  private int putUpJettyServer() throws IOException {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>    if (!conf.getBoolean("hbase.master.infoserver.redirect", true)) {<a name="line.558"></a>
-<span class="sourceLineNo">559</span>      return -1;<a name="line.559"></a>
-<span class="sourceLineNo">560</span>    }<a name="line.560"></a>
-<span class="sourceLineNo">561</span>    final int infoPort = conf.getInt("hbase.master.info.port.orig",<a name="line.561"></a>
-<span class="sourceLineNo">562</span>      HConstants.DEFAULT_MASTER_INFOPORT);<a name="line.562"></a>
-<span class="sourceLineNo">563</span>    // -1 is for disabling info server, so no redirecting<a name="line.563"></a>
-<span class="sourceLineNo">564</span>    if (infoPort &lt; 0 || infoServer == null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>      return -1;<a name="line.565"></a>
-<span class="sourceLineNo">566</span>    }<a name="line.566"></a>
-<span class="sourceLineNo">567</span>    if (infoPort == infoServer.getPort()) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>      // server is already running<a name="line.568"></a>
-<span class="sourceLineNo">569</span>      return infoPort;<a name="line.569"></a>
+<span class="sourceLineNo">495</span>      this.activeMasterManager = createActiveMasterManager(zooKeeper, serverName, this);<a name="line.495"></a>
+<span class="sourceLineNo">496</span><a name="line.496"></a>
+<span class="sourceLineNo">497</span>      cachedClusterId = new CachedClusterId(this, conf);<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      this.regionServerTracker = new RegionServerTracker(zooKeeper, this);<a name="line.499"></a>
+<span class="sourceLineNo">500</span>    } catch (Throwable t) {<a name="line.500"></a>
+<span class="sourceLineNo">501</span>      // Make sure we log the exception. HMaster is often started via reflection and the<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      // cause of failed startup is lost.<a name="line.502"></a>
+<span class="sourceLineNo">503</span>      LOG.error("Failed construction of Master", t);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      throw t;<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><a name="line.507"></a>
+<span class="sourceLineNo">508</span>  /**<a name="line.508"></a>
+<span class="sourceLineNo">509</span>   * Protected to have custom implementations in tests override the default ActiveMaster<a name="line.509"></a>
+<span class="sourceLineNo">510</span>   * implementation.<a name="line.510"></a>
+<span class="sourceLineNo">511</span>   */<a name="line.511"></a>
+<span class="sourceLineNo">512</span>  protected ActiveMasterManager createActiveMasterManager(ZKWatcher zk, ServerName sn,<a name="line.512"></a>
+<span class="sourceLineNo">513</span>      org.apache.hadoop.hbase.Server server) throws InterruptedIOException {<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    return new ActiveMasterManager(zk, sn, server);<a name="line.514"></a>
+<span class="sourceLineNo">515</span>  }<a name="line.515"></a>
+<span class="sourceLineNo">516</span><a name="line.516"></a>
+<span class="sourceLineNo">517</span>  @Override<a name="line.517"></a>
+<span class="sourceLineNo">518</span>  protected String getUseThisHostnameInstead(Configuration conf) {<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    return conf.get(MASTER_HOSTNAME_KEY);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>  }<a name="line.520"></a>
+<span class="sourceLineNo">521</span><a name="line.521"></a>
+<span class="sourceLineNo">522</span>  // Main run loop. Calls through to the regionserver run loop AFTER becoming active Master; will<a name="line.522"></a>
+<span class="sourceLineNo">523</span>  // block in here until then.<a name="line.523"></a>
+<span class="sourceLineNo">524</span>  @Override<a name="line.524"></a>
+<span class="sourceLineNo">525</span>  public void run() {<a name="line.525"></a>
+<span class="sourceLineNo">526</span>    try {<a name="line.526"></a>
+<span class="sourceLineNo">527</span>      Threads.setDaemonThreadRunning(new Thread(() -&gt; {<a name="line.527"></a>
+<span class="sourceLineNo">528</span>        try {<a name="line.528"></a>
+<span class="sourceLineNo">529</span>          int infoPort = putUpJettyServer();<a name="line.529"></a>
+<span class="sourceLineNo">530</span>          startActiveMasterManager(infoPort);<a name="line.530"></a>
+<span class="sourceLineNo">531</span>        } catch (Throwable t) {<a name="line.531"></a>
+<span class="sourceLineNo">532</span>          // Make sure we log the exception.<a name="line.532"></a>
+<span class="sourceLineNo">533</span>          String error = "Failed to become Active Master";<a name="line.533"></a>
+<span class="sourceLineNo">534</span>          LOG.error(error, t);<a name="line.534"></a>
+<span class="sourceLineNo">535</span>          // Abort should have been called already.<a name="line.535"></a>
+<span class="sourceLineNo">536</span>          if (!isAborted()) {<a name="line.536"></a>
+<span class="sourceLineNo">537</span>            abort(error, t);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>          }<a name="line.538"></a>
+<span class="sourceLineNo">539</span>        }<a name="line.539"></a>
+<span class="sourceLineNo">540</span>      }), getName() + ":becomeActiveMaster");<a name="line.540"></a>
+<span class="sourceLineNo">541</span>      // Fall in here even if we have been aborted. Need to run the shutdown services and<a name="line.541"></a>
+<span class="sourceLineNo">542</span>      // the super run call will do this for us.<a name="line.542"></a>
+<span class="sourceLineNo">543</span>      super.run();<a name="line.543"></a>
+<span class="sourceLineNo">544</span>    } finally {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>      if (this.clusterSchemaService != null) {<a name="line.545"></a>
+<span class="sourceLineNo">546</span>        // If on way out, then we are no longer active master.<a name="line.546"></a>
+<span class="sourceLineNo">547</span>        this.clusterSchemaService.stopAsync();<a name="line.547"></a>
+<span class="sourceLineNo">548</span>        try {<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          this.clusterSchemaService.awaitTerminated(<a name="line.549"></a>
+<span class="sourceLineNo">550</span>              getConfiguration().getInt(HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.550"></a>
+<span class="sourceLineNo">551</span>              DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.551"></a>
+<span class="sourceLineNo">552</span>        } catch (TimeoutException te) {<a name="line.552"></a>
+<span class="sourceLineNo">553</span>          LOG.warn("Failed shutdown of clusterSchemaService", te);<a name="line.553"></a>
+<span class="sourceLineNo">554</span>        }<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      }<a name="line.555"></a>
+<span class="sourceLineNo">556</span>      this.activeMaster = false;<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>  // return the actual infoPort, -1 means disable info server.<a name="line.560"></a>
+<span class="sourceLineNo">561</span>  private int putUpJettyServer() throws IOException {<a name="line.561"></a>
+<span class="sourceLineNo">562</span>    if (!conf.getBoolean("hbase.master.infoserver.redirect", true)) {<a name="line.562"></a>
+<span class="sourceLineNo">563</span>      return -1;<a name="line.563"></a>
+<span class="sourceLineNo">564</span>    }<a name="line.564"></a>
+<span class="sourceLineNo">565</span>    final int infoPort = conf.getInt("hbase.master.info.port.orig",<a name="line.565"></a>
+<span class="sourceLineNo">566</span>      HConstants.DEFAULT_MASTER_INFOPORT);<a name="line.566"></a>
+<span class="sourceLineNo">567</span>    // -1 is for disabling info server, so no redirecting<a name="line.567"></a>
+<span class="sourceLineNo">568</span>    if (infoPort &lt; 0 || infoServer == null) {<a name="line.568"></a>
+<span class="sourceLineNo">569</span>      return -1;<a name="line.569"></a>
 <span class="sourceLineNo">570</span>    }<a name="line.570"></a>
-<span class="sourceLineNo">571</span>    final String addr = conf.get("hbase.master.info.bindAddress", "0.0.0.0");<a name="line.571"></a>
-<span class="sourceLineNo">572</span>    if (!Addressing.isLocalAddress(InetAddress.getByName(addr))) {<a name="line.572"></a>
-<span class="sourceLineNo">573</span>      String msg =<a name="line.573"></a>
-<span class="sourceLineNo">574</span>          "Failed to start redirecting jetty server. Address " + addr<a name="line.574"></a>
-<span class="sourceLineNo">575</span>              + " does not belong to this host. Correct configuration parameter: "<a name="line.575"></a>
-<span class="sourceLineNo">576</span>              + "hbase.master.info.bindAddress";<a name="line.576"></a>
-<span class="sourceLineNo">577</span>      LOG.error(msg);<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      throw new IOException(msg);<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>    // TODO I'm pretty sure we could just add another binding to the InfoServer run by<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    // the RegionServer and have it run the RedirectServlet instead of standing up<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    // a second entire stack here.<a name="line.583"></a>
-<span class="sourceLineNo">584</span>    masterJettyServer = new Server();<a name="line.584"></a>
-<span class="sourceLineNo">585</span>    final ServerConnector connector = new ServerConnector(masterJettyServer);<a name="line.585"></a>
-<span class="sourceLineNo">586</span>    connector.setHost(addr);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>    connector.setPort(infoPort);<a name="line.587"></a>
-<span class="sourceLineNo">588</span>    masterJettyServer.addConnector(connector);<a name="line.588"></a>
-<span class="sourceLineNo">589</span>    masterJettyServer.setStopAtShutdown(true);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>    masterJettyServer.setHandler(HttpServer.buildGzipHandler(masterJettyServer.getHandler()));<a name="line.590"></a>
-<span class="sourceLineNo">591</span><a name="line.591"></a>
-<span class="sourceLineNo">592</span>    final String redirectHostname =<a name="line.592"></a>
-<span class="sourceLineNo">593</span>        StringUtils.isBlank(useThisHostnameInstead) ? null : useThisHostnameInstead;<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    final MasterRedirectServlet redirect = new MasterRedirectServlet(infoServer, redirectHostname);<a name="line.595"></a>
-<span class="sourceLineNo">596</span>    final WebAppContext context = new WebAppContext(null, "/", null, null, null, null, WebAppContext.NO_SESSIONS);<a name="line.596"></a>
-<span class="sourceLineNo">597</span>    context.addServlet(new ServletHolder(redirect), "/*");<a name="line.597"></a>
-<span class="sourceLineNo">598</span>    context.setServer(masterJettyServer);<a name="line.598"></a>
-<span class="sourceLineNo">599</span><a name="line.599"></a>
-<span class="sourceLineNo">600</span>    try {<a name="line.600"></a>
-<span class="sourceLineNo">601</span>      masterJettyServer.start();<a name="line.601"></a>
-<span class="sourceLineNo">602</span>    } catch (Exception e) {<a name="line.602"></a>
-<span class="sourceLineNo">603</span>      throw new IOException("Failed to start redirecting jetty server", e);<a name="line.603"></a>
-<span class="sourceLineNo">604</span>    }<a name="line.604"></a>
-<span class="sourceLineNo">605</span>    return connector.getLocalPort();<a name="line.605"></a>
-<span class="sourceLineNo">606</span>  }<a name="line.606"></a>
-<span class="sourceLineNo">607</span><a name="line.607"></a>
-<span class="sourceLineNo">608</span>  /**<a name="line.608"></a>
-<span class="sourceLineNo">609</span>   * For compatibility, if failed with regionserver credentials, try the master one<a name="line.609"></a>
-<span class="sourceLineNo">610</span>   */<a name="line.610"></a>
-<span class="sourceLineNo">611</span>  @Override<a name="line.611"></a>
-<span class="sourceLineNo">612</span>  protected void login(UserProvider user, String host) throws IOException {<a name="line.612"></a>
-<span class="sourceLineNo">613</span>    try {<a name="line.613"></a>
-<span class="sourceLineNo">614</span>      super.login(user, host);<a name="line.614"></a>
-<span class="sourceLineNo">615</span>    } catch (IOException ie) {<a name="line.615"></a>
-<span class="sourceLineNo">616</span>      user.login(SecurityConstants.MASTER_KRB_KEYTAB_FILE,<a name="line.616"></a>
-<span class="sourceLineNo">617</span>              SecurityConstants.MASTER_KRB_PRINCIPAL, host);<a name="line.617"></a>
-<span class="sourceLineNo">618</span>    }<a name="line.618"></a>
-<span class="sourceLineNo">619</span>  }<a name="line.619"></a>
-<span class="sourceLineNo">620</span><a name="line.620"></a>
-<span class="sourceLineNo">621</span>  /**<a name="line.621"></a>
-<span class="sourceLineNo">622</span>   * Loop till the server is stopped or aborted.<a name="line.622"></a>
-<span class="sourceLineNo">623</span>   */<a name="line.623"></a>
-<span class="sourceLineNo">624</span>  @Override<a name="line.624"></a>
-<span class="sourceLineNo">625</span>  protected void waitForMasterActive() {<a name="line.625"></a>
-<span class="sourceLineNo">626</span>    if (maintenanceMode) {<a name="line.626"></a>
-<span class="sourceLineNo">627</span>      return;<a name="line.627"></a>
-<span class="sourceLineNo">628</span>    }<a name="line.628"></a>
-<span class="sourceLineNo">629</span>    while (!isStopped() &amp;&amp; !isAborted()) {<a name="line.629"></a>
-<span class="sourceLineNo">630</span>      sleeper.sleep();<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><a name="line.633"></a>
-<span class="sourceLineNo">634</span>  @InterfaceAudience.Private<a name="line.634"></a>
-<span class="sourceLineNo">635</span>  public MasterRpcServices getMasterRpcServices() {<a name="line.635"></a>
-<span class="sourceLineNo">636</span>    return (MasterRpcServices)rpcServices;<a name="line.636"></a>
-<span class="sourceLineNo">637</span>  }<a name="line.637"></a>
-<span class="sourceLineNo">638</span><a name="line.638"></a>
-<span class="sourceLineNo">639</span>  public boolean balanceSwitch(final boolean b) throws IOException {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>    return getMasterRpcServices().switchBalancer(b, BalanceSwitchMode.ASYNC);<a name="line.640"></a>
-<span class="sourceLineNo">641</span>  }<a name="line.641"></a>
-<span class="sourceLineNo">642</span><a name="line.642"></a>
-<span class="sourceLineNo">643</span>  @Override<a name="line.643"></a>
-<span class="sourceLineNo">644</span>  protected String getProcessName() {<a name="line.644"></a>
-<span class="sourceLineNo">645</span>    return MASTER;<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>  @Override<a name="line.648"></a>
-<span class="sourceLineNo">649</span>  protected boolean canCreateBaseZNode() {<a name="line.649"></a>
-<span class="sourceLineNo">650</span>    return true;<a name="line.650"></a>
-<span class="sourceLineNo">651</span>  }<a name="line.651"></a>
-<span class="sourceLineNo">652</span><a name="line.652"></a>
-<span class="sourceLineNo">653</span>  @Override<a name="line.653"></a>
-<span class="sourceLineNo">654</span>  protected boolean canUpdateTableDescriptor() {<a name="line.654"></a>
-<span class="sourceLineNo">655</span>    return true;<a name="line.655"></a>
-<span class="sourceLineNo">656</span>  }<a name="line.656"></a>
-<span class="sourceLineNo">657</span><a name="line.657"></a>
-<span class="sourceLineNo">658</span>  @Override<a name="line.658"></a>
-<span class="sourceLineNo">659</span>  protected boolean cacheTableDescriptor() {<a name="line.659"></a>
-<span class="sourceLineNo">660</span>    return true;<a name="line.660"></a>
-<span class="sourceLineNo">661</span>  }<a name="line.661"></a>
-<span class="sourceLineNo">662</span><a name="line.662"></a>
-<span class="sourceLineNo">663</span>  @Override<a name="line.663"></a>
-<span class="sourceLineNo">664</span>  protected RSRpcServices createRpcServices() throws IOException {<a name="line.664"></a>
-<span class="sourceLineNo">665</span>    return new MasterRpcServices(this);<a name="line.665"></a>
-<span class="sourceLineNo">666</span>  }<a name="line.666"></a>
-<span class="sourceLineNo">667</span><a name="line.667"></a>
-<span class="sourceLineNo">668</span>  @Override<a name="line.668"></a>
-<span class="sourceLineNo">669</span>  protected void configureInfoServer() {<a name="line.669"></a>
-<span class="sourceLineNo">670</span>    infoServer.addUnprivilegedServlet("master-status", "/master-status", MasterStatusServlet.class);<a name="line.670"></a>
-<span class="sourceLineNo">671</span>    infoServer.setAttribute(MASTER, this);<a name="line.671"></a>
-<span class="sourceLineNo">672</span>    if (maintenanceMode) {<a name="line.672"></a>
-<span class="sourceLineNo">673</span>      super.configureInfoServer();<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>  @Override<a name="line.677"></a>
-<span class="sourceLineNo">678</span>  protected Class&lt;? extends HttpServlet&gt; getDumpServlet() {<a name="line.678"></a>
-<span class="sourceLineNo">679</span>    return MasterDumpServlet.class;<a name="line.679"></a>
-<span class="sourceLineNo">680</span>  }<a name="line.680"></a>
-<span class="sourceLineNo">681</span><a name="line.681"></a>
-<span class="sourceLineNo">682</span>  @Override<a name="line.682"></a>
-<span class="sourceLineNo">683</span>  public MetricsMaster getMasterMetrics() {<a name="line.683"></a>
-<span class="sourceLineNo">684</span>    return metricsMaster;<a name="line.684"></a>
-<span class="sourceLineNo">685</span>  }<a name="line.685"></a>
-<span class="sourceLineNo">686</span><a name="line.686"></a>
-<span class="sourceLineNo">687</span>  /**<a name="line.687"></a>
-<span class="sourceLineNo">688</span>   * Initialize all ZK based system trackers. But do not include {@link RegionServerTracker}, it<a name="line.688"></a>
-<span class="sourceLineNo">689</span>   * should have already been initialized along with {@link ServerManager}.<a name="line.689"></a>
-<span class="sourceLineNo">690</span>   */<a name="line.690"></a>
-<span class="sourceLineNo">691</span>  private void initializeZKBasedSystemTrackers()<a name="line.691"></a>
-<span class="sourceLineNo">692</span>    throws IOException, KeeperException, ReplicationException {<a name="line.692"></a>
-<span class="sourceLineNo">693</span>    if (maintenanceMode) {<a name="line.693"></a>
-<span class="sourceLineNo">694</span>      // in maintenance mode, always use MaintenanceLoadBalancer.<a name="line.694"></a>
-<span class="sourceLineNo">695</span>      conf.unset(LoadBalancer.HBASE_RSGROUP_LOADBALANCER_CLASS);<a name="line.695"></a>
-<span class="sourceLineNo">696</span>      conf.setClass(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, MaintenanceLoadBalancer.class,<a name="line.696"></a>
-<span class="sourceLineNo">697</span>        LoadBalancer.class);<a name="line.697"></a>
-<span class="sourceLineNo">698</span>    }<a name="line.698"></a>
-<span class="sourceLineNo">699</span>    this.balancer = new RSGroupBasedLoadBalancer();<a name="line.699"></a>
-<span class="sourceLineNo">700</span>    this.loadBalancerTracker = new LoadBalancerTracker(zooKeeper, this);<a name="line.700"></a>
-<span class="sourceLineNo">701</span>    this.loadBalancerTracker.start();<a name="line.701"></a>
-<span class="sourceLineNo">702</span><a name="line.702"></a>
-<span class="sourceLineNo">703</span>    this.regionNormalizerManager =<a name="line.703"></a>
-<span class="sourceLineNo">704</span>      RegionNormalizerFactory.createNormalizerManager(conf, zooKeeper, this);<a name="line.704"></a>
-<span class="sourceLineNo">705</span>    this.configurationManager.registerObserver(regionNormalizerManager);<a name="line.705"></a>
-<span class="sourceLineNo">706</span>    this.regionNormalizerManager.start();<a name="line.706"></a>
-<span class="sourceLineNo">707</span><a name="line.707"></a>
-<span class="sourceLineNo">708</span>    this.splitOrMergeTracker = new SplitOrMergeTracker(zooKeeper, conf, this);<a name="line.708"></a>
-<span class="sourceLineNo">709</span>    this.splitOrMergeTracker.start();<a name="line.709"></a>
-<span class="sourceLineNo">710</span><a name="line.710"></a>
-<span class="sourceLineNo">711</span>    // This is for backwards compatible. We do not need the CP for rs group now but if user want to<a name="line.711"></a>
-<span class="sourceLineNo">712</span>    // load it, we need to enable rs group.<a name="line.712"></a>
-<span class="sourceLineNo">713</span>    String[] cpClasses = conf.getStrings(MasterCoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.713"></a>
-<span class="sourceLineNo">714</span>    if (cpClasses != null) {<a name="line.714"></a>
-<span class="sourceLineNo">715</span>      for (String cpClass : cpClasses) {<a name="line.715"></a>
-<span class="sourceLineNo">716</span>        if (RSGroupAdminEndpoint.class.getName().equals(cpClass)) {<a name="line.716"></a>
-<span class="sourceLineNo">717</span>          RSGroupUtil.enableRSGroup(conf);<a name="line.717"></a>
-<span class="sourceLineNo">718</span>          break;<a name="line.718"></a>
-<span class="sourceLineNo">719</span>        }<a name="line.719"></a>
-<span class="sourceLineNo">720</span>      }<a name="line.720"></a>
-<span class="sourceLineNo">721</span>    }<a name="line.721"></a>
-<span class="sourceLineNo">722</span>    this.rsGroupInfoManager = RSGroupInfoManager.create(this);<a name="line.722"></a>
+<span class="sourceLineNo">571</span>    if (infoPort == infoServer.getPort()) {<a name="line.571"></a>
+<span class="sourceLineNo">572</span>      // server is already running<a name="line.572"></a>
+<span class="sourceLineNo">573</span>      return infoPort;<a name="line.573"></a>
+<span class="sourceLineNo">574</span>    }<a name="line.574"></a>
+<span class="sourceLineNo">575</span>    final String addr = conf.get("hbase.master.info.bindAddress", "0.0.0.0");<a name="line.575"></a>
+<span class="sourceLineNo">576</span>    if (!Addressing.isLocalAddress(InetAddress.getByName(addr))) {<a name="line.576"></a>
+<span class="sourceLineNo">577</span>      String msg =<a name="line.577"></a>
+<span class="sourceLineNo">578</span>          "Failed to start redirecting jetty server. Address " + addr<a name="line.578"></a>
+<span class="sourceLineNo">579</span>              + " does not belong to this host. Correct configuration parameter: "<a name="line.579"></a>
+<span class="sourceLineNo">580</span>              + "hbase.master.info.bindAddress";<a name="line.580"></a>
+<span class="sourceLineNo">581</span>      LOG.error(msg);<a name="line.581"></a>
+<span class="sourceLineNo">582</span>      throw new IOException(msg);<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    }<a name="line.583"></a>
+<span class="sourceLineNo">584</span><a name="line.584"></a>
+<span class="sourceLineNo">585</span>    // TODO I'm pretty sure we could just add another binding to the InfoServer run by<a name="line.585"></a>
+<span class="sourceLineNo">586</span>    // the RegionServer and have it run the RedirectServlet instead of standing up<a name="line.586"></a>
+<span class="sourceLineNo">587</span>    // a second entire stack here.<a name="line.587"></a>
+<span class="sourceLineNo">588</span>    masterJettyServer = new Server();<a name="line.588"></a>
+<span class="sourceLineNo">589</span>    final ServerConnector connector = new ServerConnector(masterJettyServer);<a name="line.589"></a>
+<span class="sourceLineNo">590</span>    connector.setHost(addr);<a name="line.590"></a>
+<span class="sourceLineNo">591</span>    connector.setPort(infoPort);<a name="line.591"></a>
+<span class="sourceLineNo">592</span>    masterJettyServer.addConnector(connector);<a name="line.592"></a>
+<span class="sourceLineNo">593</span>    masterJettyServer.setStopAtShutdown(true);<a name="line.593"></a>
+<span class="sourceLineNo">594</span>    masterJettyServer.setHandler(HttpServer.buildGzipHandler(masterJettyServer.getHandler()));<a name="line.594"></a>
+<span class="sourceLineNo">595</span><a name="line.595"></a>
+<span class="sourceLineNo">596</span>    final String redirectHostname =<a name="line.596"></a>
+<span class="sourceLineNo">597</span>        StringUtils.isBlank(useThisHostnameInstead) ? null : useThisHostnameInstead;<a name="line.597"></a>
+<span class="sourceLineNo">598</span><a name="line.598"></a>
+<span class="sourceLineNo">599</span>    final MasterRedirectServlet redirect = new MasterRedirectServlet(infoServer, redirectHostname);<a name="line.599"></a>
+<span class="sourceLineNo">600</span>    final WebAppContext context = new WebAppContext(null, "/", null, null, null, null, WebAppContext.NO_SESSIONS);<a name="line.600"></a>
+<span class="sourceLineNo">601</span>    context.addServlet(new ServletHolder(redirect), "/*");<a name="line.601"></a>
+<span class="sourceLineNo">602</span>    context.setServer(masterJettyServer);<a name="line.602"></a>
+<span class="sourceLineNo">603</span><a name="line.603"></a>
+<span class="sourceLineNo">604</span>    try {<a name="line.604"></a>
+<span class="sourceLineNo">605</span>      masterJettyServer.start();<a name="line.605"></a>
+<span class="sourceLineNo">606</span>    } catch (Exception e) {<a name="line.606"></a>
+<span class="sourceLineNo">607</span>      throw new IOException("Failed to start redirecting jetty server", e);<a name="line.607"></a>
+<span class="sourceLineNo">608</span>    }<a name="line.608"></a>
+<span class="sourceLineNo">609</span>    return connector.getLocalPort();<a name="line.609"></a>
+<span class="sourceLineNo">610</span>  }<a name="line.610"></a>
+<span class="sourceLineNo">611</span><a name="line.611"></a>
+<span class="sourceLineNo">612</span>  /**<a name="line.612"></a>
+<span class="sourceLineNo">613</span>   * For compatibility, if failed with regionserver credentials, try the master one<a name="line.613"></a>
+<span class="sourceLineNo">614</span>   */<a name="line.614"></a>
+<span class="sourceLineNo">615</span>  @Override<a name="line.615"></a>
+<span class="sourceLineNo">616</span>  protected void login(UserProvider user, String host) throws IOException {<a name="line.616"></a>
+<span class="sourceLineNo">617</span>    try {<a name="line.617"></a>
+<span class="sourceLineNo">618</span>      super.login(user, host);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>    } catch (IOException ie) {<a name="line.619"></a>
+<span class="sourceLineNo">620</span>      user.login(SecurityConstants.MASTER_KRB_KEYTAB_FILE,<a name="line.620"></a>
+<span class="sourceLineNo">621</span>              SecurityConstants.MASTER_KRB_PRINCIPAL, host);<a name="line.621"></a>
+<span class="sourceLineNo">622</span>    }<a name="line.622"></a>
+<span class="sourceLineNo">623</span>  }<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>   * Loop till the server is stopped or aborted.<a name="line.626"></a>
+<span class="sourceLineNo">627</span>   */<a name="line.627"></a>
+<span class="sourceLineNo">628</span>  @Override<a name="line.628"></a>
+<span class="sourceLineNo">629</span>  protected void waitForMasterActive() {<a name="line.629"></a>
+<span class="sourceLineNo">630</span>    while (!isStopped() &amp;&amp; !isAborted()) {<a name="line.630"></a>
+<span class="sourceLineNo">631</span>      sleeper.sleep();<a name="line.631"></a>
+<span class="sourceLineNo">632</span>    }<a name="line.632"></a>
+<span class="sourceLineNo">633</span>  }<a name="line.633"></a>
+<span class="sourceLineNo">634</span><a name="line.634"></a>
+<span class="sourceLineNo">635</span>  @InterfaceAudience.Private<a name="line.635"></a>
+<span class="sourceLineNo">636</span>  public MasterRpcServices getMasterRpcServices() {<a name="line.636"></a>
+<span class="sourceLineNo">637</span>    return (MasterRpcServices)rpcServices;<a name="line.637"></a>
+<span class="sourceLineNo">638</span>  }<a name="line.638"></a>
+<span class="sourceLineNo">639</span><a name="line.639"></a>
+<span class="sourceLineNo">640</span>  public boolean balanceSwitch(final boolean b) throws IOException {<a name="line.640"></a>
+<span class="sourceLineNo">641</span>    return getMasterRpcServices().switchBalancer(b, BalanceSwitchMode.ASYNC);<a name="line.641"></a>
+<span class="sourceLineNo">642</span>  }<a name="line.642"></a>
+<span class="sourceLineNo">643</span><a name="line.643"></a>
+<span class="sourceLineNo">644</span>  @Override<a name="line.644"></a>
+<span class="sourceLineNo">645</span>  protected String getProcessName() {<a name="line.645"></a>
+<span class="sourceLineNo">646</span>    return MASTER;<a name="line.646"></a>
+<span class="sourceLineNo">647</span>  }<a name="line.647"></a>
+<span class="sourceLineNo">648</span><a name="line.648"></a>
+<span class="sourceLineNo">649</span>  @Override<a name="line.649"></a>
+<span class="sourceLineNo">650</span>  protected boolean canCreateBaseZNode() {<a name="line.650"></a>
+<span class="sourceLineNo">651</span>    return true;<a name="line.651"></a>
+<span class="sourceLineNo">652</span>  }<a name="line.652"></a>
+<span class="sourceLineNo">653</span><a name="line.653"></a>
+<span class="sourceLineNo">654</span>  @Override<a name="line.654"></a>
+<span class="sourceLineNo">655</span>  protected boolean canUpdateTableDescriptor() {<a name="line.655"></a>
+<span class="sourceLineNo">656</span>    return true;<a name="line.656"></a>
+<span class="sourceLineNo">657</span>  }<a name="line.657"></a>
+<span class="sourceLineNo">658</span><a name="line.658"></a>
+<span class="sourceLineNo">659</span>  @Override<a name="line.659"></a>
+<span class="sourceLineNo">660</span>  protected boolean cacheTableDescriptor() {<a name="line.660"></a>
+<span class="sourceLineNo">661</span>    return true;<a name="line.661"></a>
+<span class="sourceLineNo">662</span>  }<a name="line.662"></a>
+<span class="sourceLineNo">663</span><a name="line.663"></a>
+<span class="sourceLineNo">664</span>  @Override<a name="line.664"></a>
+<span class="sourceLineNo">665</span>  protected RSRpcServices createRpcServices() throws IOException {<a name="line.665"></a>
+<span class="sourceLineNo">666</span>    return new MasterRpcServices(this);<a name="line.666"></a>
+<span class="sourceLineNo">667</span>  }<a name="line.667"></a>
+<span class="sourceLineNo">668</span><a name="line.668"></a>
+<span class="sourceLineNo">669</span>  @Override<a name="line.669"></a>
+<span class="sourceLineNo">670</span>  protected void configureInfoServer() {<a name="line.670"></a>
+<span class="sourceLineNo">671</span>    infoServer.addUnprivilegedServlet("master-status", "/master-status", MasterStatusServlet.class);<a name="line.671"></a>
+<span class="sourceLineNo">672</span>    infoServer.setAttribute(MASTER, this);<a name="line.672"></a>
+<span class="sourceLineNo">673</span>  }<a name="line.673"></a>
+<span class="sourceLineNo">674</span><a name="line.674"></a>
+<span class="sourceLineNo">675</span>  @Override<a name="line.675"></a>
+<span class="sourceLineNo">676</span>  protected Class&lt;? extends HttpServlet&gt; getDumpServlet() {<a name="line.676"></a>
+<span class="sourceLineNo">677</span>    return MasterDumpServlet.class;<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>  @Override<a name="line.680"></a>
+<span class="sourceLineNo">681</span>  public MetricsMaster getMasterMetrics() {<a name="line.681"></a>
+<span class="sourceLineNo">682</span>    return metricsMaster;<a name="line.682"></a>
+<span class="sourceLineNo">683</span>  }<a name="line.683"></a>
+<span class="sourceLineNo">684</span><a name="line.684"></a>
+<span class="sourceLineNo">685</span>  /**<a name="line.685"></a>
+<span class="sourceLineNo">686</span>   * Initialize all ZK based system trackers. But do not include {@link RegionServerTracker}, it<a name="line.686"></a>
+<span class="sourceLineNo">687</span>   * should have already been initialized along with {@link ServerManager}.<a name="line.687"></a>
+<span class="sourceLineNo">688</span>   */<a name="line.688"></a>
+<span class="sourceLineNo">689</span>  private void initializeZKBasedSystemTrackers()<a name="line.689"></a>
+<span class="sourceLineNo">690</span>    throws IOException, KeeperException, ReplicationException {<a name="line.690"></a>
+<span class="sourceLineNo">691</span>    if (maintenanceMode) {<a name="line.691"></a>
+<span class="sourceLineNo">692</span>      // in maintenance mode, always use MaintenanceLoadBalancer.<a name="line.692"></a>
+<span class="sourceLineNo">693</span>      conf.unset(LoadBalancer.HBASE_RSGROUP_LOADBALANCER_CLASS);<a name="line.693"></a>
+<span class="sourceLineNo">694</span>      conf.setClass(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, MaintenanceLoadBalancer.class,<a name="line.694"></a>
+<span class="sourceLineNo">695</span>        LoadBalancer.class);<a name="line.695"></a>
+<span class="sourceLineNo">696</span>    }<a name="line.696"></a>
+<span class="sourceLineNo">697</span>    this.balancer = new RSGroupBasedLoadBalancer();<a name="line.697"></a>
+<span class="sourceLineNo">698</span>    this.loadBalancerTracker = new LoadBalancerTracker(zooKeeper, this);<a name="line.698"></a>
+<span class="sourceLineNo">699</span>    this.loadBalancerTracker.start();<a name="line.699"></a>
+<span class="sourceLineNo">700</span><a name="line.700"></a>
+<span class="sourceLineNo">701</span>    this.regionNormalizerManager =<a name="line.701"></a>
+<span class="sourceLineNo">702</span>      RegionNormalizerFactory.createNormalizerManager(conf, zooKeeper, this);<a name="line.702"></a>
+<span class="sourceLineNo">703</span>    this.configurationManager.registerObserver(regionNormalizerManager);<a name="line.703"></a>
+<span class="sourceLineNo">704</span>    this.regionNormalizerManager.start();<a name="line.704"></a>
+<span class="sourceLineNo">705</span><a name="line.705"></a>
+<span class="sourceLineNo">706</span>    this.splitOrMergeTracker = new SplitOrMergeTracker(zooKeeper, conf, this);<a name="line.706"></a>
+<span class="sourceLineNo">707</span>    this.splitOrMergeTracker.start();<a name="line.707"></a>
+<span class="sourceLineNo">708</span><a name="line.708"></a>
+<span class="sourceLineNo">709</span>    // This is for backwards compatible. We do not need the CP for rs group now but if user want to<a name="line.709"></a>
+<span class="sourceLineNo">710</span>    // load it, we need to enable rs group.<a name="line.710"></a>
+<span class="sourceLineNo">711</span>    String[] cpClasses = conf.getStrings(MasterCoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.711"></a>
+<span class="sourceLineNo">712</span>    if (cpClasses != null) {<a name="line.712"></a>
+<span class="sourceLineNo">713</span>      for (String cpClass : cpClasses) {<a name="line.713"></a>
+<span class="sourceLineNo">714</span>        if (RSGroupAdminEndpoint.class.getName().equals(cpClass)) {<a name="line.714"></a>
+<span class="sourceLineNo">715</span>          RSGroupUtil.enableRSGroup(conf);<a name="line.715"></a>
+<span class="sourceLineNo">716</span>          break;<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>    }<a name="line.719"></a>
+<span class="sourceLineNo">720</span>    this.rsGroupInfoManager = RSGroupInfoManager.create(this);<a name="line.720"></a>
+<span class="sourceLineNo">721</span><a name="line.721"></a>
+<span class="sourceLineNo">722</span>    this.replicationPeerManager = ReplicationPeerManager.create(zooKeeper, conf, clusterId);<a name="line.722"></a>
 <span class="sourceLineNo">723</span><a name="line.723"></a>
-<span class="sourceLineNo">724</span>    this.replicationPeerManager = ReplicationPeerManager.create(zooKeeper, conf, clusterId);<a name="line.724"></a>
-<span class="sourceLineNo">725</span><a name="line.725"></a>
-<span class="sourceLineNo">726</span>    this.drainingServerTracker = new DrainingServerTracker(zooKeeper, this, this.serverManager);<a name="line.726"></a>
-<span class="sourceLineNo">727</span>    this.drainingServerTracker.start();<a name="line.727"></a>
-<span class="sourceLineNo">728</span><a name="line.728"></a>
-<span class="sourceLineNo">729</span>    this.snapshotCleanupTracker = new SnapshotCleanupTracker(zooKeeper, this);<a name="line.729"></a>
-<span class="sourceLineNo">730</span>    this.snapshotCleanupTracker.start();<a name="line.730"></a>
-<span class="sourceLineNo">731</span><a name="line.731"></a>
-<span class="sourceLineNo">732</span>    String clientQuorumServers = conf.get(HConstants.CLIENT_ZOOKEEPER_QUORUM);<a name="line.732"></a>
-<span class="sourceLineNo">733</span>    boolean clientZkObserverMode = conf.getBoolean(HConstants.CLIENT_ZOOKEEPER_OBSERVER_MODE,<a name="line.733"></a>
-<span class="sourceLineNo">734</span>      HConstants.DEFAULT_CLIENT_ZOOKEEPER_OBSERVER_MODE);<a name="line.734"></a>
-<span class="sourceLineNo">735</span>    if (clientQuorumServers != null &amp;&amp; !clientZkObserverMode) {<a name="line.735"></a>
-<span class="sourceLineNo">736</span>      // we need to take care of the ZK information synchronization<a name="line.736"></a>
-<span class="sourceLineNo">737</span>      // if given client ZK are not observer nodes<a name="line.737"></a>
-<span class="sourceLineNo">738</span>      ZKWatcher clientZkWatcher = new ZKWatcher(conf,<a name="line.738"></a>
-<span class="sourceLineNo">739</span>          getProcessName() + ":" + rpcServices.getSocketAddress().getPort() + "-clientZK", this,<a name="line.739"></a>
-<span class="sourceLineNo">740</span>          false, true);<a name="line.740"></a>
-<span class="sourceLineNo">741</span>      this.metaLocationSyncer = new MetaLocationSyncer(zooKeeper, clientZkWatcher, this);<a name="line.741"></a>
-<span class="sourceLineNo">742</span>      this.metaLocationSyncer.start();<a name="line.742"></a>
-<span class="sourceLineNo">743</span>      this.masterAddressSyncer = new MasterAddressSyncer(zooKeeper, clientZkWatcher, this);<a name="line.743"></a>
-<span class="sourceLineNo">744</span>      this.masterAddressSyncer.start();<a name="line.744"></a>
-<span class="sourceLineNo">745</span>      // set cluster id is a one-go effort<a name="line.745"></a>
-<span class="sourceLineNo">746</span>      ZKClusterId.setClusterId(clientZkWatcher, fileSystemManager.getClusterId());<a name="line.746"></a>
-<span class="sourceLineNo">747</span>    }<a name="line.747"></a>
-<span class="sourceLineNo">748</span><a name="line.748"></a>
-<span class="sourceLineNo">749</span>    // Set the cluster as up.  If new RSs, they'll be waiting on this before<a name="line.749"></a>
-<span class="sourceLineNo">750</span>    // going ahead with their startup.<a name="line.750"></a>
-<span class="sourceLineNo">751</span>    boolean wasUp = this.clusterStatusTracker.isClusterUp();<a name="line.751"></a>
-<span class="sourceLineNo">752</span>    if (!wasUp) this.clusterStatusTracker.setClusterUp();<a name="line.752"></a>
-<span class="sourceLineNo">753</span><a name="line.753"></a>
-<span class="sourceLineNo">754</span>    LOG.info("Active/primary master=" + this.serverName +<a name="line.754"></a>
-<span class="sourceLineNo">755</span>        ", sessionid=0x" +<a name="line.755"></a>
-<span class="sourceLineNo">756</span>        Long.toHexString(this.zooKeeper.getRecoverableZooKeeper().getSessionId()) +<a name="line.756"></a>
-<span class="sourceLineNo">757</span>        ", setting cluster-up flag (Was=" + wasUp + ")");<a name="line.757"></a>
-<span class="sourceLineNo">758</span><a name="line.758"></a>
-<span class="sourceLineNo">759</span>    // create/initialize the snapshot manager and other procedure managers<a name="line.759"></a>
-<span class="sourceLineNo">760</span>    this.snapshotManager = new SnapshotManager();<a name="line.760"></a>
-<span class="sourceLineNo">761</span>    this.mpmHost = new MasterProcedureManagerHost();<a name="line.761"></a>
-<span class="sourceLineNo">762</span>    this.mpmHost.register(this.snapshotManager);<a name="line.762"></a>
-<span class="sourceLineNo">763</span>    this.mpmHost.register(new MasterFlushTableProcedureManager());<a name="line.763"></a>
-<span class="sourceLineNo">764</span>    this.mpmHost.loadProcedures(conf);<a name="line.764"></a>
-<span class="sourceLineNo">765</span>    this.mpmHost.initialize(this, this.metricsMaster);<a name="line.765"></a>
-<span class="sourceLineNo">766</span>  }<a name="line.766"></a>
-<span class="sourceLineNo">767</span><a name="line.767"></a>
-<span class="sourceLineNo">768</span>  // Will be overriden in test to inject customized AssignmentManager<a name="line.768"></a>
-<span class="sourceLineNo">769</span>  @InterfaceAudience.Private<a name="line.769"></a>
-<span class="sourceLineNo">770</span>  protected AssignmentManager createAssignmentManager(MasterServices master,<a name="line.770"></a>
-<span class="sourceLineNo">771</span>    MasterRegion masterRegion) {<a name="line.771"></a>
-<span class="sourceLineNo">772</span>    return new AssignmentManager(master, masterRegion);<a name="line.772"></a>
-<span class="sourceLineNo">773</span>  }<a name="line.773"></a>
-<span class="sourceLineNo">774</span><a name="line.774"></a>
-<span class="sourceLineNo">775</span>  private void tryMigrateMetaLocationsFromZooKeeper() throws IOException, KeeperException {<a name="line.775"></a>
-<span class="sourceLineNo">776</span>    // try migrate data from zookeeper<a name="line.776"></a>
-<span class="sourceLineNo">777</span>    try (ResultScanner scanner =<a name="line.777"></a>
-<span class="sourceLineNo">778</span>      masterRegion.getScanner(new Scan().addFamily(HConstants.CATALOG_FAMILY))) {<a name="line.778"></a>
-<span class="sourceLineNo">779</span>      if (scanner.next() != null) {<a name="line.779"></a>
-<span class="sourceLineNo">780</span>        // notice that all replicas for a region are in the same row, so the migration can be<a name="line.780"></a>
-<span class="sourceLineNo">781</span>        // done with in a one row put, which means if we have data in catalog family then we can<a name="line.781"></a>
-<span class="sourceLineNo">782</span>        // make sure that the migration is done.<a name="line.782"></a>
-<span class="sourceLineNo">783</span>        LOG.info("The {} family in master local region already has data in it, skip migrating...",<a name="line.783"></a>
-<span class="sourceLineNo">784</span>          HConstants.CATALOG_FAMILY);<a name="line.784"></a>
-<span class="sourceLineNo">785</span>        return;<a name="line.785"></a>
-<span class="sourceLineNo">786</span>      }<a name="line.786"></a>
-<span class="sourceLineNo">787</span>    }<a name="line.787"></a>
-<span class="sourceLineNo">788</span>    // start migrating<a name="line.788"></a>
-<span class="sourceLineNo">789</span>    byte[] row = CatalogFamilyFormat.getMetaKeyForRegion(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.789"></a>
-<span class="sourceLineNo">790</span>    Put put = new Put(row);<a name="line.790"></a>
-<span class="sourceLineNo">791</span>    List&lt;String&gt; metaReplicaNodes = zooKeeper.getMetaReplicaNodes();<a name="line.791"></a>
-<span class="sourceLineNo">792</span>    StringBuilder info = new StringBuilder("Migrating meta locations:");<a name="line.792"></a>
-<span class="sourceLineNo">793</span>    for (String metaReplicaNode : metaReplicaNodes) {<a name="line.793"></a>
-<span class="sourceLineNo">794</span>      int replicaId = zooKeeper.getZNodePaths().getMetaReplicaIdFromZNode(metaReplicaNode);<a name="line.794"></a>
-<span class="sourceLineNo">795</span>      RegionState state = MetaTableLocator.getMetaRegionState(zooKeeper, replicaId);<a name="line.795"></a>
-<span class="sourceLineNo">796</span>      info.append(" ").append(state);<a name="line.796"></a>
-<span class="sourceLineNo">797</span>      put.setTimestamp(state.getStamp());<a name="line.797"></a>
-<span class="sourceLineNo">798</span>      MetaTableAccessor.addRegionInfo(put, state.getRegion());<a name="line.798"></a>
-<span class="sourceLineNo">799</span>      if (state.getServerName() != null) {<a name="line.799"></a>
-<span class="sourceLineNo">800</span>        MetaTableAccessor.addLocation(put, state.getServerName(), HConstants.NO_SEQNUM, replicaId);<a name="line.800"></a>
-<span class="sourceLineNo">801</span>      }<a name="line.801"></a>
-<span class="sourceLineNo">802</span>      put.add(CellBuilderFactory.create(CellBuilderType.SHALLOW_COPY).setRow(put.getRow())<a name="line.802"></a>
-<span class="sourceLineNo">803</span>        .setFamily(HConstants.CATALOG_FAMILY)<a name="line.803"></a>
-<span class="sourceLineNo">804</span>        .setQualifier(RegionStateStore.getStateColumn(replicaId)).setTimestamp(put.getTimestamp())<a name="line.804"></a>
-<span class="sourceLineNo">805</span>        .setType(Cell.Type.Put).setValue(Bytes.toBytes(state.getState().name())).build());<a name="line.805"></a>
-<span class="sourceLineNo">806</span>    }<a name="line.806"></a>
-<span class="sourceLineNo">807</span>    if (!put.isEmpty()) {<a name="line.807"></a>
-<span class="sourceLineNo">808</span>      LOG.info(info.toString());<a name="line.808"></a>
-<span class="sourceLineNo">809</span>      masterRegion.update(r -&gt; r.put(put));<a name="line.809"></a>
-<span class="sourceLineNo">810</span>    } else {<a name="line.810"></a>
-<span class="sourceLineNo">811</span>      LOG.info("No meta location available on zookeeper, skip migrating...");<a name="line.811"></a>
-<span class="sourceLineNo">812</span>    }<a name="line.812"></a>
-<span class="sourceLineNo">813</span>  }<a name="line.813"></a>
-<span class="sourceLineNo">814</span><a name="line.814"></a>
-<span class="sourceLineNo">815</span>  /**<a name="line.815"></a>
-<span class="sourceLineNo">816</span>   * Finish initialization of HMaster after becoming the primary master.<a name="line.816"></a>
-<span class="sourceLineNo">817</span>   * &lt;p/&gt;<a name="line.817"></a>
-<span class="sourceLineNo">818</span>   * The startup order is a bit complicated but very important, do not change it unless you know<a name="line.818"></a>
-<span class="sourceLineNo">819</span>   * what you are doing.<a name="line.819"></a>
-<span class="sourceLineNo">820</span>   * &lt;ol&gt;<a name="line.820"></a>
-<span class="sourceLineNo">821</span>   * &lt;li&gt;Initialize file system based components - file system manager, wal manager, table<a name="line.821"></a>
-<span class="sourceLineNo">822</span>   * descriptors, etc&lt;/li&gt;<a name="line.822"></a>
-<span class="sourceLineNo">823</span>   * &lt;li&gt;Publish cluster id&lt;/li&gt;<a name="line.823"></a>
-<span class="sourceLineNo">824</span>   * &lt;li&gt;Here comes the most complicated part - initialize server manager, assignment manager and<a name="line.824"></a>
-<span class="sourceLineNo">825</span>   * region server tracker<a name="line.825"></a>
-<span class="sourceLineNo">826</span>   * &lt;ol type='i'&gt;<a name="line.826"></a>
-<span class="sourceLineNo">827</span>   * &lt;li&gt;Create server manager&lt;/li&gt;<a name="line.827"></a>
-<span class="sourceLineNo">828</span>   * &lt;li&gt;Create master local region&lt;/li&gt;<a name="line.828"></a>
-<span class="sourceLineNo">829</span>   * &lt;li&gt;Create procedure executor, load the procedures, but do not start workers. We will start it<a name="line.829"></a>
-<span class="sourceLineNo">830</span>   * later after we finish scheduling SCPs to avoid scheduling duplicated SCPs for the same<a name="line.830"></a>
-<span class="sourceLineNo">831</span>   * server&lt;/li&gt;<a name="line.831"></a>
-<span class="sourceLineNo">832</span>   * &lt;li&gt;Create assignment manager and start it, load the meta region state, but do not load data<a name="line.832"></a>
-<span class="sourceLineNo">833</span>   * from meta region&lt;/li&gt;<a name="line.833"></a>
-<span class="sourceLineNo">834</span>   * &lt;li&gt;Start region server tracker, construct the online servers set and find out dead servers and<a name="line.834"></a>
-<span class="sourceLineNo">835</span>   * schedule SCP for them. The online servers will be constructed by scanning zk, and we will also<a name="line.835"></a>
-<span class="sourceLineNo">836</span>   * scan the wal directory to find out possible live region servers, and the differences between<a name="line.836"></a>
-<span class="sourceLineNo">837</span>   * these two sets are the dead servers&lt;/li&gt;<a name="line.837"></a>
-<span class="sourceLineNo">838</span>   * &lt;/ol&gt;<a name="line.838"></a>
-<span class="sourceLineNo">839</span>   * &lt;/li&gt;<a name="line.839"></a>
-<span class="sourceLineNo">840</span>   * &lt;li&gt;If this is a new deploy, schedule a InitMetaProcedure to initialize meta&lt;/li&gt;<a name="line.840"></a>
-<span class="sourceLineNo">841</span>   * &lt;li&gt;Start necessary service threads - balancer, catalog janitor, executor services, and also<a name="line.841"></a>
-<span class="sourceLineNo">842</span>   * the procedure executor, etc. Notice that the balancer must be created first as assignment<a name="line.842"></a>
-<span class="sourceLineNo">843</span>   * manager may use it when assigning regions.&lt;/li&gt;<a name="line.843"></a>
-<span class="sourceLineNo">844</span>   * &lt;li&gt;Wait for meta to be initialized if necessary, start table state manager.&lt;/li&gt;<a name="line.844"></a>
-<span class="sourceLineNo">845</span>   * &lt;li&gt;Wait for enough region servers to check-in&lt;/li&gt;<a name="line.845"></a>
-<span class="sourceLineNo">846</span>   * &lt;li&gt;Let assignment manager load data from meta and construct region states&lt;/li&gt;<a name="line.846"></a>
-<span class="sourceLineNo">847</span>   * &lt;li&gt;Start all other things such as chore services, etc&lt;/li&gt;<a name="line.847"></a>
-<span class="sourceLineNo">848</span>   * &lt;/ol&gt;<a name="line.848"></a>
-<span class="sourceLineNo">849</span>   * &lt;p/&gt;<a name="line.849"></a>
-<span class="sourceLineNo">850</span>   * Notice that now we will not schedule a special procedure to make meta online(unless the first<a name="line.850"></a>
-<span class="sourceLineNo">851</span>   * time where meta has not been created yet), we will rely on SCP to bring meta online.<a name="line.851"></a>
-<span class="sourceLineNo">852</span>   */<a name="line.852"></a>
-<span class="sourceLineNo">853</span>  private void finishActiveMasterInitialization(MonitoredTask status) throws IOException,<a name="line.853"></a>
-<span class="sourceLineNo">854</span>          InterruptedException, KeeperException, ReplicationException {<a name="line.854"></a>
-<span class="sourceLineNo">855</span>    /*<a name="line.855"></a>
-<span class="sourceLineNo">856</span>     * We are active master now... go initialize components we need to run.<a name="line.856"></a>
-<span class="sourceLineNo">857</span>     */<a name="line.857"></a>
-<span class="sourceLineNo">858</span>    status.setStatus("Initializing Master file system");<a name="line.858"></a>
-<span class="sourceLineNo">859</span><a name="line.859"></a>
-<span class="sourceLineNo">860</span>    this.masterActiveTime = EnvironmentEdgeManager.currentTime();<a name="line.860"></a>
-<span class="sourceLineNo">861</span>    // TODO: Do this using Dependency Injection, using PicoContainer, Guice or Spring.<a name="line.861"></a>
-<span class="sourceLineNo">862</span><a name="line.862"></a>
-<span class="sourceLineNo">863</span>    // always initialize the MemStoreLAB as we use a region to store data in master now, see<a name="line.863"></a>
-<span class="sourceLineNo">864</span>    // localStore.<a name="line.864"></a>
-<span class="sourceLineNo">865</span>    initializeMemStoreChunkCreator();<a name="line.865"></a>
-<span class="sourceLineNo">866</span>    this.fileSystemManager = new MasterFileSystem(conf);<a name="line.866"></a>
-<span class="sourceLineNo">867</span>    this.walManager = new MasterWalManager(this);<a name="line.867"></a>
-<span class="sourceLineNo">868</span><a name="line.868"></a>
-<span class="sourceLineNo">869</span>    // warm-up HTDs cache on master initialization<a name="line.869"></a>
-<span class="sourceLineNo">870</span>    if (preLoadTableDescriptors) {<a name="line.870"></a>
-<span class="sourceLineNo">871</span>      status.setStatus("Pre-loading table descriptors");<a name="line.871"></a>
-<span class="sourceLineNo">872</span>      this.tableDescriptors.getAll();<a name="line.872"></a>
-<span class="sourceLineNo">873</span>    }<a name="line.873"></a>
-<span class="sourceLineNo">874</span><a name="line.874"></a>
-<span class="sourceLineNo">875</span>    // Publish cluster ID; set it in Master too. The superclass RegionServer does this later but<a name="line.875"></a>
-<span class="sourceLineNo">876</span>    // only after it has checked in with the Master. At least a few tests ask Master for clusterId<a name="line.876"></a>
-<span class="sourceLineNo">877</span>    // before it has called its run method and before RegionServer has done the reportForDuty.<a name="line.877"></a>
-<span class="sourceLineNo">878</span>    ClusterId clusterId = fileSystemManager.getClusterId();<a name="line.878"></a>
-<span class="sourceLineNo">879</span>    status.setStatus("Publishing Cluster ID " + clusterId + " in ZooKeeper");<a name="line.879"></a>
-<span class="sourceLineNo">880</span>    ZKClusterId.setClusterId(this.zooKeeper, fileSystemManager.getClusterId());<a name="line.880"></a>
-<span class="sourceLineNo">881</span>    this.clusterId = clusterId.toString();<a name="line.881"></a>
-<span class="sourceLineNo">882</span><a name="line.882"></a>
-<span class="sourceLineNo">883</span>    // Precaution. Put in place the old hbck1 lock file to fence out old hbase1s running their<a name="line.883"></a>
-<span class="sourceLineNo">884</span>    // hbck1s against an hbase2 cluster; it could do damage. To skip this behavior, set<a name="line.884"></a>
-<span class="sourceLineNo">885</span>    // hbase.write.hbck1.lock.file to false.<a name="line.885"></a>
-<span class="sourceLineNo">886</span>    if (this.conf.getBoolean("hbase.write.hbck1.lock.file", true)) {<a name="line.886"></a>
-<span class="sourceLineNo">887</span>      Pair&lt;Path, FSDataOutputStream&gt; result = null;<a name="line.887"></a>
-<span class="sourceLineNo">888</span>      try {<a name="line.888"></a>
-<span class="sourceLineNo">889</span>        result = HBaseFsck.checkAndMarkRunningHbck(this.conf,<a name="line.889"></a>
-<span class="sourceLineNo">890</span>            HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.890"></a>
-<span class="sourceLineNo">891</span>      } finally {<a name="line.891"></a>
-<span class="sourceLineNo">892</span>        if (result != null) {<a name="line.892"></a>
-<span class="sourceLineNo">893</span>          Closeables.close(result.getSecond(), true);<a name="line.893"></a>
-<span class="sourceLineNo">894</span>        }<a name="line.894"></a>
-<span class="sourceLineNo">895</span>      }<a name="line.895"></a>
-<span class="sourceLineNo">896</span>    }<a name="line.896"></a>
-<span class="sourceLineNo">897</span><a name="line.897"></a>
-<span class="sourceLineNo">898</span>    status.setStatus("Initialize ServerManager and schedule SCP for crash servers");<a name="line.898"></a>
-<span class="sourceLineNo">899</span>    // The below two managers must be created before loading procedures, as they will be used during<a name="line.899"></a>
-<span class="sourceLineNo">900</span>    // loading.<a name="line.900"></a>
-<span class="sourceLineNo">901</span>    this.serverManager = createServerManager(this);<a name="line.901"></a>
-<span class="sourceLineNo">902</span>    this.syncReplicationReplayWALManager = new SyncReplicationReplayWALManager(this);<a name="line.902"></a>
-<span class="sourceLineNo">903</span>    if (!conf.getBoolean(HBASE_SPLIT_WAL_COORDINATED_BY_ZK,<a name="line.903"></a>
-<span class="sourceLineNo">904</span>      DEFAULT_HBASE_SPLIT_COORDINATED_BY_ZK)) {<a name="line.904"></a>
-<span class="sourceLineNo">905</span>      this.splitWALManager = new SplitWALManager(this);<a name="line.905"></a>
-<span class="sourceLineNo">906</span>    }<a name="line.906"></a>
-<span class="sourceLineNo">907</span><a name="line.907"></a>
-<span class="sourceLineNo">908</span>    // initialize master local region<a name="line.908"></a>
-<span class="sourceLineNo">909</span>    masterRegion = MasterRegionFactory.create(this);<a name="line.909"></a>
+<span class="sourceLineNo">724</span>    this.drainingServerTracker = new DrainingServerTracker(zooKeeper, this, this.serverManager);<a name="line.724"></a>
+<span class="sourceLineNo">725</span>    this.drainingServerTracker.start();<a name="line.725"></a>
+<span class="sourceLineNo">726</span><a name="line.726"></a>
+<span class="sourceLineNo">727</span>    this.snapshotCleanupTracker = new SnapshotCleanupTracker(zooKeeper, this);<a name="line.727"></a>
+<span class="sourceLineNo">728</span>    this.snapshotCleanupTracker.start();<a name="line.728"></a>
+<span class="sourceLineNo">729</span><a name="line.729"></a>
+<span class="sourceLineNo">730</span>    String clientQuorumServers = conf.get(HConstants.CLIENT_ZOOKEEPER_QUORUM);<a name="line.730"></a>
+<span class="sourceLineNo">731</span>    boolean clientZkObserverMode = conf.getBoolean(HConstants.CLIENT_ZOOKEEPER_OBSERVER_MODE,<a name="line.731"></a>
+<span class="sourceLineNo">732</span>      HConstants.DEFAULT_CLIENT_ZOOKEEPER_OBSERVER_MODE);<a name="line.732"></a>
+<span class="sourceLineNo">733</span>    if (clientQuorumServers != null &amp;&amp; !clientZkObserverMode) {<a name="line.733"></a>
+<span class="sourceLineNo">734</span>      // we need to take care of the ZK information synchronization<a name="line.734"></a>
+<span class="sourceLineNo">735</span>      // if given client ZK are not observer nodes<a name="line.735"></a>
+<span class="sourceLineNo">736</span>      ZKWatcher clientZkWatcher = new ZKWatcher(conf,<a name="line.736"></a>
+<span class="sourceLineNo">737</span>          getProcessName() + ":" + rpcServices.getSocketAddress().getPort() + "-clientZK", this,<a name="line.737"></a>
+<span class="sourceLineNo">738</span>          false, true);<a name="line.738"></a>
+<span class="sourceLineNo">739</span>      this.metaLocationSyncer = new MetaLocationSyncer(zooKeeper, clientZkWatcher, this);<a name="line.739"></a>
+<span class="sourceLineNo">740</span>      this.metaLocationSyncer.start();<a name="line.740"></a>
+<span class="sourceLineNo">741</span>      this.masterAddressSyncer = new MasterAddressSyncer(zooKeeper, clientZkWatcher, this);<a name="line.741"></a>
+<span class="sourceLineNo">742</span>      this.masterAddressSyncer.start();<a name="line.742"></a>
+<span class="sourceLineNo">743</span>      // set cluster id is a one-go effort<a name="line.743"></a>
+<span class="sourceLineNo">744</span>      ZKClusterId.setClusterId(clientZkWatcher, fileSystemManager.getClusterId());<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>    // Set the cluster as up.  If new RSs, they'll be waiting on this before<a name="line.747"></a>
+<span class="sourceLineNo">748</span>    // going ahead with their startup.<a name="line.748"></a>
+<span class="sourceLineNo">749</span>    boolean wasUp = this.clusterStatusTracker.isClusterUp();<a name="line.749"></a>
+<span class="sourceLineNo">750</span>    if (!wasUp) this.clusterStatusTracker.setClusterUp();<a name="line.750"></a>
+<span class="sourceLineNo">751</span><a name="line.751"></a>
+<span class="sourceLineNo">752</span>    LOG.info("Active/primary master=" + this.serverName +<a name="line.752"></a>
+<span class="sourceLineNo">753</span>        ", sessionid=0x" +<a name="line.753"></a>
+<span class="sourceLineNo">754</span>        Long.toHexString(this.zooKeeper.getRecoverableZooKeeper().getSessionId()) +<a name="line.754"></a>
+<span class="sourceLineNo">755</span>        ", setting cluster-up flag (Was=" + wasUp + ")");<a name="line.755"></a>
+<span class="sourceLineNo">756</span><a name="line.756"></a>
+<span class="sourceLineNo">757</span>    // create/initialize the snapshot manager and other procedure managers<a name="line.757"></a>
+<span class="sourceLineNo">758</span>    this.snapshotManager = new SnapshotManager();<a name="line.758"></a>
+<span class="sourceLineNo">759</span>    this.mpmHost = new MasterProcedureManagerHost();<a name="line.759"></a>
+<span class="sourceLineNo">760</span>    this.mpmHost.register(this.snapshotManager);<a name="line.760"></a>
+<span class="sourceLineNo">761</span>    this.mpmHost.register(new MasterFlushTableProcedureManager());<a name="line.761"></a>
+<span class="sourceLineNo">762</span>    this.mpmHost.loadProcedures(conf);<a name="line.762"></a>
+<span class="sourceLineNo">763</span>    this.mpmHost.initialize(this, this.metricsMaster);<a name="line.763"></a>
+<span class="sourceLineNo">764</span>  }<a name="line.764"></a>
+<span class="sourceLineNo">765</span><a name="line.765"></a>
+<span class="sourceLineNo">766</span>  // Will be overriden in test to inject customized AssignmentManager<a name="line.766"></a>
+<span class="sourceLineNo">767</span>  @InterfaceAudience.Private<a name="line.767"></a>
+<span class="sourceLineNo">768</span>  protected AssignmentManager createAssignmentManager(MasterServices master,<a name="line.768"></a>
+<span class="sourceLineNo">769</span>    MasterRegion masterRegion) {<a name="line.769"></a>
+<span class="sourceLineNo">770</span>    return new AssignmentManager(master, masterRegion);<a name="line.770"></a>
+<span class="sourceLineNo">771</span>  }<a name="line.771"></a>
+<span class="sourceLineNo">772</span><a name="line.772"></a>
+<span class="sourceLineNo">773</span>  private void tryMigrateMetaLocationsFromZooKeeper() throws IOException, KeeperException {<a name="line.773"></a>
+<span class="sourceLineNo">774</span>    // try migrate data from zookeeper<a name="line.774"></a>
+<span class="sourceLineNo">775</span>    try (ResultScanner scanner =<a name="line.775"></a>
+<span class="sourceLineNo">776</span>      masterRegion.getScanner(new Scan().addFamily(HConstants.CATALOG_FAMILY))) {<a name="line.776"></a>
+<span class="sourceLineNo">777</span>      if (scanner.next() != null) {<a name="line.777"></a>
+<span class="sourceLineNo">778</span>        // notice that all replicas for a region are in the same row, so the migration can be<a name="line.778"></a>
+<span class="sourceLineNo">779</span>        // done with in a one row put, which means if we have data in catalog family then we can<a name="line.779"></a>
+<span class="sourceLineNo">780</span>        // make sure that the migration is done.<a name="line.780"></a>
+<span class="sourceLineNo">781</span>        LOG.info("The {} family in master local region already has data in it, skip migrating...",<a name="line.781"></a>
+<span class="sourceLineNo">782</span>          HConstants.CATALOG_FAMILY);<a name="line.782"></a>
+<span class="sourceLineNo">783</span>        return;<a name="line.783"></a>
+<span class="sourceLineNo">784</span>      }<a name="line.784"></a>
+<span class="sourceLineNo">785</span>    }<a name="line.785"></a>
+<span class="sourceLineNo">786</span>    // start migrating<a name="line.786"></a>
+<span class="sourceLineNo">787</span>    byte[] row = CatalogFamilyFormat.getMetaKeyForRegion(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.787"></a>
+<span class="sourceLineNo">788</span>    Put put = new Put(row);<a name="line.788"></a>
+<span class="sourceLineNo">789</span>    List&lt;String&gt; metaReplicaNodes = zooKeeper.getMetaReplicaNodes();<a name="line.789"></a>
+<span class="sourceLineNo">790</span>    StringBuilder info = new StringBuilder("Migrating meta locations:");<a name="line.790"></a>
+<span class="sourceLineNo">791</span>    for (String metaReplicaNode : metaReplicaNodes) {<a name="line.791"></a>
+<span class="sourceLineNo">792</span>      int replicaId = zooKeeper.getZNodePaths().getMetaReplicaIdFromZNode(metaReplicaNode);<a name="line.792"></a>
+<span class="sourceLineNo">793</span>      RegionState state = MetaTableLocator.getMetaRegionState(zooKeeper, replicaId);<a name="line.793"></a>
+<span class="sourceLineNo">794</span>      info.append(" ").append(state);<a name="line.794"></a>
+<span class="sourceLineNo">795</span>      put.setTimestamp(state.getStamp());<a name="line.795"></a>
+<span class="sourceLineNo">796</span>      MetaTableAccessor.addRegionInfo(put, state.getRegion());<a name="line.796"></a>
+<span class="sourceLineNo">797</span>      if (state.getServerName() != null) {<a name="line.797"></a>
+<span class="sourceLineNo">798</span>        MetaTableAccessor.addLocation(put, state.getServerName(), HConstants.NO_SEQNUM, replicaId);<a name="line.798"></a>
+<span class="sourceLineNo">799</span>      }<a name="line.799"></a>
+<span class="sourceLineNo">800</span>      put.add(CellBuilderFactory.create(CellBuilderType.SHALLOW_COPY).setRow(put.getRow())<a name="line.800"></a>
+<span class="sourceLineNo">801</span>        .setFamily(HConstants.CATALOG_FAMILY)<a name="line.801"></a>
+<span class="sourceLineNo">802</span>        .setQualifier(RegionStateStore.getStateColumn(replicaId)).setTimestamp(put.getTimestamp())<a name="line.802"></a>
+<span class="sourceLineNo">803</span>        .setType(Cell.Type.Put).setValue(Bytes.toBytes(state.getState().name())).build());<a name="line.803"></a>
+<span class="sourceLineNo">804</span>    }<a name="line.804"></a>
+<span class="sourceLineNo">805</span>    if (!put.isEmpty()) {<a name="line.805"></a>
+<span class="sourceLineNo">806</span>      LOG.info(info.toString());<a name="line.806"></a>
+<span class="sourceLineNo">807</span>      masterRegion.update(r -&gt; r.put(put));<a name="line.807"></a>
+<span class="sourceLineNo">808</span>    } else {<a name="line.808"></a>
+<span class="sourceLineNo">809</span>      LOG.info("No meta location available on zookeeper, skip migrating...");<a name="line.809"></a>
+<span class="sourceLineNo">810</span>    }<a name="line.810"></a>
+<span class="sourceLineNo">811</span>  }<a name="line.811"></a>
+<span class="sourceLineNo">812</span><a name="line.812"></a>
+<span class="sourceLineNo">813</span>  /**<a name="line.813"></a>
+<span class="sourceLineNo">814</span>   * Finish initialization of HMaster after becoming the primary master.<a name="line.814"></a>
+<span class="sourceLineNo">815</span>   * &lt;p/&gt;<a name="line.815"></a>
+<span class="sourceLineNo">816</span>   * The startup order is a bit complicated but very important, do not change it unless you know<a name="line.816"></a>
+<span class="sourceLineNo">817</span>   * what you are doing.<a name="line.817"></a>
+<span class="sourceLineNo">818</span>   * &lt;ol&gt;<a name="line.818"></a>
+<span class="sourceLineNo">819</span>   * &lt;li&gt;Initialize file system based components - file system manager, wal manager, table<a name="line.819"></a>
+<span class="sourceLineNo">820</span>   * descriptors, etc&lt;/li&gt;<a name="line.820"></a>
+<span class="sourceLineNo">821</span>   * &lt;li&gt;Publish cluster id&lt;/li&gt;<a name="line.821"></a>
+<span class="sourceLineNo">822</span>   * &lt;li&gt;Here comes the most complicated part - initialize server manager, assignment manager and<a name="line.822"></a>
+<span class="sourceLineNo">823</span>   * region server tracker<a name="line.823"></a>
+<span class="sourceLineNo">824</span>   * &lt;ol type='i'&gt;<a name="line.824"></a>
+<span class="sourceLineNo">825</span>   * &lt;li&gt;Create server manager&lt;/li&gt;<a name="line.825"></a>
+<span class="sourceLineNo">826</span>   * &lt;li&gt;Create master local region&lt;/li&gt;<a name="line.826"></a>
+<span class="sourceLineNo">827</span>   * &lt;li&gt;Create procedure executor, load the procedures, but do not start workers. We will start it<a name="line.827"></a>
+<span class="sourceLineNo">828</span>   * later after we finish scheduling SCPs to avoid scheduling duplicated SCPs for the same<a name="line.828"></a>
+<span class="sourceLineNo">829</span>   * server&lt;/li&gt;<a name="line.829"></a>
+<span class="sourceLineNo">830</span>   * &lt;li&gt;Create assignment manager and start it, load the meta region state, but do not load data<a name="line.830"></a>
+<span class="sourceLineNo">831</span>   * from meta region&lt;/li&gt;<a name="line.831"></a>
+<span class="sourceLineNo">832</span>   * &lt;li&gt;Start region server tracker, construct the online servers set and find out dead servers and<a name="line.832"></a>
+<span class="sourceLineNo">833</span>   * schedule SCP for them. The online servers will be constructed by scanning zk, and we will also<a name="line.833"></a>
+<span class="sourceLineNo">834</span>   * scan the wal directory to find out possible live region servers, and the differences between<a name="line.834"></a>
+<span class="sourceLineNo">835</span>   * these two sets are the dead servers&lt;/li&gt;<a name="line.835"></a>
+<span class="sourceLineNo">836</span>   * &lt;/ol&gt;<a name="line.836"></a>
+<span class="sourceLineNo">837</span>   * &lt;/li&gt;<a name="line.837"></a>
+<span class="sourceLineNo">838</span>   * &lt;li&gt;If this is a new deploy, schedule a InitMetaProcedure to initialize meta&lt;/li&gt;<a name="line.838"></a>
+<span class="sourceLineNo">839</span>   * &lt;li&gt;Start necessary service threads - balancer, catalog janitor, executor services, and also<a name="line.839"></a>
+<span class="sourceLineNo">840</span>   * the procedure executor, etc. Notice that the balancer must be created first as assignment<a name="line.840"></a>
+<span class="sourceLineNo">841</span>   * manager may use it when assigning regions.&lt;/li&gt;<a name="line.841"></a>
+<span class="sourceLineNo">842</span>   * &lt;li&gt;Wait for meta to be initialized if necessary, start table state manager.&lt;/li&gt;<a name="line.842"></a>
+<span class="sourceLineNo">843</span>   * &lt;li&gt;Wait for enough region servers to check-in&lt;/li&gt;<a name="line.843"></a>
+<span class="sourceLineNo">844</span>   * &lt;li&gt;Let assignment manager load data from meta and construct region states&lt;/li&gt;<a name="line.844"></a>
+<span class="sourceLineNo">845</span>   * &lt;li&gt;Start all other things such as chore services, etc&lt;/li&gt;<a name="line.845"></a>
+<span class="sourceLineNo">846</span>   * &lt;/ol&gt;<a name="line.846"></a>
+<span class="sourceLineNo">847</span>   * &lt;p/&gt;<a name="line.847"></a>
+<span class="sourceLineNo">848</span>   * Notice that now we will not schedule a special procedure to make meta online(unless the first<a name="line.848"></a>
+<span class="sourceLineNo">849</span>   * time where meta has not been created yet), we will rely on SCP to bring meta online.<a name="line.849"></a>
+<span class="sourceLineNo">850</span>   */<a name="line.850"></a>
+<span class="sourceLineNo">851</span>  private void finishActiveMasterInitialization(MonitoredTask status) throws IOException,<a name="line.851"></a>
+<span class="sourceLineNo">852</span>          InterruptedException, KeeperException, ReplicationException {<a name="line.852"></a>
+<span class="sourceLineNo">853</span>    /*<a name="line.853"></a>
+<span class="sourceLineNo">854</span>     * We are active master now... go initialize components we need to run.<a name="line.854"></a>
+<span class="sourceLineNo">855</span>     */<a name="line.855"></a>
+<span class="sourceLineNo">856</span>    status.setStatus("Initializing Master file system");<a name="line.856"></a>
+<span class="sourceLineNo">857</span><a name="line.857"></a>
+<span class="sourceLineNo">858</span>    this.masterActiveTime = EnvironmentEdgeManager.currentTime();<a name="line.858"></a>
+<span class="sourceLineNo">859</span>    // TODO: Do this using Dependency Injection, using PicoContainer, Guice or Spring.<a name="line.859"></a>
+<span class="sourceLineNo">860</span><a name="line.860"></a>
+<span class="sourceLineNo">861</span>    // always initialize the MemStoreLAB as we use a region to store data in master now, see<a name="line.861"></a>
+<span class="sourceLineNo">862</span>    // localStore.<a name="line.862"></a>
+<span class="sourceLineNo">863</span>    initializeMemStoreChunkCreator();<a name="line.863"></a>
+<span class="sourceLineNo">864</span>    this.fileSystemManager = new MasterFileSystem(conf);<a name="line.864"></a>
+<span class="sourceLineNo">865</span>    this.walManager = new MasterWalManager(this);<a name="line.865"></a>
+<span class="sourceLineNo">866</span><a name="line.866"></a>
+<span class="sourceLineNo">867</span>    // warm-up HTDs cache on master initialization<a name="line.867"></a>
+<span class="sourceLineNo">868</span>    if (preLoadTableDescriptors) {<a name="line.868"></a>
+<span class="sourceLineNo">869</span>      status.setStatus("Pre-loading table descriptors");<a name="line.869"></a>
+<span class="sourceLineNo">870</span>      this.tableDescriptors.getAll();<a name="line.870"></a>
+<span class="sourceLineNo">871</span>    }<a name="line.871"></a>
+<span class="sourceLineNo">872</span><a name="line.872"></a>
+<span class="sourceLineNo">873</span>    // Publish cluster ID; set it in Master too. The superclass RegionServer does this later but<a name="line.873"></a>
+<span class="sourceLineNo">874</span>    // only after it has checked in with the Master. At least a few tests ask Master for clusterId<a name="line.874"></a>
+<span class="sourceLineNo">875</span>    // before it has called its run method and before RegionServer has done the reportForDuty.<a name="line.875"></a>
+<span class="sourceLineNo">876</span>    ClusterId clusterId = fileSystemManager.getClusterId();<a name="line.876"></a>
+<span class="sourceLineNo">877</span>    status.setStatus("Publishing Cluster ID " + clusterId + " in ZooKeeper");<a name="line.877"></a>
+<span class="sourceLineNo">878</span>    ZKClusterId.setClusterId(this.zooKeeper, fileSystemManager.getClusterId());<a name="line.878"></a>
+<span class="sourceLineNo">879</span>    this.clusterId = clusterId.toString();<a name="line.879"></a>
+<span class="sourceLineNo">880</span><a name="line.880"></a>
+<span class="sourceLineNo">881</span>    // Precaution. Put in place the old hbck1 lock file to fence out old hbase1s running their<a name="line.881"></a>
+<span class="sourceLineNo">882</span>    // hbck1s against an hbase2 cluster; it could do damage. To skip this behavior, set<a name="line.882"></a>
+<span class="sourceLineNo">883</span>    // hbase.write.hbck1.lock.file to false.<a name="line.883"></a>
+<span class="sourceLineNo">884</span>    if (this.conf.getBoolean("hbase.write.hbck1.lock.file", true)) {<a name="line.884"></a>
+<span class="sourceLineNo">885</span>      Pair&lt;Path, FSDataOutputStream&gt; result = null;<a name="line.885"></a>
+<span class="sourceLineNo">886</span>      try {<a name="line.886"></a>
+<span class="sourceLineNo">887</span>        result = HBaseFsck.checkAndMarkRunningHbck(this.conf,<a name="line.887"></a>
+<span class="sourceLineNo">888</span>            HBaseFsck.createLockRetryCounterFactory(this.conf).create());<a name="line.888"></a>
+<span class="sourceLineNo">889</span>      } finally {<a name="line.889"></a>
+<span class="sourceLineNo">890</span>        if (result != null) {<a name="line.890"></a>
+<span class="sourceLineNo">891</span>          Closeables.close(result.getSecond(), true);<a name="line.891"></a>
+<span class="sourceLineNo">892</span>        }<a name="line.892"></a>
+<span class="sourceLineNo">893</span>      }<a name="line.893"></a>
+<span class="sourceLineNo">894</span>    }<a name="line.894"></a>
+<span class="sourceLineNo">895</span><a name="line.895"></a>
+<span class="sourceLineNo">896</span>    status.setStatus("Initialize ServerManager and schedule SCP for crash servers");<a name="line.896"></a>
+<span class="sourceLineNo">897</span>    // The below two managers must be created before loading procedures, as they will be used during<a name="line.897"></a>
+<span class="sourceLineNo">898</span>    // loading.<a name="line.898"></a>
+<span class="sourceLineNo">899</span>    this.serverManager = createServerManager(this);<a name="line.899"></a>
+<span class="sourceLineNo">900</span>    this.syncReplicationReplayWALManager = new SyncReplicationReplayWALManager(this);<a name="line.900"></a>
+<span class="sourceLineNo">901</span>    if (!conf.getBoolean(HBASE_SPLIT_WAL_COORDINATED_BY_ZK,<a name="line.901"></a>
+<span class="sourceLineNo">902</span>      DEFAULT_HBASE_SPLIT_COORDINATED_BY_ZK)) {<a name="line.902"></a>
+<span class="sourceLineNo">903</span>      this.splitWALManager = new SplitWALManager(this);<a name="line.903"></a>
+<span class="sourceLineNo">904</span>    }<a name="line.904"></a>
+<span class="sourceLineNo">905</span><a name="line.905"></a>
+<span class="sourceLineNo">906</span>    // initialize master local region<a name="line.906"></a>
+<span class="sourceLineNo">907</span>    masterRegion = MasterRegionFactory.create(this);<a name="line.907"></a>
+<span class="sourceLineNo">908</span><a name="line.908"></a>
+<span class="sourceLineNo">909</span>    tryMigrateMetaLocationsFromZooKeeper();<a name="line.909"></a>
 <span class="sourceLineNo">910</span><a name="line.910"></a>
-<span class="sourceLineNo">911</span>    tryMigrateMetaLocationsFromZooKeeper();<a name="line.911"></a>
-<span class="sourceLineNo">912</span><a name="line.912"></a>
-<span class="sourceLineNo">913</span>    createProcedureExecutor();<a name="line.913"></a>
-<span class="sourceLineNo">914</span>    Map&lt;Class&lt;?&gt;, List&lt;Procedure&lt;MasterProcedureEnv&gt;&gt;&gt; procsByType =<a name="line.914"></a>
-<span class="sourceLineNo">915</span>      procedureExecutor.getActiveProceduresNoCopy().stream()<a name="line.915"></a>
-<span class="sourceLineNo">916</span>        .collect(Collectors.groupingBy(p -&gt; p.getClass()));<a name="line.916"></a>
-<span class="sourceLineNo">917</span><a name="line.917"></a>
-<span class="sourceLineNo">918</span>    // Create Assignment Manager<a name="line.918"></a>
-<span class="sourceLineNo">919</span>    this.assignmentManager = createAssignmentManager(this, masterRegion);<a name="line.919"></a>
-<span class="sourceLineNo">920</span>    this.assignmentManager.start();<a name="line.920"></a>
-<span class="sourceLineNo">921</span>    // TODO: TRSP can perform as the sub procedure for other procedures, so even if it is marked as<a name="line.921"></a>
-<span class="sourceLineNo">922</span>    // completed, it could still be in the procedure list. This is a bit strange but is another<a name="line.922"></a>
-<span class="sourceLineNo">923</span>    // story, need to verify the implementation for ProcedureExecutor and ProcedureStore.<a name="line.923"></a>
-<span class="sourceLineNo">924</span>    List&lt;TransitRegionStateProcedure&gt; ritList =<a name="line.924"></a>
-<span class="sourceLineNo">925</span>      procsByType.getOrDefault(TransitRegionStateProcedure.class, Collections.emptyList()).stream()<a name="line.925"></a>
-<span class="sourceLineNo">926</span>        .filter(p -&gt; !p.isFinished()).map(p -&gt; (TransitRegionStateProcedure) p)<a name="line.926"></a>
-<span class="sourceLineNo">927</span>        .collect(Collectors.toList());<a name="line.927"></a>
-<span class="sourceLineNo">928</span>    this.assignmentManager.setupRIT(ritList);<a name="line.928"></a>
-<span class="sourceLineNo">929</span><a name="line.929"></a>
-<span class="sourceLineNo">930</span>    // Start RegionServerTracker with listing of servers found with exiting SCPs -- these should<a name="line.930"></a>
-<span class="sourceLineNo">931</span>    // be registered in the deadServers set -- and with the list of servernames out on the<a name="line.931"></a>
-<span class="sourceLineNo">932</span>    // filesystem that COULD BE 'alive' (we'll schedule SCPs for each and let SCP figure it out).<a name="line.932"></a>
-<span class="sourceLineNo">933</span>    // We also pass dirs that are already 'splitting'... so we can do some checks down in tracker.<a name="line.933"></a>
-<span class="sourceLineNo">934</span>    // TODO: Generate the splitting and live Set in one pass instead of two as we currently do.<a name="line.934"></a>
-<span class="sourceLineNo">935</span>    this.regionServerTracker.upgrade(<a name="line.935"></a>
-<span class="sourceLineNo">936</span>      procsByType.getOrDefault(ServerCrashProcedure.class, Collections.emptyList()).stream()<a name="line.936"></a>
-<span class="sourceLineNo">937</span>        .map(p -&gt; (ServerCrashProcedure) p).map(p -&gt; p.getServerName()).collect(Collectors.toSet()),<a name="line.937"></a>
-<span class="sourceLineNo">938</span>      walManager.getLiveServersFromWALDir(), walManager.getSplittingServersFromWALDir());<a name="line.938"></a>
-<span class="sourceLineNo">939</span>    // This manager must be accessed AFTER hbase:meta is confirmed on line..<a name="line.939"></a>
-<span class="sourceLineNo">940</span>    this.tableStateManager = new TableStateManager(this);<a name="line.940"></a>
-<span class="sourceLineNo">941</span><a name="line.941"></a>
-<span class="sourceLineNo">942</span>    status.setStatus("Initializing ZK system trackers");<a name="line.942"></a>
-<span class="sourceLineNo">943</span>    initializeZKBasedSystemTrackers();<a name="line.943"></a>
-<span class="sourceLineNo">944</span>    status.setStatus("Loading last flushed sequence id of regions");<a name="line.944"></a>
-<span class="sourceLineNo">945</span>    try {<a name="line.945"></a>
-<span class="sourceLineNo">946</span>      this.serverManager.loadLastFlushedSequenceIds();<a name="line.946"></a>
-<span class="sourceLineNo">947</span>    } catch (IOException e) {<a name="line.947"></a>
-<span class="sourceLineNo">948</span>      LOG.info("Failed to load last flushed sequence id of regions"<a name="line.948"></a>
-<span class="sourceLineNo">949</span>          + " from file system", e);<a name="line.949"></a>
-<span class="sourceLineNo">950</span>    }<a name="line.950"></a>
-<span class="sourceLineNo">951</span>    // Set ourselves as active Master now our claim has succeeded up in zk.<a name="line.951"></a>
-<span class="sourceLineNo">952</span>    this.activeMaster = true;<a name="line.952"></a>
-<span class="sourceLineNo">953</span><a name="line.953"></a>
-<span class="sourceLineNo">954</span>    // Start the Zombie master detector after setting master as active, see HBASE-21535<a name="line.954"></a>
-<span class="sourceLineNo">955</span>    Thread zombieDetector = new Thread(new MasterInitializationMonitor(this),<a name="line.955"></a>
-<span class="sourceLineNo">956</span>        "ActiveMasterInitializationMonitor-" + EnvironmentEdgeManager.currentTime());<a name="line.956"></a>
-<span class="sourceLineNo">957</span>    zombieDetector.setDaemon(true);<a name="line.957"></a>
-<span class="sourceLineNo">958</span>    zombieDetector.start();<a name="line.958"></a>
-<span class="sourceLineNo">959</span><a name="line.959"></a>
-<span class="sourceLineNo">960</span>    if (!maintenanceMode) {<a name="line.960"></a>
-<span class="sourceLineNo">961</span>      // Add the Observer to delete quotas on table deletion before starting all CPs by<a name="line.961"></a>
-<span class="sourceLineNo">962</span>      // default with quota support, avoiding if user specifically asks to not load this Observer.<a name="line.962"></a>
-<span class="sourceLineNo">963</span>      if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.963"></a>
-<span class="sourceLineNo">964</span>        updateConfigurationForQuotasObserver(conf);<a name="line.964"></a>
-<span class="sourceLineNo">965</span>      }<a name="line.965"></a>
-<span class="sourceLineNo">966</span>      // initialize master side coprocessors before we start handling requests<a name="line.966"></a>
-<span class="sourceLineNo">967</span>      status.setStatus("Initializing master coprocessors");<a name="line.967"></a>
-<span class="sourceLineNo">968</span>      this.cpHost = new MasterCoprocessorHost(this, this.conf);<a name="line.968"></a>
-<span class="sourceLineNo">969</span>    }<a name="line.969"></a>
-<span class="sourceLineNo">970</span><a name="line.970"></a>
-<span class="sourceLineNo">971</span>    // Checking if meta needs initializing.<a name="line.971"></a>
-<span class="sourceLineNo">972</span>    status.setStatus("Initializing meta table if this is a new deploy");<a name="line.972"></a>
-<span class="sourceLineNo">973</span>    InitMetaProcedure initMetaProc = null;<a name="line.973"></a>
-<span class="sourceLineNo">974</span>    // Print out state of hbase:meta on startup; helps debugging.<a name="line.974"></a>
-<span class="sourceLineNo">975</span>    if (!this.assignmentManager.getRegionStates().hasTableRegionStates(TableName.META_TABLE_NAME)) {<a name="line.975"></a>
-<span class="sourceLineNo">976</span>      Optional&lt;InitMetaProcedure&gt; optProc = procedureExecutor.getProcedures().stream()<a name="line.976"></a>
-<span class="sourceLineNo">977</span>        .filter(p -&gt; p instanceof InitMetaProcedure).map(o -&gt; (InitMetaProcedure) o).findAny();<a name="line.977"></a>
-<span class="sourceLineNo">978</span>      initMetaProc = optProc.orElseGet(() -&gt; {<a name="line.978"></a>
-<span class="sourceLineNo">979</span>        // schedule an init meta procedure if meta has not been deployed yet<a name="line.979"></a>
-<span class="sourceLineNo">980</span>        InitMetaProcedure temp = new InitMetaProcedure();<a name="line.980"></a>
-<span class="sourceLineNo">981</span>        procedureExecutor.submitProcedure(temp);<a name="line.981"></a>
-<span class="sourceLineNo">982</span>        return temp;<a name="line.982"></a>
-<span class="sourceLineNo">983</span>      });<a name="line.983"></a>
-<span class="sourceLineNo">984</span>    }<a name="line.984"></a>
-<span class="sourceLineNo">985</span><a name="line.985"></a>
-<span class="sourceLineNo">986</span>    // initialize load balancer<a name="line.986"></a>
-<span class="sourceLineNo">987</span>    this.balancer.setMasterServices(this);<a name="line.987"></a>
-<span class="sourceLineNo">988</span>    this.balancer.initialize();<a name="line.988"></a>
-<span class="sourceLineNo">989</span>    this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.989"></a>
-<span class="sourceLineNo">990</span><a name="line.990"></a>
-<span class="sourceLineNo">991</span>    // start up all service threads.<a name="line.991"></a>
-<span class="sourceLineNo">992</span>    status.setStatus("Initializing master service threads");<a name="line.992"></a>
-<span class="sourceLineNo">993</span>    startServiceThreads();<a name="line.993"></a>
-<span class="sourceLineNo">994</span>    // wait meta to be initialized after we start procedure executor<a name="line.994"></a>
-<span class="sourceLineNo">995</span>    if (initMetaProc != null) {<a name="line.995"></a>
-<span class="sourceLineNo">996</span>      initMetaProc.await();<a name="line.996"></a>
-<span class="sourceLineNo">997</span>    }<a name="line.997"></a>
-<span class="sourceLineNo">998</span>    // Wake up this server to check in<a name="line.998"></a>
-<span class="sourceLineNo">999</span>    sleeper.skipSleepCycle();<a name="line.999"></a>
-<span class="sourceLineNo">1000</span><a name="line.1000"></a>
-<span class="sourceLineNo">1001</span>    // Wait for region servers to report in.<a name="line.1001"></a>
-<span class="sourceLineNo">1002</span>    // With this as part of master initialization, it precludes our being able to start a single<a name="line.1002"></a>
-<span class="sourceLineNo">1003</span>    // server that is both Master and RegionServer. Needs more thought. TODO.<a name="line.1003"></a>
-<span class="sourceLineNo">1004</span>    String statusStr = "Wait for region servers to report in";<a name="line.1004"></a>
-<span class="sourceLineNo">1005</span>    status.setStatus(statusStr);<a name="line.1005"></a>
-<span class="sourceLineNo">1006</span>    LOG.info(Objects.toString(status));<a name="line.1006"></a>
-<span class="sourceLineNo">1007</span>    waitForRegionServers(status);<a name="line.1007"></a>
-<span class="sourceLineNo">1008</span><a name="line.1008"></a>
-<span class="sourceLineNo">1009</span>    // Check if master is shutting down because issue initializing regionservers or balancer.<a name="line.1009"></a>
-<span class="sourceLineNo">1010</span>    if (isStopped()) {<a name="line.1010"></a>
-<span class="sourceLineNo">1011</span>      return;<a name="line.1011"></a>
-<span class="sourceLineNo">1012</span>    }<a name="line.1012"></a>
-<span class="sourceLineNo">1013</span><a name="line.1013"></a>
-<span class="sourceLineNo">1014</span>    status.setStatus("Starting assignment manager");<a name="line.1014"></a>
-<span class="sourceLineNo">1015</span>    // FIRST HBASE:META READ!!!!<a name="line.1015"></a>
-<span class="sourceLineNo">1016</span>    // The below cannot make progress w/o hbase:meta being online.<a name="line.1016"></a>
-<span class="sourceLineNo">1017</span>    // This is the FIRST attempt at going to hbase:meta. Meta on-lining is going on in background<a name="line.1017"></a>
-<span class="sourceLineNo">1018</span>    // as procedures run -- in particular SCPs for crashed servers... One should put up hbase:meta<a name="line.1018"></a>
-<span class="sourceLineNo">1019</span>    // if it is down. It may take a while to come online. So, wait here until meta if for sure<a name="line.1019"></a>
-<span class="sourceLineNo">1020</span>    // available. That's what waitForMetaOnline does.<a name="line.1020"></a>
-<span class="sourceLineNo">1021</span>    if (!waitForMetaOnline()) {<a name="line.1021"></a>
-<span class="sourceLineNo">1022</span>      return;<a name="line.1022"></a>
-<span class="sourceLineNo">1023</span>    }<a name="line.1023"></a>
-<span class="sourceLineNo">1024</span><a name="line.1024"></a>
-<span class="sourceLineNo">1025</span>    TableDescriptor metaDescriptor =<a name="line.1025"></a>
-<span class="sourceLineNo">1026</span>      tableDescriptors.get(TableName.META_TABLE_NAME);<a name="line.1026"></a>
-<span class="sourceLineNo">1027</span>    final ColumnFamilyDescriptor tableFamilyDesc =<a name="line.1027"></a>
-<span class="sourceLineNo">1028</span>      metaDescriptor.getColumnFamily(HConstants.TABLE_FAMILY);<a name="line.1028"></a>
-<span class="sourceLineNo">1029</span>    final ColumnFamilyDescriptor replBarrierFamilyDesc =<a name="line.1029"></a>
-<span class="sourceLineNo">1030</span>      metaDescriptor.getColumnFamily(HConstants.REPLICATION_BARRIER_FAMILY);<a name="line.1030"></a>
-<span class="sourceLineNo">1031</span><a name="line.1031"></a>
-<span class="sourceLineNo">1032</span>    this.assignmentManager.joinCluster();<a name="line.1032"></a>
-<span class="sourceLineNo">1033</span>    // The below depends on hbase:meta being online.<a name="line.1033"></a>
-<span class="sourceLineNo">1034</span>    this.assignmentManager.processOfflineRegions();<a name="line.1034"></a>
-<span class="sourceLineNo">1035</span>    // this must be called after the above processOfflineRegions to prevent race<a name="line.1035"></a>
-<span class="sourceLineNo">1036</span>    this.assignmentManager.wakeMetaLoadedEvent();<a name="line.1036"></a>
-<span class="sourceLineNo">1037</span><a name="line.1037"></a>
-<span class="sourceLineNo">1038</span>    // for migrating from a version without HBASE-25099, and also for honoring the configuration<a name="line.1038"></a>
-<span class="sourceLineNo">1039</span>    // first.<a name="line.1039"></a>
-<span class="sourceLineNo">1040</span>    if (conf.get(HConstants.META_REPLICAS_NUM) != null) {<a name="line.1040"></a>
-<span class="sourceLineNo">1041</span>      int replicasNumInConf =<a name="line.1041"></a>
-<span class="sourceLineNo">1042</span>        conf.getInt(HConstants.META_REPLICAS_NUM, HConstants.DEFAULT_META_REPLICA_NUM);<a name="line.1042"></a>
-<span class="sourceLineNo">1043</span>      TableDescriptor metaDesc = tableDescriptors.get(TableName.META_TABLE_NAME);<a name="line.1043"></a>
-<span class="sourceLineNo">1044</span>      if (metaDesc.getRegionReplication() != replicasNumInConf) {<a name="line.1044"></a>
-<span class="sourceLineNo">1045</span>        // it is possible that we already have some replicas before upgrading, so we must set the<a name="line.1045"></a>
-<span class="sourceLineNo">1046</span>        // region replication number in meta TableDescriptor directly first, without creating a<a name="line.1046"></a>
-<span class="sourceLineNo">1047</span>        // ModifyTableProcedure, otherwise it may cause a double assign for the meta replicas.<a name="line.1047"></a>
-<span class="sourceLineNo">1048</span>        int existingReplicasCount =<a name="line.1048"></a>
-<span class="sourceLineNo">1049</span>          assignmentManager.getRegionStates().getRegionsOfTable(TableName.META_TABLE_NAME).size();<a name="line.1049"></a>
-<span class="sourceLineNo">1050</span>        if (existingReplicasCount &gt; metaDesc.getRegionReplication()) {<a name="line.1050"></a>
-<span class="sourceLineNo">1051</span>          LOG.info("Update replica count of hbase:meta from {}(in TableDescriptor)" +<a name="line.1051"></a>
-<span class="sourceLineNo">1052</span>            " to {}(existing ZNodes)", metaDesc.getRegionReplication(), existingReplicasCount);<a name="line.1052"></a>
-<span class="sourceLineNo">1053</span>          metaDesc = TableDescriptorBuilder.newBuilder(metaDesc)<a name="line.1053"></a>
-<span class="sourceLineNo">1054</span>            .setRegionReplication(existingReplicasCount).build();<a name="line.1054"></a>
-<span class="sourceLineNo">1055</span>          tableDescriptors.update(metaDesc);<a name="line.1055"></a>
-<span class="sourceLineNo">1056</span>        }<a name="line.1056"></a>
-<span class="sourceLineNo">1057</span>        // check again, and issue a ModifyTableProcedure if needed<a name="line.1057"></a>
-<span class="sourceLineNo">1058</span>        if (metaDesc.getRegionReplication() != replicasNumInConf) {<a name="line.1058"></a>
-<span class="sourceLineNo">1059</span>          LOG.info(<a name="line.1059"></a>
-<span class="sourceLineNo">1060</span>            "The {} config is {} while the replica count in TableDescriptor is {}" +<a name="line.1060"></a>
-<span class="sourceLineNo">1061</span>              " for hbase:meta, altering...",<a name="line.1061"></a>
-<span class="sourceLineNo">1062</span>            HConstants.META_REPLICAS_NUM, replicasNumInConf, metaDesc.getRegionReplication());<a name="line.1062"></a>
-<span class="sourceLineNo">1063</span>          procedureExecutor.submitProcedure(new ModifyTableProcedure(<a name="line.1063"></a>
-<span class="sourceLineNo">1064</span>            procedureExecutor.getEnvironment(), TableDescriptorBuilder.newBuilder(metaDesc)<a name="line.1064"></a>
-<span class="sourceLineNo">1065</span>              .setRegionReplication(replicasNumInConf).build(),<a name="line.1065"></a>
-<span class="sourceLineNo">1066</span>            null, metaDesc, false));<a name="line.1066"></a>
-<span class="sourceLineNo">1067</span>        }<a name="line.1067"></a>
-<span class="sourceLineNo">1068</span>      }<a name="line.1068"></a>
-<span class="sourceLineNo">1069</span>    }<a name="line.1069"></a>
-<span class="sourceLineNo">1070</span>    // Initialize after meta is up as below scans meta<a name="line.1070"></a>
-<span class="sourceLineNo">1071</span>    FavoredNodesManager fnm = getFavoredNodesManager();<a name="line.1071"></a>
-<span class="sourceLineNo">1072</span>    if (fnm != null) {<a name="line.1072"></a>
-<span class="sourceLineNo">1073</span>      fnm.initializeFromMeta();<a name="line.1073"></a>
-<span class="sourceLineNo">1074</span>    }<a name="line.1074"></a>
-<span class="sourceLineNo">1075</span><a name="line.1075"></a>
-<span class="sourceLineNo">1076</span>    // set cluster status again after user regions are assigned<a name="line.1076"></a>
-<span class="sourceLineNo">1077</span>    this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1077"></a>
+<span class="sourceLineNo">911</span>    createProcedureExecutor();<a name="line.911"></a>
+<span class="sourceLineNo">912</span>    Map&lt;Class&lt;?&gt;, List&lt;Procedure&lt;MasterProcedureEnv&gt;&gt;&gt; procsByType =<a name="line.912"></a>
+<span class="sourceLineNo">913</span>      procedureExecutor.getActiveProceduresNoCopy().stream()<a name="line.913"></a>
+<span class="sourceLineNo">914</span>        .collect(Collectors.groupingBy(p -&gt; p.getClass()));<a name="line.914"></a>
+<span class="sourceLineNo">915</span><a name="line.915"></a>
+<span class="sourceLineNo">916</span>    // Create Assignment Manager<a name="line.916"></a>
+<span class="sourceLineNo">917</span>    this.assignmentManager = createAssignmentManager(this, masterRegion);<a name="line.917"></a>
+<span class="sourceLineNo">918</span>    this.assignmentManager.start();<a name="line.918"></a>
+<span class="sourceLineNo">919</span>    // TODO: TRSP can perform as the sub procedure for other procedures, so even if it is marked as<a name="line.919"></a>
+<span class="sourceLineNo">920</span>    // completed, it could still be in the procedure list. This is a bit strange but is another<a name="line.920"></a>
+<span class="sourceLineNo">921</span>    // story, need to verify the implementation for ProcedureExecutor and ProcedureStore.<a name="line.921"></a>
+<span class="sourceLineNo">922</span>    List&lt;TransitRegionStateProcedure&gt; ritList =<a name="line.922"></a>
+<span class="sourceLineNo">923</span>      procsByType.getOrDefault(TransitRegionStateProcedure.class, Collections.emptyList()).stream()<a name="line.923"></a>
+<span class="sourceLineNo">924</span>        .filter(p -&gt; !p.isFinished()).map(p -&gt; (TransitRegionStateProcedure) p)<a name="line.924"></a>
+<span class="sourceLineNo">925</span>        .collect(Collectors.toList());<a name="line.925"></a>
+<span class="sourceLineNo">926</span>    this.assignmentManager.setupRIT(ritList);<a name="line.926"></a>
+<span class="sourceLineNo">927</span><a name="line.927"></a>
+<span class="sourceLineNo">928</span>    // Start RegionServerTracker with listing of servers found with exiting SCPs -- these should<a name="line.928"></a>
+<span class="sourceLineNo">929</span>    // be registered in the deadServers set -- and with the list of servernames out on the<a name="line.929"></a>
+<span class="sourceLineNo">930</span>    // filesystem that COULD BE 'alive' (we'll schedule SCPs for each and let SCP figure it out).<a name="line.930"></a>
+<span class="sourceLineNo">931</span>    // We also pass dirs that are already 'splitting'... so we can do some checks down in tracker.<a name="line.931"></a>
+<span class="sourceLineNo">932</span>    // TODO: Generate the splitting and live Set in one pass instead of two as we currently do.<a name="line.932"></a>
+<span class="sourceLineNo">933</span>    this.regionServerTracker.upgrade(<a name="line.933"></a>
+<span class="sourceLineNo">934</span>      procsByType.getOrDefault(ServerCrashProcedure.class, Collections.emptyList()).stream()<a name="line.934"></a>
+<span class="sourceLineNo">935</span>        .map(p -&gt; (ServerCrashProcedure) p).map(p -&gt; p.getServerName()).collect(Collectors.toSet()),<a name="line.935"></a>
+<span class="sourceLineNo">936</span>      walManager.getLiveServersFromWALDir(), walManager.getSplittingServersFromWALDir());<a name="line.936"></a>
+<span class="sourceLineNo">937</span>    // This manager must be accessed AFTER hbase:meta is confirmed on line..<a name="line.937"></a>
+<span class="sourceLineNo">938</span>    this.tableStateManager = new TableStateManager(this);<a name="line.938"></a>
+<span class="sourceLineNo">939</span><a name="line.939"></a>
+<span class="sourceLineNo">940</span>    status.setStatus("Initializing ZK system trackers");<a name="line.940"></a>
+<span class="sourceLineNo">941</span>    initializeZKBasedSystemTrackers();<a name="line.941"></a>
+<span class="sourceLineNo">942</span>    status.setStatus("Loading last flushed sequence id of regions");<a name="line.942"></a>
+<span class="sourceLineNo">943</span>    try {<a name="line.943"></a>
+<span class="sourceLineNo">944</span>      this.serverManager.loadLastFlushedSequenceIds();<a name="line.944"></a>
+<span class="sourceLineNo">945</span>    } catch (IOException e) {<a name="line.945"></a>
+<span class="sourceLineNo">946</span>      LOG.info("Failed to load last flushed sequence id of regions"<a name="line.946"></a>
+<span class="sourceLineNo">947</span>          + " from file system", e);<a name="line.947"></a>
+<span class="sourceLineNo">948</span>    }<a name="line.948"></a>
+<span class="sourceLineNo">949</span>    // Set ourselves as active Master now our claim has succeeded up in zk.<a name="line.949"></a>
+<span class="sourceLineNo">950</span>    this.activeMaster = true;<a name="line.950"></a>
+<span class="sourceLineNo">951</span><a name="line.951"></a>
+<span class="sourceLineNo">952</span>    // Start the Zombie master detector after setting master as active, see HBASE-21535<a name="line.952"></a>
+<span class="sourceLineNo">953</span>    Thread zombieDetector = new Thread(new MasterInitializationMonitor(this),<a name="line.953"></a>
+<span class="sourceLineNo">954</span>        "ActiveMasterInitializationMonitor-" + EnvironmentEdgeManager.currentTime());<a name="line.954"></a>
+<span class="sourceLineNo">955</span>    zombieDetector.setDaemon(true);<a name="line.955"></a>
+<span class="sourceLineNo">956</span>    zombieDetector.start();<a name="line.956"></a>
+<span class="sourceLineNo">957</span><a name="line.957"></a>
+<span class="sourceLineNo">958</span>    if (!maintenanceMode) {<a name="line.958"></a>
+<span class="sourceLineNo">959</span>      // Add the Observer to delete quotas on table deletion before starting all CPs by<a name="line.959"></a>
+<span class="sourceLineNo">960</span>      // default with quota support, avoiding if user specifically asks to not load this Observer.<a name="line.960"></a>
+<span class="sourceLineNo">961</span>      if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.961"></a>
+<span class="sourceLineNo">962</span>        updateConfigurationForQuotasObserver(conf);<a name="line.962"></a>
+<span class="sourceLineNo">963</span>      }<a name="line.963"></a>
+<span class="sourceLineNo">964</span>      // initialize master side coprocessors before we start handling requests<a name="line.964"></a>
+<span class="sourceLineNo">965</span>      status.setStatus("Initializing master coprocessors");<a name="line.965"></a>
+<span class="sourceLineNo">966</span>      this.cpHost = new MasterCoprocessorHost(this, this.conf);<a name="line.966"></a>
+<span class="sourceLineNo">967</span>    } else {<a name="line.967"></a>
+<span class="sourceLineNo">968</span>      // start an in process region server for carrying system regions<a name="line.968"></a>
+<span class="sourceLineNo">969</span>      maintenanceRegionServer =<a name="line.969"></a>
+<span class="sourceLineNo">970</span>        JVMClusterUtil.createRegionServerThread(getConfiguration(), HRegionServer.class, 0);<a name="line.970"></a>
+<span class="sourceLineNo">971</span>      maintenanceRegionServer.start();<a name="line.971"></a>
+<span class="sourceLineNo">972</span>    }<a name="line.972"></a>
+<span class="sourceLineNo">973</span><a name="line.973"></a>
+<span class="sourceLineNo">974</span>    // Checking if meta needs initializing.<a name="line.974"></a>
+<span class="sourceLineNo">975</span>    status.setStatus("Initializing meta table if this is a new deploy");<a name="line.975"></a>
+<span class="sourceLineNo">976</span>    InitMetaProcedure initMetaProc = null;<a name="line.976"></a>
+<span class="sourceLineNo">977</span>    // Print out state of hbase:meta on startup; helps debugging.<a name="line.977"></a>
+<span class="sourceLineNo">978</span>    if (!this.assignmentManager.getRegionStates().hasTableRegionStates(TableName.META_TABLE_NAME)) {<a name="line.978"></a>
+<span class="sourceLineNo">979</span>      Optional&lt;InitMetaProcedure&gt; optProc = procedureExecutor.getProcedures().stream()<a name="line.979"></a>
+<span class="sourceLineNo">980</span>        .filter(p -&gt; p instanceof InitMetaProcedure).map(o -&gt; (InitMetaProcedure) o).findAny();<a name="line.980"></a>
+<span class="sourceLineNo">981</span>      initMetaProc = optProc.orElseGet(() -&gt; {<a name="line.981"></a>
+<span class="sourceLineNo">982</span>        // schedule an init meta procedure if meta has not been deployed yet<a name="line.982"></a>
+<span class="sourceLineNo">983</span>        InitMetaProcedure temp = new InitMetaProcedure();<a name="line.983"></a>
+<span class="sourceLineNo">984</span>        procedureExecutor.submitProcedure(temp);<a name="line.984"></a>
+<span class="sourceLineNo">985</span>        return temp;<a name="line.985"></a>
+<span class="sourceLineNo">986</span>      });<a name="line.986"></a>
+<span class="sourceLineNo">987</span>    }<a name="line.987"></a>
+<span class="sourceLineNo">988</span><a name="line.988"></a>
+<span class="sourceLineNo">989</span>    // initialize load balancer<a name="line.989"></a>
+<span class="sourceLineNo">990</span>    this.balancer.setMasterServices(this);<a name="line.990"></a>
+<span class="sourceLineNo">991</span>    this.balancer.initialize();<a name="line.991"></a>
+<span class="sourceLineNo">992</span>    this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.992"></a>
+<span class="sourceLineNo">993</span><a name="line.993"></a>
+<span class="sourceLineNo">994</span>    // start up all service threads.<a name="line.994"></a>
+<span class="sourceLineNo">995</span>    status.setStatus("Initializing master service threads");<a name="line.995"></a>
+<span class="sourceLineNo">996</span>    startServiceThreads();<a name="line.996"></a>
+<span class="sourceLineNo">997</span>    // wait meta to be initialized after we start procedure executor<a name="line.997"></a>
+<span class="sourceLineNo">998</span>    if (initMetaProc != null) {<a name="line.998"></a>
+<span class="sourceLineNo">999</span>      initMetaProc.await();<a name="line.999"></a>
+<span class="sourceLineNo">1000</span>    }<a name="line.1000"></a>
+<span class="sourceLineNo">1001</span>    // Wake up this server to check in<a name="line.1001"></a>
+<span class="sourceLineNo">1002</span>    sleeper.skipSleepCycle();<a name="line.1002"></a>
+<span class="sourceLineNo">1003</span><a name="line.1003"></a>
+<span class="sourceLineNo">1004</span>    // Wait for region servers to report in.<a name="line.1004"></a>
+<span class="sourceLineNo">1005</span>    // With this as part of master initialization, it precludes our being able to start a single<a name="line.1005"></a>
+<span class="sourceLineNo">1006</span>    // server that is both Master and RegionServer. Needs more thought. TODO.<a name="line.1006"></a>
+<span class="sourceLineNo">1007</span>    String statusStr = "Wait for region servers to report in";<a name="line.1007"></a>
+<span class="sourceLineNo">1008</span>    status.setStatus(statusStr);<a name="line.1008"></a>
+<span class="sourceLineNo">1009</span>    LOG.info(Objects.toString(status));<a name="line.1009"></a>
+<span class="sourceLineNo">1010</span>    waitForRegionServers(status);<a name="line.1010"></a>
+<span class="sourceLineNo">1011</span><a name="line.1011"></a>
+<span class="sourceLineNo">1012</span>    // Check if master is shutting down because issue initializing regionservers or balancer.<a name="line.1012"></a>
+<span class="sourceLineNo">1013</span>    if (isStopped()) {<a name="line.1013"></a>
+<span class="sourceLineNo">1014</span>      return;<a name="line.1014"></a>
+<span class="sourceLineNo">1015</span>    }<a name="line.1015"></a>
+<span class="sourceLineNo">1016</span><a name="line.1016"></a>
+<span class="sourceLineNo">1017</span>    status.setStatus("Starting assignment manager");<a name="line.1017"></a>
+<span class="sourceLineNo">1018</span>    // FIRST HBASE:META READ!!!!<a name="line.1018"></a>
+<span class="sourceLineNo">1019</span>    // The below cannot make progress w/o hbase:meta being online.<a name="line.1019"></a>
+<span class="sourceLineNo">1020</span>    // This is the FIRST attempt at going to hbase:meta. Meta on-lining is going on in background<a name="line.1020"></a>
+<span class="sourceLineNo">1021</span>    // as procedures run -- in particular SCPs for crashed servers... One should put up hbase:meta<a name="line.1021"></a>
+<span class="sourceLineNo">1022</span>    // if it is down. It may take a while to come online. So, wait here until meta if for sure<a name="line.1022"></a>
+<span class="sourceLineNo">1023</span>    // available. That's what waitForMetaOnline does.<a name="line.1023"></a>
+<span class="sourceLineNo">1024</span>    if (!waitForMetaOnline()) {<a name="line.1024"></a>
+<span class="sourceLineNo">1025</span>      return;<a name="line.1025"></a>
+<span class="sourceLineNo">1026</span>    }<a name="line.1026"></a>
+<span class="sourceLineNo">1027</span><a name="line.1027"></a>
+<span class="sourceLineNo">1028</span>    TableDescriptor metaDescriptor =<a name="line.1028"></a>
+<span class="sourceLineNo">1029</span>      tableDescriptors.get(TableName.META_TABLE_NAME);<a name="line.1029"></a>
+<span class="sourceLineNo">1030</span>    final ColumnFamilyDescriptor tableFamilyDesc =<a name="line.1030"></a>
+<span class="sourceLineNo">1031</span>      metaDescriptor.getColumnFamily(HConstants.TABLE_FAMILY);<a name="line.1031"></a>
+<span class="sourceLineNo">1032</span>    final ColumnFamilyDescriptor replBarrierFamilyDesc =<a name="line.1032"></a>
+<span class="sourceLineNo">1033</span>      metaDescriptor.getColumnFamily(HConstants.REPLICATION_BARRIER_FAMILY);<a name="line.1033"></a>
+<span class="sourceLineNo">1034</span><a name="line.1034"></a>
+<span class="sourceLineNo">1035</span>    this.assignmentManager.joinCluster();<a name="line.1035"></a>
+<span class="sourceLineNo">1036</span>    // The below depends on hbase:meta being online.<a name="line.1036"></a>
+<span class="sourceLineNo">1037</span>    this.assignmentManager.processOfflineRegions();<a name="line.1037"></a>
+<span class="sourceLineNo">1038</span>    // this must be called after the above processOfflineRegions to prevent race<a name="line.1038"></a>
+<span class="sourceLineNo">1039</span>    this.assignmentManager.wakeMetaLoadedEvent();<a name="line.1039"></a>
+<span class="sourceLineNo">1040</span><a name="line.1040"></a>
+<span class="sourceLineNo">1041</span>    // for migrating from a version without HBASE-25099, and also for honoring the configuration<a name="line.1041"></a>
+<span class="sourceLineNo">1042</span>    // first.<a name="line.1042"></a>
+<span class="sourceLineNo">1043</span>    if (conf.get(HConstants.META_REPLICAS_NUM) != null) {<a name="line.1043"></a>
+<span class="sourceLineNo">1044</span>      int replicasNumInConf =<a name="line.1044"></a>
+<span class="sourceLineNo">1045</span>        conf.getInt(HConstants.META_REPLICAS_NUM, HConstants.DEFAULT_META_REPLICA_NUM);<a name="line.1045"></a>
+<span class="sourceLineNo">1046</span>      TableDescriptor metaDesc = tableDescriptors.get(TableName.META_TABLE_NAME);<a name="line.1046"></a>
+<span class="sourceLineNo">1047</span>      if (metaDesc.getRegionReplication() != replicasNumInConf) {<a name="line.1047"></a>
+<span class="sourceLineNo">1048</span>        // it is possible that we already have some replicas before upgrading, so we must set the<a name="line.1048"></a>
+<span class="sourceLineNo">1049</span>        // region replication number in meta TableDescriptor directly first, without creating a<a name="line.1049"></a>
+<span class="sourceLineNo">1050</span>        // ModifyTableProcedure, otherwise it may cause a double assign for the meta replicas.<a name="line.1050"></a>
+<span class="sourceLineNo">1051</span>        int existingReplicasCount =<a name="line.1051"></a>
+<span class="sourceLineNo">1052</span>          assignmentManager.getRegionStates().getRegionsOfTable(TableName.META_TABLE_NAME).size();<a name="line.1052"></a>
+<span class="sourceLineNo">1053</span>        if (existingReplicasCount &gt; metaDesc.getRegionReplication()) {<a name="line.1053"></a>
+<span class="sourceLineNo">1054</span>          LOG.info("Update replica count of hbase:meta from {}(in TableDescriptor)" +<a name="line.1054"></a>
+<span class="sourceLineNo">1055</span>            " to {}(existing ZNodes)", metaDesc.getRegionReplication(), existingReplicasCount);<a name="line.1055"></a>
+<span class="sourceLineNo">1056</span>          metaDesc = TableDescriptorBuilder.newBuilder(metaDesc)<a name="line.1056"></a>
+<span class="sourceLineNo">1057</span>            .setRegionReplication(existingReplicasCount).build();<a name="line.1057"></a>
+<span class="sourceLineNo">1058</span>          tableDescriptors.update(metaDesc);<a name="line.1058"></a>
+<span class="sourceLineNo">1059</span>        }<a name="line.1059"></a>
+<span class="sourceLineNo">1060</span>        // check again, and issue a ModifyTableProcedure if needed<a name="line.1060"></a>
+<span class="sourceLineNo">1061</span>        if (metaDesc.getRegionReplication() != replicasNumInConf) {<a name="line.1061"></a>
+<span class="sourceLineNo">1062</span>          LOG.info(<a name="line.1062"></a>
+<span class="sourceLineNo">1063</span>            "The {} config is {} while the replica count in TableDescriptor is {}" +<a name="line.1063"></a>
+<span class="sourceLineNo">1064</span>              " for hbase:meta, altering...",<a name="line.1064"></a>
+<span class="sourceLineNo">1065</span>            HConstants.META_REPLICAS_NUM, replicasNumInConf, metaDesc.getRegionReplication());<a name="line.1065"></a>
+<span class="sourceLineNo">1066</span>          procedureExecutor.submitProcedure(new ModifyTableProcedure(<a name="line.1066"></a>
+<span class="sourceLineNo">1067</span>            procedureExecutor.getEnvironment(), TableDescriptorBuilder.newBuilder(metaDesc)<a name="line.1067"></a>
+<span class="sourceLineNo">1068</span>              .setRegionReplication(replicasNumInConf).build(),<a name="line.1068"></a>
+<span class="sourceLineNo">1069</span>            null, metaDesc, false));<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>    // Initialize after meta is up as below scans meta<a name="line.1073"></a>
+<span class="sourceLineNo">1074</span>    FavoredNodesManager fnm = getFavoredNodesManager();<a name="line.1074"></a>
+<span class="sourceLineNo">1075</span>    if (fnm != null) {<a name="line.1075"></a>
+<span class="sourceLineNo">1076</span>      fnm.initializeFromMeta();<a name="line.1076"></a>
+<span class="sourceLineNo">1077</span>    }<a name="line.1077"></a>
 <span class="sourceLineNo">1078</span><a name="line.1078"></a>
-<span class="sourceLineNo">1079</span>    // Start balancer and meta catalog janitor after meta and regions have been assigned.<a name="line.1079"></a>
-<span class="sourceLineNo">1080</span>    status.setStatus("Starting balancer and catalog janitor");<a name="line.1080"></a>
-<span class="sourceLineNo">1081</span>    this.clusterStatusChore = new ClusterStatusChore(this, balancer);<a name="line.1081"></a>
-<span class="sourceLineNo">1082</span>    getChoreService().scheduleChore(clusterStatusChore);<a name="line.1082"></a>
-<span class="sourceLineNo">1083</span>    this.balancerChore = new BalancerChore(this);<a name="line.1083"></a>
-<span class="sourceLineNo">1084</span>    getChoreService().scheduleChore(balancerChore);<a name="line.1084"></a>
-<span class="sourceLineNo">1085</span>    if (regionNormalizerManager != null) {<a name="line.1085"></a>
-<span class="sourceLineNo">1086</span>      getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1086"></a>
-<span class="sourceLineNo">1087</span>    }<a name="line.1087"></a>
-<span class="sourceLineNo">1088</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1088"></a>
-<span class="sourceLineNo">1089</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1089"></a>
-<span class="sourceLineNo">1090</span>    this.hbckChore = new HbckChore(this);<a name="line.1090"></a>
-<span class="sourceLineNo">1091</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1091"></a>
-<span class="sourceLineNo">1092</span>    this.serverManager.startChore();<a name="line.1092"></a>
-<span class="sourceLineNo">1093</span><a name="line.1093"></a>
-<span class="sourceLineNo">1094</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1094"></a>
-<span class="sourceLineNo">1095</span>    if (!waitForNamespaceOnline()) {<a name="line.1095"></a>
-<span class="sourceLineNo">1096</span>      return;<a name="line.1096"></a>
-<span class="sourceLineNo">1097</span>    }<a name="line.1097"></a>
-<span class="sourceLineNo">1098</span>    status.setStatus("Starting cluster schema service");<a name="line.1098"></a>
-<span class="sourceLineNo">1099</span>    try {<a name="line.1099"></a>
-<span class="sourceLineNo">1100</span>      initClusterSchemaService();<a name="line.1100"></a>
-<span class="sourceLineNo">1101</span>    } catch (IllegalStateException e) {<a name="line.1101"></a>
-<span class="sourceLineNo">1102</span>      if (e.getCause() != null &amp;&amp; e.getCause() instanceof NoSuchColumnFamilyException<a name="line.1102"></a>
-<span class="sourceLineNo">1103</span>          &amp;&amp; tableFamilyDesc == null &amp;&amp; replBarrierFamilyDesc == null) {<a name="line.1103"></a>
-<span class="sourceLineNo">1104</span>        LOG.info("ClusterSchema service could not be initialized. This is "<a name="line.1104"></a>
-<span class="sourceLineNo">1105</span>            + "expected during HBase 1 to 2 upgrade", e);<a name="line.1105"></a>
-<span class="sourceLineNo">1106</span>      } else {<a name="line.1106"></a>
-<span class="sourceLineNo">1107</span>        throw e;<a name="line.1107"></a>
-<span class="sourceLineNo">1108</span>      }<a name="line.1108"></a>
-<span class="sourceLineNo">1109</span>    }<a name="line.1109"></a>
-<span class="sourceLineNo">1110</span><a name="line.1110"></a>
-<span class="sourceLineNo">1111</span>    if (this.cpHost != null) {<a name="line.1111"></a>
-<span class="sourceLineNo">1112</span>      try {<a name="line.1112"></a>
-<span class="sourceLineNo">1113</span>        this.cpHost.preMasterInitialization();<a name="line.1113"></a>
-<span class="sourceLineNo">1114</span>      } catch (IOException e) {<a name="line.1114"></a>
-<span class="sourceLineNo">1115</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<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><a name="line.1118"></a>
-<span class="sourceLineNo">1119</span>    status.markComplete("Initialization successful");<a name="line.1119"></a>
-<span class="sourceLineNo">1120</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1120"></a>
-<span class="sourceLineNo">1121</span>       (EnvironmentEdgeManager.currentTime() - masterActiveTime) / 1000.0f));<a name="line.1121"></a>
-<span class="sourceLineNo">1122</span>    this.masterFinishedInitializationTime = EnvironmentEdgeManager.currentTime();<a name="line.1122"></a>
-<span class="sourceLineNo">1123</span>    configurationManager.registerObserver(this.balancer);<a name="line.1123"></a>
-<span class="sourceLineNo">1124</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1124"></a>
-<span class="sourceLineNo">1125</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1125"></a>
-<span class="sourceLineNo">1126</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1126"></a>
-<span class="sourceLineNo">1127</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1127"></a>
-<span class="sourceLineNo">1128</span>    // Set master as 'initialized'.<a name="line.1128"></a>
-<span class="sourceLineNo">1129</span>    setInitialized(true);<a name="line.1129"></a>
-<span class="sourceLineNo">1130</span><a name="line.1130"></a>
-<span class="sourceLineNo">1131</span>    if (tableFamilyDesc == null &amp;&amp; replBarrierFamilyDesc == null) {<a name="line.1131"></a>
-<span class="sourceLineNo">1132</span>      // create missing CFs in meta table after master is set to 'initialized'.<a name="line.1132"></a>
-<span class="sourceLineNo">1133</span>      createMissingCFsInMetaDuringUpgrade(metaDescriptor);<a name="line.1133"></a>
-<span class="sourceLineNo">1134</span><a name="line.1134"></a>
-<span class="sourceLineNo">1135</span>      // Throwing this Exception to abort active master is painful but this<a name="line.1135"></a>
-<span class="sourceLineNo">1136</span>      // seems the only way to add missing CFs in meta while upgrading from<a name="line.1136"></a>
-<span class="sourceLineNo">1137</span>      // HBase 1 to 2 (where HBase 2 has HBASE-23055 &amp; HBASE-23782 checked-in).<a name="line.1137"></a>
-<span class="sourceLineNo">1138</span>      // So, why do we abort active master after adding missing CFs in meta?<a name="line.1138"></a>
-<span class="sourceLineNo">1139</span>      // When we reach here, we would have already bypassed NoSuchColumnFamilyException<a name="line.1139"></a>
-<span class="sourceLineNo">1140</span>      // in initClusterSchemaService(), meaning ClusterSchemaService is not<a name="line.1140"></a>
-<span class="sourceLineNo">1141</span>      // correctly initialized but we bypassed it. Similarly, we bypassed<a name="line.1141"></a>
-<span class="sourceLineNo">1142</span>      // tableStateManager.start() as well. Hence, we should better abort<a name="line.1142"></a>
-<span class="sourceLineNo">1143</span>      // current active master because our main task - adding missing CFs<a name="line.1143"></a>
-<span class="sourceLineNo">1144</span>      // in meta table is done (possible only after master state is set as<a name="line.1144"></a>
-<span class="sourceLineNo">1145</span>      // initialized) at the expense of bypassing few important tasks as part<a name="line.1145"></a>
-<span class="sourceLineNo">1146</span>      // of active master init routine. So now we abort active master so that<a name="line.1146"></a>
-<span class="sourceLineNo">1147</span>      // next active master init will not face any issues and all mandatory<a name="line.1147"></a>
-<span class="sourceLineNo">1148</span>      // services will be started during master init phase.<a name="line.1148"></a>
-<span class="sourceLineNo">1149</span>      throw new PleaseRestartMasterException("Aborting active master after missing"<a name="line.1149"></a>
-<span class="sourceLineNo">1150</span>          + " CFs are successfully added in meta. Subsequent active master "<a name="line.1150"></a>
-<span class="sourceLineNo">1151</span>          + "initialization should be uninterrupted");<a name="line.1151"></a>
-<span class="sourceLineNo">1152</span>    }<a name="line.1152"></a>
-<span class="sourceLineNo">1153</span><a name="line.1153"></a>
-<span class="sourceLineNo">1154</span>    if (maintenanceMode) {<a name="line.1154"></a>
-<span class="sourceLineNo">1155</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1155"></a>
-<span class="sourceLineNo">1156</span>      return;<a name="line.1156"></a>
-<span class="sourceLineNo">1157</span>    }<a name="line.1157"></a>
-<span class="sourceLineNo">1158</span><a name="line.1158"></a>
-<span class="sourceLineNo">1159</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1159"></a>
-<span class="sourceLineNo">1160</span>    status.setStatus("Starting quota manager");<a name="line.1160"></a>
-<span class="sourceLineNo">1161</span>    initQuotaManager();<a name="line.1161"></a>
-<span class="sourceLineNo">1162</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1162"></a>
-<span class="sourceLineNo">1163</span>      // Create the quota snapshot notifier<a name="line.1163"></a>
-<span class="sourceLineNo">1164</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1164"></a>
-<span class="sourceLineNo">1165</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1165"></a>
-<span class="sourceLineNo">1166</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1166"></a>
-<span class="sourceLineNo">1167</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1167"></a>
-<span class="sourceLineNo">1168</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1168"></a>
-<span class="sourceLineNo">1169</span><a name="line.1169"></a>
-<span class="sourceLineNo">1170</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1170"></a>
-<span class="sourceLineNo">1171</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1171"></a>
-<span class="sourceLineNo">1172</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1172"></a>
-<span class="sourceLineNo">1173</span>    }<a name="line.1173"></a>
-<span class="sourceLineNo">1174</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1174"></a>
-<span class="sourceLineNo">1175</span>    slowLogMasterService.init();<a name="line.1175"></a>
-<span class="sourceLineNo">1176</span><a name="line.1176"></a>
-<span class="sourceLineNo">1177</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1177"></a>
-<span class="sourceLineNo">1178</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1178"></a>
-<span class="sourceLineNo">1179</span>    // master initialization. See HBASE-5916.<a name="line.1179"></a>
-<span class="sourceLineNo">1180</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1180"></a>
-<span class="sourceLineNo">1181</span><a name="line.1181"></a>
-<span class="sourceLineNo">1182</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1182"></a>
-<span class="sourceLineNo">1183</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1183"></a>
-<span class="sourceLineNo">1184</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1184"></a>
-<span class="sourceLineNo">1185</span><a name="line.1185"></a>
-<span class="sourceLineNo">1186</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1186"></a>
-<span class="sourceLineNo">1187</span>    initMobCleaner();<a name="line.1187"></a>
+<span class="sourceLineNo">1079</span>    // set cluster status again after user regions are assigned<a name="line.1079"></a>
+<span class="sourceLineNo">1080</span>    this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1080"></a>
+<span class="sourceLineNo">1081</span><a name="line.1081"></a>
+<span class="sourceLineNo">1082</span>    // Start balancer and meta catalog janitor after meta and regions have been assigned.<a name="line.1082"></a>
+<span class="sourceLineNo">1083</span>    status.setStatus("Starting balancer and catalog janitor");<a name="line.1083"></a>
+<span class="sourceLineNo">1084</span>    this.clusterStatusChore = new ClusterStatusChore(this, balancer);<a name="line.1084"></a>
+<span class="sourceLineNo">1085</span>    getChoreService().scheduleChore(clusterStatusChore);<a name="line.1085"></a>
+<span class="sourceLineNo">1086</span>    this.balancerChore = new BalancerChore(this);<a name="line.1086"></a>
+<span class="sourceLineNo">1087</span>    getChoreService().scheduleChore(balancerChore);<a name="line.1087"></a>
+<span class="sourceLineNo">1088</span>    if (regionNormalizerManager != null) {<a name="line.1088"></a>
+<span class="sourceLineNo">1089</span>      getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1089"></a>
+<span class="sourceLineNo">1090</span>    }<a name="line.1090"></a>
+<span class="sourceLineNo">1091</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1091"></a>
+<span class="sourceLineNo">1092</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1092"></a>
+<span class="sourceLineNo">1093</span>    this.hbckChore = new HbckChore(this);<a name="line.1093"></a>
+<span class="sourceLineNo">1094</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1094"></a>
+<span class="sourceLineNo">1095</span>    this.serverManager.startChore();<a name="line.1095"></a>
+<span class="sourceLineNo">1096</span><a name="line.1096"></a>
+<span class="sourceLineNo">1097</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1097"></a>
+<span class="sourceLineNo">1098</span>    if (!waitForNamespaceOnline()) {<a name="line.1098"></a>
+<span class="sourceLineNo">1099</span>      return;<a name="line.1099"></a>
+<span class="sourceLineNo">1100</span>    }<a name="line.1100"></a>
+<span class="sourceLineNo">1101</span>    status.setStatus("Starting cluster schema service");<a name="line.1101"></a>
+<span class="sourceLineNo">1102</span>    try {<a name="line.1102"></a>
+<span class="sourceLineNo">1103</span>      initClusterSchemaService();<a name="line.1103"></a>
+<span class="sourceLineNo">1104</span>    } catch (IllegalStateException e) {<a name="line.1104"></a>
+<span class="sourceLineNo">1105</span>      if (e.getCause() != null &amp;&amp; e.getCause() instanceof NoSuchColumnFamilyException<a name="line.1105"></a>
+<span class="sourceLineNo">1106</span>          &amp;&amp; tableFamilyDesc == null &amp;&amp; replBarrierFamilyDesc == null) {<a name="line.1106"></a>
+<span class="sourceLineNo">1107</span>        LOG.info("ClusterSchema service could not be initialized. This is "<a name="line.1107"></a>
+<span class="sourceLineNo">1108</span>            + "expected during HBase 1 to 2 upgrade", e);<a name="line.1108"></a>
+<span class="sourceLineNo">1109</span>      } else {<a name="line.1109"></a>
+<span class="sourceLineNo">1110</span>        throw e;<a name="line.1110"></a>
+<span class="sourceLineNo">1111</span>      }<a name="line.1111"></a>
+<span class="sourceLineNo">1112</span>    }<a name="line.1112"></a>
+<span class="sourceLineNo">1113</span><a name="line.1113"></a>
+<span class="sourceLineNo">1114</span>    if (this.cpHost != null) {<a name="line.1114"></a>
+<span class="sourceLineNo">1115</span>      try {<a name="line.1115"></a>
+<span class="sourceLineNo">1116</span>        this.cpHost.preMasterInitialization();<a name="line.1116"></a>
+<span class="sourceLineNo">1117</span>      } catch (IOException e) {<a name="line.1117"></a>
+<span class="sourceLineNo">1118</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<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>    status.markComplete("Initialization successful");<a name="line.1122"></a>
+<span class="sourceLineNo">1123</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1123"></a>
+<span class="sourceLineNo">1124</span>       (EnvironmentEdgeManager.currentTime() - masterActiveTime) / 1000.0f));<a name="line.1124"></a>
+<span class="sourceLineNo">1125</span>    this.masterFinishedInitializationTime = EnvironmentEdgeManager.currentTime();<a name="line.1125"></a>
+<span class="sourceLineNo">1126</span>    configurationManager.registerObserver(this.balancer);<a name="line.1126"></a>
+<span class="sourceLineNo">1127</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1127"></a>
+<span class="sourceLineNo">1128</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1128"></a>
+<span class="sourceLineNo">1129</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1129"></a>
+<span class="sourceLineNo">1130</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1130"></a>
+<span class="sourceLineNo">1131</span>    // Set master as 'initialized'.<a name="line.1131"></a>
+<span class="sourceLineNo">1132</span>    setInitialized(true);<a name="line.1132"></a>
+<span class="sourceLineNo">1133</span><a name="line.1133"></a>
+<span class="sourceLineNo">1134</span>    if (tableFamilyDesc == null &amp;&amp; replBarrierFamilyDesc == null) {<a name="line.1134"></a>
+<span class="sourceLineNo">1135</span>      // create missing CFs in meta table after master is set to 'initialized'.<a name="line.1135"></a>
+<span class="sourceLineNo">1136</span>      createMissingCFsInMetaDuringUpgrade(metaDescriptor);<a name="line.1136"></a>
+<span class="sourceLineNo">1137</span><a name="line.1137"></a>
+<span class="sourceLineNo">1138</span>      // Throwing this Exception to abort active master is painful but this<a name="line.1138"></a>
+<span class="sourceLineNo">1139</span>      // seems the only way to add missing CFs in meta while upgrading from<a name="line.1139"></a>
+<span class="sourceLineNo">1140</span>      // HBase 1 to 2 (where HBase 2 has HBASE-23055 &amp; HBASE-23782 checked-in).<a name="line.1140"></a>
+<span class="sourceLineNo">1141</span>      // So, why do we abort active master after adding missing CFs in meta?<a name="line.1141"></a>
+<span class="sourceLineNo">1142</span>      // When we reach here, we would have already bypassed NoSuchColumnFamilyException<a name="line.1142"></a>
+<span class="sourceLineNo">1143</span>      // in initClusterSchemaService(), meaning ClusterSchemaService is not<a name="line.1143"></a>
+<span class="sourceLineNo">1144</span>      // correctly initialized but we bypassed it. Similarly, we bypassed<a name="line.1144"></a>
+<span class="sourceLineNo">1145</span>      // tableStateManager.start() as well. Hence, we should better abort<a name="line.1145"></a>
+<span class="sourceLineNo">1146</span>      // current active master because our main task - adding missing CFs<a name="line.1146"></a>
+<span class="sourceLineNo">1147</span>      // in meta table is done (possible only after master state is set as<a name="line.1147"></a>
+<span class="sourceLineNo">1148</span>      // initialized) at the expense of bypassing few important tasks as part<a name="line.1148"></a>
+<span class="sourceLineNo">1149</span>      // of active master init routine. So now we abort active master so that<a name="line.1149"></a>
+<span class="sourceLineNo">1150</span>      // next active master init will not face any issues and all mandatory<a name="line.1150"></a>
+<span class="sourceLineNo">1151</span>      // services will be started during master init phase.<a name="line.1151"></a>
+<span class="sourceLineNo">1152</span>      throw new PleaseRestartMasterException("Aborting active master after missing"<a name="line.1152"></a>
+<span class="sourceLineNo">1153</span>          + " CFs are successfully added in meta. Subsequent active master "<a name="line.1153"></a>
+<span class="sourceLineNo">1154</span>          + "initialization should be uninterrupted");<a name="line.1154"></a>
+<span class="sourceLineNo">1155</span>    }<a name="line.1155"></a>
+<span class="sourceLineNo">1156</span><a name="line.1156"></a>
+<span class="sourceLineNo">1157</span>    if (maintenanceMode) {<a name="line.1157"></a>
+<span class="sourceLineNo">1158</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1158"></a>
+<span class="sourceLineNo">1159</span>      return;<a name="line.1159"></a>
+<span class="sourceLineNo">1160</span>    }<a name="line.1160"></a>
+<span class="sourceLineNo">1161</span><a name="line.1161"></a>
+<span class="sourceLineNo">1162</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1162"></a>
+<span class="sourceLineNo">1163</span>    status.setStatus("Starting quota manager");<a name="line.1163"></a>
+<span class="sourceLineNo">1164</span>    initQuotaManager();<a name="line.1164"></a>
+<span class="sourceLineNo">1165</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1165"></a>
+<span class="sourceLineNo">1166</span>      // Create the quota snapshot notifier<a name="line.1166"></a>
+<span class="sourceLineNo">1167</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1167"></a>
+<span class="sourceLineNo">1168</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1168"></a>
+<span class="sourceLineNo">1169</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1169"></a>
+<span class="sourceLineNo">1170</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1170"></a>
+<span class="sourceLineNo">1171</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1171"></a>
+<span class="sourceLineNo">1172</span><a name="line.1172"></a>
+<span class="sourceLineNo">1173</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1173"></a>
+<span class="sourceLineNo">1174</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1174"></a>
+<span class="sourceLineNo">1175</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1175"></a>
+<span class="sourceLineNo">1176</span>    }<a name="line.1176"></a>
+<span class="sourceLineNo">1177</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1177"></a>
+<span class="sourceLineNo">1178</span>    slowLogMasterService.init();<a name="line.1178"></a>
+<span class="sourceLineNo">1179</span><a name="line.1179"></a>
+<span class="sourceLineNo">1180</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1180"></a>
+<span class="sourceLineNo">1181</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1181"></a>
+<span class="sourceLineNo">1182</span>    // master initialization. See HBASE-5916.<a name="line.1182"></a>
+<span class="sourceLineNo">1183</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1183"></a>
+<span class="sourceLineNo">1184</span><a name="line.1184"></a>
+<span class="sourceLineNo">1185</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1185"></a>
+<span class="sourceLineNo">1186</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1186"></a>
+<span class="sourceLineNo">1187</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1187"></a>
 <span class="sourceLineNo">1188</span><a name="line.1188"></a>
-<span class="sourceLineNo">1189</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1189"></a>
-<span class="sourceLineNo">1190</span>    if (this.cpHost != null) {<a name="line.1190"></a>
-<span class="sourceLineNo">1191</span>      // don't let cp initialization errors kill the master<a name="line.1191"></a>
-<span class="sourceLineNo">1192</span>      try {<a name="line.1192"></a>
-<span class="sourceLineNo">1193</span>        this.cpHost.postStartMaster();<a name="line.1193"></a>
-<span class="sourceLineNo">1194</span>      } catch (IOException ioe) {<a name="line.1194"></a>
-<span class="sourceLineNo">1195</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1195"></a>
-<span class="sourceLineNo">1196</span>      }<a name="line.1196"></a>
-<span class="sourceLineNo">1197</span>    }<a name="line.1197"></a>
-<span class="sourceLineNo">1198</span><a name="line.1198"></a>
-<span class="sourceLineNo">1199</span>    zombieDetector.interrupt();<a name="line.1199"></a>
-<span class="sourceLineNo">1200</span><a name="line.1200"></a>
-<span class="sourceLineNo">1201</span>    /*<a name="line.1201"></a>
-<span class="sourceLineNo">1202</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1202"></a>
-<span class="sourceLineNo">1203</span>     * in activeMasterManager thread, it should be fine.<a name="line.1203"></a>
-<span class="sourceLineNo">1204</span>     */<a name="line.1204"></a>
-<span class="sourceLineNo">1205</span>    long start = EnvironmentEdgeManager.currentTime();<a name="line.1205"></a>
-<span class="sourceLineNo">1206</span>    this.balancer.postMasterStartupInitialize();<a name="line.1206"></a>
-<span class="sourceLineNo">1207</span>    if (LOG.isDebugEnabled()) {<a name="line.1207"></a>
-<span class="sourceLineNo">1208</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1208"></a>
-<span class="sourceLineNo">1209</span>          (EnvironmentEdgeManager.currentTime() - start) / 1000) + " seconds");<a name="line.1209"></a>
-<span class="sourceLineNo">1210</span>    }<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>  private void createMissingCFsInMetaDuringUpgrade(<a name="line.1213"></a>
-<span class="sourceLineNo">1214</span>      TableDescriptor metaDescriptor) throws IOException {<a name="line.1214"></a>
-<span class="sourceLineNo">1215</span>    TableDescriptor newMetaDesc =<a name="line.1215"></a>
-<span class="sourceLineNo">1216</span>        TableDescriptorBuilder.newBuilder(metaDescriptor)<a name="line.1216"></a>
-<span class="sourceLineNo">1217</span>            .setColumnFamily(FSTableDescriptors.getTableFamilyDescForMeta(conf))<a name="line.1217"></a>
-<span class="sourceLineNo">1218</span>            .setColumnFamily(FSTableDescriptors.getReplBarrierFamilyDescForMeta())<a name="line.1218"></a>
-<span class="sourceLineNo">1219</span>            .build();<a name="line.1219"></a>
-<span class="sourceLineNo">1220</span>    long pid = this.modifyTable(TableName.META_TABLE_NAME, () -&gt; newMetaDesc,<a name="line.1220"></a>
-<span class="sourceLineNo">1221</span>        0, 0, false);<a name="line.1221"></a>
-<span class="sourceLineNo">1222</span>    int tries = 30;<a name="line.1222"></a>
-<span class="sourceLineNo">1223</span>    while (!(getMasterProcedureExecutor().isFinished(pid))<a name="line.1223"></a>
-<span class="sourceLineNo">1224</span>        &amp;&amp; getMasterProcedureExecutor().isRunning() &amp;&amp; tries &gt; 0) {<a name="line.1224"></a>
-<span class="sourceLineNo">1225</span>      try {<a name="line.1225"></a>
-<span class="sourceLineNo">1226</span>        Thread.sleep(1000);<a name="line.1226"></a>
-<span class="sourceLineNo">1227</span>      } catch (InterruptedException e) {<a name="line.1227"></a>
-<span class="sourceLineNo">1228</span>        throw new IOException("Wait interrupted", e);<a name="line.1228"></a>
-<span class="sourceLineNo">1229</span>      }<a name="line.1229"></a>
-<span class="sourceLineNo">1230</span>      tries--;<a name="line.1230"></a>
-<span class="sourceLineNo">1231</span>    }<a name="line.1231"></a>
-<span class="sourceLineNo">1232</span>    if (tries &lt;= 0) {<a name="line.1232"></a>
-<span class="sourceLineNo">1233</span>      throw new HBaseIOException(<a name="line.1233"></a>
-<span class="sourceLineNo">1234</span>          "Failed to add table and rep_barrier CFs to meta in a given time.");<a name="line.1234"></a>
-<span class="sourceLineNo">1235</span>    } else {<a name="line.1235"></a>
-<span class="sourceLineNo">1236</span>      Procedure&lt;?&gt; result = getMasterProcedureExecutor().getResult(pid);<a name="line.1236"></a>
-<span class="sourceLineNo">1237</span>      if (result != null &amp;&amp; result.isFailed()) {<a name="line.1237"></a>
-<span class="sourceLineNo">1238</span>        throw new IOException(<a name="line.1238"></a>
-<span class="sourceLineNo">1239</span>            "Failed to add table and rep_barrier CFs to meta. "<a name="line.1239"></a>
-<span class="sourceLineNo">1240</span>                + MasterProcedureUtil.unwrapRemoteIOException(result));<a name="line.1240"></a>
-<span class="sourceLineNo">1241</span>      }<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>  /**<a name="line.1245"></a>
-<span class="sourceLineNo">1246</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1246"></a>
-<span class="sourceLineNo">1247</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1247"></a>
-<span class="sourceLineNo">1248</span>   *   and we will hold here until operator intervention.<a name="line.1248"></a>
-<span class="sourceLineNo">1249</span>   */<a name="line.1249"></a>
-<span class="sourceLineNo">1250</span>  @InterfaceAudience.Private<a name="line.1250"></a>
-<span class="sourceLineNo">1251</span>  public boolean waitForMetaOnline() {<a name="line.1251"></a>
-<span class="sourceLineNo">1252</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<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>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1256"></a>
-<span class="sourceLineNo">1257</span>   *   we just block in here holding up all forward-progess).<a name="line.1257"></a>
-<span class="sourceLineNo">1258</span>   */<a name="line.1258"></a>
-<span class="sourceLineNo">1259</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1259"></a>
-<span class="sourceLineNo">1260</span>    RetryCounter rc = null;<a name="line.1260"></a>
-<span class="sourceLineNo">1261</span>    while (!isStopped()) {<a name="line.1261"></a>
-<span class="sourceLineNo">1262</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1262"></a>
-<span class="sourceLineNo">1263</span>      if (rs.isOpened()) {<a name="line.1263"></a>
-<span class="sourceLineNo">1264</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1264"></a>
-<span class="sourceLineNo">1265</span>          return true;<a name="line.1265"></a>
-<span class="sourceLineNo">1266</span>        }<a name="line.1266"></a>
-<span class="sourceLineNo">1267</span>      }<a name="line.1267"></a>
-<span class="sourceLineNo">1268</span>      // Region is not OPEN.<a name="line.1268"></a>
-<span class="sourceLineNo">1269</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1269"></a>
-<span class="sourceLineNo">1270</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1270"></a>
-<span class="sourceLineNo">1271</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1271"></a>
-<span class="sourceLineNo">1272</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1272"></a>
-<span class="sourceLineNo">1273</span>      // then how to assign including how to break region lock if one held.<a name="line.1273"></a>
-<span class="sourceLineNo">1274</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1274"></a>
-<span class="sourceLineNo">1275</span>          "progress, in holding-pattern until region onlined.",<a name="line.1275"></a>
-<span class="sourceLineNo">1276</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1276"></a>
-<span class="sourceLineNo">1277</span>      // Check once-a-minute.<a name="line.1277"></a>
-<span class="sourceLineNo">1278</span>      if (rc == null) {<a name="line.1278"></a>
-<span class="sourceLineNo">1279</span>        rc = new RetryCounterFactory(Integer.MAX_VALUE, 1000, 60_000).create();<a name="line.1279"></a>
-<span class="sourceLineNo">1280</span>      }<a name="line.1280"></a>
-<span class="sourceLineNo">1281</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1281"></a>
-<span class="sourceLineNo">1282</span>    }<a name="line.1282"></a>
-<span class="sourceLineNo">1283</span>    return false;<a name="line.1283"></a>
-<span class="sourceLineNo">1284</span>  }<a name="line.1284"></a>
-<span class="sourceLineNo">1285</span><a name="line.1285"></a>
-<span class="sourceLineNo">1286</span>  /**<a name="line.1286"></a>
-<span class="sourceLineNo">1287</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1287"></a>
-<span class="sourceLineNo">1288</span>   * &lt;p/&gt;<a name="line.1288"></a>
-<span class="sourceLineNo">1289</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1289"></a>
-<span class="sourceLineNo">1290</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1290"></a>
-<span class="sourceLineNo">1291</span>   * no namespace table/region.<a name="line.1291"></a>
-<span class="sourceLineNo">1292</span>   * @return True if namespace table is up/online.<a name="line.1292"></a>
-<span class="sourceLineNo">1293</span>   */<a name="line.1293"></a>
-<span class="sourceLineNo">1294</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1294"></a>
-<span class="sourceLineNo">1295</span>    TableState nsTableState =<a name="line.1295"></a>
-<span class="sourceLineNo">1296</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1296"></a>
-<span class="sourceLineNo">1297</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1297"></a>
-<span class="sourceLineNo">1298</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1298"></a>
-<span class="sourceLineNo">1299</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1299"></a>
-<span class="sourceLineNo">1300</span>      return true;<a name="line.1300"></a>
-<span class="sourceLineNo">1301</span>    }<a name="line.1301"></a>
-<span class="sourceLineNo">1302</span>    List&lt;RegionInfo&gt; ris =<a name="line.1302"></a>
-<span class="sourceLineNo">1303</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1303"></a>
-<span class="sourceLineNo">1304</span>    if (ris.isEmpty()) {<a name="line.1304"></a>
-<span class="sourceLineNo">1305</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1305"></a>
-<span class="sourceLineNo">1306</span>      return true;<a name="line.1306"></a>
-<span class="sourceLineNo">1307</span>    }<a name="line.1307"></a>
-<span class="sourceLineNo">1308</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1308"></a>
-<span class="sourceLineNo">1309</span>    for (RegionInfo ri : ris) {<a name="line.1309"></a>
-<span class="sourceLineNo">1310</span>      if (!isRegionOnline(ri)) {<a name="line.1310"></a>
-<span class="sourceLineNo">1311</span>        return false;<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>    return true;<a name="line.1314"></a>
-<span class="sourceLineNo">1315</span>  }<a name="line.1315"></a>
-<span class="sourceLineNo">1316</span><a name="line.1316"></a>
-<span class="sourceLineNo">1317</span>  /**<a name="line.1317"></a>
-<span class="sourceLineNo">1318</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1318"></a>
-<span class="sourceLineNo">1319</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1319"></a>
-<span class="sourceLineNo">1320</span>   */<a name="line.1320"></a>
-<span class="sourceLineNo">1321</span>  @InterfaceAudience.Private<a name="line.1321"></a>
-<span class="sourceLineNo">1322</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1322"></a>
-<span class="sourceLineNo">1323</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1323"></a>
-<span class="sourceLineNo">1324</span>    if (!conf.getBoolean(<a name="line.1324"></a>
-<span class="sourceLineNo">1325</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1325"></a>
-<span class="sourceLineNo">1326</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1326"></a>
-<span class="sourceLineNo">1327</span>      return;<a name="line.1327"></a>
-<span class="sourceLineNo">1328</span>    }<a name="line.1328"></a>
-<span class="sourceLineNo">1329</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1329"></a>
-<span class="sourceLineNo">1330</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1330"></a>
-<span class="sourceLineNo">1331</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1331"></a>
-<span class="sourceLineNo">1332</span>    if (length &gt; 0) {<a name="line.1332"></a>
-<span class="sourceLineNo">1333</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1333"></a>
-<span class="sourceLineNo">1334</span>    }<a name="line.1334"></a>
-<span class="sourceLineNo">1335</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1335"></a>
-<span class="sourceLineNo">1336</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1336"></a>
-<span class="sourceLineNo">1337</span>  }<a name="line.1337"></a>
-<span class="sourceLineNo">1338</span><a name="line.1338"></a>
-<span class="sourceLineNo">1339</span>  private void initMobCleaner() {<a name="line.1339"></a>
-<span class="sourceLineNo">1340</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1340"></a>
-<span class="sourceLineNo">1341</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1341"></a>
-<span class="sourceLineNo">1342</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1342"></a>
-<span class="sourceLineNo">1343</span>    getChoreService().scheduleChore(mobFileCompactionChore);<a name="line.1343"></a>
-<span class="sourceLineNo">1344</span>  }<a name="line.1344"></a>
-<span class="sourceLineNo">1345</span><a name="line.1345"></a>
-<span class="sourceLineNo">1346</span>  /**<a name="line.1346"></a>
-<span class="sourceLineNo">1347</span>   * &lt;p&gt;<a name="line.1347"></a>
-<span class="sourceLineNo">1348</span>   * Create a {@link ServerManager} instance.<a name="line.1348"></a>
-<span class="sourceLineNo">1349</span>   * &lt;/p&gt;<a name="line.1349"></a>
+<span class="sourceLineNo">1189</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1189"></a>
+<span class="sourceLineNo">1190</span>    initMobCleaner();<a name="line.1190"></a>
+<span class="sourceLineNo">1191</span><a name="line.1191"></a>
+<span class="sourceLineNo">1192</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1192"></a>
+<span class="sourceLineNo">1193</span>    if (this.cpHost != null) {<a name="line.1193"></a>
+<span class="sourceLineNo">1194</span>      // don't let cp initialization errors kill the master<a name="line.1194"></a>
+<span class="sourceLineNo">1195</span>      try {<a name="line.1195"></a>
+<span class="sourceLineNo">1196</span>        this.cpHost.postStartMaster();<a name="line.1196"></a>
+<span class="sourceLineNo">1197</span>      } catch (IOException ioe) {<a name="line.1197"></a>
+<span class="sourceLineNo">1198</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1198"></a>
+<span class="sourceLineNo">1199</span>      }<a name="line.1199"></a>
+<span class="sourceLineNo">1200</span>    }<a name="line.1200"></a>
+<span class="sourceLineNo">1201</span><a name="line.1201"></a>
+<span class="sourceLineNo">1202</span>    zombieDetector.interrupt();<a name="line.1202"></a>
+<span class="sourceLineNo">1203</span><a name="line.1203"></a>
+<span class="sourceLineNo">1204</span>    /*<a name="line.1204"></a>
+<span class="sourceLineNo">1205</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1205"></a>
+<span class="sourceLineNo">1206</span>     * in activeMasterManager thread, it should be fine.<a name="line.1206"></a>
+<span class="sourceLineNo">1207</span>     */<a name="line.1207"></a>
+<span class="sourceLineNo">1208</span>    long start = EnvironmentEdgeManager.currentTime();<a name="line.1208"></a>
+<span class="sourceLineNo">1209</span>    this.balancer.postMasterStartupInitialize();<a name="line.1209"></a>
+<span class="sourceLineNo">1210</span>    if (LOG.isDebugEnabled()) {<a name="line.1210"></a>
+<span class="sourceLineNo">1211</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1211"></a>
+<span class="sourceLineNo">1212</span>          (EnvironmentEdgeManager.currentTime() - start) / 1000) + " seconds");<a name="line.1212"></a>
+<span class="sourceLineNo">1213</span>    }<a name="line.1213"></a>
+<span class="sourceLineNo">1214</span>  }<a name="line.1214"></a>
+<span class="sourceLineNo">1215</span><a name="line.1215"></a>
+<span class="sourceLineNo">1216</span>  private void createMissingCFsInMetaDuringUpgrade(<a name="line.1216"></a>
+<span class="sourceLineNo">1217</span>      TableDescriptor metaDescriptor) throws IOException {<a name="line.1217"></a>
+<span class="sourceLineNo">1218</span>    TableDescriptor newMetaDesc =<a name="line.1218"></a>
+<span class="sourceLineNo">1219</span>        TableDescriptorBuilder.newBuilder(metaDescriptor)<a name="line.1219"></a>
+<span class="sourceLineNo">1220</span>            .setColumnFamily(FSTableDescriptors.getTableFamilyDescForMeta(conf))<a name="line.1220"></a>
+<span class="sourceLineNo">1221</span>            .setColumnFamily(FSTableDescriptors.getReplBarrierFamilyDescForMeta())<a name="line.1221"></a>
+<span class="sourceLineNo">1222</span>            .build();<a name="line.1222"></a>
+<span class="sourceLineNo">1223</span>    long pid = this.modifyTable(TableName.META_TABLE_NAME, () -&gt; newMetaDesc,<a name="line.1223"></a>
+<span class="sourceLineNo">1224</span>        0, 0, false);<a name="line.1224"></a>
+<span class="sourceLineNo">1225</span>    int tries = 30;<a name="line.1225"></a>
+<span class="sourceLineNo">1226</span>    while (!(getMasterProcedureExecutor().isFinished(pid))<a name="line.1226"></a>
+<span class="sourceLineNo">1227</span>        &amp;&amp; getMasterProcedureExecutor().isRunning() &amp;&amp; tries &gt; 0) {<a name="line.1227"></a>
+<span class="sourceLineNo">1228</span>      try {<a name="line.1228"></a>
+<span class="sourceLineNo">1229</span>        Thread.sleep(1000);<a name="line.1229"></a>
+<span class="sourceLineNo">1230</span>      } catch (InterruptedException e) {<a name="line.1230"></a>
+<span class="sourceLineNo">1231</span>        throw new IOException("Wait interrupted", e);<a name="line.1231"></a>
+<span class="sourceLineNo">1232</span>      }<a name="line.1232"></a>
+<span class="sourceLineNo">1233</span>      tries--;<a name="line.1233"></a>
+<span class="sourceLineNo">1234</span>    }<a name="line.1234"></a>
+<span class="sourceLineNo">1235</span>    if (tries &lt;= 0) {<a name="line.1235"></a>
+<span class="sourceLineNo">1236</span>      throw new HBaseIOException(<a name="line.1236"></a>
+<span class="sourceLineNo">1237</span>          "Failed to add table and rep_barrier CFs to meta in a given time.");<a name="line.1237"></a>
+<span class="sourceLineNo">1238</span>    } else {<a name="line.1238"></a>
+<span class="sourceLineNo">1239</span>      Procedure&lt;?&gt; result = getMasterProcedureExecutor().getResult(pid);<a name="line.1239"></a>
+<span class="sourceLineNo">1240</span>      if (result != null &amp;&amp; result.isFailed()) {<a name="line.1240"></a>
+<span class="sourceLineNo">1241</span>        throw new IOException(<a name="line.1241"></a>
+<span class="sourceLineNo">1242</span>            "Failed to add table and rep_barrier CFs to meta. "<a name="line.1242"></a>
+<span class="sourceLineNo">1243</span>                + MasterProcedureUtil.unwrapRemoteIOException(result));<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>  }<a name="line.1246"></a>
+<span class="sourceLineNo">1247</span><a name="line.1247"></a>
+<span class="sourceLineNo">1248</span>  /**<a name="line.1248"></a>
+<span class="sourceLineNo">1249</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1249"></a>
+<span class="sourceLineNo">1250</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1250"></a>
+<span class="sourceLineNo">1251</span>   *   and we will hold here until operator intervention.<a name="line.1251"></a>
+<span class="sourceLineNo">1252</span>   */<a name="line.1252"></a>
+<span class="sourceLineNo">1253</span>  @InterfaceAudience.Private<a name="line.1253"></a>
+<span class="sourceLineNo">1254</span>  public boolean waitForMetaOnline() {<a name="line.1254"></a>
+<span class="sourceLineNo">1255</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<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>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1259"></a>
+<span class="sourceLineNo">1260</span>   *   we just block in here holding up all forward-progess).<a name="line.1260"></a>
+<span class="sourceLineNo">1261</span>   */<a name="line.1261"></a>
+<span class="sourceLineNo">1262</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1262"></a>
+<span class="sourceLineNo">1263</span>    RetryCounter rc = null;<a name="line.1263"></a>
+<span class="sourceLineNo">1264</span>    while (!isStopped()) {<a name="line.1264"></a>
+<span class="sourceLineNo">1265</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1265"></a>
+<span class="sourceLineNo">1266</span>      if (rs.isOpened()) {<a name="line.1266"></a>
+<span class="sourceLineNo">1267</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1267"></a>
+<span class="sourceLineNo">1268</span>          return true;<a name="line.1268"></a>
+<span class="sourceLineNo">1269</span>        }<a name="line.1269"></a>
+<span class="sourceLineNo">1270</span>      }<a name="line.1270"></a>
+<span class="sourceLineNo">1271</span>      // Region is not OPEN.<a name="line.1271"></a>
+<span class="sourceLineNo">1272</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1272"></a>
+<span class="sourceLineNo">1273</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1273"></a>
+<span class="sourceLineNo">1274</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1274"></a>
+<span class="sourceLineNo">1275</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1275"></a>
+<span class="sourceLineNo">1276</span>      // then how to assign including how to break region lock if one held.<a name="line.1276"></a>
+<span class="sourceLineNo">1277</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1277"></a>
+<span class="sourceLineNo">1278</span>          "progress, in holding-pattern until region onlined.",<a name="line.1278"></a>
+<span class="sourceLineNo">1279</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1279"></a>
+<span class="sourceLineNo">1280</span>      // Check once-a-minute.<a name="line.1280"></a>
+<span class="sourceLineNo">1281</span>      if (rc == null) {<a name="line.1281"></a>
+<span class="sourceLineNo">1282</span>        rc = new RetryCounterFactory(Integer.MAX_VALUE, 1000, 60_000).create();<a name="line.1282"></a>
+<span class="sourceLineNo">1283</span>      }<a name="line.1283"></a>
+<span class="sourceLineNo">1284</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1284"></a>
+<span class="sourceLineNo">1285</span>    }<a name="line.1285"></a>
+<span class="sourceLineNo">1286</span>    return false;<a name="line.1286"></a>
+<span class="sourceLineNo">1287</span>  }<a name="line.1287"></a>
+<span class="sourceLineNo">1288</span><a name="line.1288"></a>
+<span class="sourceLineNo">1289</span>  /**<a name="line.1289"></a>
+<span class="sourceLineNo">1290</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1290"></a>
+<span class="sourceLineNo">1291</span>   * &lt;p/&gt;<a name="line.1291"></a>
+<span class="sourceLineNo">1292</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1292"></a>
+<span class="sourceLineNo">1293</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1293"></a>
+<span class="sourceLineNo">1294</span>   * no namespace table/region.<a name="line.1294"></a>
+<span class="sourceLineNo">1295</span>   * @return True if namespace table is up/online.<a name="line.1295"></a>
+<span class="sourceLineNo">1296</span>   */<a name="line.1296"></a>
+<span class="sourceLineNo">1297</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1297"></a>
+<span class="sourceLineNo">1298</span>    TableState nsTableState =<a name="line.1298"></a>
+<span class="sourceLineNo">1299</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1299"></a>
+<span class="sourceLineNo">1300</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1300"></a>
+<span class="sourceLineNo">1301</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1301"></a>
+<span class="sourceLineNo">1302</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1302"></a>
+<span class="sourceLineNo">1303</span>      return true;<a name="line.1303"></a>
+<span class="sourceLineNo">1304</span>    }<a name="line.1304"></a>
+<span class="sourceLineNo">1305</span>    List&lt;RegionInfo&gt; ris =<a name="line.1305"></a>
+<span class="sourceLineNo">1306</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1306"></a>
+<span class="sourceLineNo">1307</span>    if (ris.isEmpty()) {<a name="line.1307"></a>
+<span class="sourceLineNo">1308</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1308"></a>
+<span class="sourceLineNo">1309</span>      return true;<a name="line.1309"></a>
+<span class="sourceLineNo">1310</span>    }<a name="line.1310"></a>
+<span class="sourceLineNo">1311</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1311"></a>
+<span class="sourceLineNo">1312</span>    for (RegionInfo ri : ris) {<a name="line.1312"></a>
+<span class="sourceLineNo">1313</span>      if (!isRegionOnline(ri)) {<a name="line.1313"></a>
+<span class="sourceLineNo">1314</span>        return false;<a name="line.1314"></a>
+<span class="sourceLineNo">1315</span>      }<a name="line.1315"></a>
+<span class="sourceLineNo">1316</span>    }<a name="line.1316"></a>
+<span class="sourceLineNo">1317</span>    return true;<a name="line.1317"></a>
+<span class="sourceLineNo">1318</span>  }<a name="line.1318"></a>
+<span class="sourceLineNo">1319</span><a name="line.1319"></a>
+<span class="sourceLineNo">1320</span>  /**<a name="line.1320"></a>
+<span class="sourceLineNo">1321</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1321"></a>
+<span class="sourceLineNo">1322</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1322"></a>
+<span class="sourceLineNo">1323</span>   */<a name="line.1323"></a>
+<span class="sourceLineNo">1324</span>  @InterfaceAudience.Private<a name="line.1324"></a>
+<span class="sourceLineNo">1325</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1325"></a>
+<span class="sourceLineNo">1326</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1326"></a>
+<span class="sourceLineNo">1327</span>    if (!conf.getBoolean(<a name="line.1327"></a>
+<span class="sourceLineNo">1328</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1328"></a>
+<span class="sourceLineNo">1329</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1329"></a>
+<span class="sourceLineNo">1330</span>      return;<a name="line.1330"></a>
+<span class="sourceLineNo">1331</span>    }<a name="line.1331"></a>
+<span class="sourceLineNo">1332</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1332"></a>
+<span class="sourceLineNo">1333</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1333"></a>
+<span class="sourceLineNo">1334</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1334"></a>
+<span class="sourceLineNo">1335</span>    if (length &gt; 0) {<a name="line.1335"></a>
+<span class="sourceLineNo">1336</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1336"></a>
+<span class="sourceLineNo">1337</span>    }<a name="line.1337"></a>
+<span class="sourceLineNo">1338</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1338"></a>
+<span class="sourceLineNo">1339</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1339"></a>
+<span class="sourceLineNo">1340</span>  }<a name="line.1340"></a>
+<span class="sourceLineNo">1341</span><a name="line.1341"></a>
+<span class="sourceLineNo">1342</span>  private void initMobCleaner() {<a name="line.1342"></a>
+<span class="sourceLineNo">1343</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1343"></a>
+<span class="sourceLineNo">1344</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1344"></a>
+<span class="sourceLineNo">1345</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1345"></a>
+<span class="sourceLineNo">1346</span>    getChoreService().scheduleChore(mobFileCompactionChore);<a name="line.1346"></a>
+<span class="sourceLineNo">1347</span>  }<a name="line.1347"></a>
+<span class="sourceLineNo">1348</span><a name="line.1348"></a>
+<span class="sourceLineNo">1349</span>  /**<a name="line.1349"></a>
 <span class="sourceLineNo">1350</span>   * &lt;p&gt;<a name="line.1350"></a>
-<span class="sourceLineNo">1351</span>   * Will be overridden in tests.<a name="line.1351"></a>
+<span class="sourceLineNo">1351</span>   * Create a {@link ServerManager} instance.<a name="line.1351"></a>
 <span class="sourceLineNo">1352</span>   * &lt;/p&gt;<a name="line.1352"></a>
-<span class="sourceLineNo">1353</span>   */<a name="line.1353"></a>
-<span class="sourceLineNo">1354</span>  @InterfaceAudience.Private<a name="line.1354"></a>
-<span class="sourceLineNo">1355</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1355"></a>
-<span class="sourceLineNo">1356</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1356"></a>
-<span class="sourceLineNo">1357</span>    // w/ a mocked up ServerManager.<a name="line.1357"></a>
-<span class="sourceLineNo">1358</span>    setupClusterConnection();<a name="line.1358"></a>
-<span class="sourceLineNo">1359</span>    return new ServerManager(master);<a name="line.1359"></a>
-<span class="sourceLineNo">1360</span>  }<a name="line.1360"></a>
-<span class="sourceLineNo">1361</span><a name="line.1361"></a>
-<span class="sourceLineNo">1362</span>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1362"></a>
-<span class="sourceLineNo">1363</span>      throws IOException, InterruptedException {<a name="line.1363"></a>
-<span class="sourceLineNo">1364</span>    this.serverManager.waitForRegionServers(status);<a name="line.1364"></a>
-<span class="sourceLineNo">1365</span>  }<a name="line.1365"></a>
-<span class="sourceLineNo">1366</span><a name="line.1366"></a>
-<span class="sourceLineNo">1367</span>  // Will be overridden in tests<a name="line.1367"></a>
-<span class="sourceLineNo">1368</span>  @InterfaceAudience.Private<a name="line.1368"></a>
-<span class="sourceLineNo">1369</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1369"></a>
-<span class="sourceLineNo">1370</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1370"></a>
-<span class="sourceLineNo">1371</span>    this.clusterSchemaService.startAsync();<a name="line.1371"></a>
-<span class="sourceLineNo">1372</span>    try {<a name="line.1372"></a>
-<span class="sourceLineNo">1373</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1373"></a>
-<span class="sourceLineNo">1374</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1374"></a>
-<span class="sourceLineNo">1375</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1375"></a>
-<span class="sourceLineNo">1376</span>    } catch (TimeoutException toe) {<a name="line.1376"></a>
-<span class="sourceLineNo">1377</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<a name="line.1377"></a>
-<span class="sourceLineNo">1378</span>    }<a name="line.1378"></a>
-<span class="sourceLineNo">1379</span>  }<a name="line.1379"></a>
-<span class="sourceLineNo">1380</span><a name="line.1380"></a>
-<span class="sourceLineNo">1381</span>  private void initQuotaManager() throws IOException {<a name="line.1381"></a>
-<span class="sourceLineNo">1382</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1382"></a>
-<span class="sourceLineNo">1383</span>    quotaManager.start();<a name="line.1383"></a>
-<span class="sourceLineNo">1384</span>    this.quotaManager = quotaManager;<a name="line.1384"></a>
-<span class="sourceLineNo">1385</span>  }<a name="line.1385"></a>
-<span class="sourceLineNo">1386</span><a name="line.1386"></a>
-<span class="sourceLineNo">1387</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1387"></a>
-<span class="sourceLineNo">1388</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1388"></a>
-<span class="sourceLineNo">1389</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1389"></a>
-<span class="sourceLineNo">1390</span>    return notifier;<a name="line.1390"></a>
-<span class="sourceLineNo">1391</span>  }<a name="line.1391"></a>
-<span class="sourceLineNo">1392</span><a name="line.1392"></a>
-<span class="sourceLineNo">1393</span>  public boolean isCatalogJanitorEnabled() {<a name="line.1393"></a>
-<span class="sourceLineNo">1394</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<a name="line.1394"></a>
-<span class="sourceLineNo">1395</span>  }<a name="line.1395"></a>
-<span class="sourceLineNo">1396</span><a name="line.1396"></a>
-<span class="sourceLineNo">1397</span>  boolean isCleanerChoreEnabled() {<a name="line.1397"></a>
-<span class="sourceLineNo">1398</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1398"></a>
+<span class="sourceLineNo">1353</span>   * &lt;p&gt;<a name="line.1353"></a>
+<span class="sourceLineNo">1354</span>   * Will be overridden in tests.<a name="line.1354"></a>
+<span class="sourceLineNo">1355</span>   * &lt;/p&gt;<a name="line.1355"></a>
+<span class="sourceLineNo">1356</span>   */<a name="line.1356"></a>
+<span class="sourceLineNo">1357</span>  @InterfaceAudience.Private<a name="line.1357"></a>
+<span class="sourceLineNo">1358</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1358"></a>
+<span class="sourceLineNo">1359</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1359"></a>
+<span class="sourceLineNo">1360</span>    // w/ a mocked up ServerManager.<a name="line.1360"></a>
+<span class="sourceLineNo">1361</span>    setupClusterConnection();<a name="line.1361"></a>
+<span class="sourceLineNo">1362</span>    return new ServerManager(master);<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>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1365"></a>
+<span class="sourceLineNo">1366</span>      throws IOException, InterruptedException {<a name="line.1366"></a>
+<span class="sourceLineNo">1367</span>    this.serverManager.waitForRegionServers(status);<a name="line.1367"></a>
+<span class="sourceLineNo">1368</span>  }<a name="line.1368"></a>
+<span class="sourceLineNo">1369</span><a name="line.1369"></a>
+<span class="sourceLineNo">1370</span>  // Will be overridden in tests<a name="line.1370"></a>
+<span class="sourceLineNo">1371</span>  @InterfaceAudience.Private<a name="line.1371"></a>
+<span class="sourceLineNo">1372</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1372"></a>
+<span class="sourceLineNo">1373</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1373"></a>
+<span class="sourceLineNo">1374</span>    this.clusterSchemaService.startAsync();<a name="line.1374"></a>
+<span class="sourceLineNo">1375</span>    try {<a name="line.1375"></a>
+<span class="sourceLineNo">1376</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1376"></a>
+<span class="sourceLineNo">1377</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1377"></a>
+<span class="sourceLineNo">1378</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1378"></a>
+<span class="sourceLineNo">1379</span>    } catch (TimeoutException toe) {<a name="line.1379"></a>
+<span class="sourceLineNo">1380</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<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>  private void initQuotaManager() throws IOException {<a name="line.1384"></a>
+<span class="sourceLineNo">1385</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1385"></a>
+<span class="sourceLineNo">1386</span>    quotaManager.start();<a name="line.1386"></a>
+<span class="sourceLineNo">1387</span>    this.quotaManager = quotaManager;<a name="line.1387"></a>
+<span class="sourceLineNo">1388</span>  }<a name="line.1388"></a>
+<span class="sourceLineNo">1389</span><a name="line.1389"></a>
+<span class="sourceLineNo">1390</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1390"></a>
+<span class="sourceLineNo">1391</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1391"></a>
+<span class="sourceLineNo">1392</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1392"></a>
+<span class="sourceLineNo">1393</span>    return notifier;<a name="line.1393"></a>
+<span class="sourceLineNo">1394</span>  }<a name="line.1394"></a>
+<span class="sourceLineNo">1395</span><a name="line.1395"></a>
+<span class="sourceLineNo">1396</span>  public boolean isCatalogJanitorEnabled() {<a name="line.1396"></a>
+<span class="sourceLineNo">1397</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<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>    if (hfileCleaner != null) {<a name="line.1400"></a>
-<span class="sourceLineNo">1401</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<a name="line.1401"></a>
-<span class="sourceLineNo">1402</span>    }<a name="line.1402"></a>
-<span class="sourceLineNo">1403</span><a name="line.1403"></a>
-<span class="sourceLineNo">1404</span>    if (logCleaner != null) {<a name="line.1404"></a>
-<span class="sourceLineNo">1405</span>      logCleanerFlag = logCleaner.getEnabled();<a name="line.1405"></a>
-<span class="sourceLineNo">1406</span>    }<a name="line.1406"></a>
-<span class="sourceLineNo">1407</span><a name="line.1407"></a>
-<span class="sourceLineNo">1408</span>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<a name="line.1408"></a>
-<span class="sourceLineNo">1409</span>  }<a name="line.1409"></a>
+<span class="sourceLineNo">1400</span>  boolean isCleanerChoreEnabled() {<a name="line.1400"></a>
+<span class="sourceLineNo">1401</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1401"></a>
+<span class="sourceLineNo">1402</span><a name="line.1402"></a>
+<span class="sourceLineNo">1403</span>    if (hfileCleaner != null) {<a name="line.1403"></a>
+<span class="sourceLineNo">1404</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<a name="line.1404"></a>
+<span class="sourceLineNo">1405</span>    }<a name="line.1405"></a>
+<span class="sourceLineNo">1406</span><a name="line.1406"></a>
+<span class="sourceLineNo">1407</span>    if (logCleaner != null) {<a name="line.1407"></a>
+<span class="sourceLineNo">1408</span>      logCleanerFlag = logCleaner.getEnabled();<a name="line.1408"></a>
+<span class="sourceLineNo">1409</span>    }<a name="line.1409"></a>
 <span class="sourceLineNo">1410</span><a name="line.1410"></a>
-<span class="sourceLineNo">1411</span>  @Override<a name="line.1411"></a>
-<span class="sourceLineNo">1412</span>  public ServerManager getServerManager() {<a name="line.1412"></a>
-<span class="sourceLineNo">1413</span>    return this.serverManager;<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>  @Override<a name="line.1416"></a>
-<span class="sourceLineNo">1417</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1417"></a>
-<span class="sourceLineNo">1418</span>    return this.fileSystemManager;<a name="line.1418"></a>
-<span class="sourceLineNo">1419</span>  }<a name="line.1419"></a>
-<span class="sourceLineNo">1420</span><a name="line.1420"></a>
-<span class="sourceLineNo">1421</span>  @Override<a name="line.1421"></a>
-<span class="sourceLineNo">1422</span>  public MasterWalManager getMasterWalManager() {<a name="line.1422"></a>
-<span class="sourceLineNo">1423</span>    return this.walManager;<a name="line.1423"></a>
-<span class="sourceLineNo">1424</span>  }<a name="line.1424"></a>
-<span class="sourceLineNo">1425</span><a name="line.1425"></a>
-<span class="sourceLineNo">1426</span>  @Override<a name="line.1426"></a>
-<span class="sourceLineNo">1427</span>  public SplitWALManager getSplitWALManager() {<a name="line.1427"></a>
-<span class="sourceLineNo">1428</span>    return splitWALManager;<a name="line.1428"></a>
-<span class="sourceLineNo">1429</span>  }<a name="line.1429"></a>
-<span class="sourceLineNo">1430</span><a name="line.1430"></a>
-<span class="sourceLineNo">1431</span>  @Override<a name="line.1431"></a>
-<span class="sourceLineNo">1432</span>  public TableStateManager getTableStateManager() {<a name="line.1432"></a>
-<span class="sourceLineNo">1433</span>    return tableStateManager;<a name="line.1433"></a>
-<span class="sourceLineNo">1434</span>  }<a name="line.1434"></a>
-<span class="sourceLineNo">1435</span><a name="line.1435"></a>
-<span class="sourceLineNo">1436</span>  /*<a name="line.1436"></a>
-<span class="sourceLineNo">1437</span>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1437"></a>
-<span class="sourceLineNo">1438</span>   * then they just die with a logged message.  This should be fine because<a name="line.1438"></a>
-<span class="sourceLineNo">1439</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1439"></a>
-<span class="sourceLineNo">1440</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1440"></a>
-<span class="sourceLineNo">1441</span>   *  need to install an unexpected exception handler.<a name="line.1441"></a>
-<span class="sourceLineNo">1442</span>   */<a name="line.1442"></a>
-<span class="sourceLineNo">1443</span>  private void startServiceThreads() throws IOException {<a name="line.1443"></a>
-<span class="sourceLineNo">1444</span>    // Start the executor service pools<a name="line.1444"></a>
-<span class="sourceLineNo">1445</span>    final int masterOpenRegionPoolSize = conf.getInt(<a name="line.1445"></a>
-<span class="sourceLineNo">1446</span>        HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT);<a name="line.1446"></a>
-<span class="sourceLineNo">1447</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1447"></a>
-<span class="sourceLineNo">1448</span>        ExecutorType.MASTER_OPEN_REGION).setCorePoolSize(masterOpenRegionPoolSize));<a name="line.1448"></a>
-<span class="sourceLineNo">1449</span>    final int masterCloseRegionPoolSize = conf.getInt(<a name="line.1449"></a>
-<span class="sourceLineNo">1450</span>        HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT);<a name="line.1450"></a>
-<span class="sourceLineNo">1451</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1451"></a>
-<span class="sourceLineNo">1452</span>        ExecutorType.MASTER_CLOSE_REGION).setCorePoolSize(masterCloseRegionPoolSize));<a name="line.1452"></a>
-<span class="sourceLineNo">1453</span>    final int masterServerOpThreads = conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1453"></a>
-<span class="sourceLineNo">1454</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT);<a name="line.1454"></a>
-<span class="sourceLineNo">1455</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1455"></a>
-<span class="sourceLineNo">1456</span>        ExecutorType.MASTER_SERVER_OPERATIONS).setCorePoolSize(masterServerOpThreads));<a name="line.1456"></a>
-<span class="sourceLineNo">1457</span>    final int masterServerMetaOpsThreads = conf.getInt(<a name="line.1457"></a>
-<span class="sourceLineNo">1458</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1458"></a>
-<span class="sourceLineNo">1459</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT);<a name="line.1459"></a>
-<span class="sourceLineNo">1460</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1460"></a>
-<span class="sourceLineNo">1461</span>        ExecutorType.MASTER_META_SERVER_OPERATIONS).setCorePoolSize(masterServerMetaOpsThreads));<a name="line.1461"></a>
-<span class="sourceLineNo">1462</span>    final int masterLogReplayThreads = conf.getInt(<a name="line.1462"></a>
-<span class="sourceLineNo">1463</span>        HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT);<a name="line.1463"></a>
-<span class="sourceLineNo">1464</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1464"></a>
-<span class="sourceLineNo">1465</span>        ExecutorType.M_LOG_REPLAY_OPS).setCorePoolSize(masterLogReplayThreads));<a name="line.1465"></a>
-<span class="sourceLineNo">1466</span>    final int masterSnapshotThreads = conf.getInt(<a name="line.1466"></a>
-<span class="sourceLineNo">1467</span>        SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT);<a name="line.1467"></a>
-<span class="sourceLineNo">1468</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1468"></a>
-<span class="sourceLineNo">1469</span>        ExecutorType.MASTER_SNAPSHOT_OPERATIONS).setCorePoolSize(masterSnapshotThreads)<a name="line.1469"></a>
-<span class="sourceLineNo">1470</span>        .setAllowCoreThreadTimeout(true));<a name="line.1470"></a>
-<span class="sourceLineNo">1471</span>    final int masterMergeDispatchThreads = conf.getInt(HConstants.MASTER_MERGE_DISPATCH_THREADS,<a name="line.1471"></a>
-<span class="sourceLineNo">1472</span>        HConstants.MASTER_MERGE_DISPATCH_THREADS_DEFAULT);<a name="line.1472"></a>
-<span class="sourceLineNo">1473</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1473"></a>
-<span class="sourceLineNo">1474</span>        ExecutorType.MASTER_MERGE_OPERATIONS).setCorePoolSize(masterMergeDispatchThreads)<a name="line.1474"></a>
-<span class="sourceLineNo">1475</span>        .setAllowCoreThreadTimeout(true));<a name="line.1475"></a>
-<span class="sourceLineNo">1476</span><a name="line.1476"></a>
-<span class="sourceLineNo">1477</span>    // We depend on there being only one instance of this executor running<a name="line.1477"></a>
-<span class="sourceLineNo">1478</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1478"></a>
-<span class="sourceLineNo">1479</span>    // tables.<a name="line.1479"></a>
-<span class="sourceLineNo">1480</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1480"></a>
-<span class="sourceLineNo">1481</span>    // AccessController#postCompletedCreateTableAction<a name="line.1481"></a>
-<span class="sourceLineNo">1482</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1482"></a>
-<span class="sourceLineNo">1483</span>        ExecutorType.MASTER_TABLE_OPERATIONS).setCorePoolSize(1));<a name="line.1483"></a>
-<span class="sourceLineNo">1484</span>    startProcedureExecutor();<a name="line.1484"></a>
-<span class="sourceLineNo">1485</span><a name="line.1485"></a>
-<span class="sourceLineNo">1486</span>    // Create cleaner thread pool<a name="line.1486"></a>
-<span class="sourceLineNo">1487</span>    cleanerPool = new DirScanPool(conf);<a name="line.1487"></a>
-<span class="sourceLineNo">1488</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1488"></a>
-<span class="sourceLineNo">1489</span>    params.put(MASTER, this);<a name="line.1489"></a>
-<span class="sourceLineNo">1490</span>    // Start log cleaner thread<a name="line.1490"></a>
-<span class="sourceLineNo">1491</span>    int cleanerInterval =<a name="line.1491"></a>
-<span class="sourceLineNo">1492</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1492"></a>
-<span class="sourceLineNo">1493</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1493"></a>
-<span class="sourceLineNo">1494</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool, params);<a name="line.1494"></a>
-<span class="sourceLineNo">1495</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1495"></a>
-<span class="sourceLineNo">1496</span><a name="line.1496"></a>
-<span class="sourceLineNo">1497</span>    // start the hfile archive cleaner thread<a name="line.1497"></a>
-<span class="sourceLineNo">1498</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1498"></a>
-<span class="sourceLineNo">1499</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1499"></a>
-<span class="sourceLineNo">1500</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1500"></a>
-<span class="sourceLineNo">1501</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1501"></a>
-<span class="sourceLineNo">1502</span><a name="line.1502"></a>
-<span class="sourceLineNo">1503</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1503"></a>
-<span class="sourceLineNo">1504</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1504"></a>
-<span class="sourceLineNo">1505</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1505"></a>
-<span class="sourceLineNo">1506</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1506"></a>
-<span class="sourceLineNo">1507</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1507"></a>
-<span class="sourceLineNo">1508</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1508"></a>
-<span class="sourceLineNo">1509</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1509"></a>
-<span class="sourceLineNo">1510</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1510"></a>
-<span class="sourceLineNo">1511</span>    } else {<a name="line.1511"></a>
-<span class="sourceLineNo">1512</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1512"></a>
-<span class="sourceLineNo">1513</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1513"></a>
-<span class="sourceLineNo">1514</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1514"></a>
-<span class="sourceLineNo">1515</span>    }<a name="line.1515"></a>
-<span class="sourceLineNo">1516</span><a name="line.1516"></a>
-<span class="sourceLineNo">1517</span>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1517"></a>
-<span class="sourceLineNo">1518</span><a name="line.1518"></a>
-<span class="sourceLineNo">1519</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1519"></a>
-<span class="sourceLineNo">1520</span>      replicationPeerManager);<a name="line.1520"></a>
-<span class="sourceLineNo">1521</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1521"></a>
-<span class="sourceLineNo">1522</span><a name="line.1522"></a>
-<span class="sourceLineNo">1523</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1523"></a>
-<span class="sourceLineNo">1524</span>        .isSnapshotCleanupEnabled();<a name="line.1524"></a>
-<span class="sourceLineNo">1525</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1525"></a>
-<span class="sourceLineNo">1526</span>    if (isSnapshotChoreEnabled) {<a name="line.1526"></a>
-<span class="sourceLineNo">1527</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1527"></a>
-<span class="sourceLineNo">1528</span>    } else {<a name="line.1528"></a>
-<span class="sourceLineNo">1529</span>      if (LOG.isTraceEnabled()) {<a name="line.1529"></a>
-<span class="sourceLineNo">1530</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1530"></a>
-<span class="sourceLineNo">1531</span>      }<a name="line.1531"></a>
-<span class="sourceLineNo">1532</span>    }<a name="line.1532"></a>
-<span class="sourceLineNo">1533</span>    serviceStarted = true;<a name="line.1533"></a>
-<span class="sourceLineNo">1534</span>    if (LOG.isTraceEnabled()) {<a name="line.1534"></a>
-<span class="sourceLineNo">1535</span>      LOG.trace("Started service threads");<a name="line.1535"></a>
-<span class="sourceLineNo">1536</span>    }<a name="line.1536"></a>
-<span class="sourceLineNo">1537</span>  }<a name="line.1537"></a>
-<span class="sourceLineNo">1538</span><a name="line.1538"></a>
-<span class="sourceLineNo">1539</span>  @Override<a name="line.1539"></a>
-<span class="sourceLineNo">1540</span>  protected void stopServiceThreads() {<a name="line.1540"></a>
-<span class="sourceLineNo">1541</span>    if (masterJettyServer != null) {<a name="line.1541"></a>
-<span class="sourceLineNo">1542</span>      LOG.info("Stopping master jetty server");<a name="line.1542"></a>
-<span class="sourceLineNo">1543</span>      try {<a name="line.1543"></a>
-<span class="sourceLineNo">1544</span>        masterJettyServer.stop();<a name="line.1544"></a>
-<span class="sourceLineNo">1545</span>      } catch (Exception e) {<a name="line.1545"></a>
-<span class="sourceLineNo">1546</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1546"></a>
-<span class="sourceLineNo">1547</span>      }<a name="line.1547"></a>
-<span class="sourceLineNo">1548</span>    }<a name="line.1548"></a>
-<span class="sourceLineNo">1549</span>    stopChores();<a name="line.1549"></a>
-<span class="sourceLineNo">1550</span><a name="line.1550"></a>
-<span class="sourceLineNo">1551</span>    super.stopServiceThreads();<a name="line.1551"></a>
-<span class="sourceLineNo">1552</span>    if (cleanerPool != null) {<a name="line.1552"></a>
-<span class="sourceLineNo">1553</span>      cleanerPool.shutdownNow();<a name="line.1553"></a>
-<span class="sourceLineNo">1554</span>      cleanerPool = null;<a name="line.1554"></a>
-<span class="sourceLineNo">1555</span>    }<a name="line.1555"></a>
-<span class="sourceLineNo">1556</span><a name="line.1556"></a>
-<span class="sourceLineNo">1557</span>    LOG.debug("Stopping service threads");<a name="line.1557"></a>
-<span class="sourceLineNo">1558</span><a name="line.1558"></a>
-<span class="sourceLineNo">1559</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1559"></a>
-<span class="sourceLineNo">1560</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1560"></a>
-<span class="sourceLineNo">1561</span>    // example.<a name="line.1561"></a>
-<span class="sourceLineNo">1562</span>    stopProcedureExecutor();<a name="line.1562"></a>
-<span class="sourceLineNo">1563</span><a name="line.1563"></a>
-<span class="sourceLineNo">1564</span>    if (regionNormalizerManager != null) {<a name="line.1564"></a>
-<span class="sourceLineNo">1565</span>      regionNormalizerManager.stop();<a name="line.1565"></a>
-<span class="sourceLineNo">1566</span>    }<a name="line.1566"></a>
-<span class="sourceLineNo">1567</span>    if (this.quotaManager != null) {<a name="line.1567"></a>
-<span class="sourceLineNo">1568</span>      this.quotaManager.stop();<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>    if (this.activeMasterManager != null) {<a name="line.1571"></a>
-<span class="sourceLineNo">1572</span>      this.activeMasterManager.stop();<a name="line.1572"></a>
-<span class="sourceLineNo">1573</span>    }<a name="line.1573"></a>
-<span class="sourceLineNo">1574</span>    if (this.serverManager != null) {<a name="line.1574"></a>
-<span class="sourceLineNo">1575</span>      this.serverManager.stop();<a name="line.1575"></a>
-<span class="sourceLineNo">1576</span>    }<a name="line.1576"></a>
-<span class="sourceLineNo">1577</span>    if (this.assignmentManager != null) {<a name="line.1577"></a>
-<span class="sourceLineNo">1578</span>      this.assignmentManager.stop();<a name="line.1578"></a>
-<span class="sourceLineNo">1579</span>    }<a name="line.1579"></a>
-<span class="sourceLineNo">1580</span><a name="line.1580"></a>
-<span class="sourceLineNo">1581</span>    if (masterRegion != null) {<a name="line.1581"></a>
-<span class="sourceLineNo">1582</span>      masterRegion.close(isAborted());<a name="line.1582"></a>
-<span class="sourceLineNo">1583</span>    }<a name="line.1583"></a>
-<span class="sourceLineNo">1584</span>    if (this.walManager != null) {<a name="line.1584"></a>
-<span class="sourceLineNo">1585</span>      this.walManager.stop();<a name="line.1585"></a>
-<span class="sourceLineNo">1586</span>    }<a name="line.1586"></a>
-<span class="sourceLineNo">1587</span>    if (this.fileSystemManager != null) {<a name="line.1587"></a>
-<span class="sourceLineNo">1588</span>      this.fileSystemManager.stop();<a name="line.1588"></a>
-<span class="sourceLineNo">1589</span>    }<a name="line.1589"></a>
-<span class="sourceLineNo">1590</span>    if (this.mpmHost != null) {<a name="line.1590"></a>
-<span class="sourceLineNo">1591</span>      this.mpmHost.stop("server shutting down.");<a name="line.1591"></a>
-<span class="sourceLineNo">1592</span>    }<a name="line.1592"></a>
-<span class="sourceLineNo">1593</span>    if (this.regionServerTracker != null) {<a name="line.1593"></a>
-<span class="sourceLineNo">1594</span>      this.regionServerTracker.stop();<a name="line.1594"></a>
-<span class="sourceLineNo">1595</span>    }<a name="line.1595"></a>
-<span class="sourceLineNo">1596</span>  }<a name="line.1596"></a>
-<span class="sourceLineNo">1597</span><a name="line.1597"></a>
-<span class="sourceLineNo">1598</span>  private void createProcedureExecutor() throws IOException {<a name="line.1598"></a>
-<span class="sourceLineNo">1599</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1599"></a>
-<span class="sourceLineNo">1600</span>    procedureStore =<a name="line.1600"></a>
-<span class="sourceLineNo">1601</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1601"></a>
-<span class="sourceLineNo">1602</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1602"></a>
-<span class="sourceLineNo">1603</span><a name="line.1603"></a>
-<span class="sourceLineNo">1604</span>      @Override<a name="line.1604"></a>
-<span class="sourceLineNo">1605</span>      public void abortProcess() {<a name="line.1605"></a>
-<span class="sourceLineNo">1606</span>        abort("The Procedure Store lost the lease", null);<a name="line.1606"></a>
-<span class="sourceLineNo">1607</span>      }<a name="line.1607"></a>
-<span class="sourceLineNo">1608</span>    });<a name="line.1608"></a>
-<span class="sourceLineNo">1609</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1609"></a>
-<span class="sourceLineNo">1610</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1610"></a>
-<span class="sourceLineNo">1611</span>    configurationManager.registerObserver(procEnv);<a name="line.1611"></a>
-<span class="sourceLineNo">1612</span><a name="line.1612"></a>
-<span class="sourceLineNo">1613</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1613"></a>
-<span class="sourceLineNo">1614</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1614"></a>
-<span class="sourceLineNo">1615</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1615"></a>
-<span class="sourceLineNo">1616</span>    final boolean abortOnCorruption =<a name="line.1616"></a>
-<span class="sourceLineNo">1617</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1617"></a>
-<span class="sourceLineNo">1618</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1618"></a>
-<span class="sourceLineNo">1619</span>    procedureStore.start(numThreads);<a name="line.1619"></a>
-<span class="sourceLineNo">1620</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1620"></a>
-<span class="sourceLineNo">1621</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1621"></a>
-<span class="sourceLineNo">1622</span>    // details.<a name="line.1622"></a>
-<span class="sourceLineNo">1623</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1623"></a>
-<span class="sourceLineNo">1624</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1624"></a>
-<span class="sourceLineNo">1625</span>      throw new HBaseIOException("Failed start of remote dispatcher");<a name="line.1625"></a>
-<span class="sourceLineNo">1626</span>    }<a name="line.1626"></a>
-<span class="sourceLineNo">1627</span>  }<a name="line.1627"></a>
-<span class="sourceLineNo">1628</span><a name="line.1628"></a>
-<span class="sourceLineNo">1629</span>  // will be override in UT<a name="line.1629"></a>
-<span class="sourceLineNo">1630</span>  protected void startProcedureExecutor() throws IOException {<a name="line.1630"></a>
-<span class="sourceLineNo">1631</span>    procedureExecutor.startWorkers();<a name="line.1631"></a>
+<span class="sourceLineNo">1411</span>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<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>  @Override<a name="line.1414"></a>
+<span class="sourceLineNo">1415</span>  public ServerManager getServerManager() {<a name="line.1415"></a>
+<span class="sourceLineNo">1416</span>    return this.serverManager;<a name="line.1416"></a>
+<span class="sourceLineNo">1417</span>  }<a name="line.1417"></a>
+<span class="sourceLineNo">1418</span><a name="line.1418"></a>
+<span class="sourceLineNo">1419</span>  @Override<a name="line.1419"></a>
+<span class="sourceLineNo">1420</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1420"></a>
+<span class="sourceLineNo">1421</span>    return this.fileSystemManager;<a name="line.1421"></a>
+<span class="sourceLineNo">1422</span>  }<a name="line.1422"></a>
+<span class="sourceLineNo">1423</span><a name="line.1423"></a>
+<span class="sourceLineNo">1424</span>  @Override<a name="line.1424"></a>
+<span class="sourceLineNo">1425</span>  public MasterWalManager getMasterWalManager() {<a name="line.1425"></a>
+<span class="sourceLineNo">1426</span>    return this.walManager;<a name="line.1426"></a>
+<span class="sourceLineNo">1427</span>  }<a name="line.1427"></a>
+<span class="sourceLineNo">1428</span><a name="line.1428"></a>
+<span class="sourceLineNo">1429</span>  @Override<a name="line.1429"></a>
+<span class="sourceLineNo">1430</span>  public SplitWALManager getSplitWALManager() {<a name="line.1430"></a>
+<span class="sourceLineNo">1431</span>    return splitWALManager;<a name="line.1431"></a>
+<span class="sourceLineNo">1432</span>  }<a name="line.1432"></a>
+<span class="sourceLineNo">1433</span><a name="line.1433"></a>
+<span class="sourceLineNo">1434</span>  @Override<a name="line.1434"></a>
+<span class="sourceLineNo">1435</span>  public TableStateManager getTableStateManager() {<a name="line.1435"></a>
+<span class="sourceLineNo">1436</span>    return tableStateManager;<a name="line.1436"></a>
+<span class="sourceLineNo">1437</span>  }<a name="line.1437"></a>
+<span class="sourceLineNo">1438</span><a name="line.1438"></a>
+<span class="sourceLineNo">1439</span>  /*<a name="line.1439"></a>
+<span class="sourceLineNo">1440</span>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1440"></a>
+<span class="sourceLineNo">1441</span>   * then they just die with a logged message.  This should be fine because<a name="line.1441"></a>
+<span class="sourceLineNo">1442</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1442"></a>
+<span class="sourceLineNo">1443</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1443"></a>
+<span class="sourceLineNo">1444</span>   *  need to install an unexpected exception handler.<a name="line.1444"></a>
+<span class="sourceLineNo">1445</span>   */<a name="line.1445"></a>
+<span class="sourceLineNo">1446</span>  private void startServiceThreads() throws IOException {<a name="line.1446"></a>
+<span class="sourceLineNo">1447</span>    // Start the executor service pools<a name="line.1447"></a>
+<span class="sourceLineNo">1448</span>    final int masterOpenRegionPoolSize = conf.getInt(<a name="line.1448"></a>
+<span class="sourceLineNo">1449</span>        HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT);<a name="line.1449"></a>
+<span class="sourceLineNo">1450</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1450"></a>
+<span class="sourceLineNo">1451</span>        ExecutorType.MASTER_OPEN_REGION).setCorePoolSize(masterOpenRegionPoolSize));<a name="line.1451"></a>
+<span class="sourceLineNo">1452</span>    final int masterCloseRegionPoolSize = conf.getInt(<a name="line.1452"></a>
+<span class="sourceLineNo">1453</span>        HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT);<a name="line.1453"></a>
+<span class="sourceLineNo">1454</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1454"></a>
+<span class="sourceLineNo">1455</span>        ExecutorType.MASTER_CLOSE_REGION).setCorePoolSize(masterCloseRegionPoolSize));<a name="line.1455"></a>
+<span class="sourceLineNo">1456</span>    final int masterServerOpThreads = conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1456"></a>
+<span class="sourceLineNo">1457</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT);<a name="line.1457"></a>
+<span class="sourceLineNo">1458</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1458"></a>
+<span class="sourceLineNo">1459</span>        ExecutorType.MASTER_SERVER_OPERATIONS).setCorePoolSize(masterServerOpThreads));<a name="line.1459"></a>
+<span class="sourceLineNo">1460</span>    final int masterServerMetaOpsThreads = conf.getInt(<a name="line.1460"></a>
+<span class="sourceLineNo">1461</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1461"></a>
+<span class="sourceLineNo">1462</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT);<a name="line.1462"></a>
+<span class="sourceLineNo">1463</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1463"></a>
+<span class="sourceLineNo">1464</span>        ExecutorType.MASTER_META_SERVER_OPERATIONS).setCorePoolSize(masterServerMetaOpsThreads));<a name="line.1464"></a>
+<span class="sourceLineNo">1465</span>    final int masterLogReplayThreads = conf.getInt(<a name="line.1465"></a>
+<span class="sourceLineNo">1466</span>        HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT);<a name="line.1466"></a>
+<span class="sourceLineNo">1467</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1467"></a>
+<span class="sourceLineNo">1468</span>        ExecutorType.M_LOG_REPLAY_OPS).setCorePoolSize(masterLogReplayThreads));<a name="line.1468"></a>
+<span class="sourceLineNo">1469</span>    final int masterSnapshotThreads = conf.getInt(<a name="line.1469"></a>
+<span class="sourceLineNo">1470</span>        SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT);<a name="line.1470"></a>
+<span class="sourceLineNo">1471</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1471"></a>
+<span class="sourceLineNo">1472</span>        ExecutorType.MASTER_SNAPSHOT_OPERATIONS).setCorePoolSize(masterSnapshotThreads)<a name="line.1472"></a>
+<span class="sourceLineNo">1473</span>        .setAllowCoreThreadTimeout(true));<a name="line.1473"></a>
+<span class="sourceLineNo">1474</span>    final int masterMergeDispatchThreads = conf.getInt(HConstants.MASTER_MERGE_DISPATCH_THREADS,<a name="line.1474"></a>
+<span class="sourceLineNo">1475</span>        HConstants.MASTER_MERGE_DISPATCH_THREADS_DEFAULT);<a name="line.1475"></a>
+<span class="sourceLineNo">1476</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1476"></a>
+<span class="sourceLineNo">1477</span>        ExecutorType.MASTER_MERGE_OPERATIONS).setCorePoolSize(masterMergeDispatchThreads)<a name="line.1477"></a>
+<span class="sourceLineNo">1478</span>        .setAllowCoreThreadTimeout(true));<a name="line.1478"></a>
+<span class="sourceLineNo">1479</span><a name="line.1479"></a>
+<span class="sourceLineNo">1480</span>    // We depend on there being only one instance of this executor running<a name="line.1480"></a>
+<span class="sourceLineNo">1481</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1481"></a>
+<span class="sourceLineNo">1482</span>    // tables.<a name="line.1482"></a>
+<span class="sourceLineNo">1483</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1483"></a>
+<span class="sourceLineNo">1484</span>    // AccessController#postCompletedCreateTableAction<a name="line.1484"></a>
+<span class="sourceLineNo">1485</span>    executorService.startExecutorService(executorService.new ExecutorConfig().setExecutorType(<a name="line.1485"></a>
+<span class="sourceLineNo">1486</span>        ExecutorType.MASTER_TABLE_OPERATIONS).setCorePoolSize(1));<a name="line.1486"></a>
+<span class="sourceLineNo">1487</span>    startProcedureExecutor();<a name="line.1487"></a>
+<span class="sourceLineNo">1488</span><a name="line.1488"></a>
+<span class="sourceLineNo">1489</span>    // Create cleaner thread pool<a name="line.1489"></a>
+<span class="sourceLineNo">1490</span>    cleanerPool = new DirScanPool(conf);<a name="line.1490"></a>
+<span class="sourceLineNo">1491</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1491"></a>
+<span class="sourceLineNo">1492</span>    params.put(MASTER, this);<a name="line.1492"></a>
+<span class="sourceLineNo">1493</span>    // Start log cleaner thread<a name="line.1493"></a>
+<span class="sourceLineNo">1494</span>    int cleanerInterval =<a name="line.1494"></a>
+<span class="sourceLineNo">1495</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1495"></a>
+<span class="sourceLineNo">1496</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1496"></a>
+<span class="sourceLineNo">1497</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool, params);<a name="line.1497"></a>
+<span class="sourceLineNo">1498</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1498"></a>
+<span class="sourceLineNo">1499</span><a name="line.1499"></a>
+<span class="sourceLineNo">1500</span>    // start the hfile archive cleaner thread<a name="line.1500"></a>
+<span class="sourceLineNo">1501</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1501"></a>
+<span class="sourceLineNo">1502</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1502"></a>
+<span class="sourceLineNo">1503</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1503"></a>
+<span class="sourceLineNo">1504</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1504"></a>
+<span class="sourceLineNo">1505</span><a name="line.1505"></a>
+<span class="sourceLineNo">1506</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1506"></a>
+<span class="sourceLineNo">1507</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1507"></a>
+<span class="sourceLineNo">1508</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1508"></a>
+<span class="sourceLineNo">1509</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1509"></a>
+<span class="sourceLineNo">1510</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1510"></a>
+<span class="sourceLineNo">1511</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1511"></a>
+<span class="sourceLineNo">1512</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1512"></a>
+<span class="sourceLineNo">1513</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1513"></a>
+<span class="sourceLineNo">1514</span>    } else {<a name="line.1514"></a>
+<span class="sourceLineNo">1515</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1515"></a>
+<span class="sourceLineNo">1516</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1516"></a>
+<span class="sourceLineNo">1517</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<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>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1520"></a>
+<span class="sourceLineNo">1521</span><a name="line.1521"></a>
+<span class="sourceLineNo">1522</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1522"></a>
+<span class="sourceLineNo">1523</span>      replicationPeerManager);<a name="line.1523"></a>
+<span class="sourceLineNo">1524</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1524"></a>
+<span class="sourceLineNo">1525</span><a name="line.1525"></a>
+<span class="sourceLineNo">1526</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1526"></a>
+<span class="sourceLineNo">1527</span>        .isSnapshotCleanupEnabled();<a name="line.1527"></a>
+<span class="sourceLineNo">1528</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1528"></a>
+<span class="sourceLineNo">1529</span>    if (isSnapshotChoreEnabled) {<a name="line.1529"></a>
+<span class="sourceLineNo">1530</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1530"></a>
+<span class="sourceLineNo">1531</span>    } else {<a name="line.1531"></a>
+<span class="sourceLineNo">1532</span>      if (LOG.isTraceEnabled()) {<a name="line.1532"></a>
+<span class="sourceLineNo">1533</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1533"></a>
+<span class="sourceLineNo">1534</span>      }<a name="line.1534"></a>
+<span class="sourceLineNo">1535</span>    }<a name="line.1535"></a>
+<span class="sourceLineNo">1536</span>    serviceStarted = true;<a name="line.1536"></a>
+<span class="sourceLineNo">1537</span>    if (LOG.isTraceEnabled()) {<a name="line.1537"></a>
+<span class="sourceLineNo">1538</span>      LOG.trace("Started service threads");<a name="line.1538"></a>
+<span class="sourceLineNo">1539</span>    }<a name="line.1539"></a>
+<span class="sourceLineNo">1540</span>  }<a name="line.1540"></a>
+<span class="sourceLineNo">1541</span><a name="line.1541"></a>
+<span class="sourceLineNo">1542</span>  @Override<a name="line.1542"></a>
+<span class="sourceLineNo">1543</span>  protected void stopServiceThreads() {<a name="line.1543"></a>
+<span class="sourceLineNo">1544</span>    if (masterJettyServer != null) {<a name="line.1544"></a>
+<span class="sourceLineNo">1545</span>      LOG.info("Stopping master jetty server");<a name="line.1545"></a>
+<span class="sourceLineNo">1546</span>      try {<a name="line.1546"></a>
+<span class="sourceLineNo">1547</span>        masterJettyServer.stop();<a name="line.1547"></a>
+<span class="sourceLineNo">1548</span>      } catch (Exception e) {<a name="line.1548"></a>
+<span class="sourceLineNo">1549</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1549"></a>
+<span class="sourceLineNo">1550</span>      }<a name="line.1550"></a>
+<span class="sourceLineNo">1551</span>    }<a name="line.1551"></a>
+<span class="sourceLineNo">1552</span>    stopChores();<a name="line.1552"></a>
+<span class="sourceLineNo">1553</span><a name="line.1553"></a>
+<span class="sourceLineNo">1554</span>    super.stopServiceThreads();<a name="line.1554"></a>
+<span class="sourceLineNo">1555</span>    if (cleanerPool != null) {<a name="line.1555"></a>
+<span class="sourceLineNo">1556</span>      cleanerPool.shutdownNow();<a name="line.1556"></a>
+<span class="sourceLineNo">1557</span>      cleanerPool = null;<a name="line.1557"></a>
+<span class="sourceLineNo">1558</span>    }<a name="line.1558"></a>
+<span class="sourceLineNo">1559</span>    if (maintenanceRegionServer != null) {<a name="line.1559"></a>
+<span class="sourceLineNo">1560</span>      maintenanceRegionServer.getRegionServer().stop(HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1560"></a>
+<span class="sourceLineNo">1561</span>    }<a name="line.1561"></a>
+<span class="sourceLineNo">1562</span><a name="line.1562"></a>
+<span class="sourceLineNo">1563</span>    LOG.debug("Stopping service threads");<a name="line.1563"></a>
+<span class="sourceLineNo">1564</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1564"></a>
+<span class="sourceLineNo">1565</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1565"></a>
+<span class="sourceLineNo">1566</span>    // example.<a name="line.1566"></a>
+<span class="sourceLineNo">1567</span>    stopProcedureExecutor();<a name="line.1567"></a>
+<span class="sourceLineNo">1568</span><a name="line.1568"></a>
+<span class="sourceLineNo">1569</span>    if (regionNormalizerManager != null) {<a name="line.1569"></a>
+<span class="sourceLineNo">1570</span>      regionNormalizerManager.stop();<a name="line.1570"></a>
+<span class="sourceLineNo">1571</span>    }<a name="line.1571"></a>
+<span class="sourceLineNo">1572</span>    if (this.quotaManager != null) {<a name="line.1572"></a>
+<span class="sourceLineNo">1573</span>      this.quotaManager.stop();<a name="line.1573"></a>
+<span class="sourceLineNo">1574</span>    }<a name="line.1574"></a>
+<span class="sourceLineNo">1575</span><a name="line.1575"></a>
+<span class="sourceLineNo">1576</span>    if (this.activeMasterManager != null) {<a name="line.1576"></a>
+<span class="sourceLineNo">1577</span>      this.activeMasterManager.stop();<a name="line.1577"></a>
+<span class="sourceLineNo">1578</span>    }<a name="line.1578"></a>
+<span class="sourceLineNo">1579</span>    if (this.serverManager != null) {<a name="line.1579"></a>
+<span class="sourceLineNo">1580</span>      this.serverManager.stop();<a name="line.1580"></a>
+<span class="sourceLineNo">1581</span>    }<a name="line.1581"></a>
+<span class="sourceLineNo">1582</span>    if (this.assignmentManager != null) {<a name="line.1582"></a>
+<span class="sourceLineNo">1583</span>      this.assignmentManager.stop();<a name="line.1583"></a>
+<span class="sourceLineNo">1584</span>    }<a name="line.1584"></a>
+<span class="sourceLineNo">1585</span><a name="line.1585"></a>
+<span class="sourceLineNo">1586</span>    if (masterRegion != null) {<a name="line.1586"></a>
+<span class="sourceLineNo">1587</span>      masterRegion.close(isAborted());<a name="line.1587"></a>
+<span class="sourceLineNo">1588</span>    }<a name="line.1588"></a>
+<span class="sourceLineNo">1589</span>    if (this.walManager != null) {<a name="line.1589"></a>
+<span class="sourceLineNo">1590</span>      this.walManager.stop();<a name="line.1590"></a>
+<span class="sourceLineNo">1591</span>    }<a name="line.1591"></a>
+<span class="sourceLineNo">1592</span>    if (this.fileSystemManager != null) {<a name="line.1592"></a>
+<span class="sourceLineNo">1593</span>      this.fileSystemManager.stop();<a name="line.1593"></a>
+<span class="sourceLineNo">1594</span>    }<a name="line.1594"></a>
+<span class="sourceLineNo">1595</span>    if (this.mpmHost != null) {<a name="line.1595"></a>
+<span class="sourceLineNo">1596</span>      this.mpmHost.stop("server shutting down.");<a name="line.1596"></a>
+<span class="sourceLineNo">1597</span>    }<a name="line.1597"></a>
+<span class="sourceLineNo">1598</span>    if (this.regionServerTracker != null) {<a name="line.1598"></a>
+<span class="sourceLineNo">1599</span>      this.regionServerTracker.stop();<a name="line.1599"></a>
+<span class="sourceLineNo">1600</span>    }<a name="line.1600"></a>
+<span class="sourceLineNo">1601</span>  }<a name="line.1601"></a>
+<span class="sourceLineNo">1602</span><a name="line.1602"></a>
+<span class="sourceLineNo">1603</span>  private void createProcedureExecutor() throws IOException {<a name="line.1603"></a>
+<span class="sourceLineNo">1604</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1604"></a>
+<span class="sourceLineNo">1605</span>    procedureStore =<a name="line.1605"></a>
+<span class="sourceLineNo">1606</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1606"></a>
+<span class="sourceLineNo">1607</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1607"></a>
+<span class="sourceLineNo">1608</span><a name="line.1608"></a>
+<span class="sourceLineNo">1609</span>      @Override<a name="line.1609"></a>
+<span class="sourceLineNo">1610</span>      public void abortProcess() {<a name="line.1610"></a>
+<span class="sourceLineNo">1611</span>        abort("The Procedure Store lost the lease", null);<a name="line.1611"></a>
+<span class="sourceLineNo">1612</span>      }<a name="line.1612"></a>
+<span class="sourceLineNo">1613</span>    });<a name="line.1613"></a>
+<span class="sourceLineNo">1614</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1614"></a>
+<span class="sourceLineNo">1615</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1615"></a>
+<span class="sourceLineNo">1616</span>    configurationManager.registerObserver(procEnv);<a name="line.1616"></a>
+<span class="sourceLineNo">1617</span><a name="line.1617"></a>
+<span class="sourceLineNo">1618</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1618"></a>
+<span class="sourceLineNo">1619</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1619"></a>
+<span class="sourceLineNo">1620</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1620"></a>
+<span class="sourceLineNo">1621</span>    final boolean abortOnCorruption =<a name="line.1621"></a>
+<span class="sourceLineNo">1622</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1622"></a>
+<span class="sourceLineNo">1623</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1623"></a>
+<span class="sourceLineNo">1624</span>    procedureStore.start(numThreads);<a name="line.1624"></a>
+<span class="sourceLineNo">1625</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1625"></a>
+<span class="sourceLineNo">1626</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1626"></a>
+<span class="sourceLineNo">1627</span>    // details.<a name="line.1627"></a>
+<span class="sourceLineNo">1628</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1628"></a>
+<span class="sourceLineNo">1629</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1629"></a>
+<span class="sourceLineNo">1630</span>      throw new HBaseIOException("Failed start of remote dispatcher");<a name="line.1630"></a>
+<span class="sourceLineNo">1631</span>    }<a name="line.1631"></a>
 <span class="sourceLineNo">1632</span>  }<a name="line.1632"></a>
 <span class="sourceLineNo">1633</span><a name="line.1633"></a>
-<span class="sourceLineNo">1634</span>  /**<a name="line.1634"></a>
-<span class="sourceLineNo">1635</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1635"></a>
-<span class="sourceLineNo">1636</span>   *<a name="line.1636"></a>
-<span class="sourceLineNo">1637</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1637"></a>
-<span class="sourceLineNo">1638</span>   */<a name="line.1638"></a>
-<span class="sourceLineNo">1639</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1639"></a>
-<span class="sourceLineNo">1640</span>    if (synchronous) {<a name="line.1640"></a>
-<span class="sourceLineNo">1641</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1641"></a>
-<span class="sourceLineNo">1642</span>        switchSnapshotCleanup(on);<a name="line.1642"></a>
-<span class="sourceLineNo">1643</span>      }<a name="line.1643"></a>
-<span class="sourceLineNo">1644</span>    } else {<a name="line.1644"></a>
-<span class="sourceLineNo">1645</span>      switchSnapshotCleanup(on);<a name="line.1645"></a>
-<span class="sourceLineNo">1646</span>    }<a name="line.1646"></a>
-<span class="sourceLineNo">1647</span>  }<a name="line.1647"></a>
-<span class="sourceLineNo">1648</span><a name="line.1648"></a>
-<span class="sourceLineNo">1649</span>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1649"></a>
-<span class="sourceLineNo">1650</span>    try {<a name="line.1650"></a>
-<span class="sourceLineNo">1651</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1651"></a>
-<span class="sourceLineNo">1652</span>      if (on) {<a name="line.1652"></a>
-<span class="sourceLineNo">1653</span>        getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1653"></a>
-<span class="sourceLineNo">1654</span>      } else {<a name="line.1654"></a>
-<span class="sourceLineNo">1655</span>        this.snapshotCleanerChore.cancel();<a name="line.1655"></a>
-<span class="sourceLineNo">1656</span>      }<a name="line.1656"></a>
-<span class="sourceLineNo">1657</span>    } catch (KeeperException e) {<a name="line.1657"></a>
-<span class="sourceLineNo">1658</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1658"></a>
-<span class="sourceLineNo">1659</span>    }<a name="line.1659"></a>
-<span class="sourceLineNo">1660</span>  }<a name="line.1660"></a>
-<span class="sourceLineNo">1661</span><a name="line.1661"></a>
-<span class="sourceLineNo">1662</span><a name="line.1662"></a>
-<span class="sourceLineNo">1663</span>  private void stopProcedureExecutor() {<a name="line.1663"></a>
-<span class="sourceLineNo">1664</span>    if (procedureExecutor != null) {<a name="line.1664"></a>
-<span class="sourceLineNo">1665</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1665"></a>
-<span class="sourceLineNo">1666</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1666"></a>
-<span class="sourceLineNo">1667</span>      procedureExecutor.stop();<a name="line.1667"></a>
-<span class="sourceLineNo">1668</span>      procedureExecutor.join();<a name="line.1668"></a>
-<span class="sourceLineNo">1669</span>      procedureExecutor = null;<a name="line.1669"></a>
-<span class="sourceLineNo">1670</span>    }<a name="line.1670"></a>
-<span class="sourceLineNo">1671</span><a name="line.1671"></a>
-<span class="sourceLineNo">1672</span>    if (procedureStore != null) {<a name="line.1672"></a>
-<span class="sourceLineNo">1673</span>      procedureStore.stop(isAborted());<a name="line.1673"></a>
-<span class="sourceLineNo">1674</span>      procedureStore = null;<a name="line.1674"></a>
+<span class="sourceLineNo">1634</span>  // will be override in UT<a name="line.1634"></a>
+<span class="sourceLineNo">1635</span>  protected void startProcedureExecutor() throws IOException {<a name="line.1635"></a>
+<span class="sourceLineNo">1636</span>    procedureExecutor.startWorkers();<a name="line.1636"></a>
+<span class="sourceLineNo">1637</span>  }<a name="line.1637"></a>
+<span class="sourceLineNo">1638</span><a name="line.1638"></a>
+<span class="sourceLineNo">1639</span>  /**<a name="line.1639"></a>
+<span class="sourceLineNo">1640</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1640"></a>
+<span class="sourceLineNo">1641</span>   *<a name="line.1641"></a>
+<span class="sourceLineNo">1642</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1642"></a>
+<span class="sourceLineNo">1643</span>   */<a name="line.1643"></a>
+<span class="sourceLineNo">1644</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1644"></a>
+<span class="sourceLineNo">1645</span>    if (synchronous) {<a name="line.1645"></a>
+<span class="sourceLineNo">1646</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1646"></a>
+<span class="sourceLineNo">1647</span>        switchSnapshotCleanup(on);<a name="line.1647"></a>
+<span class="sourceLineNo">1648</span>      }<a name="line.1648"></a>
+<span class="sourceLineNo">1649</span>    } else {<a name="line.1649"></a>
+<span class="sourceLineNo">1650</span>      switchSnapshotCleanup(on);<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>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1654"></a>
+<span class="sourceLineNo">1655</span>    try {<a name="line.1655"></a>
+<span class="sourceLineNo">1656</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1656"></a>
+<span class="sourceLineNo">1657</span>      if (on) {<a name="line.1657"></a>
+<span class="sourceLineNo">1658</span>        getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1658"></a>
+<span class="sourceLineNo">1659</span>      } else {<a name="line.1659"></a>
+<span class="sourceLineNo">1660</span>        this.snapshotCleanerChore.cancel();<a name="line.1660"></a>
+<span class="sourceLineNo">1661</span>      }<a name="line.1661"></a>
+<span class="sourceLineNo">1662</span>    } catch (KeeperException e) {<a name="line.1662"></a>
+<span class="sourceLineNo">1663</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1663"></a>
+<span class="sourceLineNo">1664</span>    }<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>  private void stopProcedureExecutor() {<a name="line.1668"></a>
+<span class="sourceLineNo">1669</span>    if (procedureExecutor != null) {<a name="line.1669"></a>
+<span class="sourceLineNo">1670</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1670"></a>
+<span class="sourceLineNo">1671</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1671"></a>
+<span class="sourceLineNo">1672</span>      procedureExecutor.stop();<a name="line.1672"></a>
+<span class="sourceLineNo">1673</span>      procedureExecutor.join();<a name="line.1673"></a>
+<span class="sourceLineNo">1674</span>      procedureExecutor = null;<a name="line.1674"></a>
 <span class="sourceLineNo">1675</span>    }<a name="line.1675"></a>
-<span class="sourceLineNo">1676</span>  }<a name="line.1676"></a>
-<span class="sourceLineNo">1677</span><a name="line.1677"></a>
-<span class="sourceLineNo">1678</span>  private void stopChores() {<a name="line.1678"></a>
-<span class="sourceLineNo">1679</span>    if (getChoreService() != null) {<a name="line.1679"></a>
-<span class="sourceLineNo">1680</span>      shutdownChore(mobFileCleanerChore);<a name="line.1680"></a>
-<span class="sourceLineNo">1681</span>      shutdownChore(mobFileCompactionChore);<a name="line.1681"></a>
-<span class="sourceLineNo">1682</span>      shutdownChore(balancerChore);<a name="line.1682"></a>
-<span class="sourceLineNo">1683</span>      if (regionNormalizerManager != null) {<a name="line.1683"></a>
-<span class="sourceLineNo">1684</span>        shutdownChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1684"></a>
-<span class="sourceLineNo">1685</span>      }<a name="line.1685"></a>
-<span class="sourceLineNo">1686</span>      shutdownChore(clusterStatusChore);<a name="line.1686"></a>
-<span class="sourceLineNo">1687</span>      shutdownChore(catalogJanitorChore);<a name="line.1687"></a>
-<span class="sourceLineNo">1688</span>      shutdownChore(clusterStatusPublisherChore);<a name="line.1688"></a>
-<span class="sourceLineNo">1689</span>      shutdownChore(snapshotQuotaChore);<a name="line.1689"></a>
-<span class="sourceLineNo">1690</span>      shutdownChore(logCleaner);<a name="line.1690"></a>
-<span class="sourceLineNo">1691</span>      shutdownChore(hfileCleaner);<a name="line.1691"></a>
-<span class="sourceLineNo">1692</span>      shutdownChore(replicationBarrierCleaner);<a name="line.1692"></a>
-<span class="sourceLineNo">1693</span>      shutdownChore(snapshotCleanerChore);<a name="line.1693"></a>
-<span class="sourceLineNo">1694</span>      shutdownChore(hbckChore);<a name="line.1694"></a>
-<span class="sourceLineNo">1695</span>      shutdownChore(regionsRecoveryChore);<a name="line.1695"></a>
-<span class="sourceLineNo">1696</span>    }<a name="line.1696"></a>
-<span class="sourceLineNo">1697</span>  }<a name="line.1697"></a>
-<span class="sourceLineNo">1698</span><a name="line.1698"></a>
-<span class="sourceLineNo">1699</span>  /**<a name="line.1699"></a>
-<span class="sourceLineNo">1700</span>   * @return Get remote side's InetAddress<a name="line.1700"></a>
-<span class="sourceLineNo">1701</span>   */<a name="line.1701"></a>
-<span class="sourceLineNo">1702</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1702"></a>
-<span class="sourceLineNo">1703</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1703"></a>
-<span class="sourceLineNo">1704</span>    // Do it out here in its own little method so can fake an address when<a name="line.1704"></a>
-<span class="sourceLineNo">1705</span>    // mocking up in tests.<a name="line.1705"></a>
-<span class="sourceLineNo">1706</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1706"></a>
-<span class="sourceLineNo">1707</span><a name="line.1707"></a>
-<span class="sourceLineNo">1708</span>    // The call could be from the local regionserver,<a name="line.1708"></a>
-<span class="sourceLineNo">1709</span>    // in which case, there is no remote address.<a name="line.1709"></a>
-<span class="sourceLineNo">1710</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1710"></a>
-<span class="sourceLineNo">1711</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1711"></a>
-<span class="sourceLineNo">1712</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1712"></a>
-<span class="sourceLineNo">1713</span>        ia = isa.getAddress();<a name="line.1713"></a>
-<span class="sourceLineNo">1714</span>      }<a name="line.1714"></a>
-<span class="sourceLineNo">1715</span>    }<a name="line.1715"></a>
-<span class="sourceLineNo">1716</span>    return ia;<a name="line.1716"></a>
-<span class="sourceLineNo">1717</span>  }<a name="line.1717"></a>
-<span class="sourceLineNo">1718</span><a name="line.1718"></a>
-<span class="sourceLineNo">1719</span>  /**<a name="line.1719"></a>
-<span class="sourceLineNo">1720</span>   * @return Maximum time we should run balancer for<a name="line.1720"></a>
-<span class="sourceLineNo">1721</span>   */<a name="line.1721"></a>
-<span class="sourceLineNo">1722</span>  private int getMaxBalancingTime() {<a name="line.1722"></a>
-<span class="sourceLineNo">1723</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1723"></a>
-<span class="sourceLineNo">1724</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1724"></a>
-<span class="sourceLineNo">1725</span>      getConfiguration()<a name="line.1725"></a>
-<span class="sourceLineNo">1726</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1726"></a>
-<span class="sourceLineNo">1727</span>    return maxBalancingTime;<a name="line.1727"></a>
-<span class="sourceLineNo">1728</span>  }<a name="line.1728"></a>
-<span class="sourceLineNo">1729</span><a name="line.1729"></a>
-<span class="sourceLineNo">1730</span>  /**<a name="line.1730"></a>
-<span class="sourceLineNo">1731</span>   * @return Maximum number of regions in transition<a name="line.1731"></a>
-<span class="sourceLineNo">1732</span>   */<a name="line.1732"></a>
-<span class="sourceLineNo">1733</span>  private int getMaxRegionsInTransition() {<a name="line.1733"></a>
-<span class="sourceLineNo">1734</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1734"></a>
-<span class="sourceLineNo">1735</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<a name="line.1735"></a>
-<span class="sourceLineNo">1736</span>  }<a name="line.1736"></a>
-<span class="sourceLineNo">1737</span><a name="line.1737"></a>
-<span class="sourceLineNo">1738</span>  /**<a name="line.1738"></a>
-<span class="sourceLineNo">1739</span>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1739"></a>
-<span class="sourceLineNo">1740</span>   * number regions in transition to protect availability.<a name="line.1740"></a>
-<span class="sourceLineNo">1741</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1741"></a>
-<span class="sourceLineNo">1742</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1742"></a>
-<span class="sourceLineNo">1743</span>   * @param cutoffTime when to exit balancer<a name="line.1743"></a>
-<span class="sourceLineNo">1744</span>   */<a name="line.1744"></a>
-<span class="sourceLineNo">1745</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1745"></a>
-<span class="sourceLineNo">1746</span>      long cutoffTime) {<a name="line.1746"></a>
-<span class="sourceLineNo">1747</span>    boolean interrupted = false;<a name="line.1747"></a>
-<span class="sourceLineNo">1748</span><a name="line.1748"></a>
-<span class="sourceLineNo">1749</span>    // Sleep to next balance plan start time<a name="line.1749"></a>
-<span class="sourceLineNo">1750</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1750"></a>
-<span class="sourceLineNo">1751</span>    while (!interrupted &amp;&amp; EnvironmentEdgeManager.currentTime() &lt; nextBalanceStartTime<a name="line.1751"></a>
-<span class="sourceLineNo">1752</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1752"></a>
-<span class="sourceLineNo">1753</span>      try {<a name="line.1753"></a>
-<span class="sourceLineNo">1754</span>        Thread.sleep(100);<a name="line.1754"></a>
-<span class="sourceLineNo">1755</span>      } catch (InterruptedException ie) {<a name="line.1755"></a>
-<span class="sourceLineNo">1756</span>        interrupted = true;<a name="line.1756"></a>
-<span class="sourceLineNo">1757</span>      }<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>    // Throttling by max number regions in transition<a name="line.1760"></a>
-<span class="sourceLineNo">1761</span>    while (!interrupted<a name="line.1761"></a>
-<span class="sourceLineNo">1762</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1762"></a>
-<span class="sourceLineNo">1763</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1763"></a>
-<span class="sourceLineNo">1764</span>        &gt;= maxRegionsInTransition &amp;&amp; EnvironmentEdgeManager.currentTime() &lt;= cutoffTime) {<a name="line.1764"></a>
-<span class="sourceLineNo">1765</span>      try {<a name="line.1765"></a>
-<span class="sourceLineNo">1766</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1766"></a>
-<span class="sourceLineNo">1767</span>        Thread.sleep(100);<a name="line.1767"></a>
-<span class="sourceLineNo">1768</span>      } catch (InterruptedException ie) {<a name="line.1768"></a>
-<span class="sourceLineNo">1769</span>        interrupted = true;<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>    if (interrupted) Thread.currentThread().interrupt();<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>  public BalanceResponse balance() throws IOException {<a name="line.1776"></a>
-<span class="sourceLineNo">1777</span>    return balance(BalanceRequest.defaultInstance());<a name="line.1777"></a>
-<span class="sourceLineNo">1778</span>  }<a name="line.1778"></a>
-<span class="sourceLineNo">1779</span><a name="line.1779"></a>
-<span class="sourceLineNo">1780</span>  /**<a name="line.1780"></a>
-<span class="sourceLineNo">1781</span>   * Checks master state before initiating action over region topology.<a name="line.1781"></a>
-<span class="sourceLineNo">1782</span>   * @param action the name of the action under consideration, for logging.<a name="line.1782"></a>
-<span class="sourceLineNo">1783</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1783"></a>
-<span class="sourceLineNo">1784</span>   */<a name="line.1784"></a>
-<span class="sourceLineNo">1785</span>  @Override<a name="line.1785"></a>
-<span class="sourceLineNo">1786</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1786"></a>
-<span class="sourceLineNo">1787</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1787"></a>
-<span class="sourceLineNo">1788</span>    if (!isInitialized()) {<a name="line.1788"></a>
-<span class="sourceLineNo">1789</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1789"></a>
-<span class="sourceLineNo">1790</span>      return true;<a name="line.1790"></a>
-<span class="sourceLineNo">1791</span>    }<a name="line.1791"></a>
-<span class="sourceLineNo">1792</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1792"></a>
-<span class="sourceLineNo">1793</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1793"></a>
-<span class="sourceLineNo">1794</span>      return true;<a name="line.1794"></a>
-<span class="sourceLineNo">1795</span>    }<a name="line.1795"></a>
-<span class="sourceLineNo">1796</span>    if (isInMaintenanceMode()) {<a name="line.1796"></a>
-<span class="sourceLineNo">1797</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1797"></a>
-<span class="sourceLineNo">1798</span>      return true;<a name="line.1798"></a>
-<span class="sourceLineNo">1799</span>    }<a name="line.1799"></a>
-<span class="sourceLineNo">1800</span>    return false;<a name="line.1800"></a>
-<span class="sourceLineNo">1801</span>  }<a name="line.1801"></a>
-<span class="sourceLineNo">1802</span><a name="line.1802"></a>
-<span class="sourceLineNo">1803</span>  public BalanceResponse balance(BalanceRequest request) throws IOException {<a name="line.1803"></a>
-<span class="sourceLineNo">1804</span>    BalanceResponse.Builder responseBuilder = BalanceResponse.newBuilder();<a name="line.1804"></a>
-<span class="sourceLineNo">1805</span><a name="line.1805"></a>
-<span class="sourceLineNo">1806</span>    if (loadBalancerTracker == null<a name="line.1806"></a>
-<span class="sourceLineNo">1807</span>      || !(loadBalancerTracker.isBalancerOn() || request.isDryRun())) {<a name="line.1807"></a>
-<span class="sourceLineNo">1808</span>      return responseBuilder.build();<a name="line.1808"></a>
-<span class="sourceLineNo">1809</span>    }<a name="line.1809"></a>
+<span class="sourceLineNo">1676</span><a name="line.1676"></a>
+<span class="sourceLineNo">1677</span>    if (procedureStore != null) {<a name="line.1677"></a>
+<span class="sourceLineNo">1678</span>      procedureStore.stop(isAborted());<a name="line.1678"></a>
+<span class="sourceLineNo">1679</span>      procedureStore = null;<a name="line.1679"></a>
+<span class="sourceLineNo">1680</span>    }<a name="line.1680"></a>
+<span class="sourceLineNo">1681</span>  }<a name="line.1681"></a>
+<span class="sourceLineNo">1682</span><a name="line.1682"></a>
+<span class="sourceLineNo">1683</span>  private void stopChores() {<a name="line.1683"></a>
+<span class="sourceLineNo">1684</span>    if (getChoreService() != null) {<a name="line.1684"></a>
+<span class="sourceLineNo">1685</span>      shutdownChore(mobFileCleanerChore);<a name="line.1685"></a>
+<span class="sourceLineNo">1686</span>      shutdownChore(mobFileCompactionChore);<a name="line.1686"></a>
+<span class="sourceLineNo">1687</span>      shutdownChore(balancerChore);<a name="line.1687"></a>
+<span class="sourceLineNo">1688</span>      if (regionNormalizerManager != null) {<a name="line.1688"></a>
+<span class="sourceLineNo">1689</span>        shutdownChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1689"></a>
+<span class="sourceLineNo">1690</span>      }<a name="line.1690"></a>
+<span class="sourceLineNo">1691</span>      shutdownChore(clusterStatusChore);<a name="line.1691"></a>
+<span class="sourceLineNo">1692</span>      shutdownChore(catalogJanitorChore);<a name="line.1692"></a>
+<span class="sourceLineNo">1693</span>      shutdownChore(clusterStatusPublisherChore);<a name="line.1693"></a>
+<span class="sourceLineNo">1694</span>      shutdownChore(snapshotQuotaChore);<a name="line.1694"></a>
+<span class="sourceLineNo">1695</span>      shutdownChore(logCleaner);<a name="line.1695"></a>
+<span class="sourceLineNo">1696</span>      shutdownChore(hfileCleaner);<a name="line.1696"></a>
+<span class="sourceLineNo">1697</span>      shutdownChore(replicationBarrierCleaner);<a name="line.1697"></a>
+<span class="sourceLineNo">1698</span>      shutdownChore(snapshotCleanerChore);<a name="line.1698"></a>
+<span class="sourceLineNo">1699</span>      shutdownChore(hbckChore);<a name="line.1699"></a>
+<span class="sourceLineNo">1700</span>      shutdownChore(regionsRecoveryChore);<a name="line.1700"></a>
+<span class="sourceLineNo">1701</span>    }<a name="line.1701"></a>
+<span class="sourceLineNo">1702</span>  }<a name="line.1702"></a>
+<span class="sourceLineNo">1703</span><a name="line.1703"></a>
+<span class="sourceLineNo">1704</span>  /**<a name="line.1704"></a>
+<span class="sourceLineNo">1705</span>   * @return Get remote side's InetAddress<a name="line.1705"></a>
+<span class="sourceLineNo">1706</span>   */<a name="line.1706"></a>
+<span class="sourceLineNo">1707</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1707"></a>
+<span class="sourceLineNo">1708</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1708"></a>
+<span class="sourceLineNo">1709</span>    // Do it out here in its own little method so can fake an address when<a name="line.1709"></a>
+<span class="sourceLineNo">1710</span>    // mocking up in tests.<a name="line.1710"></a>
+<span class="sourceLineNo">1711</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1711"></a>
+<span class="sourceLineNo">1712</span><a name="line.1712"></a>
+<span class="sourceLineNo">1713</span>    // The call could be from the local regionserver,<a name="line.1713"></a>
+<span class="sourceLineNo">1714</span>    // in which case, there is no remote address.<a name="line.1714"></a>
+<span class="sourceLineNo">1715</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1715"></a>
+<span class="sourceLineNo">1716</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1716"></a>
+<span class="sourceLineNo">1717</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1717"></a>
+<span class="sourceLineNo">1718</span>        ia = isa.getAddress();<a name="line.1718"></a>
+<span class="sourceLineNo">1719</span>      }<a name="line.1719"></a>
+<span class="sourceLineNo">1720</span>    }<a name="line.1720"></a>
+<span class="sourceLineNo">1721</span>    return ia;<a name="line.1721"></a>
+<span class="sourceLineNo">1722</span>  }<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 Maximum time we should run balancer for<a name="line.1725"></a>
+<span class="sourceLineNo">1726</span>   */<a name="line.1726"></a>
+<span class="sourceLineNo">1727</span>  private int getMaxBalancingTime() {<a name="line.1727"></a>
+<span class="sourceLineNo">1728</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1728"></a>
+<span class="sourceLineNo">1729</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1729"></a>
+<span class="sourceLineNo">1730</span>      getConfiguration()<a name="line.1730"></a>
+<span class="sourceLineNo">1731</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1731"></a>
+<span class="sourceLineNo">1732</span>    return maxBalancingTime;<a name="line.1732"></a>
+<span class="sourceLineNo">1733</span>  }<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>   * @return Maximum number of regions in transition<a name="line.1736"></a>
+<span class="sourceLineNo">1737</span>   */<a name="line.1737"></a>
+<span class="sourceLineNo">1738</span>  private int getMaxRegionsInTransition() {<a name="line.1738"></a>
+<span class="sourceLineNo">1739</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1739"></a>
+<span class="sourceLineNo">1740</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<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>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1744"></a>
+<span class="sourceLineNo">1745</span>   * number regions in transition to protect availability.<a name="line.1745"></a>
+<span class="sourceLineNo">1746</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1746"></a>
+<span class="sourceLineNo">1747</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1747"></a>
+<span class="sourceLineNo">1748</span>   * @param cutoffTime when to exit balancer<a name="line.1748"></a>
+<span class="sourceLineNo">1749</span>   */<a name="line.1749"></a>
+<span class="sourceLineNo">1750</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1750"></a>
+<span class="sourceLineNo">1751</span>      long cutoffTime) {<a name="line.1751"></a>
+<span class="sourceLineNo">1752</span>    boolean interrupted = false;<a name="line.1752"></a>
+<span class="sourceLineNo">1753</span><a name="line.1753"></a>
+<span class="sourceLineNo">1754</span>    // Sleep to next balance plan start time<a name="line.1754"></a>
+<span class="sourceLineNo">1755</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1755"></a>
+<span class="sourceLineNo">1756</span>    while (!interrupted &amp;&amp; EnvironmentEdgeManager.currentTime() &lt; nextBalanceStartTime<a name="line.1756"></a>
+<span class="sourceLineNo">1757</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1757"></a>
+<span class="sourceLineNo">1758</span>      try {<a name="line.1758"></a>
+<span class="sourceLineNo">1759</span>        Thread.sleep(100);<a name="line.1759"></a>
+<span class="sourceLineNo">1760</span>      } catch (InterruptedException ie) {<a name="line.1760"></a>
+<span class="sourceLineNo">1761</span>        interrupted = true;<a name="line.1761"></a>
+<span class="sourceLineNo">1762</span>      }<a name="line.1762"></a>
+<span class="sourceLineNo">1763</span>    }<a name="line.1763"></a>
+<span class="sourceLineNo">1764</span><a name="line.1764"></a>
+<span class="sourceLineNo">1765</span>    // Throttling by max number regions in transition<a name="line.1765"></a>
+<span class="sourceLineNo">1766</span>    while (!interrupted<a name="line.1766"></a>
+<span class="sourceLineNo">1767</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1767"></a>
+<span class="sourceLineNo">1768</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1768"></a>
+<span class="sourceLineNo">1769</span>        &gt;= maxRegionsInTransition &amp;&amp; EnvironmentEdgeManager.currentTime() &lt;= cutoffTime) {<a name="line.1769"></a>
+<span class="sourceLineNo">1770</span>      try {<a name="line.1770"></a>
+<span class="sourceLineNo">1771</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1771"></a>
+<span class="sourceLineNo">1772</span>        Thread.sleep(100);<a name="line.1772"></a>
+<span class="sourceLineNo">1773</span>      } catch (InterruptedException ie) {<a name="line.1773"></a>
+<span class="sourceLineNo">1774</span>        interrupted = true;<a name="line.1774"></a>
+<span class="sourceLineNo">1775</span>      }<a name="line.1775"></a>
+<span class="sourceLineNo">1776</span>    }<a name="line.1776"></a>
+<span class="sourceLineNo">1777</span><a name="line.1777"></a>
+<span class="sourceLineNo">1778</span>    if (interrupted) Thread.currentThread().interrupt();<a name="line.1778"></a>
+<span class="sourceLineNo">1779</span>  }<a name="line.1779"></a>
+<span class="sourceLineNo">1780</span><a name="line.1780"></a>
+<span class="sourceLineNo">1781</span>  public BalanceResponse balance() throws IOException {<a name="line.1781"></a>
+<span class="sourceLineNo">1782</span>    return balance(BalanceRequest.defaultInstance());<a name="line.1782"></a>
+<span class="sourceLineNo">1783</span>  }<a name="line.1783"></a>
+<span class="sourceLineNo">1784</span><a name="line.1784"></a>
+<span class="sourceLineNo">1785</span>  /**<a name="line.1785"></a>
+<span class="sourceLineNo">1786</span>   * Checks master state before initiating action over region topology.<a name="line.1786"></a>
+<span class="sourceLineNo">1787</span>   * @param action the name of the action under consideration, for logging.<a name="line.1787"></a>
+<span class="sourceLineNo">1788</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1788"></a>
+<span class="sourceLineNo">1789</span>   */<a name="line.1789"></a>
+<span class="sourceLineNo">1790</span>  @Override<a name="line.1790"></a>
+<span class="sourceLineNo">1791</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1791"></a>
+<span class="sourceLineNo">1792</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1792"></a>
+<span class="sourceLineNo">1793</span>    if (!isInitialized()) {<a name="line.1793"></a>
+<span class="sourceLineNo">1794</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1794"></a>
+<span class="sourceLineNo">1795</span>      return true;<a name="line.1795"></a>
+<span class="sourceLineNo">1796</span>    }<a name="line.1796"></a>
+<span class="sourceLineNo">1797</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1797"></a>
+<span class="sourceLineNo">1798</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1798"></a>
+<span class="sourceLineNo">1799</span>      return true;<a name="line.1799"></a>
+<span class="sourceLineNo">1800</span>    }<a name="line.1800"></a>
+<span class="sourceLineNo">1801</span>    if (isInMaintenanceMode()) {<a name="line.1801"></a>
+<span class="sourceLineNo">1802</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1802"></a>
+<span class="sourceLineNo">1803</span>      return true;<a name="line.1803"></a>
+<span class="sourceLineNo">1804</span>    }<a name="line.1804"></a>
+<span class="sourceLineNo">1805</span>    return false;<a name="line.1805"></a>
+<span class="sourceLineNo">1806</span>  }<a name="line.1806"></a>
+<span class="sourceLineNo">1807</span><a name="line.1807"></a>
+<span class="sourceLineNo">1808</span>  public BalanceResponse balance(BalanceRequest request) throws IOException {<a name="line.1808"></a>
+<span class="sourceLineNo">1809</span>    BalanceResponse.Builder responseBuilder = BalanceResponse.newBuilder();<a name="line.1809"></a>
 <span class="sourceLineNo">1810</span><a name="line.1810"></a>
-<span class="sourceLineNo">1811</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1811"></a>
-<span class="sourceLineNo">1812</span>      return responseBuilder.build();<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>    synchronized (this.balancer) {<a name="line.1815"></a>
-<span class="sourceLineNo">1816</span>        // Only allow one balance run at at time.<a name="line.1816"></a>
-<span class="sourceLineNo">1817</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1817"></a>
-<span class="sourceLineNo">1818</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1818"></a>
-<span class="sourceLineNo">1819</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1819"></a>
-<span class="sourceLineNo">1820</span>        // ignore the force flag in that case<a name="line.1820"></a>
-<span class="sourceLineNo">1821</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1821"></a>
-<span class="sourceLineNo">1822</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1822"></a>
-<span class="sourceLineNo">1823</span>        int max = 5;<a name="line.1823"></a>
-<span class="sourceLineNo">1824</span>        boolean truncated = false;<a name="line.1824"></a>
-<span class="sourceLineNo">1825</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1825"></a>
-<span class="sourceLineNo">1826</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1826"></a>
-<span class="sourceLineNo">1827</span>          truncated = true;<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>        if (!request.isIgnoreRegionsInTransition() || metaInTransition) {<a name="line.1830"></a>
-<span class="sourceLineNo">1831</span>          LOG.info("Not running balancer (ignoreRIT=false" + ", metaRIT=" + metaInTransition +<a name="line.1831"></a>
-<span class="sourceLineNo">1832</span>            ") because " + regionsInTransition.size() + " region(s) in transition: " + toPrint<a name="line.1832"></a>
-<span class="sourceLineNo">1833</span>            + (truncated? "(truncated list)": ""));<a name="line.1833"></a>
-<span class="sourceLineNo">1834</span>          return responseBuilder.build();<a name="line.1834"></a>
-<span class="sourceLineNo">1835</span>        }<a name="line.1835"></a>
-<span class="sourceLineNo">1836</span>      }<a name="line.1836"></a>
-<span class="sourceLineNo">1837</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1837"></a>
-<span class="sourceLineNo">1838</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1838"></a>
-<span class="sourceLineNo">1839</span>          this.serverManager.getDeadServers());<a name="line.1839"></a>
-<span class="sourceLineNo">1840</span>        return responseBuilder.build();<a name="line.1840"></a>
+<span class="sourceLineNo">1811</span>    if (loadBalancerTracker == null<a name="line.1811"></a>
+<span class="sourceLineNo">1812</span>      || !(loadBalancerTracker.isBalancerOn() || request.isDryRun())) {<a name="line.1812"></a>
+<span class="sourceLineNo">1813</span>      return responseBuilder.build();<a name="line.1813"></a>
+<span class="sourceLineNo">1814</span>    }<a name="line.1814"></a>
+<span class="sourceLineNo">1815</span><a name="line.1815"></a>
+<span class="sourceLineNo">1816</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1816"></a>
+<span class="sourceLineNo">1817</span>      return responseBuilder.build();<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>    synchronized (this.balancer) {<a name="line.1820"></a>
+<span class="sourceLineNo">1821</span>        // Only allow one balance run at at time.<a name="line.1821"></a>
+<span class="sourceLineNo">1822</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1822"></a>
+<span class="sourceLineNo">1823</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1823"></a>
+<span class="sourceLineNo">1824</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1824"></a>
+<span class="sourceLineNo">1825</span>        // ignore the force flag in that case<a name="line.1825"></a>
+<span class="sourceLineNo">1826</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1826"></a>
+<span class="sourceLineNo">1827</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1827"></a>
+<span class="sourceLineNo">1828</span>        int max = 5;<a name="line.1828"></a>
+<span class="sourceLineNo">1829</span>        boolean truncated = false;<a name="line.1829"></a>
+<span class="sourceLineNo">1830</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1830"></a>
+<span class="sourceLineNo">1831</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1831"></a>
+<span class="sourceLineNo">1832</span>          truncated = true;<a name="line.1832"></a>
+<span class="sourceLineNo">1833</span>        }<a name="line.1833"></a>
+<span class="sourceLineNo">1834</span><a name="line.1834"></a>
+<span class="sourceLineNo">1835</span>        if (!request.isIgnoreRegionsInTransition() || metaInTransition) {<a name="line.1835"></a>
+<span class="sourceLineNo">1836</span>          LOG.info("Not running balancer (ignoreRIT=false" + ", metaRIT=" + metaInTransition +<a name="line.1836"></a>
+<span class="sourceLineNo">1837</span>            ") because " + regionsInTransition.size() + " region(s) in transition: " + toPrint<a name="line.1837"></a>
+<span class="sourceLineNo">1838</span>            + (truncated? "(truncated list)": ""));<a name="line.1838"></a>
+<span class="sourceLineNo">1839</span>          return responseBuilder.build();<a name="line.1839"></a>
+<span class="sourceLineNo">1840</span>        }<a name="line.1840"></a>
 <span class="sourceLineNo">1841</span>      }<a name="line.1841"></a>
-<span class="sourceLineNo">1842</span><a name="line.1842"></a>
-<span class="sourceLineNo">1843</span>      if (this.cpHost != null) {<a name="line.1843"></a>
-<span class="sourceLineNo">1844</span>        try {<a name="line.1844"></a>
-<span class="sourceLineNo">1845</span>          if (this.cpHost.preBalance(request)) {<a name="line.1845"></a>
-<span class="sourceLineNo">1846</span>            LOG.debug("Coprocessor bypassing balancer request");<a name="line.1846"></a>
-<span class="sourceLineNo">1847</span>            return responseBuilder.build();<a name="line.1847"></a>
-<span class="sourceLineNo">1848</span>          }<a name="line.1848"></a>
-<span class="sourceLineNo">1849</span>        } catch (IOException ioe) {<a name="line.1849"></a>
-<span class="sourceLineNo">1850</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<a name="line.1850"></a>
-<span class="sourceLineNo">1851</span>          return responseBuilder.build();<a name="line.1851"></a>
-<span class="sourceLineNo">1852</span>        }<a name="line.1852"></a>
-<span class="sourceLineNo">1853</span>      }<a name="line.1853"></a>
-<span class="sourceLineNo">1854</span><a name="line.1854"></a>
-<span class="sourceLineNo">1855</span>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1855"></a>
-<span class="sourceLineNo">1856</span>        this.assignmentManager.getRegionStates()<a name="line.1856"></a>
-<span class="sourceLineNo">1857</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1857"></a>
-<span class="sourceLineNo">1858</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1858"></a>
-<span class="sourceLineNo">1859</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<a name="line.1859"></a>
-<span class="sourceLineNo">1860</span>      }<a name="line.1860"></a>
-<span class="sourceLineNo">1861</span><a name="line.1861"></a>
-<span class="sourceLineNo">1862</span>      //Give the balancer the current cluster state.<a name="line.1862"></a>
-<span class="sourceLineNo">1863</span>      this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1863"></a>
-<span class="sourceLineNo">1864</span><a name="line.1864"></a>
-<span class="sourceLineNo">1865</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<a name="line.1865"></a>
+<span class="sourceLineNo">1842</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1842"></a>
+<span class="sourceLineNo">1843</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1843"></a>
+<span class="sourceLineNo">1844</span>          this.serverManager.getDeadServers());<a name="line.1844"></a>
+<span class="sourceLineNo">1845</span>        return responseBuilder.build();<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>      if (this.cpHost != null) {<a name="line.1848"></a>
+<span class="sourceLineNo">1849</span>        try {<a name="line.1849"></a>
+<span class="sourceLineNo">1850</span>          if (this.cpHost.preBalance(request)) {<a name="line.1850"></a>
+<span class="sourceLineNo">1851</span>            LOG.debug("Coprocessor bypassing balancer request");<a name="line.1851"></a>
+<span class="sourceLineNo">1852</span>            return responseBuilder.build();<a name="line.1852"></a>
+<span class="sourceLineNo">1853</span>          }<a name="line.1853"></a>
+<span class="sourceLineNo">1854</span>        } catch (IOException ioe) {<a name="line.1854"></a>
+<span class="sourceLineNo">1855</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<a name="line.1855"></a>
+<span class="sourceLineNo">1856</span>          return responseBuilder.build();<a name="line.1856"></a>
+<span class="sourceLineNo">1857</span>        }<a name="line.1857"></a>
+<span class="sourceLineNo">1858</span>      }<a name="line.1858"></a>
+<span class="sourceLineNo">1859</span><a name="line.1859"></a>
+<span class="sourceLineNo">1860</span>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1860"></a>
+<span class="sourceLineNo">1861</span>        this.assignmentManager.getRegionStates()<a name="line.1861"></a>
+<span class="sourceLineNo">1862</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1862"></a>
+<span class="sourceLineNo">1863</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1863"></a>
+<span class="sourceLineNo">1864</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<a name="line.1864"></a>
+<span class="sourceLineNo">1865</span>      }<a name="line.1865"></a>
 <span class="sourceLineNo">1866</span><a name="line.1866"></a>
-<span class="sourceLineNo">1867</span>      responseBuilder.setBalancerRan(true).setMovesCalculated(plans == null ? 0 : plans.size());<a name="line.1867"></a>
-<span class="sourceLineNo">1868</span><a name="line.1868"></a>
-<span class="sourceLineNo">1869</span>      if (skipRegionManagementAction("balancer")) {<a name="line.1869"></a>
-<span class="sourceLineNo">1870</span>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1870"></a>
-<span class="sourceLineNo">1871</span>        return responseBuilder.build();<a name="line.1871"></a>
-<span class="sourceLineNo">1872</span>      }<a name="line.1872"></a>
+<span class="sourceLineNo">1867</span>      //Give the balancer the current cluster state.<a name="line.1867"></a>
+<span class="sourceLineNo">1868</span>      this.balancer.updateClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1868"></a>
+<span class="sourceLineNo">1869</span><a name="line.1869"></a>
+<span class="sourceLineNo">1870</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<a name="line.1870"></a>
+<span class="sourceLineNo">1871</span><a name="line.1871"></a>
+<span class="sourceLineNo">1872</span>      responseBuilder.setBalancerRan(true).setMovesCalculated(plans == null ? 0 : plans.size());<a name="line.1872"></a>
 <span class="sourceLineNo">1873</span><a name="line.1873"></a>
-<span class="sourceLineNo">1874</span>      // For dry run we don't actually want to execute the moves, but we do want<a name="line.1874"></a>
-<span class="sourceLineNo">1875</span>      // to execute the coprocessor below<a name="line.1875"></a>
-<span class="sourceLineNo">1876</span>      List&lt;RegionPlan&gt; sucRPs = request.isDryRun()<a name="line.1876"></a>
-<span class="sourceLineNo">1877</span>        ? Collections.emptyList()<a name="line.1877"></a>
-<span class="sourceLineNo">1878</span>        : executeRegionPlansWithThrottling(plans);<a name="line.1878"></a>
-<span class="sourceLineNo">1879</span><a name="line.1879"></a>
-<span class="sourceLineNo">1880</span>      if (this.cpHost != null) {<a name="line.1880"></a>
-<span class="sourceLineNo">1881</span>        try {<a name="line.1881"></a>
-<span class="sourceLineNo">1882</span>          this.cpHost.postBalance(request, sucRPs);<a name="line.1882"></a>
-<span class="sourceLineNo">1883</span>        } catch (IOException ioe) {<a name="line.1883"></a>
-<span class="sourceLineNo">1884</span>          // balancing already succeeded so don't change the result<a name="line.1884"></a>
-<span class="sourceLineNo">1885</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<a name="line.1885"></a>
-<span class="sourceLineNo">1886</span>        }<a name="line.1886"></a>
-<span class="sourceLineNo">1887</span>      }<a name="line.1887"></a>
-<span class="sourceLineNo">1888</span><a name="line.1888"></a>
-<span class="sourceLineNo">1889</span>      responseBuilder.setMovesExecuted(sucRPs.size());<a name="line.1889"></a>
-<span class="sourceLineNo">1890</span>    }<a name="line.1890"></a>
-<span class="sourceLineNo">1891</span><a name="line.1891"></a>
-<span class="sourceLineNo">1892</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1892"></a>
-<span class="sourceLineNo">1893</span>    // Return true indicating a success.<a name="line.1893"></a>
-<span class="sourceLineNo">1894</span>    return responseBuilder.build();<a name="line.1894"></a>
-<span class="sourceLineNo">1895</span>  }<a name="line.1895"></a>
+<span class="sourceLineNo">1874</span>      if (skipRegionManagementAction("balancer")) {<a name="line.1874"></a>
+<span class="sourceLineNo">1875</span>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1875"></a>
+<span class="sourceLineNo">1876</span>        return responseBuilder.build();<a name="line.1876"></a>
+<span class="sourceLineNo">1877</span>      }<a name="line.1877"></a>
+<span class="sourceLineNo">1878</span><a name="line.1878"></a>
+<span class="sourceLineNo">1879</span>      // For dry run we don't actually want to execute the moves, but we do want<a name="line.1879"></a>
+<span class="sourceLineNo">1880</span>      // to execute the coprocessor below<a name="line.1880"></a>
+<span class="sourceLineNo">1881</span>      List&lt;RegionPlan&gt; sucRPs = request.isDryRun()<a name="line.1881"></a>
+<span class="sourceLineNo">1882</span>        ? Collections.emptyList()<a name="line.1882"></a>
+<span class="sourceLineNo">1883</span>        : executeRegionPlansWithThrottling(plans);<a name="line.1883"></a>
+<span class="sourceLineNo">1884</span><a name="line.1884"></a>
+<span class="sourceLineNo">1885</span>      if (this.cpHost != null) {<a name="line.1885"></a>
+<span class="sourceLineNo">1886</span>        try {<a name="line.1886"></a>
+<span class="sourceLineNo">1887</span>          this.cpHost.postBalance(request, sucRPs);<a name="line.1887"></a>
+<span class="sourceLineNo">1888</span>        } catch (IOException ioe) {<a name="line.1888"></a>
+<span class="sourceLineNo">1889</span>          // balancing already succeeded so don't change the result<a name="line.1889"></a>
+<span class="sourceLineNo">1890</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<a name="line.1890"></a>
+<span class="sourceLineNo">1891</span>        }<a name="line.1891"></a>
+<span class="sourceLineNo">1892</span>      }<a name="line.1892"></a>
+<span class="sourceLineNo">1893</span><a name="line.1893"></a>
+<span class="sourceLineNo">1894</span>      responseBuilder.setMovesExecuted(sucRPs.size());<a name="line.1894"></a>
+<span class="sourceLineNo">1895</span>    }<a name="line.1895"></a>
 <span class="sourceLineNo">1896</span><a name="line.1896"></a>
-<span class="sourceLineNo">1897</span>  /**<a name="line.1897"></a>
-<span class="sourceLineNo">1898</span>   * Execute region plans with throttling<a name="line.1898"></a>
-<span class="sourceLineNo">1899</span>   * @param plans to execute<a name="line.1899"></a>
-<span class="sourceLineNo">1900</span>   * @return succeeded plans<a name="line.1900"></a>
-<span class="sourceLineNo">1901</span>   */<a name="line.1901"></a>
-<span class="sourceLineNo">1902</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1902"></a>
-<span class="sourceLineNo">1903</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1903"></a>
-<span class="sourceLineNo">1904</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1904"></a>
-<span class="sourceLineNo">1905</span>    long balanceStartTime = EnvironmentEdgeManager.currentTime();<a name="line.1905"></a>
-<span class="sourceLineNo">1906</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1906"></a>
-<span class="sourceLineNo">1907</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1907"></a>
-<span class="sourceLineNo">1908</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1908"></a>
-<span class="sourceLineNo">1909</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1909"></a>
-<span class="sourceLineNo">1910</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1910"></a>
-<span class="sourceLineNo">1911</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1911"></a>
-<span class="sourceLineNo">1912</span>          + maxRegionsInTransition);<a name="line.1912"></a>
-<span class="sourceLineNo">1913</span><a name="line.1913"></a>
-<span class="sourceLineNo">1914</span>      for (RegionPlan plan: plans) {<a name="line.1914"></a>
-<span class="sourceLineNo">1915</span>        LOG.info("balance " + plan);<a name="line.1915"></a>
-<span class="sourceLineNo">1916</span>        //TODO: bulk assign<a name="line.1916"></a>
-<span class="sourceLineNo">1917</span>        try {<a name="line.1917"></a>
-<span class="sourceLineNo">1918</span>          this.assignmentManager.balance(plan);<a name="line.1918"></a>
-<span class="sourceLineNo">1919</span>        } catch (HBaseIOException hioe) {<a name="line.1919"></a>
-<span class="sourceLineNo">1920</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1920"></a>
-<span class="sourceLineNo">1921</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1921"></a>
-<span class="sourceLineNo">1922</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1922"></a>
-<span class="sourceLineNo">1923</span>        }<a name="line.1923"></a>
-<span class="sourceLineNo">1924</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1924"></a>
-<span class="sourceLineNo">1925</span>        rpCount++;<a name="line.1925"></a>
-<span class="sourceLineNo">1926</span>        successRegionPlans.add(plan);<a name="line.1926"></a>
-<span class="sourceLineNo">1927</span><a name="line.1927"></a>
-<span class="sourceLineNo">1928</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1928"></a>
-<span class="sourceLineNo">1929</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1929"></a>
-<span class="sourceLineNo">1930</span>            cutoffTime);<a name="line.1930"></a>
-<span class="sourceLineNo">1931</span>        }<a name="line.1931"></a>
+<span class="sourceLineNo">1897</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1897"></a>
+<span class="sourceLineNo">1898</span>    // Return true indicating a success.<a name="line.1898"></a>
+<span class="sourceLineNo">1899</span>    return responseBuilder.build();<a name="line.1899"></a>
+<span class="sourceLineNo">1900</span>  }<a name="line.1900"></a>
+<span class="sourceLineNo">1901</span><a name="line.1901"></a>
+<span class="sourceLineNo">1902</span>  /**<a name="line.1902"></a>
+<span class="sourceLineNo">1903</span>   * Execute region plans with throttling<a name="line.1903"></a>
+<span class="sourceLineNo">1904</span>   * @param plans to execute<a name="line.1904"></a>
+<span class="sourceLineNo">1905</span>   * @return succeeded plans<a name="line.1905"></a>
+<span class="sourceLineNo">1906</span>   */<a name="line.1906"></a>
+<span class="sourceLineNo">1907</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1907"></a>
+<span class="sourceLineNo">1908</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1908"></a>
+<span class="sourceLineNo">1909</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1909"></a>
+<span class="sourceLineNo">1910</span>    long balanceStartTime = EnvironmentEdgeManager.currentTime();<a name="line.1910"></a>
+<span class="sourceLineNo">1911</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1911"></a>
+<span class="sourceLineNo">1912</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1912"></a>
+<span class="sourceLineNo">1913</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1913"></a>
+<span class="sourceLineNo">1914</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1914"></a>
+<span class="sourceLineNo">1915</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1915"></a>
+<span class="sourceLineNo">1916</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1916"></a>
+<span class="sourceLineNo">1917</span>          + maxRegionsInTransition);<a name="line.1917"></a>
+<span class="sourceLineNo">1918</span><a name="line.1918"></a>
+<span class="sourceLineNo">1919</span>      for (RegionPlan plan: plans) {<a name="line.1919"></a>
+<span class="sourceLineNo">1920</span>        LOG.info("balance " + plan);<a name="line.1920"></a>
+<span class="sourceLineNo">1921</span>        //TODO: bulk assign<a name="line.1921"></a>
+<span class="sourceLineNo">1922</span>        try {<a name="line.1922"></a>
+<span class="sourceLineNo">1923</span>          this.assignmentManager.balance(plan);<a name="line.1923"></a>
+<span class="sourceLineNo">1924</span>        } catch (HBaseIOException hioe) {<a name="line.1924"></a>
+<span class="sourceLineNo">1925</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1925"></a>
+<span class="sourceLineNo">1926</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1926"></a>
+<span class="sourceLineNo">1927</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1927"></a>
+<span class="sourceLineNo">1928</span>        }<a name="line.1928"></a>
+<span class="sourceLineNo">1929</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1929"></a>
+<span class="sourceLineNo">1930</span>        rpCount++;<a name="line.1930"></a>
+<span class="sourceLineNo">1931</span>        successRegionPlans.add(plan);<a name="line.1931"></a>
 <span class="sourceLineNo">1932</span><a name="line.1932"></a>
-<span class="sourceLineNo">1933</span>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1933"></a>
-<span class="sourceLineNo">1934</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1934"></a>
-<span class="sourceLineNo">1935</span>          &amp;&amp; EnvironmentEdgeManager.currentTime() &gt; cutoffTime) {<a name="line.1935"></a>
-<span class="sourceLineNo">1936</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1936"></a>
-<span class="sourceLineNo">1937</span>          // a security net for now)<a name="line.1937"></a>
-<span class="sourceLineNo">1938</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1938"></a>
-<span class="sourceLineNo">1939</span>              + this.maxBalancingTime);<a name="line.1939"></a>
-<span class="sourceLineNo">1940</span>          break;<a name="line.1940"></a>
-<span class="sourceLineNo">1941</span>        }<a name="line.1941"></a>
-<span class="sourceLineNo">1942</span>      }<a name="line.1942"></a>
-<span class="sourceLineNo">1943</span>    }<a name="line.1943"></a>
-<span class="sourceLineNo">1944</span>    LOG.info("Balancer is going into sleep until next period in {}ms", getConfiguration()<a name="line.1944"></a>
-<span class="sourceLineNo">1945</span>      .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1945"></a>
-<span class="sourceLineNo">1946</span>    return successRegionPlans;<a name="line.1946"></a>
-<span class="sourceLineNo">1947</span>  }<a name="line.1947"></a>
-<span class="sourceLineNo">1948</span><a name="line.1948"></a>
-<span class="sourceLineNo">1949</span>  @Override<a name="line.1949"></a>
-<span class="sourceLineNo">1950</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1950"></a>
-<span class="sourceLineNo">1951</span>    return regionNormalizerManager;<a name="line.1951"></a>
+<span class="sourceLineNo">1933</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1933"></a>
+<span class="sourceLineNo">1934</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1934"></a>
+<span class="sourceLineNo">1935</span>            cutoffTime);<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>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1938"></a>
+<span class="sourceLineNo">1939</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1939"></a>
+<span class="sourceLineNo">1940</span>          &amp;&amp; EnvironmentEdgeManager.currentTime() &gt; cutoffTime) {<a name="line.1940"></a>
+<span class="sourceLineNo">1941</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1941"></a>
+<span class="sourceLineNo">1942</span>          // a security net for now)<a name="line.1942"></a>
+<span class="sourceLineNo">1943</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1943"></a>
+<span class="sourceLineNo">1944</span>              + this.maxBalancingTime);<a name="line.1944"></a>
+<span class="sourceLineNo">1945</span>          break;<a name="line.1945"></a>
+<span class="sourceLineNo">1946</span>        }<a name="line.1946"></a>
+<span class="sourceLineNo">1947</span>      }<a name="line.1947"></a>
+<span class="sourceLineNo">1948</span>    }<a name="line.1948"></a>
+<span class="sourceLineNo">1949</span>    LOG.info("Balancer is going into sleep until next period in {}ms", getConfiguration()<a name="line.1949"></a>
+<span class="sourceLineNo">1950</span>      .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1950"></a>
+<span class="sourceLineNo">1951</span>    return successRegionPlans;<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>  @Override<a name="line.1954"></a>
-<span class="sourceLineNo">1955</span>  public boolean normalizeRegions(<a name="line.1955"></a>
-<span class="sourceLineNo">1956</span>    final NormalizeTableFilterParams ntfp,<a name="line.1956"></a>
-<span class="sourceLineNo">1957</span>    final boolean isHighPriority<a name="line.1957"></a>
-<span class="sourceLineNo">1958</span>  ) throws IOException {<a name="line.1958"></a>
-<span class="sourceLineNo">1959</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1959"></a>
-<span class="sourceLineNo">1960</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1960"></a>
-<span class="sourceLineNo">1961</span>      return false;<a name="line.1961"></a>
-<span class="sourceLineNo">1962</span>    }<a name="line.1962"></a>
-<span class="sourceLineNo">1963</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1963"></a>
-<span class="sourceLineNo">1964</span>      return false;<a name="line.1964"></a>
-<span class="sourceLineNo">1965</span>    }<a name="line.1965"></a>
-<span class="sourceLineNo">1966</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1966"></a>
-<span class="sourceLineNo">1967</span>      return false;<a name="line.1967"></a>
-<span class="sourceLineNo">1968</span>    }<a name="line.1968"></a>
-<span class="sourceLineNo">1969</span><a name="line.1969"></a>
-<span class="sourceLineNo">1970</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1970"></a>
-<span class="sourceLineNo">1971</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1971"></a>
-<span class="sourceLineNo">1972</span>      .stream()<a name="line.1972"></a>
-<span class="sourceLineNo">1973</span>      .map(TableDescriptor::getTableName)<a name="line.1973"></a>
-<span class="sourceLineNo">1974</span>      .collect(Collectors.toSet());<a name="line.1974"></a>
-<span class="sourceLineNo">1975</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1975"></a>
-<span class="sourceLineNo">1976</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1976"></a>
-<span class="sourceLineNo">1977</span>    final List&lt;TableName&gt; targetTables =<a name="line.1977"></a>
-<span class="sourceLineNo">1978</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1978"></a>
-<span class="sourceLineNo">1979</span>    Collections.shuffle(targetTables);<a name="line.1979"></a>
-<span class="sourceLineNo">1980</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1980"></a>
-<span class="sourceLineNo">1981</span>  }<a name="line.1981"></a>
-<span class="sourceLineNo">1982</span><a name="line.1982"></a>
-<span class="sourceLineNo">1983</span>  /**<a name="line.1983"></a>
-<span class="sourceLineNo">1984</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1984"></a>
-<span class="sourceLineNo">1985</span>   */<a name="line.1985"></a>
-<span class="sourceLineNo">1986</span>  @Override<a name="line.1986"></a>
-<span class="sourceLineNo">1987</span>  public String getClientIdAuditPrefix() {<a name="line.1987"></a>
-<span class="sourceLineNo">1988</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1988"></a>
-<span class="sourceLineNo">1989</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<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>   * Switch for the background CatalogJanitor thread.<a name="line.1993"></a>
-<span class="sourceLineNo">1994</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1994"></a>
-<span class="sourceLineNo">1995</span>   * if disabled.<a name="line.1995"></a>
-<span class="sourceLineNo">1996</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.1996"></a>
-<span class="sourceLineNo">1997</span>   */<a name="line.1997"></a>
-<span class="sourceLineNo">1998</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.1998"></a>
-<span class="sourceLineNo">1999</span>    this.catalogJanitorChore.setEnabled(b);<a name="line.1999"></a>
-<span class="sourceLineNo">2000</span>  }<a name="line.2000"></a>
-<span class="sourceLineNo">2001</span><a name="line.2001"></a>
-<span class="sourceLineNo">2002</span>  @Override<a name="line.2002"></a>
-<span class="sourceLineNo">2003</span>  public long mergeRegions(<a name="line.2003"></a>
-<span class="sourceLineNo">2004</span>      final RegionInfo[] regionsToMerge,<a name="line.2004"></a>
-<span class="sourceLineNo">2005</span>      final boolean forcible,<a name="line.2005"></a>
-<span class="sourceLineNo">2006</span>      final long ng,<a name="line.2006"></a>
-<span class="sourceLineNo">2007</span>      final long nonce) throws IOException {<a name="line.2007"></a>
-<span class="sourceLineNo">2008</span>    checkInitialized();<a name="line.2008"></a>
-<span class="sourceLineNo">2009</span><a name="line.2009"></a>
-<span class="sourceLineNo">2010</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.2010"></a>
-<span class="sourceLineNo">2011</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.2011"></a>
-<span class="sourceLineNo">2012</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.2012"></a>
-<span class="sourceLineNo">2013</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.2013"></a>
-<span class="sourceLineNo">2014</span>          " failed because merge switch is off");<a name="line.2014"></a>
-<span class="sourceLineNo">2015</span>    }<a name="line.2015"></a>
-<span class="sourceLineNo">2016</span><a name="line.2016"></a>
-<span class="sourceLineNo">2017</span>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.2017"></a>
-<span class="sourceLineNo">2018</span>      .collect(Collectors.joining(", "));<a name="line.2018"></a>
-<span class="sourceLineNo">2019</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.2019"></a>
-<span class="sourceLineNo">2020</span>      @Override<a name="line.2020"></a>
-<span class="sourceLineNo">2021</span>      protected void run() throws IOException {<a name="line.2021"></a>
-<span class="sourceLineNo">2022</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.2022"></a>
-<span class="sourceLineNo">2023</span>        String aid = getClientIdAuditPrefix();<a name="line.2023"></a>
-<span class="sourceLineNo">2024</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.2024"></a>
-<span class="sourceLineNo">2025</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.2025"></a>
-<span class="sourceLineNo">2026</span>            regionsToMerge, forcible));<a name="line.2026"></a>
-<span class="sourceLineNo">2027</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<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>      @Override<a name="line.2030"></a>
-<span class="sourceLineNo">2031</span>      protected String getDescription() {<a name="line.2031"></a>
-<span class="sourceLineNo">2032</span>        return "MergeTableProcedure";<a name="line.2032"></a>
+<span class="sourceLineNo">1955</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1955"></a>
+<span class="sourceLineNo">1956</span>    return regionNormalizerManager;<a name="line.1956"></a>
+<span class="sourceLineNo">1957</span>  }<a name="line.1957"></a>
+<span class="sourceLineNo">1958</span><a name="line.1958"></a>
+<span class="sourceLineNo">1959</span>  @Override<a name="line.1959"></a>
+<span class="sourceLineNo">1960</span>  public boolean normalizeRegions(<a name="line.1960"></a>
+<span class="sourceLineNo">1961</span>    final NormalizeTableFilterParams ntfp,<a name="line.1961"></a>
+<span class="sourceLineNo">1962</span>    final boolean isHighPriority<a name="line.1962"></a>
+<span class="sourceLineNo">1963</span>  ) throws IOException {<a name="line.1963"></a>
+<span class="sourceLineNo">1964</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1964"></a>
+<span class="sourceLineNo">1965</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1965"></a>
+<span class="sourceLineNo">1966</span>      return false;<a name="line.1966"></a>
+<span class="sourceLineNo">1967</span>    }<a name="line.1967"></a>
+<span class="sourceLineNo">1968</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1968"></a>
+<span class="sourceLineNo">1969</span>      return false;<a name="line.1969"></a>
+<span class="sourceLineNo">1970</span>    }<a name="line.1970"></a>
+<span class="sourceLineNo">1971</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1971"></a>
+<span class="sourceLineNo">1972</span>      return false;<a name="line.1972"></a>
+<span class="sourceLineNo">1973</span>    }<a name="line.1973"></a>
+<span class="sourceLineNo">1974</span><a name="line.1974"></a>
+<span class="sourceLineNo">1975</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1975"></a>
+<span class="sourceLineNo">1976</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1976"></a>
+<span class="sourceLineNo">1977</span>      .stream()<a name="line.1977"></a>
+<span class="sourceLineNo">1978</span>      .map(TableDescriptor::getTableName)<a name="line.1978"></a>
+<span class="sourceLineNo">1979</span>      .collect(Collectors.toSet());<a name="line.1979"></a>
+<span class="sourceLineNo">1980</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1980"></a>
+<span class="sourceLineNo">1981</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1981"></a>
+<span class="sourceLineNo">1982</span>    final List&lt;TableName&gt; targetTables =<a name="line.1982"></a>
+<span class="sourceLineNo">1983</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1983"></a>
+<span class="sourceLineNo">1984</span>    Collections.shuffle(targetTables);<a name="line.1984"></a>
+<span class="sourceLineNo">1985</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1985"></a>
+<span class="sourceLineNo">1986</span>  }<a name="line.1986"></a>
+<span class="sourceLineNo">1987</span><a name="line.1987"></a>
+<span class="sourceLineNo">1988</span>  /**<a name="line.1988"></a>
+<span class="sourceLineNo">1989</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1989"></a>
+<span class="sourceLineNo">1990</span>   */<a name="line.1990"></a>
+<span class="sourceLineNo">1991</span>  @Override<a name="line.1991"></a>
+<span class="sourceLineNo">1992</span>  public String getClientIdAuditPrefix() {<a name="line.1992"></a>
+<span class="sourceLineNo">1993</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1993"></a>
+<span class="sourceLineNo">1994</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<a name="line.1994"></a>
+<span class="sourceLineNo">1995</span>  }<a name="line.1995"></a>
+<span class="sourceLineNo">1996</span><a name="line.1996"></a>
+<span class="sourceLineNo">1997</span>  /**<a name="line.1997"></a>
+<span class="sourceLineNo">1998</span>   * Switch for the background CatalogJanitor thread.<a name="line.1998"></a>
+<span class="sourceLineNo">1999</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1999"></a>
+<span class="sourceLineNo">2000</span>   * if disabled.<a name="line.2000"></a>
+<span class="sourceLineNo">2001</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.2001"></a>
+<span class="sourceLineNo">2002</span>   */<a name="line.2002"></a>
+<span class="sourceLineNo">2003</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.2003"></a>
+<span class="sourceLineNo">2004</span>    this.catalogJanitorChore.setEnabled(b);<a name="line.2004"></a>
+<span class="sourceLineNo">2005</span>  }<a name="line.2005"></a>
+<span class="sourceLineNo">2006</span><a name="line.2006"></a>
+<span class="sourceLineNo">2007</span>  @Override<a name="line.2007"></a>
+<span class="sourceLineNo">2008</span>  public long mergeRegions(<a name="line.2008"></a>
+<span class="sourceLineNo">2009</span>      final RegionInfo[] regionsToMerge,<a name="line.2009"></a>
+<span class="sourceLineNo">2010</span>      final boolean forcible,<a name="line.2010"></a>
+<span class="sourceLineNo">2011</span>      final long ng,<a name="line.2011"></a>
+<span class="sourceLineNo">2012</span>      final long nonce) throws IOException {<a name="line.2012"></a>
+<span class="sourceLineNo">2013</span>    checkInitialized();<a name="line.2013"></a>
+<span class="sourceLineNo">2014</span><a name="line.2014"></a>
+<span class="sourceLineNo">2015</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.2015"></a>
+<span class="sourceLineNo">2016</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.2016"></a>
+<span class="sourceLineNo">2017</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.2017"></a>
+<span class="sourceLineNo">2018</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.2018"></a>
+<span class="sourceLineNo">2019</span>          " failed because merge switch is off");<a name="line.2019"></a>
+<span class="sourceLineNo">2020</span>    }<a name="line.2020"></a>
+<span class="sourceLineNo">2021</span><a name="line.2021"></a>
+<span class="sourceLineNo">2022</span>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.2022"></a>
+<span class="sourceLineNo">2023</span>      .collect(Collectors.joining(", "));<a name="line.2023"></a>
+<span class="sourceLineNo">2024</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.2024"></a>
+<span class="sourceLineNo">2025</span>      @Override<a name="line.2025"></a>
+<span class="sourceLineNo">2026</span>      protected void run() throws IOException {<a name="line.2026"></a>
+<span class="sourceLineNo">2027</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.2027"></a>
+<span class="sourceLineNo">2028</span>        String aid = getClientIdAuditPrefix();<a name="line.2028"></a>
+<span class="sourceLineNo">2029</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.2029"></a>
+<span class="sourceLineNo">2030</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.2030"></a>
+<span class="sourceLineNo">2031</span>            regionsToMerge, forcible));<a name="line.2031"></a>
+<span class="sourceLineNo">2032</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<a name="line.2032"></a>
 <span class="sourceLineNo">2033</span>      }<a name="line.2033"></a>
-<span class="sourceLineNo">2034</span>    });<a name="line.2034"></a>
-<span class="sourceLineNo">2035</span>  }<a name="line.2035"></a>
-<span class="sourceLineNo">2036</span><a name="line.2036"></a>
-<span class="sourceLineNo">2037</span>  @Override<a name="line.2037"></a>
-<span class="sourceLineNo">2038</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.2038"></a>
-<span class="sourceLineNo">2039</span>      final long nonceGroup, final long nonce)<a name="line.2039"></a>
-<span class="sourceLineNo">2040</span>  throws IOException {<a name="line.2040"></a>
-<span class="sourceLineNo">2041</span>    checkInitialized();<a name="line.2041"></a>
-<span class="sourceLineNo">2042</span><a name="line.2042"></a>
-<span class="sourceLineNo">2043</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.2043"></a>
-<span class="sourceLineNo">2044</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.2044"></a>
-<span class="sourceLineNo">2045</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.2045"></a>
-<span class="sourceLineNo">2046</span>          " failed due to split switch off");<a name="line.2046"></a>
-<span class="sourceLineNo">2047</span>    }<a name="line.2047"></a>
-<span class="sourceLineNo">2048</span><a name="line.2048"></a>
-<span class="sourceLineNo">2049</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2049"></a>
-<span class="sourceLineNo">2050</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2050"></a>
-<span class="sourceLineNo">2051</span>      @Override<a name="line.2051"></a>
-<span class="sourceLineNo">2052</span>      protected void run() throws IOException {<a name="line.2052"></a>
-<span class="sourceLineNo">2053</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.2053"></a>
-<span class="sourceLineNo">2054</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.2054"></a>
-<span class="sourceLineNo">2055</span><a name="line.2055"></a>
-<span class="sourceLineNo">2056</span>        // Execute the operation asynchronously<a name="line.2056"></a>
-<span class="sourceLineNo">2057</span>        submitProcedure(getAssignmentManager().createSplitProcedure(regionInfo, splitRow));<a name="line.2057"></a>
-<span class="sourceLineNo">2058</span>      }<a name="line.2058"></a>
-<span class="sourceLineNo">2059</span><a name="line.2059"></a>
-<span class="sourceLineNo">2060</span>      @Override<a name="line.2060"></a>
-<span class="sourceLineNo">2061</span>      protected String getDescription() {<a name="line.2061"></a>
-<span class="sourceLineNo">2062</span>        return "SplitTableProcedure";<a name="line.2062"></a>
+<span class="sourceLineNo">2034</span><a name="line.2034"></a>
+<span class="sourceLineNo">2035</span>      @Override<a name="line.2035"></a>
+<span class="sourceLineNo">2036</span>      protected String getDescription() {<a name="line.2036"></a>
+<span class="sourceLineNo">2037</span>        return "MergeTableProcedure";<a name="line.2037"></a>
+<span class="sourceLineNo">2038</span>      }<a name="line.2038"></a>
+<span class="sourceLineNo">2039</span>    });<a name="line.2039"></a>
+<span class="sourceLineNo">2040</span>  }<a name="line.2040"></a>
+<span class="sourceLineNo">2041</span><a name="line.2041"></a>
+<span class="sourceLineNo">2042</span>  @Override<a name="line.2042"></a>
+<span class="sourceLineNo">2043</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.2043"></a>
+<span class="sourceLineNo">2044</span>      final long nonceGroup, final long nonce)<a name="line.2044"></a>
+<span class="sourceLineNo">2045</span>  throws IOException {<a name="line.2045"></a>
+<span class="sourceLineNo">2046</span>    checkInitialized();<a name="line.2046"></a>
+<span class="sourceLineNo">2047</span><a name="line.2047"></a>
+<span class="sourceLineNo">2048</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.2048"></a>
+<span class="sourceLineNo">2049</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.2049"></a>
+<span class="sourceLineNo">2050</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.2050"></a>
+<span class="sourceLineNo">2051</span>          " failed due to split switch off");<a name="line.2051"></a>
+<span class="sourceLineNo">2052</span>    }<a name="line.2052"></a>
+<span class="sourceLineNo">2053</span><a name="line.2053"></a>
+<span class="sourceLineNo">2054</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2054"></a>
+<span class="sourceLineNo">2055</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2055"></a>
+<span class="sourceLineNo">2056</span>      @Override<a name="line.2056"></a>
+<span class="sourceLineNo">2057</span>      protected void run() throws IOException {<a name="line.2057"></a>
+<span class="sourceLineNo">2058</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.2058"></a>
+<span class="sourceLineNo">2059</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.2059"></a>
+<span class="sourceLineNo">2060</span><a name="line.2060"></a>
+<span class="sourceLineNo">2061</span>        // Execute the operation asynchronously<a name="line.2061"></a>
+<span class="sourceLineNo">2062</span>        submitProcedure(getAssignmentManager().createSplitProcedure(regionInfo, splitRow));<a name="line.2062"></a>
 <span class="sourceLineNo">2063</span>      }<a name="line.2063"></a>
-<span class="sourceLineNo">2064</span>    });<a name="line.2064"></a>
-<span class="sourceLineNo">2065</span>  }<a name="line.2065"></a>
-<span class="sourceLineNo">2066</span><a name="line.2066"></a>
-<span class="sourceLineNo">2067</span>  private void warmUpRegion(ServerName server, RegionInfo region) {<a name="line.2067"></a>
-<span class="sourceLineNo">2068</span>    FutureUtils.addListener(asyncClusterConnection.getRegionServerAdmin(server)<a name="line.2068"></a>
-<span class="sourceLineNo">2069</span>      .warmupRegion(RequestConverter.buildWarmupRegionRequest(region)), (r, e) -&gt; {<a name="line.2069"></a>
-<span class="sourceLineNo">2070</span>        if (e != null) {<a name="line.2070"></a>
-<span class="sourceLineNo">2071</span>          LOG.warn("Failed to warm up region {} on server {}", region, server, e);<a name="line.2071"></a>
-<span class="sourceLineNo">2072</span>        }<a name="line.2072"></a>
-<span class="sourceLineNo">2073</span>      });<a name="line.2073"></a>
-<span class="sourceLineNo">2074</span>  }<a name="line.2074"></a>
-<span class="sourceLineNo">2075</span><a name="line.2075"></a>
-<span class="sourceLineNo">2076</span>  // Public so can be accessed by tests. Blocks until move is done.<a name="line.2076"></a>
-<span class="sourceLineNo">2077</span>  // Replace with an async implementation from which you can get<a name="line.2077"></a>
-<span class="sourceLineNo">2078</span>  // a success/failure result.<a name="line.2078"></a>
-<span class="sourceLineNo">2079</span>  @InterfaceAudience.Private<a name="line.2079"></a>
-<span class="sourceLineNo">2080</span>  public void move(final byte[] encodedRegionName, byte[] destServerName) throws IOException {<a name="line.2080"></a>
-<span class="sourceLineNo">2081</span>    RegionState regionState = assignmentManager.getRegionStates().<a name="line.2081"></a>
-<span class="sourceLineNo">2082</span>      getRegionState(Bytes.toString(encodedRegionName));<a name="line.2082"></a>
-<span class="sourceLineNo">2083</span><a name="line.2083"></a>
-<span class="sourceLineNo">2084</span>    RegionInfo hri;<a name="line.2084"></a>
-<span class="sourceLineNo">2085</span>    if (regionState != null) {<a name="line.2085"></a>
-<span class="sourceLineNo">2086</span>      hri = regionState.getRegion();<a name="line.2086"></a>
-<span class="sourceLineNo">2087</span>    } else {<a name="line.2087"></a>
-<span class="sourceLineNo">2088</span>      throw new UnknownRegionException(Bytes.toStringBinary(encodedRegionName));<a name="line.2088"></a>
-<span class="sourceLineNo">2089</span>    }<a name="line.2089"></a>
-<span class="sourceLineNo">2090</span><a name="line.2090"></a>
-<span class="sourceLineNo">2091</span>    ServerName dest;<a name="line.2091"></a>
-<span class="sourceLineNo">2092</span>    List&lt;ServerName&gt; exclude = hri.getTable().isSystemTable() ? assignmentManager.getExcludedServersForSystemTable()<a name="line.2092"></a>
-<span class="sourceLineNo">2093</span>        : new ArrayList&lt;&gt;(1);<a name="line.2093"></a>
-<span class="sourceLineNo">2094</span>    if (destServerName != null &amp;&amp; exclude.contains(ServerName.valueOf(Bytes.toString(destServerName)))) {<a name="line.2094"></a>
-<span class="sourceLineNo">2095</span>      LOG.info(<a name="line.2095"></a>
-<span class="sourceLineNo">2096</span>          Bytes.toString(encodedRegionName) + " can not move to " + Bytes.toString(destServerName)<a name="line.2096"></a>
-<span class="sourceLineNo">2097</span>              + " because the server is in exclude list");<a name="line.2097"></a>
-<span class="sourceLineNo">2098</span>      destServerName = null;<a name="line.2098"></a>
-<span class="sourceLineNo">2099</span>    }<a name="line.2099"></a>
-<span class="sourceLineNo">2100</span>    if (destServerName == null || destServerName.length == 0) {<a name="line.2100"></a>
-<span class="sourceLineNo">2101</span>      LOG.info("Passed destination servername is null/empty so " +<a name="line.2101"></a>
-<span class="sourceLineNo">2102</span>        "choosing a server at random");<a name="line.2102"></a>
-<span class="sourceLineNo">2103</span>      exclude.add(regionState.getServerName());<a name="line.2103"></a>
-<span class="sourceLineNo">2104</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList(exclude);<a name="line.2104"></a>
-<span class="sourceLineNo">2105</span>      dest = balancer.randomAssignment(hri, destServers);<a name="line.2105"></a>
-<span class="sourceLineNo">2106</span>      if (dest == null) {<a name="line.2106"></a>
-<span class="sourceLineNo">2107</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2107"></a>
-<span class="sourceLineNo">2108</span>        return;<a name="line.2108"></a>
-<span class="sourceLineNo">2109</span>      }<a name="line.2109"></a>
-<span class="sourceLineNo">2110</span>    } else {<a name="line.2110"></a>
-<span class="sourceLineNo">2111</span>      ServerName candidate = ServerName.valueOf(Bytes.toString(destServerName));<a name="line.2111"></a>
-<span class="sourceLineNo">2112</span>      dest = balancer.randomAssignment(hri, Lists.newArrayList(candidate));<a name="line.2112"></a>
-<span class="sourceLineNo">2113</span>      if (dest == null) {<a name="line.2113"></a>
-<span class="sourceLineNo">2114</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2114"></a>
-<span class="sourceLineNo">2115</span>        return;<a name="line.2115"></a>
-<span class="sourceLineNo">2116</span>      }<a name="line.2116"></a>
-<span class="sourceLineNo">2117</span>      // TODO: deal with table on master for rs group.<a name="line.2117"></a>
-<span class="sourceLineNo">2118</span>      if (dest.equals(serverName)) {<a name="line.2118"></a>
-<span class="sourceLineNo">2119</span>        // To avoid unnecessary region moving later by balancer. Don't put user<a name="line.2119"></a>
-<span class="sourceLineNo">2120</span>        // regions on master.<a name="line.2120"></a>
-<span class="sourceLineNo">2121</span>        LOG.debug("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.2121"></a>
-<span class="sourceLineNo">2122</span>          " to avoid unnecessary region moving later by load balancer," +<a name="line.2122"></a>
-<span class="sourceLineNo">2123</span>          " because it should not be on master");<a name="line.2123"></a>
-<span class="sourceLineNo">2124</span>        return;<a name="line.2124"></a>
-<span class="sourceLineNo">2125</span>      }<a name="line.2125"></a>
-<span class="sourceLineNo">2126</span>    }<a name="line.2126"></a>
-<span class="sourceLineNo">2127</span><a name="line.2127"></a>
-<span class="sourceLineNo">2128</span>    if (dest.equals(regionState.getServerName())) {<a name="line.2128"></a>
-<span class="sourceLineNo">2129</span>      LOG.debug("Skipping move of region " + hri.getRegionNameAsString()<a name="line.2129"></a>
-<span class="sourceLineNo">2130</span>        + " because region already assigned to the same server " + dest + ".");<a name="line.2130"></a>
-<span class="sourceLineNo">2131</span>      return;<a name="line.2131"></a>
-<span class="sourceLineNo">2132</span>    }<a name="line.2132"></a>
-<span class="sourceLineNo">2133</span><a name="line.2133"></a>
-<span class="sourceLineNo">2134</span>    // Now we can do the move<a name="line.2134"></a>
-<span class="sourceLineNo">2135</span>    RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), dest);<a name="line.2135"></a>
-<span class="sourceLineNo">2136</span>    assert rp.getDestination() != null: rp.toString() + " " + dest;<a name="line.2136"></a>
-<span class="sourceLineNo">2137</span><a name="line.2137"></a>
-<span class="sourceLineNo">2138</span>    try {<a name="line.2138"></a>
-<span class="sourceLineNo">2139</span>      checkInitialized();<a name="line.2139"></a>
-<span class="sourceLineNo">2140</span>      if (this.cpHost != null) {<a name="line.2140"></a>
-<span class="sourceLineNo">2141</span>        this.cpHost.preMove(hri, rp.getSource(), rp.getDestination());<a name="line.2141"></a>
-<span class="sourceLineNo">2142</span>      }<a name="line.2142"></a>
-<span class="sourceLineNo">2143</span><a name="line.2143"></a>
-<span class="sourceLineNo">2144</span>      TransitRegionStateProcedure proc =<a name="line.2144"></a>
-<span class="sourceLineNo">2145</span>        this.assignmentManager.createMoveRegionProcedure(rp.getRegionInfo(), rp.getDestination());<a name="line.2145"></a>
-<span class="sourceLineNo">2146</span>      // Warmup the region on the destination before initiating the move.<a name="line.2146"></a>
-<span class="sourceLineNo">2147</span>      // A region server could reject the close request because it either does not<a name="line.2147"></a>
-<span class="sourceLineNo">2148</span>      // have the specified region or the region is being split.<a name="line.2148"></a>
-<span class="sourceLineNo">2149</span>      warmUpRegion(rp.getDestination(), hri);<a name="line.2149"></a>
-<span class="sourceLineNo">2150</span><a name="line.2150"></a>
-<span class="sourceLineNo">2151</span>      LOG.info(getClientIdAuditPrefix() + " move " + rp + ", running balancer");<a name="line.2151"></a>
-<span class="sourceLineNo">2152</span>      Future&lt;byte[]&gt; future = ProcedureSyncWait.submitProcedure(this.procedureExecutor, proc);<a name="line.2152"></a>
-<span class="sourceLineNo">2153</span>      try {<a name="line.2153"></a>
-<span class="sourceLineNo">2154</span>        // Is this going to work? Will we throw exception on error?<a name="line.2154"></a>
-<span class="sourceLineNo">2155</span>        // TODO: CompletableFuture rather than this stunted Future.<a name="line.2155"></a>
-<span class="sourceLineNo">2156</span>        future.get();<a name="line.2156"></a>
-<span class="sourceLineNo">2157</span>      } catch (InterruptedException | ExecutionException e) {<a name="line.2157"></a>
-<span class="sourceLineNo">2158</span>        throw new HBaseIOException(e);<a name="line.2158"></a>
-<span class="sourceLineNo">2159</span>      }<a name="line.2159"></a>
-<span class="sourceLineNo">2160</span>      if (this.cpHost != null) {<a name="line.2160"></a>
-<span class="sourceLineNo">2161</span>        this.cpHost.postMove(hri, rp.getSource(), rp.getDestination());<a name="line.2161"></a>
-<span class="sourceLineNo">2162</span>      }<a name="line.2162"></a>
-<span class="sourceLineNo">2163</span>    } catch (IOException ioe) {<a name="line.2163"></a>
-<span class="sourceLineNo">2164</span>      if (ioe instanceof HBaseIOException) {<a name="line.2164"></a>
-<span class="sourceLineNo">2165</span>        throw (HBaseIOException)ioe;<a name="line.2165"></a>
-<span class="sourceLineNo">2166</span>      }<a name="line.2166"></a>
-<span class="sourceLineNo">2167</span>      throw new HBaseIOException(ioe);<a name="line.2167"></a>
-<span class="sourceLineNo">2168</span>    }<a name="line.2168"></a>
-<span class="sourceLineNo">2169</span>  }<a name="line.2169"></a>
-<span class="sourceLineNo">2170</span><a name="line.2170"></a>
-<span class="sourceLineNo">2171</span>  @Override<a name="line.2171"></a>
-<span class="sourceLineNo">2172</span>  public long createTable(final TableDescriptor tableDescriptor, final byte[][] splitKeys,<a name="line.2172"></a>
-<span class="sourceLineNo">2173</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2173"></a>
-<span class="sourceLineNo">2174</span>    checkInitialized();<a name="line.2174"></a>
-<span class="sourceLineNo">2175</span>    TableDescriptor desc = getMasterCoprocessorHost().preCreateTableRegionsInfos(tableDescriptor);<a name="line.2175"></a>
-<span class="sourceLineNo">2176</span>    if (desc == null) {<a name="line.2176"></a>
-<span class="sourceLineNo">2177</span>      throw new IOException("Creation for " + tableDescriptor + " is canceled by CP");<a name="line.2177"></a>
-<span class="sourceLineNo">2178</span>    }<a name="line.2178"></a>
-<span class="sourceLineNo">2179</span>    String namespace = desc.getTableName().getNamespaceAsString();<a name="line.2179"></a>
-<span class="sourceLineNo">2180</span>    this.clusterSchemaService.getNamespace(namespace);<a name="line.2180"></a>
-<span class="sourceLineNo">2181</span><a name="line.2181"></a>
-<span class="sourceLineNo">2182</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(desc, splitKeys);<a name="line.2182"></a>
-<span class="sourceLineNo">2183</span>    TableDescriptorChecker.sanityCheck(conf, desc);<a name="line.2183"></a>
-<span class="sourceLineNo">2184</span><a name="line.2184"></a>
-<span class="sourceLineNo">2185</span>    return MasterProcedureUtil<a name="line.2185"></a>
-<span class="sourceLineNo">2186</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2186"></a>
-<span class="sourceLineNo">2187</span>        @Override<a name="line.2187"></a>
-<span class="sourceLineNo">2188</span>        protected void run() throws IOException {<a name="line.2188"></a>
-<span class="sourceLineNo">2189</span>          getMaster().getMasterCoprocessorHost().preCreateTable(desc, newRegions);<a name="line.2189"></a>
-<span class="sourceLineNo">2190</span><a name="line.2190"></a>
-<span class="sourceLineNo">2191</span>          LOG.info(getClientIdAuditPrefix() + " create " + desc);<a name="line.2191"></a>
-<span class="sourceLineNo">2192</span><a name="line.2192"></a>
-<span class="sourceLineNo">2193</span>          // TODO: We can handle/merge duplicate requests, and differentiate the case of<a name="line.2193"></a>
-<span class="sourceLineNo">2194</span>          // TableExistsException by saying if the schema is the same or not.<a name="line.2194"></a>
-<span class="sourceLineNo">2195</span>          //<a name="line.2195"></a>
-<span class="sourceLineNo">2196</span>          // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2196"></a>
-<span class="sourceLineNo">2197</span>          // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2197"></a>
-<span class="sourceLineNo">2198</span>          ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2198"></a>
-<span class="sourceLineNo">2199</span>          submitProcedure(<a name="line.2199"></a>
-<span class="sourceLineNo">2200</span>            new CreateTableProcedure(procedureExecutor.getEnvironment(), desc, newRegions, latch));<a name="line.2200"></a>
-<span class="sourceLineNo">2201</span>          latch.await();<a name="line.2201"></a>
-<span class="sourceLineNo">2202</span><a name="line.2202"></a>
-<span class="sourceLineNo">2203</span>          getMaster().getMasterCoprocessorHost().postCreateTable(desc, newRegions);<a name="line.2203"></a>
-<span class="sourceLineNo">2204</span>        }<a name="line.2204"></a>
-<span class="sourceLineNo">2205</span><a name="line.2205"></a>
-<span class="sourceLineNo">2206</span>        @Override<a name="line.2206"></a>
-<span class="sourceLineNo">2207</span>        protected String getDescription() {<a name="line.2207"></a>
-<span class="sourceLineNo">2208</span>          return "CreateTableProcedure";<a name="line.2208"></a>
+<span class="sourceLineNo">2064</span><a name="line.2064"></a>
+<span class="sourceLineNo">2065</span>      @Override<a name="line.2065"></a>
+<span class="sourceLineNo">2066</span>      protected String getDescription() {<a name="line.2066"></a>
+<span class="sourceLineNo">2067</span>        return "SplitTableProcedure";<a name="line.2067"></a>
+<span class="sourceLineNo">2068</span>      }<a name="line.2068"></a>
+<span class="sourceLineNo">2069</span>    });<a name="line.2069"></a>
+<span class="sourceLineNo">2070</span>  }<a name="line.2070"></a>
+<span class="sourceLineNo">2071</span><a name="line.2071"></a>
+<span class="sourceLineNo">2072</span>  private void warmUpRegion(ServerName server, RegionInfo region) {<a name="line.2072"></a>
+<span class="sourceLineNo">2073</span>    FutureUtils.addListener(asyncClusterConnection.getRegionServerAdmin(server)<a name="line.2073"></a>
+<span class="sourceLineNo">2074</span>      .warmupRegion(RequestConverter.buildWarmupRegionRequest(region)), (r, e) -&gt; {<a name="line.2074"></a>
+<span class="sourceLineNo">2075</span>        if (e != null) {<a name="line.2075"></a>
+<span class="sourceLineNo">2076</span>          LOG.warn("Failed to warm up region {} on server {}", region, server, e);<a name="line.2076"></a>
+<span class="sourceLineNo">2077</span>        }<a name="line.2077"></a>
+<span class="sourceLineNo">2078</span>      });<a name="line.2078"></a>
+<span class="sourceLineNo">2079</span>  }<a name="line.2079"></a>
+<span class="sourceLineNo">2080</span><a name="line.2080"></a>
+<span class="sourceLineNo">2081</span>  // Public so can be accessed by tests. Blocks until move is done.<a name="line.2081"></a>
+<span class="sourceLineNo">2082</span>  // Replace with an async implementation from which you can get<a name="line.2082"></a>
+<span class="sourceLineNo">2083</span>  // a success/failure result.<a name="line.2083"></a>
+<span class="sourceLineNo">2084</span>  @InterfaceAudience.Private<a name="line.2084"></a>
+<span class="sourceLineNo">2085</span>  public void move(final byte[] encodedRegionName, byte[] destServerName) throws IOException {<a name="line.2085"></a>
+<span class="sourceLineNo">2086</span>    RegionState regionState = assignmentManager.getRegionStates().<a name="line.2086"></a>
+<span class="sourceLineNo">2087</span>      getRegionState(Bytes.toString(encodedRegionName));<a name="line.2087"></a>
+<span class="sourceLineNo">2088</span><a name="line.2088"></a>
+<span class="sourceLineNo">2089</span>    RegionInfo hri;<a name="line.2089"></a>
+<span class="sourceLineNo">2090</span>    if (regionState != null) {<a name="line.2090"></a>
+<span class="sourceLineNo">2091</span>      hri = regionState.getRegion();<a name="line.2091"></a>
+<span class="sourceLineNo">2092</span>    } else {<a name="line.2092"></a>
+<span class="sourceLineNo">2093</span>      throw new UnknownRegionException(Bytes.toStringBinary(encodedRegionName));<a name="line.2093"></a>
+<span class="sourceLineNo">2094</span>    }<a name="line.2094"></a>
+<span class="sourceLineNo">2095</span><a name="line.2095"></a>
+<span class="sourceLineNo">2096</span>    ServerName dest;<a name="line.2096"></a>
+<span class="sourceLineNo">2097</span>    List&lt;ServerName&gt; exclude = hri.getTable().isSystemTable() ? assignmentManager.getExcludedServersForSystemTable()<a name="line.2097"></a>
+<span class="sourceLineNo">2098</span>        : new ArrayList&lt;&gt;(1);<a name="line.2098"></a>
+<span class="sourceLineNo">2099</span>    if (destServerName != null &amp;&amp; exclude.contains(ServerName.valueOf(Bytes.toString(destServerName)))) {<a name="line.2099"></a>
+<span class="sourceLineNo">2100</span>      LOG.info(<a name="line.2100"></a>
+<span class="sourceLineNo">2101</span>          Bytes.toString(encodedRegionName) + " can not move to " + Bytes.toString(destServerName)<a name="line.2101"></a>
+<span class="sourceLineNo">2102</span>              + " because the server is in exclude list");<a name="line.2102"></a>
+<span class="sourceLineNo">2103</span>      destServerName = null;<a name="line.2103"></a>
+<span class="sourceLineNo">2104</span>    }<a name="line.2104"></a>
+<span class="sourceLineNo">2105</span>    if (destServerName == null || destServerName.length == 0) {<a name="line.2105"></a>
+<span class="sourceLineNo">2106</span>      LOG.info("Passed destination servername is null/empty so " +<a name="line.2106"></a>
+<span class="sourceLineNo">2107</span>        "choosing a server at random");<a name="line.2107"></a>
+<span class="sourceLineNo">2108</span>      exclude.add(regionState.getServerName());<a name="line.2108"></a>
+<span class="sourceLineNo">2109</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList(exclude);<a name="line.2109"></a>
+<span class="sourceLineNo">2110</span>      dest = balancer.randomAssignment(hri, destServers);<a name="line.2110"></a>
+<span class="sourceLineNo">2111</span>      if (dest == null) {<a name="line.2111"></a>
+<span class="sourceLineNo">2112</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2112"></a>
+<span class="sourceLineNo">2113</span>        return;<a name="line.2113"></a>
+<span class="sourceLineNo">2114</span>      }<a name="line.2114"></a>
+<span class="sourceLineNo">2115</span>    } else {<a name="line.2115"></a>
+<span class="sourceLineNo">2116</span>      ServerName candidate = ServerName.valueOf(Bytes.toString(destServerName));<a name="line.2116"></a>
+<span class="sourceLineNo">2117</span>      dest = balancer.randomAssignment(hri, Lists.newArrayList(candidate));<a name="line.2117"></a>
+<span class="sourceLineNo">2118</span>      if (dest == null) {<a name="line.2118"></a>
+<span class="sourceLineNo">2119</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2119"></a>
+<span class="sourceLineNo">2120</span>        return;<a name="line.2120"></a>
+<span class="sourceLineNo">2121</span>      }<a name="line.2121"></a>
+<span class="sourceLineNo">2122</span>      // TODO: deal with table on master for rs group.<a name="line.2122"></a>
+<span class="sourceLineNo">2123</span>      if (dest.equals(serverName)) {<a name="line.2123"></a>
+<span class="sourceLineNo">2124</span>        // To avoid unnecessary region moving later by balancer. Don't put user<a name="line.2124"></a>
+<span class="sourceLineNo">2125</span>        // regions on master.<a name="line.2125"></a>
+<span class="sourceLineNo">2126</span>        LOG.debug("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.2126"></a>
+<span class="sourceLineNo">2127</span>          " to avoid unnecessary region moving later by load balancer," +<a name="line.2127"></a>
+<span class="sourceLineNo">2128</span>          " because it should not be on master");<a name="line.2128"></a>
+<span class="sourceLineNo">2129</span>        return;<a name="line.2129"></a>
+<span class="sourceLineNo">2130</span>      }<a name="line.2130"></a>
+<span class="sourceLineNo">2131</span>    }<a name="line.2131"></a>
+<span class="sourceLineNo">2132</span><a name="line.2132"></a>
+<span class="sourceLineNo">2133</span>    if (dest.equals(regionState.getServerName())) {<a name="line.2133"></a>
+<span class="sourceLineNo">2134</span>      LOG.debug("Skipping move of region " + hri.getRegionNameAsString()<a name="line.2134"></a>
+<span class="sourceLineNo">2135</span>        + " because region already assigned to the same server " + dest + ".");<a name="line.2135"></a>
+<span class="sourceLineNo">2136</span>      return;<a name="line.2136"></a>
+<span class="sourceLineNo">2137</span>    }<a name="line.2137"></a>
+<span class="sourceLineNo">2138</span><a name="line.2138"></a>
+<span class="sourceLineNo">2139</span>    // Now we can do the move<a name="line.2139"></a>
+<span class="sourceLineNo">2140</span>    RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), dest);<a name="line.2140"></a>
+<span class="sourceLineNo">2141</span>    assert rp.getDestination() != null: rp.toString() + " " + dest;<a name="line.2141"></a>
+<span class="sourceLineNo">2142</span><a name="line.2142"></a>
+<span class="sourceLineNo">2143</span>    try {<a name="line.2143"></a>
+<span class="sourceLineNo">2144</span>      checkInitialized();<a name="line.2144"></a>
+<span class="sourceLineNo">2145</span>      if (this.cpHost != null) {<a name="line.2145"></a>
+<span class="sourceLineNo">2146</span>        this.cpHost.preMove(hri, rp.getSource(), rp.getDestination());<a name="line.2146"></a>
+<span class="sourceLineNo">2147</span>      }<a name="line.2147"></a>
+<span class="sourceLineNo">2148</span><a name="line.2148"></a>
+<span class="sourceLineNo">2149</span>      TransitRegionStateProcedure proc =<a name="line.2149"></a>
+<span class="sourceLineNo">2150</span>        this.assignmentManager.createMoveRegionProcedure(rp.getRegionInfo(), rp.getDestination());<a name="line.2150"></a>
+<span class="sourceLineNo">2151</span>      // Warmup the region on the destination before initiating the move.<a name="line.2151"></a>
+<span class="sourceLineNo">2152</span>      // A region server could reject the close request because it either does not<a name="line.2152"></a>
+<span class="sourceLineNo">2153</span>      // have the specified region or the region is being split.<a name="line.2153"></a>
+<span class="sourceLineNo">2154</span>      warmUpRegion(rp.getDestination(), hri);<a name="line.2154"></a>
+<span class="sourceLineNo">2155</span><a name="line.2155"></a>
+<span class="sourceLineNo">2156</span>      LOG.info(getClientIdAuditPrefix() + " move " + rp + ", running balancer");<a name="line.2156"></a>
+<span class="sourceLineNo">2157</span>      Future&lt;byte[]&gt; future = ProcedureSyncWait.submitProcedure(this.procedureExecutor, proc);<a name="line.2157"></a>
+<span class="sourceLineNo">2158</span>      try {<a name="line.2158"></a>
+<span class="sourceLineNo">2159</span>        // Is this going to work? Will we throw exception on error?<a name="line.2159"></a>
+<span class="sourceLineNo">2160</span>        // TODO: CompletableFuture rather than this stunted Future.<a name="line.2160"></a>
+<span class="sourceLineNo">2161</span>        future.get();<a name="line.2161"></a>
+<span class="sourceLineNo">2162</span>      } catch (InterruptedException | ExecutionException e) {<a name="line.2162"></a>
+<span class="sourceLineNo">2163</span>        throw new HBaseIOException(e);<a name="line.2163"></a>
+<span class="sourceLineNo">2164</span>      }<a name="line.2164"></a>
+<span class="sourceLineNo">2165</span>      if (this.cpHost != null) {<a name="line.2165"></a>
+<span class="sourceLineNo">2166</span>        this.cpHost.postMove(hri, rp.getSource(), rp.getDestination());<a name="line.2166"></a>
+<span class="sourceLineNo">2167</span>      }<a name="line.2167"></a>
+<span class="sourceLineNo">2168</span>    } catch (IOException ioe) {<a name="line.2168"></a>
+<span class="sourceLineNo">2169</span>      if (ioe instanceof HBaseIOException) {<a name="line.2169"></a>
+<span class="sourceLineNo">2170</span>        throw (HBaseIOException)ioe;<a name="line.2170"></a>
+<span class="sourceLineNo">2171</span>      }<a name="line.2171"></a>
+<span class="sourceLineNo">2172</span>      throw new HBaseIOException(ioe);<a name="line.2172"></a>
+<span class="sourceLineNo">2173</span>    }<a name="line.2173"></a>
+<span class="sourceLineNo">2174</span>  }<a name="line.2174"></a>
+<span class="sourceLineNo">2175</span><a name="line.2175"></a>
+<span class="sourceLineNo">2176</span>  @Override<a name="line.2176"></a>
+<span class="sourceLineNo">2177</span>  public long createTable(final TableDescriptor tableDescriptor, final byte[][] splitKeys,<a name="line.2177"></a>
+<span class="sourceLineNo">2178</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2178"></a>
+<span class="sourceLineNo">2179</span>    checkInitialized();<a name="line.2179"></a>
+<span class="sourceLineNo">2180</span>    TableDescriptor desc = getMasterCoprocessorHost().preCreateTableRegionsInfos(tableDescriptor);<a name="line.2180"></a>
+<span class="sourceLineNo">2181</span>    if (desc == null) {<a name="line.2181"></a>
+<span class="sourceLineNo">2182</span>      throw new IOException("Creation for " + tableDescriptor + " is canceled by CP");<a name="line.2182"></a>
+<span class="sourceLineNo">2183</span>    }<a name="line.2183"></a>
+<span class="sourceLineNo">2184</span>    String namespace = desc.getTableName().getNamespaceAsString();<a name="line.2184"></a>
+<span class="sourceLineNo">2185</span>    this.clusterSchemaService.getNamespace(namespace);<a name="line.2185"></a>
+<span class="sourceLineNo">2186</span><a name="line.2186"></a>
+<span class="sourceLineNo">2187</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(desc, splitKeys);<a name="line.2187"></a>
+<span class="sourceLineNo">2188</span>    TableDescriptorChecker.sanityCheck(conf, desc);<a name="line.2188"></a>
+<span class="sourceLineNo">2189</span><a name="line.2189"></a>
+<span class="sourceLineNo">2190</span>    return MasterProcedureUtil<a name="line.2190"></a>
+<span class="sourceLineNo">2191</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2191"></a>
+<span class="sourceLineNo">2192</span>        @Override<a name="line.2192"></a>
+<span class="sourceLineNo">2193</span>        protected void run() throws IOException {<a name="line.2193"></a>
+<span class="sourceLineNo">2194</span>          getMaster().getMasterCoprocessorHost().preCreateTable(desc, newRegions);<a name="line.2194"></a>
+<span class="sourceLineNo">2195</span><a name="line.2195"></a>
+<span class="sourceLineNo">2196</span>          LOG.info(getClientIdAuditPrefix() + " create " + desc);<a name="line.2196"></a>
+<span class="sourceLineNo">2197</span><a name="line.2197"></a>
+<span class="sourceLineNo">2198</span>          // TODO: We can handle/merge duplicate requests, and differentiate the case of<a name="line.2198"></a>
+<span class="sourceLineNo">2199</span>          // TableExistsException by saying if the schema is the same or not.<a name="line.2199"></a>
+<span class="sourceLineNo">2200</span>          //<a name="line.2200"></a>
+<span class="sourceLineNo">2201</span>          // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2201"></a>
+<span class="sourceLineNo">2202</span>          // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2202"></a>
+<span class="sourceLineNo">2203</span>          ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2203"></a>
+<span class="sourceLineNo">2204</span>          submitProcedure(<a name="line.2204"></a>
+<span class="sourceLineNo">2205</span>            new CreateTableProcedure(procedureExecutor.getEnvironment(), desc, newRegions, latch));<a name="line.2205"></a>
+<span class="sourceLineNo">2206</span>          latch.await();<a name="line.2206"></a>
+<span class="sourceLineNo">2207</span><a name="line.2207"></a>
+<span class="sourceLineNo">2208</span>          getMaster().getMasterCoprocessorHost().postCreateTable(desc, newRegions);<a name="line.2208"></a>
 <span class="sourceLineNo">2209</span>        }<a name="line.2209"></a>
-<span class="sourceLineNo">2210</span>      });<a name="line.2210"></a>
-<span class="sourceLineNo">2211</span>  }<a name="line.2211"></a>
-<span class="sourceLineNo">2212</span><a name="line.2212"></a>
-<span class="sourceLineNo">2213</span>  @Override<a name="line.2213"></a>
-<span class="sourceLineNo">2214</span>  public long createSystemTable(final TableDescriptor tableDescriptor) throws IOException {<a name="line.2214"></a>
-<span class="sourceLineNo">2215</span>    if (isStopped()) {<a name="line.2215"></a>
-<span class="sourceLineNo">2216</span>      throw new MasterNotRunningException();<a name="line.2216"></a>
-<span class="sourceLineNo">2217</span>    }<a name="line.2217"></a>
-<span class="sourceLineNo">2218</span><a name="line.2218"></a>
-<span class="sourceLineNo">2219</span>    TableName tableName = tableDescriptor.getTableName();<a name="line.2219"></a>
-<span class="sourceLineNo">2220</span>    if (!(tableName.isSystemTable())) {<a name="line.2220"></a>
-<span class="sourceLineNo">2221</span>      throw new IllegalArgumentException(<a name="line.2221"></a>
-<span class="sourceLineNo">2222</span>        "Only system table creation can use this createSystemTable API");<a name="line.2222"></a>
-<span class="sourceLineNo">2223</span>    }<a name="line.2223"></a>
-<span class="sourceLineNo">2224</span><a name="line.2224"></a>
-<span class="sourceLineNo">2225</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(tableDescriptor, null);<a name="line.2225"></a>
-<span class="sourceLineNo">2226</span><a name="line.2226"></a>
-<span class="sourceLineNo">2227</span>    LOG.info(getClientIdAuditPrefix() + " create " + tableDescriptor);<a name="line.2227"></a>
-<span class="sourceLineNo">2228</span><a name="line.2228"></a>
-<span class="sourceLineNo">2229</span>    // This special create table is called locally to master.  Therefore, no RPC means no need<a name="line.2229"></a>
-<span class="sourceLineNo">2230</span>    // to use nonce to detect duplicated RPC call.<a name="line.2230"></a>
-<span class="sourceLineNo">2231</span>    long procId = this.procedureExecutor.submitProcedure(<a name="line.2231"></a>
-<span class="sourceLineNo">2232</span>      new CreateTableProcedure(procedureExecutor.getEnvironment(), tableDescriptor, newRegions));<a name="line.2232"></a>
+<span class="sourceLineNo">2210</span><a name="line.2210"></a>
+<span class="sourceLineNo">2211</span>        @Override<a name="line.2211"></a>
+<span class="sourceLineNo">2212</span>        protected String getDescription() {<a name="line.2212"></a>
+<span class="sourceLineNo">2213</span>          return "CreateTableProcedure";<a name="line.2213"></a>
+<span class="sourceLineNo">2214</span>        }<a name="line.2214"></a>
+<span class="sourceLineNo">2215</span>      });<a name="line.2215"></a>
+<span class="sourceLineNo">2216</span>  }<a name="line.2216"></a>
+<span class="sourceLineNo">2217</span><a name="line.2217"></a>
+<span class="sourceLineNo">2218</span>  @Override<a name="line.2218"></a>
+<span class="sourceLineNo">2219</span>  public long createSystemTable(final TableDescriptor tableDescriptor) throws IOException {<a name="line.2219"></a>
+<span class="sourceLineNo">2220</span>    if (isStopped()) {<a name="line.2220"></a>
+<span class="sourceLineNo">2221</span>      throw new MasterNotRunningException();<a name="line.2221"></a>
+<span class="sourceLineNo">2222</span>    }<a name="line.2222"></a>
+<span class="sourceLineNo">2223</span><a name="line.2223"></a>
+<span class="sourceLineNo">2224</span>    TableName tableName = tableDescriptor.getTableName();<a name="line.2224"></a>
+<span class="sourceLineNo">2225</span>    if (!(tableName.isSystemTable())) {<a name="line.2225"></a>
+<span class="sourceLineNo">2226</span>      throw new IllegalArgumentException(<a name="line.2226"></a>
+<span class="sourceLineNo">2227</span>        "Only system table creation can use this createSystemTable API");<a name="line.2227"></a>
+<span class="sourceLineNo">2228</span>    }<a name="line.2228"></a>
+<span class="sourceLineNo">2229</span><a name="line.2229"></a>
+<span class="sourceLineNo">2230</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(tableDescriptor, null);<a name="line.2230"></a>
+<span class="sourceLineNo">2231</span><a name="line.2231"></a>
+<span class="sourceLineNo">2232</span>    LOG.info(getClientIdAuditPrefix() + " create " + tableDescriptor);<a name="line.2232"></a>
 <span class="sourceLineNo">2233</span><a name="line.2233"></a>
-<span class="sourceLineNo">2234</span>    return procId;<a name="line.2234"></a>
-<span class="sourceLineNo">2235</span>  }<a name="line.2235"></a>
-<span class="sourceLineNo">2236</span><a name="line.2236"></a>
-<span class="sourceLineNo">2237</span>  private void startActiveMasterManager(int infoPort) throws KeeperException {<a name="line.2237"></a>
-<span class="sourceLineNo">2238</span>    String backupZNode = ZNodePaths.joinZNode(<a name="line.2238"></a>
-<span class="sourceLineNo">2239</span>      zooKeeper.getZNodePaths().backupMasterAddressesZNode, serverName.toString());<a name="line.2239"></a>
-<span class="sourceLineNo">2240</span>    /*<a name="line.2240"></a>
-<span class="sourceLineNo">2241</span>    * Add a ZNode for ourselves in the backup master directory since we<a name="line.2241"></a>
-<span class="sourceLineNo">2242</span>    * may not become the active master. If so, we want the actual active<a name="line.2242"></a>
-<span class="sourceLineNo">2243</span>    * master to know we are backup masters, so that it won't assign<a name="line.2243"></a>
-<span class="sourceLineNo">2244</span>    * regions to us if so configured.<a name="line.2244"></a>
-<span class="sourceLineNo">2245</span>    *<a name="line.2245"></a>
-<span class="sourceLineNo">2246</span>    * If we become the active master later, ActiveMasterManager will delete<a name="line.2246"></a>
-<span class="sourceLineNo">2247</span>    * this node explicitly.  If we crash before then, ZooKeeper will delete<a name="line.2247"></a>
-<span class="sourceLineNo">2248</span>    * this node for us since it is ephemeral.<a name="line.2248"></a>
-<span class="sourceLineNo">2249</span>    */<a name="line.2249"></a>
-<span class="sourceLineNo">2250</span>    LOG.info("Adding backup master ZNode " + backupZNode);<a name="line.2250"></a>
-<span class="sourceLineNo">2251</span>    if (!MasterAddressTracker.setMasterAddress(zooKeeper, backupZNode, serverName, infoPort)) {<a name="line.2251"></a>
-<span class="sourceLineNo">2252</span>      LOG.warn("Failed create of " + backupZNode + " by " + serverName);<a name="line.2252"></a>
-<span class="sourceLineNo">2253</span>    }<a name="line.2253"></a>
-<span class="sourceLineNo">2254</span>    this.activeMasterManager.setInfoPort(infoPort);<a name="line.2254"></a>
-<span class="sourceLineNo">2255</span>    int timeout = conf.getInt(HConstants.ZK_SESSION_TIMEOUT, HConstants.DEFAULT_ZK_SESSION_TIMEOUT);<a name="line.2255"></a>
-<span class="sourceLineNo">2256</span>    // If we're a backup master, stall until a primary to write this address<a name="line.2256"></a>
-<span class="sourceLineNo">2257</span>    if (conf.getBoolean(HConstants.MASTER_TYPE_BACKUP, HConstants.DEFAULT_MASTER_TYPE_BACKUP)) {<a name="line.2257"></a>
-<span class="sourceLineNo">2258</span>      LOG.debug("HMaster started in backup mode. Stalling until master znode is written.");<a name="line.2258"></a>
-<span class="sourceLineNo">2259</span>      // This will only be a minute or so while the cluster starts up,<a name="line.2259"></a>
-<span class="sourceLineNo">2260</span>      // so don't worry about setting watches on the parent znode<a name="line.2260"></a>
-<span class="sourceLineNo">2261</span>      while (!activeMasterManager.hasActiveMaster()) {<a name="line.2261"></a>
-<span class="sourceLineNo">2262</span>        LOG.debug("Waiting for master address and cluster state znode to be written.");<a name="line.2262"></a>
-<span class="sourceLineNo">2263</span>        Threads.sleep(timeout);<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>    MonitoredTask status = TaskMonitor.get().createStatus("Master startup");<a name="line.2266"></a>
-<span class="sourceLineNo">2267</span>    status.setDescription("Master startup");<a name="line.2267"></a>
-<span class="sourceLineNo">2268</span>    try {<a name="line.2268"></a>
-<span class="sourceLineNo">2269</span>      if (activeMasterManager.blockUntilBecomingActiveMaster(timeout, status)) {<a name="line.2269"></a>
-<span class="sourceLineNo">2270</span>        finishActiveMasterInitialization(status);<a name="line.2270"></a>
-<span class="sourceLineNo">2271</span>      }<a name="line.2271"></a>
-<span class="sourceLineNo">2272</span>    } catch (Throwable t) {<a name="line.2272"></a>
-<span class="sourceLineNo">2273</span>      status.setStatus("Failed to become active: " + t.getMessage());<a name="line.2273"></a>
-<span class="sourceLineNo">2274</span>      LOG.error(HBaseMarkers.FATAL, "Failed to become active master", t);<a name="line.2274"></a>
-<span class="sourceLineNo">2275</span>      // HBASE-5680: Likely hadoop23 vs hadoop 20.x/1.x incompatibility<a name="line.2275"></a>
-<span class="sourceLineNo">2276</span>      if (t instanceof NoClassDefFoundError &amp;&amp; t.getMessage().<a name="line.2276"></a>
-<span class="sourceLineNo">2277</span>          contains("org/apache/hadoop/hdfs/protocol/HdfsConstants$SafeModeAction")) {<a name="line.2277"></a>
-<span class="sourceLineNo">2278</span>        // improved error message for this special case<a name="line.2278"></a>
-<span class="sourceLineNo">2279</span>        abort("HBase is having a problem with its Hadoop jars.  You may need to recompile " +<a name="line.2279"></a>
-<span class="sourceLineNo">2280</span>          "HBase against Hadoop version " + org.apache.hadoop.util.VersionInfo.getVersion() +<a name="line.2280"></a>
-<span class="sourceLineNo">2281</span>          " or change your hadoop jars to start properly", t);<a name="line.2281"></a>
-<span class="sourceLineNo">2282</span>      } else {<a name="line.2282"></a>
-<span class="sourceLineNo">2283</span>        abort("Unhandled exception. Starting shutdown.", t);<a name="line.2283"></a>
-<span class="sourceLineNo">2284</span>      }<a name="line.2284"></a>
-<span class="sourceLineNo">2285</span>    } finally {<a name="line.2285"></a>
-<span class="sourceLineNo">2286</span>      status.cleanup();<a name="line.2286"></a>
-<span class="sourceLineNo">2287</span>    }<a name="line.2287"></a>
-<span class="sourceLineNo">2288</span>  }<a name="line.2288"></a>
-<span class="sourceLineNo">2289</span><a name="line.2289"></a>
-<span class="sourceLineNo">2290</span>  private static boolean isCatalogTable(final TableName tableName) {<a name="line.2290"></a>
-<span class="sourceLineNo">2291</span>    return tableName.equals(TableName.META_TABLE_NAME);<a name="line.2291"></a>
-<span class="sourceLineNo">2292</span>  }<a name="line.2292"></a>
-<span class="sourceLineNo">2293</span><a name="line.2293"></a>
-<span class="sourceLineNo">2294</span>  @Override<a name="line.2294"></a>
-<span class="sourceLineNo">2295</span>  public long deleteTable(<a name="line.2295"></a>
-<span class="sourceLineNo">2296</span>      final TableName tableName,<a name="line.2296"></a>
-<span class="sourceLineNo">2297</span>      final long nonceGroup,<a name="line.2297"></a>
-<span class="sourceLineNo">2298</span>      final long nonce) throws IOException {<a name="line.2298"></a>
-<span class="sourceLineNo">2299</span>    checkInitialized();<a name="line.2299"></a>
-<span class="sourceLineNo">2300</span><a name="line.2300"></a>
-<span class="sourceLineNo">2301</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2301"></a>
-<span class="sourceLineNo">2302</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2302"></a>
-<span class="sourceLineNo">2303</span>      @Override<a name="line.2303"></a>
-<span class="sourceLineNo">2304</span>      protected void run() throws IOException {<a name="line.2304"></a>
-<span class="sourceLineNo">2305</span>        getMaster().getMasterCoprocessorHost().preDeleteTable(tableName);<a name="line.2305"></a>
-<span class="sourceLineNo">2306</span><a name="line.2306"></a>
-<span class="sourceLineNo">2307</span>        LOG.info(getClientIdAuditPrefix() + " delete " + tableName);<a name="line.2307"></a>
-<span class="sourceLineNo">2308</span><a name="line.2308"></a>
-<span class="sourceLineNo">2309</span>        // TODO: We can handle/merge duplicate request<a name="line.2309"></a>
-<span class="sourceLineNo">2310</span>        //<a name="line.2310"></a>
-<span class="sourceLineNo">2311</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2311"></a>
-<span class="sourceLineNo">2312</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2312"></a>
-<span class="sourceLineNo">2313</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2313"></a>
-<span class="sourceLineNo">2314</span>        submitProcedure(new DeleteTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2314"></a>
-<span class="sourceLineNo">2315</span>            tableName, latch));<a name="line.2315"></a>
-<span class="sourceLineNo">2316</span>        latch.await();<a name="line.2316"></a>
-<span class="sourceLineNo">2317</span><a name="line.2317"></a>
-<span class="sourceLineNo">2318</span>        getMaster().getMasterCoprocessorHost().postDeleteTable(tableName);<a name="line.2318"></a>
-<span class="sourceLineNo">2319</span>      }<a name="line.2319"></a>
-<span class="sourceLineNo">2320</span><a name="line.2320"></a>
-<span class="sourceLineNo">2321</span>      @Override<a name="line.2321"></a>
-<span class="sourceLineNo">2322</span>      protected String getDescription() {<a name="line.2322"></a>
-<span class="sourceLineNo">2323</span>        return "DeleteTableProcedure";<a name="line.2323"></a>
+<span class="sourceLineNo">2234</span>    // This special create table is called locally to master.  Therefore, no RPC means no need<a name="line.2234"></a>
+<span class="sourceLineNo">2235</span>    // to use nonce to detect duplicated RPC call.<a name="line.2235"></a>
+<span class="sourceLineNo">2236</span>    long procId = this.procedureExecutor.submitProcedure(<a name="line.2236"></a>
+<span class="sourceLineNo">2237</span>      new CreateTableProcedure(procedureExecutor.getEnvironment(), tableDescriptor, newRegions));<a name="line.2237"></a>
+<span class="sourceLineNo">2238</span><a name="line.2238"></a>
+<span class="sourceLineNo">2239</span>    return procId;<a name="line.2239"></a>
+<span class="sourceLineNo">2240</span>  }<a name="line.2240"></a>
+<span class="sourceLineNo">2241</span><a name="line.2241"></a>
+<span class="sourceLineNo">2242</span>  private void startActiveMasterManager(int infoPort) throws KeeperException {<a name="line.2242"></a>
+<span class="sourceLineNo">2243</span>    String backupZNode = ZNodePaths.joinZNode(<a name="line.2243"></a>
+<span class="sourceLineNo">2244</span>      zooKeeper.getZNodePaths().backupMasterAddressesZNode, serverName.toString());<a name="line.2244"></a>
+<span class="sourceLineNo">2245</span>    /*<a name="line.2245"></a>
+<span class="sourceLineNo">2246</span>    * Add a ZNode for ourselves in the backup master directory since we<a name="line.2246"></a>
+<span class="sourceLineNo">2247</span>    * may not become the active master. If so, we want the actual active<a name="line.2247"></a>
+<span class="sourceLineNo">2248</span>    * master to know we are backup masters, so that it won't assign<a name="line.2248"></a>
+<span class="sourceLineNo">2249</span>    * regions to us if so configured.<a name="line.2249"></a>
+<span class="sourceLineNo">2250</span>    *<a name="line.2250"></a>
+<span class="sourceLineNo">2251</span>    * If we become the active master later, ActiveMasterManager will delete<a name="line.2251"></a>
+<span class="sourceLineNo">2252</span>    * this node explicitly.  If we crash before then, ZooKeeper will delete<a name="line.2252"></a>
+<span class="sourceLineNo">2253</span>    * this node for us since it is ephemeral.<a name="line.2253"></a>
+<span class="sourceLineNo">2254</span>    */<a name="line.2254"></a>
+<span class="sourceLineNo">2255</span>    LOG.info("Adding backup master ZNode " + backupZNode);<a name="line.2255"></a>
+<span class="sourceLineNo">2256</span>    if (!MasterAddressTracker.setMasterAddress(zooKeeper, backupZNode, serverName, infoPort)) {<a name="line.2256"></a>
+<span class="sourceLineNo">2257</span>      LOG.warn("Failed create of " + backupZNode + " by " + serverName);<a name="line.2257"></a>
+<span class="sourceLineNo">2258</span>    }<a name="line.2258"></a>
+<span class="sourceLineNo">2259</span>    this.activeMasterManager.setInfoPort(infoPort);<a name="line.2259"></a>
+<span class="sourceLineNo">2260</span>    int timeout = conf.getInt(HConstants.ZK_SESSION_TIMEOUT, HConstants.DEFAULT_ZK_SESSION_TIMEOUT);<a name="line.2260"></a>
+<span class="sourceLineNo">2261</span>    // If we're a backup master, stall until a primary to write this address<a name="line.2261"></a>
+<span class="sourceLineNo">2262</span>    if (conf.getBoolean(HConstants.MASTER_TYPE_BACKUP, HConstants.DEFAULT_MASTER_TYPE_BACKUP)) {<a name="line.2262"></a>
+<span class="sourceLineNo">2263</span>      LOG.debug("HMaster started in backup mode. Stalling until master znode is written.");<a name="line.2263"></a>
+<span class="sourceLineNo">2264</span>      // This will only be a minute or so while the cluster starts up,<a name="line.2264"></a>
+<span class="sourceLineNo">2265</span>      // so don't worry about setting watches on the parent znode<a name="line.2265"></a>
+<span class="sourceLineNo">2266</span>      while (!activeMasterManager.hasActiveMaster()) {<a name="line.2266"></a>
+<span class="sourceLineNo">2267</span>        LOG.debug("Waiting for master address and cluster state znode to be written.");<a name="line.2267"></a>
+<span class="sourceLineNo">2268</span>        Threads.sleep(timeout);<a name="line.2268"></a>
+<span class="sourceLineNo">2269</span>      }<a name="line.2269"></a>
+<span class="sourceLineNo">2270</span>    }<a name="line.2270"></a>
+<span class="sourceLineNo">2271</span>    MonitoredTask status = TaskMonitor.get().createStatus("Master startup");<a name="line.2271"></a>
+<span class="sourceLineNo">2272</span>    status.setDescription("Master startup");<a name="line.2272"></a>
+<span class="sourceLineNo">2273</span>    try {<a name="line.2273"></a>
+<span class="sourceLineNo">2274</span>      if (activeMasterManager.blockUntilBecomingActiveMaster(timeout, status)) {<a name="line.2274"></a>
+<span class="sourceLineNo">2275</span>        finishActiveMasterInitialization(status);<a name="line.2275"></a>
+<span class="sourceLineNo">2276</span>      }<a name="line.2276"></a>
+<span class="sourceLineNo">2277</span>    } catch (Throwable t) {<a name="line.2277"></a>
+<span class="sourceLineNo">2278</span>      status.setStatus("Failed to become active: " + t.getMessage());<a name="line.2278"></a>
+<span class="sourceLineNo">2279</span>      LOG.error(HBaseMarkers.FATAL, "Failed to become active master", t);<a name="line.2279"></a>
+<span class="sourceLineNo">2280</span>      // HBASE-5680: Likely hadoop23 vs hadoop 20.x/1.x incompatibility<a name="line.2280"></a>
+<span class="sourceLineNo">2281</span>      if (t instanceof NoClassDefFoundError &amp;&amp; t.getMessage().<a name="line.2281"></a>
+<span class="sourceLineNo">2282</span>          contains("org/apache/hadoop/hdfs/protocol/HdfsConstants$SafeModeAction")) {<a name="line.2282"></a>
+<span class="sourceLineNo">2283</span>        // improved error message for this special case<a name="line.2283"></a>
+<span class="sourceLineNo">2284</span>        abort("HBase is having a problem with its Hadoop jars.  You may need to recompile " +<a name="line.2284"></a>
+<span class="sourceLineNo">2285</span>          "HBase against Hadoop version " + org.apache.hadoop.util.VersionInfo.getVersion() +<a name="line.2285"></a>
+<span class="sourceLineNo">2286</span>          " or change your hadoop jars to start properly", t);<a name="line.2286"></a>
+<span class="sourceLineNo">2287</span>      } else {<a name="line.2287"></a>
+<span class="sourceLineNo">2288</span>        abort("Unhandled exception. Starting shutdown.", t);<a name="line.2288"></a>
+<span class="sourceLineNo">2289</span>      }<a name="line.2289"></a>
+<span class="sourceLineNo">2290</span>    } finally {<a name="line.2290"></a>
+<span class="sourceLineNo">2291</span>      status.cleanup();<a name="line.2291"></a>
+<span class="sourceLineNo">2292</span>    }<a name="line.2292"></a>
+<span class="sourceLineNo">2293</span>  }<a name="line.2293"></a>
+<span class="sourceLineNo">2294</span><a name="line.2294"></a>
+<span class="sourceLineNo">2295</span>  private static boolean isCatalogTable(final TableName tableName) {<a name="line.2295"></a>
+<span class="sourceLineNo">2296</span>    return tableName.equals(TableName.META_TABLE_NAME);<a name="line.2296"></a>
+<span class="sourceLineNo">2297</span>  }<a name="line.2297"></a>
+<span class="sourceLineNo">2298</span><a name="line.2298"></a>
+<span class="sourceLineNo">2299</span>  @Override<a name="line.2299"></a>
+<span class="sourceLineNo">2300</span>  public long deleteTable(<a name="line.2300"></a>
+<span class="sourceLineNo">2301</span>      final TableName tableName,<a name="line.2301"></a>
+<span class="sourceLineNo">2302</span>      final long nonceGroup,<a name="line.2302"></a>
+<span class="sourceLineNo">2303</span>      final long nonce) throws IOException {<a name="line.2303"></a>
+<span class="sourceLineNo">2304</span>    checkInitialized();<a name="line.2304"></a>
+<span class="sourceLineNo">2305</span><a name="line.2305"></a>
+<span class="sourceLineNo">2306</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2306"></a>
+<span class="sourceLineNo">2307</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2307"></a>
+<span class="sourceLineNo">2308</span>      @Override<a name="line.2308"></a>
+<span class="sourceLineNo">2309</span>      protected void run() throws IOException {<a name="line.2309"></a>
+<span class="sourceLineNo">2310</span>        getMaster().getMasterCoprocessorHost().preDeleteTable(tableName);<a name="line.2310"></a>
+<span class="sourceLineNo">2311</span><a name="line.2311"></a>
+<span class="sourceLineNo">2312</span>        LOG.info(getClientIdAuditPrefix() + " delete " + tableName);<a name="line.2312"></a>
+<span class="sourceLineNo">2313</span><a name="line.2313"></a>
+<span class="sourceLineNo">2314</span>        // TODO: We can handle/merge duplicate request<a name="line.2314"></a>
+<span class="sourceLineNo">2315</span>        //<a name="line.2315"></a>
+<span class="sourceLineNo">2316</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2316"></a>
+<span class="sourceLineNo">2317</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2317"></a>
+<span class="sourceLineNo">2318</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2318"></a>
+<span class="sourceLineNo">2319</span>        submitProcedure(new DeleteTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2319"></a>
+<span class="sourceLineNo">2320</span>            tableName, latch));<a name="line.2320"></a>
+<span class="sourceLineNo">2321</span>        latch.await();<a name="line.2321"></a>
+<span class="sourceLineNo">2322</span><a name="line.2322"></a>
+<span class="sourceLineNo">2323</span>        getMaster().getMasterCoprocessorHost().postDeleteTable(tableName);<a name="line.2323"></a>
 <span class="sourceLineNo">2324</span>      }<a name="line.2324"></a>
-<span class="sourceLineNo">2325</span>    });<a name="line.2325"></a>
-<span class="sourceLineNo">2326</span>  }<a name="line.2326"></a>
-<span class="sourceLineNo">2327</span><a name="line.2327"></a>
-<span class="sourceLineNo">2328</span>  @Override<a name="line.2328"></a>
-<span class="sourceLineNo">2329</span>  public long truncateTable(<a name="line.2329"></a>
-<span class="sourceLineNo">2330</span>      final TableName tableName,<a name="line.2330"></a>
-<span class="sourceLineNo">2331</span>      final boolean preserveSplits,<a name="line.2331"></a>
-<span class="sourceLineNo">2332</span>      final long nonceGroup,<a name="line.2332"></a>
-<span class="sourceLineNo">2333</span>      final long nonce) throws IOException {<a name="line.2333"></a>
-<span class="sourceLineNo">2334</span>    checkInitialized();<a name="line.2334"></a>
-<span class="sourceLineNo">2335</span><a name="line.2335"></a>
-<span class="sourceLineNo">2336</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2336"></a>
-<span class="sourceLineNo">2337</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2337"></a>
-<span class="sourceLineNo">2338</span>      @Override<a name="line.2338"></a>
-<span class="sourceLineNo">2339</span>      protected void run() throws IOException {<a name="line.2339"></a>
-<span class="sourceLineNo">2340</span>        getMaster().getMasterCoprocessorHost().preTruncateTable(tableName);<a name="line.2340"></a>
-<span class="sourceLineNo">2341</span><a name="line.2341"></a>
-<span class="sourceLineNo">2342</span>        LOG.info(getClientIdAuditPrefix() + " truncate " + tableName);<a name="line.2342"></a>
-<span class="sourceLineNo">2343</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createLatch(2, 0);<a name="line.2343"></a>
-<span class="sourceLineNo">2344</span>        submitProcedure(new TruncateTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2344"></a>
-<span class="sourceLineNo">2345</span>            tableName, preserveSplits, latch));<a name="line.2345"></a>
-<span class="sourceLineNo">2346</span>        latch.await();<a name="line.2346"></a>
-<span class="sourceLineNo">2347</span><a name="line.2347"></a>
-<span class="sourceLineNo">2348</span>        getMaster().getMasterCoprocessorHost().postTruncateTable(tableName);<a name="line.2348"></a>
-<span class="sourceLineNo">2349</span>      }<a name="line.2349"></a>
-<span class="sourceLineNo">2350</span><a name="line.2350"></a>
-<span class="sourceLineNo">2351</span>      @Override<a name="line.2351"></a>
-<span class="sourceLineNo">2352</span>      protected String getDescription() {<a name="line.2352"></a>
-<span class="sourceLineNo">2353</span>        return "TruncateTableProcedure";<a name="line.2353"></a>
+<span class="sourceLineNo">2325</span><a name="line.2325"></a>
+<span class="sourceLineNo">2326</span>      @Override<a name="line.2326"></a>
+<span class="sourceLineNo">2327</span>      protected String getDescription() {<a name="line.2327"></a>
+<span class="sourceLineNo">2328</span>        return "DeleteTableProcedure";<a name="line.2328"></a>
+<span class="sourceLineNo">2329</span>      }<a name="line.2329"></a>
+<span class="sourceLineNo">2330</span>    });<a name="line.2330"></a>
+<span class="sourceLineNo">2331</span>  }<a name="line.2331"></a>
+<span class="sourceLineNo">2332</span><a name="line.2332"></a>
+<span class="sourceLineNo">2333</span>  @Override<a name="line.2333"></a>
+<span class="sourceLineNo">2334</span>  public long truncateTable(<a name="line.2334"></a>
+<span class="sourceLineNo">2335</span>      final TableName tableName,<a name="line.2335"></a>
+<span class="sourceLineNo">2336</span>      final boolean preserveSplits,<a name="line.2336"></a>
+<span class="sourceLineNo">2337</span>      final long nonceGroup,<a name="line.2337"></a>
+<span class="sourceLineNo">2338</span>      final long nonce) throws IOException {<a name="line.2338"></a>
+<span class="sourceLineNo">2339</span>    checkInitialized();<a name="line.2339"></a>
+<span class="sourceLineNo">2340</span><a name="line.2340"></a>
+<span class="sourceLineNo">2341</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2341"></a>
+<span class="sourceLineNo">2342</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2342"></a>
+<span class="sourceLineNo">2343</span>      @Override<a name="line.2343"></a>
+<span class="sourceLineNo">2344</span>      protected void run() throws IOException {<a name="line.2344"></a>
+<span class="sourceLineNo">2345</span>        getMaster().getMasterCoprocessorHost().preTruncateTable(tableName);<a name="line.2345"></a>
+<span class="sourceLineNo">2346</span><a name="line.2346"></a>
+<span class="sourceLineNo">2347</span>        LOG.info(getClientIdAuditPrefix() + " truncate " + tableName);<a name="line.2347"></a>
+<span class="sourceLineNo">2348</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createLatch(2, 0);<a name="line.2348"></a>
+<span class="sourceLineNo">2349</span>        submitProcedure(new TruncateTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2349"></a>
+<span class="sourceLineNo">2350</span>            tableName, preserveSplits, latch));<a name="line.2350"></a>
+<span class="sourceLineNo">2351</span>        latch.await();<a name="line.2351"></a>
+<span class="sourceLineNo">2352</span><a name="line.2352"></a>
+<span class="sourceLineNo">2353</span>        getMaster().getMasterCoprocessorHost().postTruncateTable(tableName);<a name="line.2353"></a>
 <span class="sourceLineNo">2354</span>      }<a name="line.2354"></a>
-<span class="sourceLineNo">2355</span>    });<a name="line.2355"></a>
-<span class="sourceLineNo">2356</span>  }<a name="line.2356"></a>
-<span class="sourceLineNo">2357</span><a name="line.2357"></a>
-<span class="sourceLineNo">2358</span>  @Override<a name="line.2358"></a>
-<span class="sourceLineNo">2359</span>  public long addColumn(final TableName tableName, final ColumnFamilyDescriptor column,<a name="line.2359"></a>
-<span class="sourceLineNo">2360</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2360"></a>
-<span class="sourceLineNo">2361</span>    checkInitialized();<a name="line.2361"></a>
-<span class="sourceLineNo">2362</span>    checkTableExists(tableName);<a name="line.2362"></a>
-<span class="sourceLineNo">2363</span><a name="line.2363"></a>
-<span class="sourceLineNo">2364</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2364"></a>
-<span class="sourceLineNo">2365</span><a name="line.2365"></a>
-<span class="sourceLineNo">2366</span>      @Override<a name="line.2366"></a>
-<span class="sourceLineNo">2367</span>      public TableDescriptor get() throws IOException {<a name="line.2367"></a>
-<span class="sourceLineNo">2368</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2368"></a>
-<span class="sourceLineNo">2369</span>        if (old.hasColumnFamily(column.getName())) {<a name="line.2369"></a>
-<span class="sourceLineNo">2370</span>          throw new InvalidFamilyOperationException("Column family '" + column.getNameAsString()<a name="line.2370"></a>
-<span class="sourceLineNo">2371</span>              + "' in table '" + tableName + "' already exists so cannot be added");<a name="line.2371"></a>
-<span class="sourceLineNo">2372</span>        }<a name="line.2372"></a>
-<span class="sourceLineNo">2373</span><a name="line.2373"></a>
-<span class="sourceLineNo">2374</span>        return TableDescriptorBuilder.newBuilder(old).setColumnFamily(column).build();<a name="line.2374"></a>
-<span class="sourceLineNo">2375</span>      }<a name="line.2375"></a>
-<span class="sourceLineNo">2376</span>    }, nonceGroup, nonce, true);<a name="line.2376"></a>
-<span class="sourceLineNo">2377</span>  }<a name="line.2377"></a>
+<span class="sourceLineNo">2355</span><a name="line.2355"></a>
+<span class="sourceLineNo">2356</span>      @Override<a name="line.2356"></a>
+<span class="sourceLineNo">2357</span>      protected String getDescription() {<a name="line.2357"></a>
+<span class="sourceLineNo">2358</span>        return "TruncateTableProcedure";<a name="line.2358"></a>
+<span class="sourceLineNo">2359</span>      }<a name="line.2359"></a>
+<span class="sourceLineNo">2360</span>    });<a name="line.2360"></a>
+<span class="sourceLineNo">2361</span>  }<a name="line.2361"></a>
+<span class="sourceLineNo">2362</span><a name="line.2362"></a>
+<span class="sourceLineNo">2363</span>  @Override<a name="line.2363"></a>
+<span class="sourceLineNo">2364</span>  public long addColumn(final TableName tableName, final ColumnFamilyDescriptor column,<a name="line.2364"></a>
+<span class="sourceLineNo">2365</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2365"></a>
+<span class="sourceLineNo">2366</span>    checkInitialized();<a name="line.2366"></a>
+<span class="sourceLineNo">2367</span>    checkTableExists(tableName);<a name="line.2367"></a>
+<span class="sourceLineNo">2368</span><a name="line.2368"></a>
+<span class="sourceLineNo">2369</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2369"></a>
+<span class="sourceLineNo">2370</span><a name="line.2370"></a>
+<span class="sourceLineNo">2371</span>      @Override<a name="line.2371"></a>
+<span class="sourceLineNo">2372</span>      public TableDescriptor get() throws IOException {<a name="line.2372"></a>
+<span class="sourceLineNo">2373</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2373"></a>
+<span class="sourceLineNo">2374</span>        if (old.hasColumnFamily(column.getName())) {<a name="line.2374"></a>
+<span class="sourceLineNo">2375</span>          throw new InvalidFamilyOperationException("Column family '" + column.getNameAsString()<a name="line.2375"></a>
+<span class="sourceLineNo">2376</span>              + "' in table '" + tableName + "' already exists so cannot be added");<a name="line.2376"></a>
+<span class="sourceLineNo">2377</span>        }<a name="line.2377"></a>
 <span class="sourceLineNo">2378</span><a name="line.2378"></a>
-<span class="sourceLineNo">2379</span>  /**<a name="line.2379"></a>
-<span class="sourceLineNo">2380</span>   * Implement to return TableDescriptor after pre-checks<a name="line.2380"></a>
-<span class="sourceLineNo">2381</span>   */<a name="line.2381"></a>
-<span class="sourceLineNo">2382</span>  protected interface TableDescriptorGetter {<a name="line.2382"></a>
-<span class="sourceLineNo">2383</span>    TableDescriptor get() throws IOException;<a name="line.2383"></a>
-<span class="sourceLineNo">2384</span>  }<a name="line.2384"></a>
-<span class="sourceLineNo">2385</span><a name="line.2385"></a>
-<span class="sourceLineNo">2386</span>  @Override<a name="line.2386"></a>
-<span class="sourceLineNo">2387</span>  public long modifyColumn(final TableName tableName, final ColumnFamilyDescriptor descriptor,<a name="line.2387"></a>
-<span class="sourceLineNo">2388</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2388"></a>
-<span class="sourceLineNo">2389</span>    checkInitialized();<a name="line.2389"></a>
-<span class="sourceLineNo">2390</span>    checkTableExists(tableName);<a name="line.2390"></a>
-<span class="sourceLineNo">2391</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2391"></a>
-<span class="sourceLineNo">2392</span><a name="line.2392"></a>
-<span class="sourceLineNo">2393</span>      @Override<a name="line.2393"></a>
-<span class="sourceLineNo">2394</span>      public TableDescriptor get() throws IOException {<a name="line.2394"></a>
-<span class="sourceLineNo">2395</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2395"></a>
-<span class="sourceLineNo">2396</span>        if (!old.hasColumnFamily(descriptor.getName())) {<a name="line.2396"></a>
-<span class="sourceLineNo">2397</span>          throw new InvalidFamilyOperationException("Family '" + descriptor.getNameAsString()<a name="line.2397"></a>
-<span class="sourceLineNo">2398</span>              + "' does not exist, so it cannot be modified");<a name="line.2398"></a>
-<span class="sourceLineNo">2399</span>        }<a name="line.2399"></a>
-<span class="sourceLineNo">2400</span><a name="line.2400"></a>
-<span class="sourceLineNo">2401</span>        return TableDescriptorBuilder.newBuilder(old).modifyColumnFamily(descriptor).build();<a name="line.2401"></a>
-<span class="sourceLineNo">2402</span>      }<a name="line.2402"></a>
-<span class="sourceLineNo">2403</span>    }, nonceGroup, nonce, true);<a name="line.2403"></a>
-<span class="sourceLineNo">2404</span>  }<a name="line.2404"></a>
+<span class="sourceLineNo">2379</span>        return TableDescriptorBuilder.newBuilder(old).setColumnFamily(column).build();<a name="line.2379"></a>
+<span class="sourceLineNo">2380</span>      }<a name="line.2380"></a>
+<span class="sourceLineNo">2381</span>    }, nonceGroup, nonce, true);<a name="line.2381"></a>
+<span class="sourceLineNo">2382</span>  }<a name="line.2382"></a>
+<span class="sourceLineNo">2383</span><a name="line.2383"></a>
+<span class="sourceLineNo">2384</span>  /**<a name="line.2384"></a>
+<span class="sourceLineNo">2385</span>   * Implement to return TableDescriptor after pre-checks<a name="line.2385"></a>
+<span class="sourceLineNo">2386</span>   */<a name="line.2386"></a>
+<span class="sourceLineNo">2387</span>  protected interface TableDescriptorGetter {<a name="line.2387"></a>
+<span class="sourceLineNo">2388</span>    TableDescriptor get() throws IOException;<a name="line.2388"></a>
+<span class="sourceLineNo">2389</span>  }<a name="line.2389"></a>
+<span class="sourceLineNo">2390</span><a name="line.2390"></a>
+<span class="sourceLineNo">2391</span>  @Override<a name="line.2391"></a>
+<span class="sourceLineNo">2392</span>  public long modifyColumn(final TableName tableName, final ColumnFamilyDescriptor descriptor,<a name="line.2392"></a>
+<span class="sourceLineNo">2393</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2393"></a>
+<span class="sourceLineNo">2394</span>    checkInitialized();<a name="line.2394"></a>
+<span class="sourceLineNo">2395</span>    checkTableExists(tableName);<a name="line.2395"></a>
+<span class="sourceLineNo">2396</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2396"></a>
+<span class="sourceLineNo">2397</span><a name="line.2397"></a>
+<span class="sourceLineNo">2398</span>      @Override<a name="line.2398"></a>
+<span class="sourceLineNo">2399</span>      public TableDescriptor get() throws IOException {<a name="line.2399"></a>
+<span class="sourceLineNo">2400</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2400"></a>
+<span class="sourceLineNo">2401</span>        if (!old.hasColumnFamily(descriptor.getName())) {<a name="line.2401"></a>
+<span class="sourceLineNo">2402</span>          throw new InvalidFamilyOperationException("Family '" + descriptor.getNameAsString()<a name="line.2402"></a>
+<span class="sourceLineNo">2403</span>              + "' does not exist, so it cannot be modified");<a name="line.2403"></a>
+<span class="sourceLineNo">2404</span>        }<a name="line.2404"></a>
 <span class="sourceLineNo">2405</span><a name="line.2405"></a>
-<span class="sourceLineNo">2406</span>  @Override<a name="line.2406"></a>
-<span class="sourceLineNo">2407</span>  public long deleteColumn(final TableName tableName, final byte[] columnName,<a name="line.2407"></a>
-<span class="sourceLineNo">2408</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2408"></a>
-<span class="sourceLineNo">2409</span>    checkInitialized();<a name="line.2409"></a>
-<span class="sourceLineNo">2410</span>    checkTableExists(tableName);<a name="line.2410"></a>
-<span class="sourceLineNo">2411</span><a name="line.2411"></a>
-<span class="sourceLineNo">2412</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2412"></a>
-<span class="sourceLineNo">2413</span><a name="line.2413"></a>
-<span class="sourceLineNo">2414</span>      @Override<a name="line.2414"></a>
-<span class="sourceLineNo">2415</span>      public TableDescriptor get() throws IOException {<a name="line.2415"></a>
-<span class="sourceLineNo">2416</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2416"></a>
-<span class="sourceLineNo">2417</span><a name="line.2417"></a>
-<span class="sourceLineNo">2418</span>        if (!old.hasColumnFamily(columnName)) {<a name="line.2418"></a>
-<span class="sourceLineNo">2419</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2419"></a>
-<span class="sourceLineNo">2420</span>              + "' does not exist, so it cannot be deleted");<a name="line.2420"></a>
-<span class="sourceLineNo">2421</span>        }<a name="line.2421"></a>
-<span class="sourceLineNo">2422</span>        if (old.getColumnFamilyCount() == 1) {<a name="line.2422"></a>
-<span class="sourceLineNo">2423</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2423"></a>
-<span class="sourceLineNo">2424</span>              + "' is the only column family in the table, so it cannot be deleted");<a name="line.2424"></a>
-<span class="sourceLineNo">2425</span>        }<a name="line.2425"></a>
-<span class="sourceLineNo">2426</span>        return TableDescriptorBuilder.newBuilder(old).removeColumnFamily(columnName).build();<a name="line.2426"></a>
-<span class="sourceLineNo">2427</span>      }<a name="line.2427"></a>
-<span class="sourceLineNo">2428</span>    }, nonceGroup, nonce, true);<a name="line.2428"></a>
-<span class="sourceLineNo">2429</span>  }<a name="line.2429"></a>
-<span class="sourceLineNo">2430</span><a name="line.2430"></a>
-<span class="sourceLineNo">2431</span>  @Override<a name="line.2431"></a>
-<span class="sourceLineNo">2432</span>  public long enableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2432"></a>
-<span class="sourceLineNo">2433</span>      throws IOException {<a name="line.2433"></a>
-<span class="sourceLineNo">2434</span>    checkInitialized();<a name="line.2434"></a>
+<span class="sourceLineNo">2406</span>        return TableDescriptorBuilder.newBuilder(old).modifyColumnFamily(descriptor).build();<a name="line.2406"></a>
+<span class="sourceLineNo">2407</span>      }<a name="line.2407"></a>
+<span class="sourceLineNo">2408</span>    }, nonceGroup, nonce, true);<a name="line.2408"></a>
+<span class="sourceLineNo">2409</span>  }<a name="line.2409"></a>
+<span class="sourceLineNo">2410</span><a name="line.2410"></a>
+<span class="sourceLineNo">2411</span>  @Override<a name="line.2411"></a>
+<span class="sourceLineNo">2412</span>  public long deleteColumn(final TableName tableName, final byte[] columnName,<a name="line.2412"></a>
+<span class="sourceLineNo">2413</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2413"></a>
+<span class="sourceLineNo">2414</span>    checkInitialized();<a name="line.2414"></a>
+<span class="sourceLineNo">2415</span>    checkTableExists(tableName);<a name="line.2415"></a>
+<span class="sourceLineNo">2416</span><a name="line.2416"></a>
+<span class="sourceLineNo">2417</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2417"></a>
+<span class="sourceLineNo">2418</span><a name="line.2418"></a>
+<span class="sourceLineNo">2419</span>      @Override<a name="line.2419"></a>
+<span class="sourceLineNo">2420</span>      public TableDescriptor get() throws IOException {<a name="line.2420"></a>
+<span class="sourceLineNo">2421</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2421"></a>
+<span class="sourceLineNo">2422</span><a name="line.2422"></a>
+<span class="sourceLineNo">2423</span>        if (!old.hasColumnFamily(columnName)) {<a name="line.2423"></a>
+<span class="sourceLineNo">2424</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2424"></a>
+<span class="sourceLineNo">2425</span>              + "' does not exist, so it cannot be deleted");<a name="line.2425"></a>
+<span class="sourceLineNo">2426</span>        }<a name="line.2426"></a>
+<span class="sourceLineNo">2427</span>        if (old.getColumnFamilyCount() == 1) {<a name="line.2427"></a>
+<span class="sourceLineNo">2428</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2428"></a>
+<span class="sourceLineNo">2429</span>              + "' is the only column family in the table, so it cannot be deleted");<a name="line.2429"></a>
+<span class="sourceLineNo">2430</span>        }<a name="line.2430"></a>
+<span class="sourceLineNo">2431</span>        return TableDescriptorBuilder.newBuilder(old).removeColumnFamily(columnName).build();<a name="line.2431"></a>
+<span class="sourceLineNo">2432</span>      }<a name="line.2432"></a>
+<span class="sourceLineNo">2433</span>    }, nonceGroup, nonce, true);<a name="line.2433"></a>
+<span class="sourceLineNo">2434</span>  }<a name="line.2434"></a>
 <span class="sourceLineNo">2435</span><a name="line.2435"></a>
-<span class="sourceLineNo">2436</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2436"></a>
-<span class="sourceLineNo">2437</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2437"></a>
-<span class="sourceLineNo">2438</span>      @Override<a name="line.2438"></a>
-<span class="sourceLineNo">2439</span>      protected void run() throws IOException {<a name="line.2439"></a>
-<span class="sourceLineNo">2440</span>        getMaster().getMasterCoprocessorHost().preEnableTable(tableName);<a name="line.2440"></a>
-<span class="sourceLineNo">2441</span><a name="line.2441"></a>
-<span class="sourceLineNo">2442</span>        // Normally, it would make sense for this authorization check to exist inside<a name="line.2442"></a>
-<span class="sourceLineNo">2443</span>        // AccessController, but because the authorization check is done based on internal state<a name="line.2443"></a>
-<span class="sourceLineNo">2444</span>        // (rather than explicit permissions) we'll do the check here instead of in the<a name="line.2444"></a>
-<span class="sourceLineNo">2445</span>        // coprocessor.<a name="line.2445"></a>
-<span class="sourceLineNo">2446</span>        MasterQuotaManager quotaManager = getMasterQuotaManager();<a name="line.2446"></a>
-<span class="sourceLineNo">2447</span>        if (quotaManager != null) {<a name="line.2447"></a>
-<span class="sourceLineNo">2448</span>          if (quotaManager.isQuotaInitialized()) {<a name="line.2448"></a>
-<span class="sourceLineNo">2449</span>              SpaceQuotaSnapshot currSnapshotOfTable =<a name="line.2449"></a>
-<span class="sourceLineNo">2450</span>                  QuotaTableUtil.getCurrentSnapshotFromQuotaTable(getConnection(), tableName);<a name="line.2450"></a>
-<span class="sourceLineNo">2451</span>              if (currSnapshotOfTable != null) {<a name="line.2451"></a>
-<span class="sourceLineNo">2452</span>                SpaceQuotaStatus quotaStatus = currSnapshotOfTable.getQuotaStatus();<a name="line.2452"></a>
-<span class="sourceLineNo">2453</span>                if (quotaStatus.isInViolation()<a name="line.2453"></a>
-<span class="sourceLineNo">2454</span>                    &amp;&amp; SpaceViolationPolicy.DISABLE == quotaStatus.getPolicy().orElse(null)) {<a name="line.2454"></a>
-<span class="sourceLineNo">2455</span>                throw new AccessDeniedException("Enabling the table '" + tableName<a name="line.2455"></a>
-<span class="sourceLineNo">2456</span>                    + "' is disallowed due to a violated space quota.");<a name="line.2456"></a>
-<span class="sourceLineNo">2457</span>              }<a name="line.2457"></a>
-<span class="sourceLineNo">2458</span>            }<a name="line.2458"></a>
-<span class="sourceLineNo">2459</span>          } else if (LOG.isTraceEnabled()) {<a name="line.2459"></a>
-<span class="sourceLineNo">2460</span>            LOG.trace("Unable to check for space quotas as the MasterQuotaManager is not enabled");<a name="line.2460"></a>
-<span class="sourceLineNo">2461</span>          }<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>        LOG.info(getClientIdAuditPrefix() + " enable " + tableName);<a name="line.2464"></a>
-<span class="sourceLineNo">2465</span><a name="line.2465"></a>
-<span class="sourceLineNo">2466</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2466"></a>
-<span class="sourceLineNo">2467</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2467"></a>
-<span class="sourceLineNo">2468</span>        // we want to make sure that the table is prepared to be<a name="line.2468"></a>
-<span class="sourceLineNo">2469</span>        // enabled (the table is locked and the table state is set).<a name="line.2469"></a>
-<span class="sourceLineNo">2470</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2470"></a>
-<span class="sourceLineNo">2471</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createLatch();<a name="line.2471"></a>
-<span class="sourceLineNo">2472</span>        submitProcedure(new EnableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2472"></a>
-<span class="sourceLineNo">2473</span>            tableName, prepareLatch));<a name="line.2473"></a>
-<span class="sourceLineNo">2474</span>        prepareLatch.await();<a name="line.2474"></a>
-<span class="sourceLineNo">2475</span><a name="line.2475"></a>
-<span class="sourceLineNo">2476</span>        getMaster().getMasterCoprocessorHost().postEnableTable(tableName);<a name="line.2476"></a>
-<span class="sourceLineNo">2477</span>      }<a name="line.2477"></a>
-<span class="sourceLineNo">2478</span><a name="line.2478"></a>
-<span class="sourceLineNo">2479</span>      @Override<a name="line.2479"></a>
-<span class="sourceLineNo">2480</span>      protected String getDescription() {<a name="line.2480"></a>
-<span class="sourceLineNo">2481</span>        return "EnableTableProcedure";<a name="line.2481"></a>
+<span class="sourceLineNo">2436</span>  @Override<a name="line.2436"></a>
+<span class="sourceLineNo">2437</span>  public long enableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2437"></a>
+<span class="sourceLineNo">2438</span>      throws IOException {<a name="line.2438"></a>
+<span class="sourceLineNo">2439</span>    checkInitialized();<a name="line.2439"></a>
+<span class="sourceLineNo">2440</span><a name="line.2440"></a>
+<span class="sourceLineNo">2441</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2441"></a>
+<span class="sourceLineNo">2442</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2442"></a>
+<span class="sourceLineNo">2443</span>      @Override<a name="line.2443"></a>
+<span class="sourceLineNo">2444</span>      protected void run() throws IOException {<a name="line.2444"></a>
+<span class="sourceLineNo">2445</span>        getMaster().getMasterCoprocessorHost().preEnableTable(tableName);<a name="line.2445"></a>
+<span class="sourceLineNo">2446</span><a name="line.2446"></a>
+<span class="sourceLineNo">2447</span>        // Normally, it would make sense for this authorization check to exist inside<a name="line.2447"></a>
+<span class="sourceLineNo">2448</span>        // AccessController, but because the authorization check is done based on internal state<a name="line.2448"></a>
+<span class="sourceLineNo">2449</span>        // (rather than explicit permissions) we'll do the check here instead of in the<a name="line.2449"></a>
+<span class="sourceLineNo">2450</span>        // coprocessor.<a name="line.2450"></a>
+<span class="sourceLineNo">2451</span>        MasterQuotaManager quotaManager = getMasterQuotaManager();<a name="line.2451"></a>
+<span class="sourceLineNo">2452</span>        if (quotaManager != null) {<a name="line.2452"></a>
+<span class="sourceLineNo">2453</span>          if (quotaManager.isQuotaInitialized()) {<a name="line.2453"></a>
+<span class="sourceLineNo">2454</span>              SpaceQuotaSnapshot currSnapshotOfTable =<a name="line.2454"></a>
+<span class="sourceLineNo">2455</span>                  QuotaTableUtil.getCurrentSnapshotFromQuotaTable(getConnection(), tableName);<a name="line.2455"></a>
+<span class="sourceLineNo">2456</span>              if (currSnapshotOfTable != null) {<a name="line.2456"></a>
+<span class="sourceLineNo">2457</span>                SpaceQuotaStatus quotaStatus = currSnapshotOfTable.getQuotaStatus();<a name="line.2457"></a>
+<span class="sourceLineNo">2458</span>                if (quotaStatus.isInViolation()<a name="line.2458"></a>
+<span class="sourceLineNo">2459</span>                    &amp;&amp; SpaceViolationPolicy.DISABLE == quotaStatus.getPolicy().orElse(null)) {<a name="line.2459"></a>
+<span class="sourceLineNo">2460</span>                throw new AccessDeniedException("Enabling the table '" + tableName<a name="line.2460"></a>
+<span class="sourceLineNo">2461</span>                    + "' is disallowed due to a violated space quota.");<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>          } else if (LOG.isTraceEnabled()) {<a name="line.2464"></a>
+<span class="sourceLineNo">2465</span>            LOG.trace("Unable to check for space quotas as the MasterQuotaManager is not enabled");<a name="line.2465"></a>
+<span class="sourceLineNo">2466</span>          }<a name="line.2466"></a>
+<span class="sourceLineNo">2467</span>        }<a name="line.2467"></a>
+<span class="sourceLineNo">2468</span><a name="line.2468"></a>
+<span class="sourceLineNo">2469</span>        LOG.info(getClientIdAuditPrefix() + " enable " + tableName);<a name="line.2469"></a>
+<span class="sourceLineNo">2470</span><a name="line.2470"></a>
+<span class="sourceLineNo">2471</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2471"></a>
+<span class="sourceLineNo">2472</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2472"></a>
+<span class="sourceLineNo">2473</span>        // we want to make sure that the table is prepared to be<a name="line.2473"></a>
+<span class="sourceLineNo">2474</span>        // enabled (the table is locked and the table state is set).<a name="line.2474"></a>
+<span class="sourceLineNo">2475</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2475"></a>
+<span class="sourceLineNo">2476</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createLatch();<a name="line.2476"></a>
+<span class="sourceLineNo">2477</span>        submitProcedure(new EnableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2477"></a>
+<span class="sourceLineNo">2478</span>            tableName, prepareLatch));<a name="line.2478"></a>
+<span class="sourceLineNo">2479</span>        prepareLatch.await();<a name="line.2479"></a>
+<span class="sourceLineNo">2480</span><a name="line.2480"></a>
+<span class="sourceLineNo">2481</span>        getMaster().getMasterCoprocessorHost().postEnableTable(tableName);<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>  @Override<a name="line.2486"></a>
-<span class="sourceLineNo">2487</span>  public long disableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2487"></a>
-<span class="sourceLineNo">2488</span>      throws IOException {<a name="line.2488"></a>
-<span class="sourceLineNo">2489</span>    checkInitialized();<a name="line.2489"></a>
+<span class="sourceLineNo">2483</span><a name="line.2483"></a>
+<span class="sourceLineNo">2484</span>      @Override<a name="line.2484"></a>
+<span class="sourceLineNo">2485</span>      protected String getDescription() {<a name="line.2485"></a>
+<span class="sourceLineNo">2486</span>        return "EnableTableProcedure";<a name="line.2486"></a>
+<span class="sourceLineNo">2487</span>      }<a name="line.2487"></a>
+<span class="sourceLineNo">2488</span>    });<a name="line.2488"></a>
+<span class="sourceLineNo">2489</span>  }<a name="line.2489"></a>
 <span class="sourceLineNo">2490</span><a name="line.2490"></a>
-<span class="sourceLineNo">2491</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2491"></a>
-<span class="sourceLineNo">2492</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2492"></a>
-<span class="sourceLineNo">2493</span>      @Override<a name="line.2493"></a>
-<span class="sourceLineNo">2494</span>      protected void run() throws IOException {<a name="line.2494"></a>
-<span class="sourceLineNo">2495</span>        getMaster().getMasterCoprocessorHost().preDisableTable(tableName);<a name="line.2495"></a>
-<span class="sourceLineNo">2496</span><a name="line.2496"></a>
-<span class="sourceLineNo">2497</span>        LOG.info(getClientIdAuditPrefix() + " disable " + tableName);<a name="line.2497"></a>
-<span class="sourceLineNo">2498</span><a name="line.2498"></a>
-<span class="sourceLineNo">2499</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2499"></a>
-<span class="sourceLineNo">2500</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2500"></a>
-<span class="sourceLineNo">2501</span>        // we want to make sure that the table is prepared to be<a name="line.2501"></a>
-<span class="sourceLineNo">2502</span>        // enabled (the table is locked and the table state is set).<a name="line.2502"></a>
-<span class="sourceLineNo">2503</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2503"></a>
-<span class="sourceLineNo">2504</span>        //<a name="line.2504"></a>
-<span class="sourceLineNo">2505</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2505"></a>
-<span class="sourceLineNo">2506</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2506"></a>
-<span class="sourceLineNo">2507</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2507"></a>
-<span class="sourceLineNo">2508</span>        submitProcedure(new DisableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2508"></a>
-<span class="sourceLineNo">2509</span>            tableName, false, prepareLatch));<a name="line.2509"></a>
-<span class="sourceLineNo">2510</span>        prepareLatch.await();<a name="line.2510"></a>
-<span class="sourceLineNo">2511</span><a name="line.2511"></a>
-<span class="sourceLineNo">2512</span>        getMaster().getMasterCoprocessorHost().postDisableTable(tableName);<a name="line.2512"></a>
-<span class="sourceLineNo">2513</span>      }<a name="line.2513"></a>
-<span class="sourceLineNo">2514</span><a name="line.2514"></a>
-<span class="sourceLineNo">2515</span>      @Override<a name="line.2515"></a>
-<span class="sourceLineNo">2516</span>      protected String getDescription() {<a name="line.2516"></a>
-<span class="sourceLineNo">2517</span>        return "DisableTableProcedure";<a name="line.2517"></a>
+<span class="sourceLineNo">2491</span>  @Override<a name="line.2491"></a>
+<span class="sourceLineNo">2492</span>  public long disableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2492"></a>
+<span class="sourceLineNo">2493</span>      throws IOException {<a name="line.2493"></a>
+<span class="sourceLineNo">2494</span>    checkInitialized();<a name="line.2494"></a>
+<span class="sourceLineNo">2495</span><a name="line.2495"></a>
+<span class="sourceLineNo">2496</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2496"></a>
+<span class="sourceLineNo">2497</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2497"></a>
+<span class="sourceLineNo">2498</span>      @Override<a name="line.2498"></a>
+<span class="sourceLineNo">2499</span>      protected void run() throws IOException {<a name="line.2499"></a>
+<span class="sourceLineNo">2500</span>        getMaster().getMasterCoprocessorHost().preDisableTable(tableName);<a name="line.2500"></a>
+<span class="sourceLineNo">2501</span><a name="line.2501"></a>
+<span class="sourceLineNo">2502</span>        LOG.info(getClientIdAuditPrefix() + " disable " + tableName);<a name="line.2502"></a>
+<span class="sourceLineNo">2503</span><a name="line.2503"></a>
+<span class="sourceLineNo">2504</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2504"></a>
+<span class="sourceLineNo">2505</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2505"></a>
+<span class="sourceLineNo">2506</span>        // we want to make sure that the table is prepared to be<a name="line.2506"></a>
+<span class="sourceLineNo">2507</span>        // enabled (the table is locked and the table state is set).<a name="line.2507"></a>
+<span class="sourceLineNo">2508</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2508"></a>
+<span class="sourceLineNo">2509</span>        //<a name="line.2509"></a>
+<span class="sourceLineNo">2510</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2510"></a>
+<span class="sourceLineNo">2511</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2511"></a>
+<span class="sourceLineNo">2512</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2512"></a>
+<span class="sourceLineNo">2513</span>        submitProcedure(new DisableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2513"></a>
+<span class="sourceLineNo">2514</span>            tableName, false, prepareLatch));<a name="line.2514"></a>
+<span class="sourceLineNo">2515</span>        prepareLatch.await();<a name="line.2515"></a>
+<span class="sourceLineNo">2516</span><a name="line.2516"></a>
+<span class="sourceLineNo">2517</span>        getMaster().getMasterCoprocessorHost().postDisableTable(tableName);<a name="line.2517"></a>
 <span class="sourceLineNo">2518</span>      }<a name="line.2518"></a>
-<span class="sourceLineNo">2519</span>    });<a name="line.2519"></a>
-<span class="sourceLineNo">2520</span>  }<a name="line.2520"></a>
-<span class="sourceLineNo">2521</span><a name="line.2521"></a>
-<span class="sourceLineNo">2522</span>  private long modifyTable(final TableName tableName,<a name="line.2522"></a>
-<span class="sourceLineNo">2523</span>      final TableDescriptorGetter newDescriptorGetter, final long nonceGroup, final long nonce,<a name="line.2523"></a>
-<span class="sourceLineNo">2524</span>      final boolean shouldCheckDescriptor) throws IOException {<a name="line.2524"></a>
-<span class="sourceLineNo">2525</span>    return MasterProcedureUtil<a name="line.2525"></a>
-<span class="sourceLineNo">2526</span>        .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2526"></a>
-<span class="sourceLineNo">2527</span>          @Override<a name="line.2527"></a>
-<span class="sourceLineNo">2528</span>          protected void run() throws IOException {<a name="line.2528"></a>
-<span class="sourceLineNo">2529</span>            TableDescriptor oldDescriptor = getMaster().getTableDescriptors().get(tableName);<a name="line.2529"></a>
-<span class="sourceLineNo">2530</span>            TableDescriptor newDescriptor = getMaster().getMasterCoprocessorHost()<a name="line.2530"></a>
-<span class="sourceLineNo">2531</span>                .preModifyTable(tableName, oldDescriptor, newDescriptorGetter.get());<a name="line.2531"></a>
-<span class="sourceLineNo">2532</span>            TableDescriptorChecker.sanityCheck(conf, newDescriptor);<a name="line.2532"></a>
-<span class="sourceLineNo">2533</span>            LOG.info("{} modify table {} from {} to {}", getClientIdAuditPrefix(), tableName,<a name="line.2533"></a>
-<span class="sourceLineNo">2534</span>                oldDescriptor, newDescriptor);<a name="line.2534"></a>
-<span class="sourceLineNo">2535</span><a name="line.2535"></a>
-<span class="sourceLineNo">2536</span>            // Execute the operation synchronously - wait for the operation completes before<a name="line.2536"></a>
-<span class="sourceLineNo">2537</span>            // continuing.<a name="line.2537"></a>
-<span class="sourceLineNo">2538</span>            //<a name="line.2538"></a>
-<span class="sourceLineNo">2539</span>            // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2539"></a>
-<span class="sourceLineNo">2540</span>            // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2540"></a>
-<span class="sourceLineNo">2541</span>            ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2541"></a>
-<span class="sourceLineNo">2542</span>            submitProcedure(new ModifyTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2542"></a>
-<span class="sourceLineNo">2543</span>                newDescriptor, latch, oldDescriptor, shouldCheckDescriptor));<a name="line.2543"></a>
-<span class="sourceLineNo">2544</span>            latch.await();<a name="line.2544"></a>
-<span class="sourceLineNo">2545</span><a name="line.2545"></a>
-<span class="sourceLineNo">2546</span>            getMaster().getMasterCoprocessorHost().postModifyTable(tableName, oldDescriptor,<a name="line.2546"></a>
-<span class="sourceLineNo">2547</span>              newDescriptor);<a name="line.2547"></a>
-<span class="sourceLineNo">2548</span>          }<a name="line.2548"></a>
-<span class="sourceLineNo">2549</span><a name="line.2549"></a>
-<span class="sourceLineNo">2550</span>          @Override<a name="line.2550"></a>
-<span class="sourceLineNo">2551</span>          protected String getDescription() {<a name="line.2551"></a>
-<span class="sourceLineNo">2552</span>            return "ModifyTableProcedure";<a name="line.2552"></a>
+<span class="sourceLineNo">2519</span><a name="line.2519"></a>
+<span class="sourceLineNo">2520</span>      @Override<a name="line.2520"></a>
+<span class="sourceLineNo">2521</span>      protected String getDescription() {<a name="line.2521"></a>
+<span class="sourceLineNo">2522</span>        return "DisableTableProcedure";<a name="line.2522"></a>
+<span class="sourceLineNo">2523</span>      }<a name="line.2523"></a>
+<span class="sourceLineNo">2524</span>    });<a name="line.2524"></a>
+<span class="sourceLineNo">2525</span>  }<a name="line.2525"></a>
+<span class="sourceLineNo">2526</span><a name="line.2526"></a>
+<span class="sourceLineNo">2527</span>  private long modifyTable(final TableName tableName,<a name="line.2527"></a>
+<span class="sourceLineNo">2528</span>      final TableDescriptorGetter newDescriptorGetter, final long nonceGroup, final long nonce,<a name="line.2528"></a>
+<span class="sourceLineNo">2529</span>      final boolean shouldCheckDescriptor) throws IOException {<a name="line.2529"></a>
+<span class="sourceLineNo">2530</span>    return MasterProcedureUtil<a name="line.2530"></a>
+<span class="sourceLineNo">2531</span>        .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2531"></a>
+<span class="sourceLineNo">2532</span>          @Override<a name="line.2532"></a>
+<span class="sourceLineNo">2533</span>          protected void run() throws IOException {<a name="line.2533"></a>
+<span class="sourceLineNo">2534</span>            TableDescriptor oldDescriptor = getMaster().getTableDescriptors().get(tableName);<a name="line.2534"></a>
+<span class="sourceLineNo">2535</span>            TableDescriptor newDescriptor = getMaster().getMasterCoprocessorHost()<a name="line.2535"></a>
+<span class="sourceLineNo">2536</span>                .preModifyTable(tableName, oldDescriptor, newDescriptorGetter.get());<a name="line.2536"></a>
+<span class="sourceLineNo">2537</span>            TableDescriptorChecker.sanityCheck(conf, newDescriptor);<a name="line.2537"></a>
+<span class="sourceLineNo">2538</span>            LOG.info("{} modify table {} from {} to {}", getClientIdAuditPrefix(), tableName,<a name="line.2538"></a>
+<span class="sourceLineNo">2539</span>                oldDescriptor, newDescriptor);<a name="line.2539"></a>
+<span class="sourceLineNo">2540</span><a name="line.2540"></a>
+<span class="sourceLineNo">2541</span>            // Execute the operation synchronously - wait for the operation completes before<a name="line.2541"></a>
+<span class="sourceLineNo">2542</span>            // continuing.<a name="line.2542"></a>
+<span class="sourceLineNo">2543</span>            //<a name="line.2543"></a>
+<span class="sourceLineNo">2544</span>            // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2544"></a>
+<span class="sourceLineNo">2545</span>            // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2545"></a>
+<span class="sourceLineNo">2546</span>            ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2546"></a>
+<span class="sourceLineNo">2547</span>            submitProcedure(new ModifyTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2547"></a>
+<span class="sourceLineNo">2548</span>                newDescriptor, latch, oldDescriptor, shouldCheckDescriptor));<a name="line.2548"></a>
+<span class="sourceLineNo">2549</span>            latch.await();<a name="line.2549"></a>
+<span class="sourceLineNo">2550</span><a name="line.2550"></a>
+<span class="sourceLineNo">2551</span>            getMaster().getMasterCoprocessorHost().postModifyTable(tableName, oldDescriptor,<a name="line.2551"></a>
+<span class="sourceLineNo">2552</span>              newDescriptor);<a name="line.2552"></a>
 <span class="sourceLineNo">2553</span>          }<a name="line.2553"></a>
-<span class="sourceLineNo">2554</span>        });<a name="line.2554"></a>
-<span class="sourceLineNo">2555</span><a name="line.2555"></a>
-<span class="sourceLineNo">2556</span>  }<a name="line.2556"></a>
-<span class="sourceLineNo">2557</span><a name="line.2557"></a>
-<span class="sourceLineNo">2558</span>  @Override<a name="line.2558"></a>
-<span class="sourceLineNo">2559</span>  public long modifyTable(final TableName tableName, final TableDescriptor newDescriptor,<a name="line.2559"></a>
-<span class="sourceLineNo">2560</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2560"></a>
-<span class="sourceLineNo">2561</span>    checkInitialized();<a name="line.2561"></a>
-<span class="sourceLineNo">2562</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2562"></a>
-<span class="sourceLineNo">2563</span>      @Override<a name="line.2563"></a>
-<span class="sourceLineNo">2564</span>      public TableDescriptor get() throws IOException {<a name="line.2564"></a>
-<span class="sourceLineNo">2565</span>        return newDescriptor;<a name="line.2565"></a>
-<span class="sourceLineNo">2566</span>      }<a name="line.2566"></a>
-<span class="sourceLineNo">2567</span>    }, nonceGroup, nonce, false);<a name="line.2567"></a>
-<span class="sourceLineNo">2568</span><a name="line.2568"></a>
-<span class="sourceLineNo">2569</span>  }<a name="line.2569"></a>
-<span class="sourceLineNo">2570</span><a name="line.2570"></a>
-<span class="sourceLineNo">2571</span>  public long restoreSnapshot(final SnapshotDescription snapshotDesc,<a name="line.2571"></a>
-<span class="sourceLineNo">2572</span>      final long nonceGroup, final long nonce, final boolean restoreAcl) throws IOException {<a name="line.2572"></a>
-<span class="sourceLineNo">2573</span>    checkInitialized();<a name="line.2573"></a>
-<span class="sourceLineNo">2574</span>    getSnapshotManager().checkSnapshotSupport();<a name="line.2574"></a>
+<span class="sourceLineNo">2554</span><a name="line.2554"></a>
+<span class="sourceLineNo">2555</span>          @Override<a name="line.2555"></a>
+<span class="sourceLineNo">2556</span>          protected String getDescription() {<a name="line.2556"></a>
+<span class="sourceLineNo">2557</span>            return "ModifyTableProcedure";<a name="line.2557"></a>
+<span class="sourceLineNo">2558</span>          }<a name="line.2558"></a>
+<span class="sourceLineNo">2559</span>        });<a name="line.2559"></a>
+<span class="sourceLineNo">2560</span><a name="line.2560"></a>
+<span class="sourceLineNo">2561</span>  }<a name="line.2561"></a>
+<span class="sourceLineNo">2562</span><a name="line.2562"></a>
+<span class="sourceLineNo">2563</span>  @Override<a name="line.2563"></a>
+<span class="sourceLineNo">2564</span>  public long modifyTable(final TableName tableName, final TableDescriptor newDescriptor,<a name="line.2564"></a>
+<span class="sourceLineNo">2565</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2565"></a>
+<span class="sourceLineNo">2566</span>    checkInitialized();<a name="line.2566"></a>
+<span class="sourceLineNo">2567</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2567"></a>
+<span class="sourceLineNo">2568</span>      @Override<a name="line.2568"></a>
+<span class="sourceLineNo">2569</span>      public TableDescriptor get() throws IOException {<a name="line.2569"></a>
+<span class="sourceLineNo">2570</span>        return newDescriptor;<a name="line.2570"></a>
+<span class="sourceLineNo">2571</span>      }<a name="line.2571"></a>
+<span class="sourceLineNo">2572</span>    }, nonceGroup, nonce, false);<a name="line.2572"></a>
+<span class="sourceLineNo">2573</span><a name="line.2573"></a>
+<span class="sourceLineNo">2574</span>  }<a name="line.2574"></a>
 <span class="sourceLineNo">2575</span><a name="line.2575"></a>
-<span class="sourceLineNo">2576</span>    // Ensure namespace exists. Will throw exception if non-known NS.<a name="line.2576"></a>
-<span class="sourceLineNo">2577</span>    final TableName dstTable = TableName.valueOf(snapshotDesc.getTable());<a name="line.2577"></a>
-<span class="sourceLineNo">2578</span>    getClusterSchema().getNamespace(dstTable.getNamespaceAsString());<a name="line.2578"></a>
-<span class="sourceLineNo">2579</span><a name="line.2579"></a>
-<span class="sourceLineNo">2580</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2580"></a>
-<span class="sourceLineNo">2581</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2581"></a>
-<span class="sourceLineNo">2582</span>      @Override<a name="line.2582"></a>
-<span class="sourceLineNo">2583</span>      protected void run() throws IOException {<a name="line.2583"></a>
-<span class="sourceLineNo">2584</span>          setProcId(<a name="line.2584"></a>
-<span class="sourceLineNo">2585</span>            getSnapshotManager().restoreOrCloneSnapshot(snapshotDesc, getNonceKey(), restoreAcl));<a name="line.2585"></a>
-<span class="sourceLineNo">2586</span>      }<a name="line.2586"></a>
-<span class="sourceLineNo">2587</span><a name="line.2587"></a>
-<span class="sourceLineNo">2588</span>      @Override<a name="line.2588"></a>
-<span class="sourceLineNo">2589</span>      protected String getDescription() {<a name="line.2589"></a>
-<span class="sourceLineNo">2590</span>        return "RestoreSnapshotProcedure";<a name="line.2590"></a>
+<span class="sourceLineNo">2576</span>  public long restoreSnapshot(final SnapshotDescription snapshotDesc,<a name="line.2576"></a>
+<span class="sourceLineNo">2577</span>      final long nonceGroup, final long nonce, final boolean restoreAcl) throws IOException {<a name="line.2577"></a>
+<span class="sourceLineNo">2578</span>    checkInitialized();<a name="line.2578"></a>
+<span class="sourceLineNo">2579</span>    getSnapshotManager().checkSnapshotSupport();<a name="line.2579"></a>
+<span class="sourceLineNo">2580</span><a name="line.2580"></a>
+<span class="sourceLineNo">2581</span>    // Ensure namespace exists. Will throw exception if non-known NS.<a name="line.2581"></a>
+<span class="sourceLineNo">2582</span>    final TableName dstTable = TableName.valueOf(snapshotDesc.getTable());<a name="line.2582"></a>
+<span class="sourceLineNo">2583</span>    getClusterSchema().getNamespace(dstTable.getNamespaceAsString());<a name="line.2583"></a>
+<span class="sourceLineNo">2584</span><a name="line.2584"></a>
+<span class="sourceLineNo">2585</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2585"></a>
+<span class="sourceLineNo">2586</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2586"></a>
+<span class="sourceLineNo">2587</span>      @Override<a name="line.2587"></a>
+<span class="sourceLineNo">2588</span>      protected void run() throws IOException {<a name="line.2588"></a>
+<span class="sourceLineNo">2589</span>          setProcId(<a name="line.2589"></a>
+<span class="sourceLineNo">2590</span>            getSnapshotManager().restoreOrCloneSnapshot(snapshotDesc, getNonceKey(), restoreAcl));<a name="line.2590"></a>
 <span class="sourceLineNo">2591</span>      }<a name="line.2591"></a>
-<span class="sourceLineNo">2592</span>    });<a name="line.2592"></a>
-<span class="sourceLineNo">2593</span>  }<a name="line.2593"></a>
-<span class="sourceLineNo">2594</span><a name="line.2594"></a>
-<span class="sourceLineNo">2595</span>  private void checkTableExists(final TableName tableName)<a name="line.2595"></a>
-<span class="sourceLineNo">2596</span>    throws IOException, TableNotFoundException {<a name="line.2596"></a>
-<span class="sourceLineNo">2597</span>    if (!tableDescriptors.exists(tableName)) {<a name="line.2597"></a>
-<span class="sourceLineNo">2598</span>      throw new TableNotFoundException(tableName);<a name="line.2598"></a>
-<span class="sourceLineNo">2599</span>    }<a name="line.2599"></a>
-<span class="sourceLineNo">2600</span>  }<a name="line.2600"></a>
-<span class="sourceLineNo">2601</span><a name="line.2601"></a>
-<span class="sourceLineNo">2602</span>  @Override<a name="line.2602"></a>
-<span class="sourceLineNo">2603</span>  public void checkTableModifiable(final TableName tableName)<a name="line.2603"></a>
-<span class="sourceLineNo">2604</span>      throws IOException, TableNotFoundException, TableNotDisabledException {<a name="line.2604"></a>
-<span class="sourceLineNo">2605</span>    if (isCatalogTable(tableName)) {<a name="line.2605"></a>
-<span class="sourceLineNo">2606</span>      throw new IOException("Can't modify catalog tables");<a name="line.2606"></a>
-<span class="sourceLineNo">2607</span>    }<a name="line.2607"></a>
-<span class="sourceLineNo">2608</span>    checkTableExists(tableName);<a name="line.2608"></a>
-<span class="sourceLineNo">2609</span>    TableState ts = getTableStateManager().getTableState(tableName);<a name="line.2609"></a>
-<span class="sourceLineNo">2610</span>    if (!ts.isDisabled()) {<a name="line.2610"></a>
-<span class="sourceLineNo">2611</span>      throw new TableNotDisabledException("Not DISABLED; " + ts);<a name="line.2611"></a>
+<span class="sourceLineNo">2592</span><a name="line.2592"></a>
+<span class="sourceLineNo">2593</span>      @Override<a name="line.2593"></a>
+<span class="sourceLineNo">2594</span>      protected String getDescription() {<a name="line.2594"></a>
+<span class="sourceLineNo">2595</span>        return "RestoreSnapshotProcedure";<a name="line.2595"></a>
+<span class="sourceLineNo">2596</span>      }<a name="line.2596"></a>
+<span class="sourceLineNo">2597</span>    });<a name="line.2597"></a>
+<span class="sourceLineNo">2598</span>  }<a name="line.2598"></a>
+<span class="sourceLineNo">2599</span><a name="line.2599"></a>
+<span class="sourceLineNo">2600</span>  private void checkTableExists(final TableName tableName)<a name="line.2600"></a>
+<span class="sourceLineNo">2601</span>    throws IOException, TableNotFoundException {<a name="line.2601"></a>
+<span class="sourceLineNo">2602</span>    if (!tableDescriptors.exists(tableName)) {<a name="line.2602"></a>
+<span class="sourceLineNo">2603</span>      throw new TableNotFoundException(tableName);<a name="line.2603"></a>
+<span class="sourceLineNo">2604</span>    }<a name="line.2604"></a>
+<span class="sourceLineNo">2605</span>  }<a name="line.2605"></a>
+<span class="sourceLineNo">2606</span><a name="line.2606"></a>
+<span class="sourceLineNo">2607</span>  @Override<a name="line.2607"></a>
+<span class="sourceLineNo">2608</span>  public void checkTableModifiable(final TableName tableName)<a name="line.2608"></a>
+<span class="sourceLineNo">2609</span>      throws IOException, TableNotFoundException, TableNotDisabledException {<a name="line.2609"></a>
+<span class="sourceLineNo">2610</span>    if (isCatalogTable(tableName)) {<a name="line.2610"></a>
+<span class="sourceLineNo">2611</span>      throw new IOException("Can't modify catalog tables");<a name="line.2611"></a>
 <span class="sourceLineNo">2612</span>    }<a name="line.2612"></a>
-<span class="sourceLineNo">2613</span>  }<a name="line.2613"></a>
-<span class="sourceLineNo">2614</span><a name="line.2614"></a>
-<span class="sourceLineNo">2615</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor() throws InterruptedIOException {<a name="line.2615"></a>
-<span class="sourceLineNo">2616</span>    return getClusterMetricsWithoutCoprocessor(EnumSet.allOf(Option.class));<a name="line.2616"></a>
-<span class="sourceLineNo">2617</span>  }<a name="line.2617"></a>
-<span class="sourceLineNo">2618</span><a name="line.2618"></a>
-<span class="sourceLineNo">2619</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor(EnumSet&lt;Option&gt; options)<a name="line.2619"></a>
-<span class="sourceLineNo">2620</span>      throws InterruptedIOException {<a name="line.2620"></a>
-<span class="sourceLineNo">2621</span>    ClusterMetricsBuilder builder = ClusterMetricsBuilder.newBuilder();<a name="line.2621"></a>
-<span class="sourceLineNo">2622</span>    // given that hbase1 can't submit the request with Option,<a name="line.2622"></a>
-<span class="sourceLineNo">2623</span>    // we return all information to client if the list of Option is empty.<a name="line.2623"></a>
-<span class="sourceLineNo">2624</span>    if (options.isEmpty()) {<a name="line.2624"></a>
-<span class="sourceLineNo">2625</span>      options = EnumSet.allOf(Option.class);<a name="line.2625"></a>
-<span class="sourceLineNo">2626</span>    }<a name="line.2626"></a>
-<span class="sourceLineNo">2627</span><a name="line.2627"></a>
-<span class="sourceLineNo">2628</span>    for (Option opt : options) {<a name="line.2628"></a>
-<span class="sourceLineNo">2629</span>      switch (opt) {<a name="line.2629"></a>
-<span class="sourceLineNo">2630</span>        case HBASE_VERSION: builder.setHBaseVersion(VersionInfo.getVersion()); break;<a name="line.2630"></a>
-<span class="sourceLineNo">2631</span>        case CLUSTER_ID: builder.setClusterId(getClusterId()); break;<a name="line.2631"></a>
-<span class="sourceLineNo">2632</span>        case MASTER: builder.setMasterName(getServerName()); break;<a name="line.2632"></a>
-<span class="sourceLineNo">2633</span>        case BACKUP_MASTERS: builder.setBackerMasterNames(getBackupMasters()); break;<a name="line.2633"></a>
-<span class="sourceLineNo">2634</span>        case LIVE_SERVERS: {<a name="line.2634"></a>
-<span class="sourceLineNo">2635</span>          if (serverManager != null) {<a name="line.2635"></a>
-<span class="sourceLineNo">2636</span>            builder.setLiveServerMetrics(serverManager.getOnlineServers().entrySet().stream()<a name="line.2636"></a>
-<span class="sourceLineNo">2637</span>              .collect(Collectors.toMap(e -&gt; e.getKey(), e -&gt; e.getValue())));<a name="line.2637"></a>
-<span class="sourceLineNo">2638</span>          }<a name="line.2638"></a>
-<span class="sourceLineNo">2639</span>          break;<a name="line.2639"></a>
-<span class="sourceLineNo">2640</span>        }<a name="line.2640"></a>
-<span class="sourceLineNo">2641</span>        case DEAD_SERVERS: {<a name="line.2641"></a>
-<span class="sourceLineNo">2642</span>          if (serverManager != null) {<a name="line.2642"></a>
-<span class="sourceLineNo">2643</span>            builder.setDeadServerNames(new ArrayList&lt;&gt;(<a name="line.2643"></a>
-<span class="sourceLineNo">2644</span>              serverManager.getDeadServers().copyServerNames()));<a name="line.2644"></a>
-<span class="sourceLineNo">2645</span>          }<a name="line.2645"></a>
-<span class="sourceLineNo">2646</span>          break;<a name="line.2646"></a>
-<span class="sourceLineNo">2647</span>        }<a name="line.2647"></a>
-<span class="sourceLineNo">2648</span>        case MASTER_COPROCESSORS: {<a name="line.2648"></a>
-<span class="sourceLineNo">2649</span>          if (cpHost != null) {<a name="line.2649"></a>
-<span class="sourceLineNo">2650</span>            builder.setMasterCoprocessorNames(Arrays.asList(getMasterCoprocessors()));<a name="line.2650"></a>
-<span class="sourceLineNo">2651</span>          }<a name="line.2651"></a>
-<span class="sourceLineNo">2652</span>          break;<a name="line.2652"></a>
-<span class="sourceLineNo">2653</span>        }<a name="line.2653"></a>
-<span class="sourceLineNo">2654</span>        case REGIONS_IN_TRANSITION: {<a name="line.2654"></a>
-<span class="sourceLineNo">2655</span>          if (assignmentManager != null) {<a name="line.2655"></a>
-<span class="sourceLineNo">2656</span>            builder.setRegionsInTransition(assignmentManager.getRegionStates()<a name="line.2656"></a>
-<span class="sourceLineNo">2657</span>                .getRegionsStateInTransition());<a name="line.2657"></a>
-<span class="sourceLineNo">2658</span>          }<a name="line.2658"></a>
-<span class="sourceLineNo">2659</span>          break;<a name="line.2659"></a>
-<span class="sourceLineNo">2660</span>        }<a name="line.2660"></a>
-<span class="sourceLineNo">2661</span>        case BALANCER_ON: {<a name="line.2661"></a>
-<span class="sourceLineNo">2662</span>          if (loadBalancerTracker != null) {<a name="line.2662"></a>
-<span class="sourceLineNo">2663</span>            builder.setBalancerOn(loadBalancerTracker.isBalancerOn());<a name="line.2663"></a>
-<span class="sourceLineNo">2664</span>          }<a name="line.2664"></a>
-<span class="sourceLineNo">2665</span>          break;<a name="line.2665"></a>
-<span class="sourceLineNo">2666</span>        }<a name="line.2666"></a>
-<span class="sourceLineNo">2667</span>        case MASTER_INFO_PORT: {<a name="line.2667"></a>
-<span class="sourceLineNo">2668</span>          if (infoServer != null) {<a name="line.2668"></a>
-<span class="sourceLineNo">2669</span>            builder.setMasterInfoPort(infoServer.getPort());<a name="line.2669"></a>
-<span class="sourceLineNo">2670</span>          }<a name="line.2670"></a>
-<span class="sourceLineNo">2671</span>          break;<a name="line.2671"></a>
-<span class="sourceLineNo">2672</span>        }<a name="line.2672"></a>
-<span class="sourceLineNo">2673</span>        case SERVERS_NAME: {<a name="line.2673"></a>
-<span class="sourceLineNo">2674</span>          if (serverManager != null) {<a name="line.2674"></a>
-<span class="sourceLineNo">2675</span>            builder.setServerNames(serverManager.getOnlineServersList());<a name="line.2675"></a>
-<span class="sourceLineNo">2676</span>          }<a name="line.2676"></a>
-<span class="sourceLineNo">2677</span>          break;<a name="line.2677"></a>
-<span class="sourceLineNo">2678</span>        }<a name="line.2678"></a>
-<span class="sourceLineNo">2679</span>        case TABLE_TO_REGIONS_COUNT: {<a name="line.2679"></a>
-<span class="sourceLineNo">2680</span>          if (isActiveMaster() &amp;&amp; isInitialized() &amp;&amp; assignmentManager != null) {<a name="line.2680"></a>
-<span class="sourceLineNo">2681</span>            try {<a name="line.2681"></a>
-<span class="sourceLineNo">2682</span>              Map&lt;TableName, RegionStatesCount&gt; tableRegionStatesCountMap = new HashMap&lt;&gt;();<a name="line.2682"></a>
-<span class="sourceLineNo">2683</span>              Map&lt;String, TableDescriptor&gt; tableDescriptorMap = getTableDescriptors().getAll();<a name="line.2683"></a>
-<span class="sourceLineNo">2684</span>              for (TableDescriptor tableDescriptor : tableDescriptorMap.values()) {<a name="line.2684"></a>
-<span class="sourceLineNo">2685</span>                TableName tableName = tableDescriptor.getTableName();<a name="line.2685"></a>
-<span class="sourceLineNo">2686</span>                RegionStatesCount regionStatesCount = assignmentManager<a name="line.2686"></a>
-<span class="sourceLineNo">2687</span>                  .getRegionStatesCount(tableName);<a name="line.2687"></a>
-<span class="sourceLineNo">2688</span>                tableRegionStatesCountMap.put(tableName, regionStatesCount);<a name="line.2688"></a>
-<span class="sourceLineNo">2689</span>              }<a name="line.2689"></a>
-<span class="sourceLineNo">2690</span>              builder.setTableRegionStatesCount(tableRegionStatesCountMap);<a name="line.2690"></a>
-<span class="sourceLineNo">2691</span>            } catch (IOException e) {<a name="line.2691"></a>
-<span class="sourceLineNo">2692</span>              LOG.error("Error while populating TABLE_TO_REGIONS_COUNT for Cluster Metrics..", e);<a name="line.2692"></a>
-<span class="sourceLineNo">2693</span>            }<a name="line.2693"></a>
-<span class="sourceLineNo">2694</span>          }<a name="line.2694"></a>
-<span class="sourceLineNo">2695</span>          break;<a name="line.2695"></a>
-<span class="sourceLineNo">2696</span>        }<a name="line.2696"></a>
-<span class="sourceLineNo">2697</span>      }<a name="line.2697"></a>
-<span class="sourceLineNo">2698</span>    }<a name="line.2698"></a>
-<span class="sourceLineNo">2699</span>    return builder.build();<a name="line.2699"></a>
-<span class="sourceLineNo">2700</span>  }<a name="line.2700"></a>
-<span class="sourceLineNo">2701</span><a name="line.2701"></a>
-<span class="sourceLineNo">2702</span>  /**<a name="line.2702"></a>
-<span class="sourceLineNo">2703</span>   * @return cluster status<a name="line.2703"></a>
-<span class="sourceLineNo">2704</span>   */<a name="line.2704"></a>
-<span class="sourceLineNo">2705</span>  public ClusterMetrics getClusterMetrics() throws IOException {<a name="line.2705"></a>
-<span class="sourceLineNo">2706</span>    return getClusterMetrics(EnumSet.allOf(Option.class));<a name="line.2706"></a>
-<span class="sourceLineNo">2707</span>  }<a name="line.2707"></a>
-<span class="sourceLineNo">2708</span><a name="line.2708"></a>
-<span class="sourceLineNo">2709</span>  public ClusterMetrics getClusterMetrics(EnumSet&lt;Option&gt; options) throws IOException {<a name="line.2709"></a>
-<span class="sourceLineNo">2710</span>    if (cpHost != null) {<a name="line.2710"></a>
-<span class="sourceLineNo">2711</span>      cpHost.preGetClusterMetrics();<a name="line.2711"></a>
-<span class="sourceLineNo">2712</span>    }<a name="line.2712"></a>
-<span class="sourceLineNo">2713</span>    ClusterMetrics status = getClusterMetricsWithoutCoprocessor(options);<a name="line.2713"></a>
-<span class="sourceLineNo">2714</span>    if (cpHost != null) {<a name="line.2714"></a>
-<span class="sourceLineNo">2715</span>      cpHost.postGetClusterMetrics(status);<a name="line.2715"></a>
-<span class="sourceLineNo">2716</span>    }<a name="line.2716"></a>
-<span class="sourceLineNo">2717</span>    return status;<a name="line.2717"></a>
-<span class="sourceLineNo">2718</span>  }<a name="line.2718"></a>
-<span class="sourceLineNo">2719</span><a name="line.2719"></a>
-<span class="sourceLineNo">2720</span>  @Override<a name="line.2720"></a>
-<span class="sourceLineNo">2721</span>  public Optional&lt;ServerName&gt; getActiveMaster() {<a name="line.2721"></a>
-<span class="sourceLineNo">2722</span>    return activeMasterManager.getActiveMasterServerName();<a name="line.2722"></a>
+<span class="sourceLineNo">2613</span>    checkTableExists(tableName);<a name="line.2613"></a>
+<span class="sourceLineNo">2614</span>    TableState ts = getTableStateManager().getTableState(tableName);<a name="line.2614"></a>
+<span class="sourceLineNo">2615</span>    if (!ts.isDisabled()) {<a name="line.2615"></a>
+<span class="sourceLineNo">2616</span>      throw new TableNotDisabledException("Not DISABLED; " + ts);<a name="line.2616"></a>
+<span class="sourceLineNo">2617</span>    }<a name="line.2617"></a>
+<span class="sourceLineNo">2618</span>  }<a name="line.2618"></a>
+<span class="sourceLineNo">2619</span><a name="line.2619"></a>
+<span class="sourceLineNo">2620</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor() throws InterruptedIOException {<a name="line.2620"></a>
+<span class="sourceLineNo">2621</span>    return getClusterMetricsWithoutCoprocessor(EnumSet.allOf(Option.class));<a name="line.2621"></a>
+<span class="sourceLineNo">2622</span>  }<a name="line.2622"></a>
+<span class="sourceLineNo">2623</span><a name="line.2623"></a>
+<span class="sourceLineNo">2624</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor(EnumSet&lt;Option&gt; options)<a name="line.2624"></a>
+<span class="sourceLineNo">2625</span>      throws InterruptedIOException {<a name="line.2625"></a>
+<span class="sourceLineNo">2626</span>    ClusterMetricsBuilder builder = ClusterMetricsBuilder.newBuilder();<a name="line.2626"></a>
+<span class="sourceLineNo">2627</span>    // given that hbase1 can't submit the request with Option,<a name="line.2627"></a>
+<span class="sourceLineNo">2628</span>    // we return all information to client if the list of Option is empty.<a name="line.2628"></a>
+<span class="sourceLineNo">2629</span>    if (options.isEmpty()) {<a name="line.2629"></a>
+<span class="sourceLineNo">2630</span>      options = EnumSet.allOf(Option.class);<a name="line.2630"></a>
+<span class="sourceLineNo">2631</span>    }<a name="line.2631"></a>
+<span class="sourceLineNo">2632</span><a name="line.2632"></a>
+<span class="sourceLineNo">2633</span>    for (Option opt : options) {<a name="line.2633"></a>
+<span class="sourceLineNo">2634</span>      switch (opt) {<a name="line.2634"></a>
+<span class="sourceLineNo">2635</span>        case HBASE_VERSION: builder.setHBaseVersion(VersionInfo.getVersion()); break;<a name="line.2635"></a>
+<span class="sourceLineNo">2636</span>        case CLUSTER_ID: builder.setClusterId(getClusterId()); break;<a name="line.2636"></a>
+<span class="sourceLineNo">2637</span>        case MASTER: builder.setMasterName(getServerName()); break;<a name="line.2637"></a>
+<span class="sourceLineNo">2638</span>        case BACKUP_MASTERS: builder.setBackerMasterNames(getBackupMasters()); break;<a name="line.2638"></a>
+<span class="sourceLineNo">2639</span>        case LIVE_SERVERS: {<a name="line.2639"></a>
+<span class="sourceLineNo">2640</span>          if (serverManager != null) {<a name="line.2640"></a>
+<span class="sourceLineNo">2641</span>            builder.setLiveServerMetrics(serverManager.getOnlineServers().entrySet().stream()<a name="line.2641"></a>
+<span class="sourceLineNo">2642</span>              .collect(Collectors.toMap(e -&gt; e.getKey(), e -&gt; e.getValue())));<a name="line.2642"></a>
+<span class="sourceLineNo">2643</span>          }<a name="line.2643"></a>
+<span class="sourceLineNo">2644</span>          break;<a name="line.2644"></a>
+<span class="sourceLineNo">2645</span>        }<a name="line.2645"></a>
+<span class="sourceLineNo">2646</span>        case DEAD_SERVERS: {<a name="line.2646"></a>
+<span class="sourceLineNo">2647</span>          if (serverManager != null) {<a name="line.2647"></a>
+<span class="sourceLineNo">2648</span>            builder.setDeadServerNames(new ArrayList&lt;&gt;(<a name="line.2648"></a>
+<span class="sourceLineNo">2649</span>              serverManager.getDeadServers().copyServerNames()));<a name="line.2649"></a>
+<span class="sourceLineNo">2650</span>          }<a name="line.2650"></a>
+<span class="sourceLineNo">2651</span>          break;<a name="line.2651"></a>
+<span class="sourceLineNo">2652</span>        }<a name="line.2652"></a>
+<span class="sourceLineNo">2653</span>        case MASTER_COPROCESSORS: {<a name="line.2653"></a>
+<span class="sourceLineNo">2654</span>          if (cpHost != null) {<a name="line.2654"></a>
+<span class="sourceLineNo">2655</span>            builder.setMasterCoprocessorNames(Arrays.asList(getMasterCoprocessors()));<a name="line.2655"></a>
+<span class="sourceLineNo">2656</span>          }<a name="line.2656"></a>
+<span class="sourceLineNo">2657</span>          break;<a name="line.2657"></a>
+<span class="sourceLineNo">2658</span>        }<a name="line.2658"></a>
+<span class="sourceLineNo">2659</span>        case REGIONS_IN_TRANSITION: {<a name="line.2659"></a>
+<span class="sourceLineNo">2660</span>          if (assignmentManager != null) {<a name="line.2660"></a>
+<span class="sourceLineNo">2661</span>            builder.setRegionsInTransition(assignmentManager.getRegionStates()<a name="line.2661"></a>
+<span class="sourceLineNo">2662</span>                .getRegionsStateInTransition());<a name="line.2662"></a>
+<span class="sourceLineNo">2663</span>          }<a name="line.2663"></a>
+<span class="sourceLineNo">2664</span>          break;<a name="line.2664"></a>
+<span class="sourceLineNo">2665</span>        }<a name="line.2665"></a>
+<span class="sourceLineNo">2666</span>        case BALANCER_ON: {<a name="line.2666"></a>
+<span class="sourceLineNo">2667</span>          if (loadBalancerTracker != null) {<a name="line.2667"></a>
+<span class="sourceLineNo">2668</span>            builder.setBalancerOn(loadBalancerTracker.isBalancerOn());<a name="line.2668"></a>
+<span class="sourceLineNo">2669</span>          }<a name="line.2669"></a>
+<span class="sourceLineNo">2670</span>          break;<a name="line.2670"></a>
+<span class="sourceLineNo">2671</span>        }<a name="line.2671"></a>
+<span class="sourceLineNo">2672</span>        case MASTER_INFO_PORT: {<a name="line.2672"></a>
+<span class="sourceLineNo">2673</span>          if (infoServer != null) {<a name="line.2673"></a>
+<span class="sourceLineNo">2674</span>            builder.setMasterInfoPort(infoServer.getPort());<a name="line.2674"></a>
+<span class="sourceLineNo">2675</span>          }<a name="line.2675"></a>
+<span class="sourceLineNo">2676</span>          break;<a name="line.2676"></a>
+<span class="sourceLineNo">2677</span>        }<a name="line.2677"></a>
+<span class="sourceLineNo">2678</span>        case SERVERS_NAME: {<a name="line.2678"></a>
+<span class="sourceLineNo">2679</span>          if (serverManager != null) {<a name="line.2679"></a>
+<span class="sourceLineNo">2680</span>            builder.setServerNames(serverManager.getOnlineServersList());<a name="line.2680"></a>
+<span class="sourceLineNo">2681</span>          }<a name="line.2681"></a>
+<span class="sourceLineNo">2682</span>          break;<a name="line.2682"></a>
+<span class="sourceLineNo">2683</span>        }<a name="line.2683"></a>
+<span class="sourceLineNo">2684</span>        case TABLE_TO_REGIONS_COUNT: {<a name="line.2684"></a>
+<span class="sourceLineNo">2685</span>          if (isActiveMaster() &amp;&amp; isInitialized() &amp;&amp; assignmentManager != null) {<a name="line.2685"></a>
+<span class="sourceLineNo">2686</span>            try {<a name="line.2686"></a>
+<span class="sourceLineNo">2687</span>              Map&lt;TableName, RegionStatesCount&gt; tableRegionStatesCountMap = new HashMap&lt;&gt;();<a name="line.2687"></a>
+<span class="sourceLineNo">2688</span>              Map&lt;String, TableDescriptor&gt; tableDescriptorMap = getTableDescriptors().getAll();<a name="line.2688"></a>
+<span class="sourceLineNo">2689</span>              for (TableDescriptor tableDescriptor : tableDescriptorMap.values()) {<a name="line.2689"></a>
+<span class="sourceLineNo">2690</span>                TableName tableName = tableDescriptor.getTableName();<a name="line.2690"></a>
+<span class="sourceLineNo">2691</span>                RegionStatesCount regionStatesCount = assignmentManager<a name="line.2691"></a>
+<span class="sourceLineNo">2692</span>                  .getRegionStatesCount(tableName);<a name="line.2692"></a>
+<span class="sourceLineNo">2693</span>                tableRegionStatesCountMap.put(tableName, regionStatesCount);<a name="line.2693"></a>
+<span class="sourceLineNo">2694</span>              }<a name="line.2694"></a>
+<span class="sourceLineNo">2695</span>              builder.setTableRegionStatesCount(tableRegionStatesCountMap);<a name="line.2695"></a>
+<span class="sourceLineNo">2696</span>            } catch (IOException e) {<a name="line.2696"></a>
+<span class="sourceLineNo">2697</span>              LOG.error("Error while populating TABLE_TO_REGIONS_COUNT for Cluster Metrics..", e);<a name="line.2697"></a>
+<span class="sourceLineNo">2698</span>            }<a name="line.2698"></a>
+<span class="sourceLineNo">2699</span>          }<a name="line.2699"></a>
+<span class="sourceLineNo">2700</span>          break;<a name="line.2700"></a>
+<span class="sourceLineNo">2701</span>        }<a name="line.2701"></a>
+<span class="sourceLineNo">2702</span>      }<a name="line.2702"></a>
+<span class="sourceLineNo">2703</span>    }<a name="line.2703"></a>
+<span class="sourceLineNo">2704</span>    return builder.build();<a name="line.2704"></a>
+<span class="sourceLineNo">2705</span>  }<a name="line.2705"></a>
+<span class="sourceLineNo">2706</span><a name="line.2706"></a>
+<span class="sourceLineNo">2707</span>  /**<a name="line.2707"></a>
+<span class="sourceLineNo">2708</span>   * @return cluster status<a name="line.2708"></a>
+<span class="sourceLineNo">2709</span>   */<a name="line.2709"></a>
+<span class="sourceLineNo">2710</span>  public ClusterMetrics getClusterMetrics() throws IOException {<a name="line.2710"></a>
+<span class="sourceLineNo">2711</span>    return getClusterMetrics(EnumSet.allOf(Option.class));<a name="line.2711"></a>
+<span class="sourceLineNo">2712</span>  }<a name="line.2712"></a>
+<span class="sourceLineNo">2713</span><a name="line.2713"></a>
+<span class="sourceLineNo">2714</span>  public ClusterMetrics getClusterMetrics(EnumSet&lt;Option&gt; options) throws IOException {<a name="line.2714"></a>
+<span class="sourceLineNo">2715</span>    if (cpHost != null) {<a name="line.2715"></a>
+<span class="sourceLineNo">2716</span>      cpHost.preGetClusterMetrics();<a name="line.2716"></a>
+<span class="sourceLineNo">2717</span>    }<a name="line.2717"></a>
+<span class="sourceLineNo">2718</span>    ClusterMetrics status = getClusterMetricsWithoutCoprocessor(options);<a name="line.2718"></a>
+<span class="sourceLineNo">2719</span>    if (cpHost != null) {<a name="line.2719"></a>
+<span class="sourceLineNo">2720</span>      cpHost.postGetClusterMetrics(status);<a name="line.2720"></a>
+<span class="sourceLineNo">2721</span>    }<a name="line.2721"></a>
+<span class="sourceLineNo">2722</span>    return status;<a name="line.2722"></a>
 <span class="sourceLineNo">2723</span>  }<a name="line.2723"></a>
 <span class="sourceLineNo">2724</span><a name="line.2724"></a>
 <span class="sourceLineNo">2725</span>  @Override<a name="line.2725"></a>
-<span class="sourceLineNo">2726</span>  public List&lt;ServerName&gt; getBackupMasters() {<a name="line.2726"></a>
-<span class="sourceLineNo">2727</span>    return activeMasterManager.getBackupMasters();<a name="line.2727"></a>
+<span class="sourceLineNo">2726</span>  public Optional&lt;ServerName&gt; getActiveMaster() {<a name="line.2726"></a>
+<span class="sourceLineNo">2727</span>    return activeMasterManager.getActiveMasterServerName();<a name="line.2727"></a>
 <span class="sourceLineNo">2728</span>  }<a name="line.2728"></a>
 <span class="sourceLineNo">2729</span><a name="line.2729"></a>
-<span class="sourceLineNo">2730</span>  /**<a name="line.2730"></a>
-<span class="sourceLineNo">2731</span>   * @return info port of active master or 0 if any exception occurs.<a name="line.2731"></a>
-<span class="sourceLineNo">2732</span>   */<a name="line.2732"></a>
-<span class="sourceLineNo">2733</span>  public int getActiveMasterInfoPort() {<a name="line.2733"></a>
-<span class="sourceLineNo">2734</span>    return activeMasterManager.getActiveMasterInfoPort();<a name="line.2734"></a>
-<span class="sourceLineNo">2735</span>  }<a name="line.2735"></a>
-<span class="sourceLineNo">2736</span><a name="line.2736"></a>
-<span class="sourceLineNo">2737</span>  /**<a name="line.2737"></a>
-<span class="sourceLineNo">2738</span>   * @param sn is ServerName of the backup master<a name="line.2738"></a>
-<span class="sourceLineNo">2739</span>   * @return info port of backup master or 0 if any exception occurs.<a name="line.2739"></a>
-<span class="sourceLineNo">2740</span>   */<a name="line.2740"></a>
-<span class="sourceLineNo">2741</span>  public int getBackupMasterInfoPort(final ServerName sn) {<a name="line.2741"></a>
-<span class="sourceLineNo">2742</span>    return activeMasterManager.getBackupMasterInfoPort(sn);<a name="line.2742"></a>
-<span class="sourceLineNo">2743</span>  }<a name="line.2743"></a>
-<span class="sourceLineNo">2744</span><a name="line.2744"></a>
-<span class="sourceLineNo">2745</span>  @Override<a name="line.2745"></a>
-<span class="sourceLineNo">2746</span>  public Collection&lt;ServerName&gt; getRegionServers() {<a name="line.2746"></a>
-<span class="sourceLineNo">2747</span>    return regionServerTracker.getRegionServers();<a name="line.2747"></a>
+<span class="sourceLineNo">2730</span>  @Override<a name="line.2730"></a>
+<span class="sourceLineNo">2731</span>  public List&lt;ServerName&gt; getBackupMasters() {<a name="line.2731"></a>
+<span class="sourceLineNo">2732</span>    return activeMasterManager.getBackupMasters();<a name="line.2732"></a>
+<span class="sourceLineNo">2733</span>  }<a name="line.2733"></a>
+<span class="sourceLineNo">2734</span><a name="line.2734"></a>
+<span class="sourceLineNo">2735</span>  /**<a name="line.2735"></a>
+<span class="sourceLineNo">2736</span>   * @return info port of active master or 0 if any exception occurs.<a name="line.2736"></a>
+<span class="sourceLineNo">2737</span>   */<a name="line.2737"></a>
+<span class="sourceLineNo">2738</span>  public int getActiveMasterInfoPort() {<a name="line.2738"></a>
+<span class="sourceLineNo">2739</span>    return activeMasterManager.getActiveMasterInfoPort();<a name="line.2739"></a>
+<span class="sourceLineNo">2740</span>  }<a name="line.2740"></a>
+<span class="sourceLineNo">2741</span><a name="line.2741"></a>
+<span class="sourceLineNo">2742</span>  /**<a name="line.2742"></a>
+<span class="sourceLineNo">2743</span>   * @param sn is ServerName of the backup master<a name="line.2743"></a>
+<span class="sourceLineNo">2744</span>   * @return info port of backup master or 0 if any exception occurs.<a name="line.2744"></a>
+<span class="sourceLineNo">2745</span>   */<a name="line.2745"></a>
+<span class="sourceLineNo">2746</span>  public int getBackupMasterInfoPort(final ServerName sn) {<a name="line.2746"></a>
+<span class="sourceLineNo">2747</span>    return activeMasterManager.getBackupMasterInfoPort(sn);<a name="line.2747"></a>
 <span class="sourceLineNo">2748</span>  }<a name="line.2748"></a>
 <span class="sourceLineNo">2749</span><a name="line.2749"></a>
-<span class="sourceLineNo">2750</span>  /**<a name="line.2750"></a>
-<span class="sourceLineNo">2751</span>   * The set of loaded coprocessors is stored in a static set. Since it's<a name="line.2751"></a>
-<span class="sourceLineNo">2752</span>   * statically allocated, it does not require that HMaster's cpHost be<a name="line.2752"></a>
-<span class="sourceLineNo">2753</span>   * initialized prior to accessing it.<a name="line.2753"></a>
-<span class="sourceLineNo">2754</span>   * @return a String representation of the set of names of the loaded coprocessors.<a name="line.2754"></a>
-<span class="sourceLineNo">2755</span>   */<a name="line.2755"></a>
-<span class="sourceLineNo">2756</span>  public static String getLoadedCoprocessors() {<a name="line.2756"></a>
-<span class="sourceLineNo">2757</span>    return CoprocessorHost.getLoadedCoprocessors().toString();<a name="line.2757"></a>
-<span class="sourceLineNo">2758</span>  }<a name="line.2758"></a>
-<span class="sourceLineNo">2759</span><a name="line.2759"></a>
-<span class="sourceLineNo">2760</span>  /**<a name="line.2760"></a>
-<span class="sourceLineNo">2761</span>   * @return timestamp in millis when HMaster was started.<a name="line.2761"></a>
-<span class="sourceLineNo">2762</span>   */<a name="line.2762"></a>
-<span class="sourceLineNo">2763</span>  public long getMasterStartTime() {<a name="line.2763"></a>
-<span class="sourceLineNo">2764</span>    return startcode;<a name="line.2764"></a>
-<span class="sourceLineNo">2765</span>  }<a name="line.2765"></a>
-<span class="sourceLineNo">2766</span><a name="line.2766"></a>
-<span class="sourceLineNo">2767</span>  /**<a name="line.2767"></a>
-<span class="sourceLineNo">2768</span>   * @return timestamp in millis when HMaster became the active master.<a name="line.2768"></a>
-<span class="sourceLineNo">2769</span>   */<a name="line.2769"></a>
-<span class="sourceLineNo">2770</span>  public long getMasterActiveTime() {<a name="line.2770"></a>
-<span class="sourceLineNo">2771</span>    return masterActiveTime;<a name="line.2771"></a>
-<span class="sourceLineNo">2772</span>  }<a name="line.2772"></a>
-<span class="sourceLineNo">2773</span><a name="line.2773"></a>
-<span class="sourceLineNo">2774</span>  /**<a name="line.2774"></a>
-<span class="sourceLineNo">2775</span>   * @return timestamp in millis when HMaster finished becoming the active master<a name="line.2775"></a>
-<span class="sourceLineNo">2776</span>   */<a name="line.2776"></a>
-<span class="sourceLineNo">2777</span>  public long getMasterFinishedInitializationTime() {<a name="line.2777"></a>
-<span class="sourceLineNo">2778</span>    return masterFinishedInitializationTime;<a name="line.2778"></a>
-<span class="sourceLineNo">2779</span>  }<a name="line.2779"></a>
-<span class="sourceLineNo">2780</span><a name="line.2780"></a>
-<span class="sourceLineNo">2781</span>  public int getNumWALFiles() {<a name="line.2781"></a>
-<span class="sourceLineNo">2782</span>    return 0;<a name="line.2782"></a>
-<span class="sourceLineNo">2783</span>  }<a name="line.2783"></a>
-<span class="sourceLineNo">2784</span><a name="line.2784"></a>
-<span class="sourceLineNo">2785</span>  public ProcedureStore getProcedureStore() {<a name="line.2785"></a>
-<span class="sourceLineNo">2786</span>    return procedureStore;<a name="line.2786"></a>
-<span class="sourceLineNo">2787</span>  }<a name="line.2787"></a>
-<span class="sourceLineNo">2788</span><a name="line.2788"></a>
-<span class="sourceLineNo">2789</span>  public int getRegionServerInfoPort(final ServerName sn) {<a name="line.2789"></a>
-<span class="sourceLineNo">2790</span>    int port = this.serverManager.getInfoPort(sn);<a name="line.2790"></a>
-<span class="sourceLineNo">2791</span>    return port == 0 ? conf.getInt(HConstants.REGIONSERVER_INFO_PORT,<a name="line.2791"></a>
-<span class="sourceLineNo">2792</span>      HConstants.DEFAULT_REGIONSERVER_INFOPORT) : port;<a name="line.2792"></a>
-<span class="sourceLineNo">2793</span>  }<a name="line.2793"></a>
-<span class="sourceLineNo">2794</span><a name="line.2794"></a>
-<span class="sourceLineNo">2795</span>  @Override<a name="line.2795"></a>
-<span class="sourceLineNo">2796</span>  public String getRegionServerVersion(ServerName sn) {<a name="line.2796"></a>
-<span class="sourceLineNo">2797</span>    // Will return "0.0.0" if the server is not online to prevent move system region to unknown<a name="line.2797"></a>
-<span class="sourceLineNo">2798</span>    // version RS.<a name="line.2798"></a>
-<span class="sourceLineNo">2799</span>    return this.serverManager.getVersion(sn);<a name="line.2799"></a>
-<span class="sourceLineNo">2800</span>  }<a name="line.2800"></a>
-<span class="sourceLineNo">2801</span><a name="line.2801"></a>
-<span class="sourceLineNo">2802</span>  @Override<a name="line.2802"></a>
-<span class="sourceLineNo">2803</span>  public void checkIfShouldMoveSystemRegionAsync() {<a name="line.2803"></a>
-<span class="sourceLineNo">2804</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.2804"></a>
+<span class="sourceLineNo">2750</span>  @Override<a name="line.2750"></a>
+<span class="sourceLineNo">2751</span>  public Collection&lt;ServerName&gt; getRegionServers() {<a name="line.2751"></a>
+<span class="sourceLineNo">2752</span>    return regionServerTracker.getRegionServers();<a name="line.2752"></a>
+<span class="sourceLineNo">2753</span>  }<a name="line.2753"></a>
+<span class="sourceLineNo">2754</span><a name="line.2754"></a>
+<span class="sourceLineNo">2755</span>  /**<a name="line.2755"></a>
+<span class="sourceLineNo">2756</span>   * The set of loaded coprocessors is stored in a static set. Since it's<a name="line.2756"></a>
+<span class="sourceLineNo">2757</span>   * statically allocated, it does not require that HMaster's cpHost be<a name="line.2757"></a>
+<span class="sourceLineNo">2758</span>   * initialized prior to accessing it.<a name="line.2758"></a>
+<span class="sourceLineNo">2759</span>   * @return a String representation of the set of names of the loaded coprocessors.<a name="line.2759"></a>
+<span class="sourceLineNo">2760</span>   */<a name="line.2760"></a>
+<span class="sourceLineNo">2761</span>  public static String getLoadedCoprocessors() {<a name="line.2761"></a>
+<span class="sourceLineNo">2762</span>    return CoprocessorHost.getLoadedCoprocessors().toString();<a name="line.2762"></a>
+<span class="sourceLineNo">2763</span>  }<a name="line.2763"></a>
+<span class="sourceLineNo">2764</span><a name="line.2764"></a>
+<span class="sourceLineNo">2765</span>  /**<a name="line.2765"></a>
+<span class="sourceLineNo">2766</span>   * @return timestamp in millis when HMaster was started.<a name="line.2766"></a>
+<span class="sourceLineNo">2767</span>   */<a name="line.2767"></a>
+<span class="sourceLineNo">2768</span>  public long getMasterStartTime() {<a name="line.2768"></a>
+<span class="sourceLineNo">2769</span>    return startcode;<a name="line.2769"></a>
+<span class="sourceLineNo">2770</span>  }<a name="line.2770"></a>
+<span class="sourceLineNo">2771</span><a name="line.2771"></a>
+<span class="sourceLineNo">2772</span>  /**<a name="line.2772"></a>
+<span class="sourceLineNo">2773</span>   * @return timestamp in millis when HMaster became the active master.<a name="line.2773"></a>
+<span class="sourceLineNo">2774</span>   */<a name="line.2774"></a>
+<span class="sourceLineNo">2775</span>  public long getMasterActiveTime() {<a name="line.2775"></a>
+<span class="sourceLineNo">2776</span>    return masterActiveTime;<a name="line.2776"></a>
+<span class="sourceLineNo">2777</span>  }<a name="line.2777"></a>
+<span class="sourceLineNo">2778</span><a name="line.2778"></a>
+<span class="sourceLineNo">2779</span>  /**<a name="line.2779"></a>
+<span class="sourceLineNo">2780</span>   * @return timestamp in millis when HMaster finished becoming the active master<a name="line.2780"></a>
+<span class="sourceLineNo">2781</span>   */<a name="line.2781"></a>
+<span class="sourceLineNo">2782</span>  public long getMasterFinishedInitializationTime() {<a name="line.2782"></a>
+<span class="sourceLineNo">2783</span>    return masterFinishedInitializationTime;<a name="line.2783"></a>
+<span class="sourceLineNo">2784</span>  }<a name="line.2784"></a>
+<span class="sourceLineNo">2785</span><a name="line.2785"></a>
+<span class="sourceLineNo">2786</span>  public int getNumWALFiles() {<a name="line.2786"></a>
+<span class="sourceLineNo">2787</span>    return 0;<a name="line.2787"></a>
+<span class="sourceLineNo">2788</span>  }<a name="line.2788"></a>
+<span class="sourceLineNo">2789</span><a name="line.2789"></a>
+<span class="sourceLineNo">2790</span>  public ProcedureStore getProcedureStore() {<a name="line.2790"></a>
+<span class="sourceLineNo">2791</span>    return procedureStore;<a name="line.2791"></a>
+<span class="sourceLineNo">2792</span>  }<a name="line.2792"></a>
+<span class="sourceLineNo">2793</span><a name="line.2793"></a>
+<span class="sourceLineNo">2794</span>  public int getRegionServerInfoPort(final ServerName sn) {<a name="line.2794"></a>
+<span class="sourceLineNo">2795</span>    int port = this.serverManager.getInfoPort(sn);<a name="line.2795"></a>
+<span class="sourceLineNo">2796</span>    return port == 0 ? conf.getInt(HConstants.REGIONSERVER_INFO_PORT,<a name="line.2796"></a>
+<span class="sourceLineNo">2797</span>      HConstants.DEFAULT_REGIONSERVER_INFOPORT) : port;<a name="line.2797"></a>
+<span class="sourceLineNo">2798</span>  }<a name="line.2798"></a>
+<span class="sourceLineNo">2799</span><a name="line.2799"></a>
+<span class="sourceLineNo">2800</span>  @Override<a name="line.2800"></a>
+<span class="sourceLineNo">2801</span>  public String getRegionServerVersion(ServerName sn) {<a name="line.2801"></a>
+<span class="sourceLineNo">2802</span>    // Will return "0.0.0" if the server is not online to prevent move system region to unknown<a name="line.2802"></a>
+<span class="sourceLineNo">2803</span>    // version RS.<a name="line.2803"></a>
+<span class="sourceLineNo">2804</span>    return this.serverManager.getVersion(sn);<a name="line.2804"></a>
 <span class="sourceLineNo">2805</span>  }<a name="line.2805"></a>
 <span class="sourceLineNo">2806</span><a name="line.2806"></a>
-<span class="sourceLineNo">2807</span>  /**<a name="line.2807"></a>
-<span class="sourceLineNo">2808</span>   * @return array of coprocessor SimpleNames.<a name="line.2808"></a>
-<span class="sourceLineNo">2809</span>   */<a name="line.2809"></a>
-<span class="sourceLineNo">2810</span>  public String[] getMasterCoprocessors() {<a name="line.2810"></a>
-<span class="sourceLineNo">2811</span>    Set&lt;String&gt; masterCoprocessors = getMasterCoprocessorHost().getCoprocessors();<a name="line.2811"></a>
-<span class="sourceLineNo">2812</span>    return masterCoprocessors.toArray(new String[masterCoprocessors.size()]);<a name="line.2812"></a>
-<span class="sourceLineNo">2813</span>  }<a name="line.2813"></a>
-<span class="sourceLineNo">2814</span><a name="line.2814"></a>
-<span class="sourceLineNo">2815</span>  @Override<a name="line.2815"></a>
-<span class="sourceLineNo">2816</span>  public void abort(String reason, Throwable cause) {<a name="line.2816"></a>
-<span class="sourceLineNo">2817</span>    if (!setAbortRequested() || isStopped()) {<a name="line.2817"></a>
-<span class="sourceLineNo">2818</span>      LOG.debug("Abort called but aborted={}, stopped={}", isAborted(), isStopped());<a name="line.2818"></a>
-<span class="sourceLineNo">2819</span>      return;<a name="line.2819"></a>
-<span class="sourceLineNo">2820</span>    }<a name="line.2820"></a>
-<span class="sourceLineNo">2821</span>    if (cpHost != null) {<a name="line.2821"></a>
-<span class="sourceLineNo">2822</span>      // HBASE-4014: dump a list of loaded coprocessors.<a name="line.2822"></a>
-<span class="sourceLineNo">2823</span>      LOG.error(HBaseMarkers.FATAL, "Master server abort: loaded coprocessors are: " +<a name="line.2823"></a>
-<span class="sourceLineNo">2824</span>          getLoadedCoprocessors());<a name="line.2824"></a>
+<span class="sourceLineNo">2807</span>  @Override<a name="line.2807"></a>
+<span class="sourceLineNo">2808</span>  public void checkIfShouldMoveSystemRegionAsync() {<a name="line.2808"></a>
+<span class="sourceLineNo">2809</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.2809"></a>
+<span class="sourceLineNo">2810</span>  }<a name="line.2810"></a>
+<span class="sourceLineNo">2811</span><a name="line.2811"></a>
+<span class="sourceLineNo">2812</span>  /**<a name="line.2812"></a>
+<span class="sourceLineNo">2813</span>   * @return array of coprocessor SimpleNames.<a name="line.2813"></a>
+<span class="sourceLineNo">2814</span>   */<a name="line.2814"></a>
+<span class="sourceLineNo">2815</span>  public String[] getMasterCoprocessors() {<a name="line.2815"></a>
+<span class="sourceLineNo">2816</span>    Set&lt;String&gt; masterCoprocessors = getMasterCoprocessorHost().getCoprocessors();<a name="line.2816"></a>
+<span class="sourceLineNo">2817</span>    return masterCoprocessors.toArray(new String[masterCoprocessors.size()]);<a name="line.2817"></a>
+<span class="sourceLineNo">2818</span>  }<a name="line.2818"></a>
+<span class="sourceLineNo">2819</span><a name="line.2819"></a>
+<span class="sourceLineNo">2820</span>  @Override<a name="line.2820"></a>
+<span class="sourceLineNo">2821</span>  public void abort(String reason, Throwable cause) {<a name="line.2821"></a>
+<span class="sourceLineNo">2822</span>    if (!setAbortRequested() || isStopped()) {<a name="line.2822"></a>
+<span class="sourceLineNo">2823</span>      LOG.debug("Abort called but aborted={}, stopped={}", isAborted(), isStopped());<a name="line.2823"></a>
+<span class="sourceLineNo">2824</span>      return;<a name="line.2824"></a>
 <span class="sourceLineNo">2825</span>    }<a name="line.2825"></a>
-<span class="sourceLineNo">2826</span>    String msg = "***** ABORTING master " + this + ": " + reason + " *****";<a name="line.2826"></a>
-<span class="sourceLineNo">2827</span>    if (cause != null) {<a name="line.2827"></a>
-<span class="sourceLineNo">2828</span>      LOG.error(HBaseMarkers.FATAL, msg, cause);<a name="line.2828"></a>
-<span class="sourceLineNo">2829</span>    } else {<a name="line.2829"></a>
-<span class="sourceLineNo">2830</span>      LOG.error(HBaseMarkers.FATAL, msg);<a name="line.2830"></a>
-<span class="sourceLineNo">2831</span>    }<a name="line.2831"></a>
-<span class="sourceLineNo">2832</span><a name="line.2832"></a>
-<span class="sourceLineNo">2833</span>    try {<a name="line.2833"></a>
-<span class="sourceLineNo">2834</span>      stopMaster();<a name="line.2834"></a>
-<span class="sourceLineNo">2835</span>    } catch (IOException e) {<a name="line.2835"></a>
-<span class="sourceLineNo">2836</span>      LOG.error("Exception occurred while stopping master", e);<a name="line.2836"></a>
-<span class="sourceLineNo">2837</span>    }<a name="line.2837"></a>
-<span class="sourceLineNo">2838</span>  }<a name="line.2838"></a>
-<span class="sourceLineNo">2839</span><a name="line.2839"></a>
-<span class="sourceLineNo">2840</span>  @Override<a name="line.2840"></a>
-<span class="sourceLineNo">2841</span>  public ZKWatcher getZooKeeper() {<a name="line.2841"></a>
-<span class="sourceLineNo">2842</span>    return zooKeeper;<a name="line.2842"></a>
+<span class="sourceLineNo">2826</span>    if (cpHost != null) {<a name="line.2826"></a>
+<span class="sourceLineNo">2827</span>      // HBASE-4014: dump a list of loaded coprocessors.<a name="line.2827"></a>
+<span class="sourceLineNo">2828</span>      LOG.error(HBaseMarkers.FATAL, "Master server abort: loaded coprocessors are: " +<a name="line.2828"></a>
+<span class="sourceLineNo">2829</span>          getLoadedCoprocessors());<a name="line.2829"></a>
+<span class="sourceLineNo">2830</span>    }<a name="line.2830"></a>
+<span class="sourceLineNo">2831</span>    String msg = "***** ABORTING master " + this + ": " + reason + " *****";<a name="line.2831"></a>
+<span class="sourceLineNo">2832</span>    if (cause != null) {<a name="line.2832"></a>
+<span class="sourceLineNo">2833</span>      LOG.error(HBaseMarkers.FATAL, msg, cause);<a name="line.2833"></a>
+<span class="sourceLineNo">2834</span>    } else {<a name="line.2834"></a>
+<span class="sourceLineNo">2835</span>      LOG.error(HBaseMarkers.FATAL, msg);<a name="line.2835"></a>
+<span class="sourceLineNo">2836</span>    }<a name="line.2836"></a>
+<span class="sourceLineNo">2837</span><a name="line.2837"></a>
+<span class="sourceLineNo">2838</span>    try {<a name="line.2838"></a>
+<span class="sourceLineNo">2839</span>      stopMaster();<a name="line.2839"></a>
+<span class="sourceLineNo">2840</span>    } catch (IOException e) {<a name="line.2840"></a>
+<span class="sourceLineNo">2841</span>      LOG.error("Exception occurred while stopping master", e);<a name="line.2841"></a>
+<span class="sourceLineNo">2842</span>    }<a name="line.2842"></a>
 <span class="sourceLineNo">2843</span>  }<a name="line.2843"></a>
 <span class="sourceLineNo">2844</span><a name="line.2844"></a>
 <span class="sourceLineNo">2845</span>  @Override<a name="line.2845"></a>
-<span class="sourceLineNo">2846</span>  public MasterCoprocessorHost getMasterCoprocessorHost() {<a name="line.2846"></a>
-<span class="sourceLineNo">2847</span>    return cpHost;<a name="line.2847"></a>
+<span class="sourceLineNo">2846</span>  public ZKWatcher getZooKeeper() {<a name="line.2846"></a>
+<span class="sourceLineNo">2847</span>    return zooKeeper;<a name="line.2847"></a>
 <span class="sourceLineNo">2848</span>  }<a name="line.2848"></a>
 <span class="sourceLineNo">2849</span><a name="line.2849"></a>
 <span class="sourceLineNo">2850</span>  @Override<a name="line.2850"></a>
-<span class="sourceLineNo">2851</span>  public MasterQuotaManager getMasterQuotaManager() {<a name="line.2851"></a>
-<span class="sourceLineNo">2852</span>    return quotaManager;<a name="line.2852"></a>
+<span class="sourceLineNo">2851</span>  public MasterCoprocessorHost getMasterCoprocessorHost() {<a name="line.2851"></a>
+<span class="sourceLineNo">2852</span>    return cpHost;<a name="line.2852"></a>
 <span class="sourceLineNo">2853</span>  }<a name="line.2853"></a>
 <span class="sourceLineNo">2854</span><a name="line.2854"></a>
 <span class="sourceLineNo">2855</span>  @Override<a name="line.2855"></a>
-<span class="sourceLineNo">2856</span>  public ProcedureExecutor&lt;MasterProcedureEnv&gt; getMasterProcedureExecutor() {<a name="line.2856"></a>
-<span class="sourceLineNo">2857</span>    return procedureExecutor;<a name="line.2857"></a>
+<span class="sourceLineNo">2856</span>  public MasterQuotaManager getMasterQuotaManager() {<a name="line.2856"></a>
+<span class="sourceLineNo">2857</span>    return quotaManager;<a name="line.2857"></a>
 <span class="sourceLineNo">2858</span>  }<a name="line.2858"></a>
 <span class="sourceLineNo">2859</span><a name="line.2859"></a>
 <span class="sourceLineNo">2860</span>  @Override<a name="line.2860"></a>
-<span class="sourceLineNo">2861</span>  public ServerName getServerName() {<a name="line.2861"></a>
-<span class="sourceLineNo">2862</span>    return this.serverName;<a name="line.2862"></a>
+<span class="sourceLineNo">2861</span>  public ProcedureExecutor&lt;MasterProcedureEnv&gt; getMasterProcedureExecutor() {<a name="line.2861"></a>
+<span class="sourceLineNo">2862</span>    return procedureExecutor;<a name="line.2862"></a>
 <span class="sourceLineNo">2863</span>  }<a name="line.2863"></a>
 <span class="sourceLineNo">2864</span><a name="line.2864"></a>
 <span class="sourceLineNo">2865</span>  @Override<a name="line.2865"></a>
-<span class="sourceLineNo">2866</span>  public AssignmentManager getAssignmentManager() {<a name="line.2866"></a>
-<span class="sourceLineNo">2867</span>    return this.assignmentManager;<a name="line.2867"></a>
+<span class="sourceLineNo">2866</span>  public ServerName getServerName() {<a name="line.2866"></a>
+<span class="sourceLineNo">2867</span>    return this.serverName;<a name="line.2867"></a>
 <span class="sourceLineNo">2868</span>  }<a name="line.2868"></a>
 <span class="sourceLineNo">2869</span><a name="line.2869"></a>
 <span class="sourceLineNo">2870</span>  @Override<a name="line.2870"></a>
-<span class="sourceLineNo">2871</span>  public CatalogJanitor getCatalogJanitor() {<a name="line.2871"></a>
-<span class="sourceLineNo">2872</span>    return this.catalogJanitorChore;<a name="line.2872"></a>
+<span class="sourceLineNo">2871</span>  public AssignmentManager getAssignmentManager() {<a name="line.2871"></a>
+<span class="sourceLineNo">2872</span>    return this.assignmentManager;<a name="line.2872"></a>
 <span class="sourceLineNo">2873</span>  }<a name="line.2873"></a>
 <span class="sourceLineNo">2874</span><a name="line.2874"></a>
-<span class="sourceLineNo">2875</span>  public MemoryBoundedLogMessageBuffer getRegionServerFatalLogBuffer() {<a name="line.2875"></a>
-<span class="sourceLineNo">2876</span>    return rsFatals;<a name="line.2876"></a>
-<span class="sourceLineNo">2877</span>  }<a name="line.2877"></a>
-<span class="sourceLineNo">2878</span><a name="line.2878"></a>
-<span class="sourceLineNo">2879</span>  /**<a name="line.2879"></a>
-<span class="sourceLineNo">2880</span>   * Shutdown the cluster.<a name="line.2880"></a>
-<span class="sourceLineNo">2881</span>   * Master runs a coordinated stop of all RegionServers and then itself.<a name="line.2881"></a>
-<span class="sourceLineNo">2882</span>   */<a name="line.2882"></a>
-<span class="sourceLineNo">2883</span>  public void shutdown() throws IOException {<a name="line.2883"></a>
-<span class="sourceLineNo">2884</span>    if (cpHost != null) {<a name="line.2884"></a>
-<span class="sourceLineNo">2885</span>      cpHost.preShutdown();<a name="line.2885"></a>
-<span class="sourceLineNo">2886</span>    }<a name="line.2886"></a>
-<span class="sourceLineNo">2887</span><a name="line.2887"></a>
-<span class="sourceLineNo">2888</span>    // Tell the servermanager cluster shutdown has been called. This makes it so when Master is<a name="line.2888"></a>
-<span class="sourceLineNo">2889</span>    // last running server, it'll stop itself. Next, we broadcast the cluster shutdown by setting<a name="line.2889"></a>
-<span class="sourceLineNo">2890</span>    // the cluster status as down. RegionServers will notice this change in state and will start<a name="line.2890"></a>
-<span class="sourceLineNo">2891</span>    // shutting themselves down. When last has exited, Master can go down.<a name="line.2891"></a>
-<span class="sourceLineNo">2892</span>    if (this.serverManager != null) {<a name="line.2892"></a>
-<span class="sourceLineNo">2893</span>      this.serverManager.shutdownCluster();<a name="line.2893"></a>
-<span class="sourceLineNo">2894</span>    }<a name="line.2894"></a>
-<span class="sourceLineNo">2895</span>    if (this.clusterStatusTracker != null) {<a name="line.2895"></a>
-<span class="sourceLineNo">2896</span>      try {<a name="line.2896"></a>
-<span class="sourceLineNo">2897</span>        this.clusterStatusTracker.setClusterDown();<a name="line.2897"></a>
-<span class="sourceLineNo">2898</span>      } catch (KeeperException e) {<a name="line.2898"></a>
-<span class="sourceLineNo">2899</span>        LOG.error("ZooKeeper exception trying to set cluster as down in ZK", e);<a name="line.2899"></a>
-<span class="sourceLineNo">2900</span>      }<a name="line.2900"></a>
-<span class="sourceLineNo">2901</span>    }<a name="line.2901"></a>
-<span class="sourceLineNo">2902</span>    // Stop the procedure executor. Will stop any ongoing assign, unassign, server crash etc.,<a name="line.2902"></a>
-<span class="sourceLineNo">2903</span>    // processing so we can go down.<a name="line.2903"></a>
-<span class="sourceLineNo">2904</span>    if (this.procedureExecutor != null) {<a name="line.2904"></a>
-<span class="sourceLineNo">2905</span>      this.procedureExecutor.stop();<a name="line.2905"></a>
+<span class="sourceLineNo">2875</span>  @Override<a name="line.2875"></a>
+<span class="sourceLineNo">2876</span>  public CatalogJanitor getCatalogJanitor() {<a name="line.2876"></a>
+<span class="sourceLineNo">2877</span>    return this.catalogJanitorChore;<a name="line.2877"></a>
+<span class="sourceLineNo">2878</span>  }<a name="line.2878"></a>
+<span class="sourceLineNo">2879</span><a name="line.2879"></a>
+<span class="sourceLineNo">2880</span>  public MemoryBoundedLogMessageBuffer getRegionServerFatalLogBuffer() {<a name="line.2880"></a>
+<span class="sourceLineNo">2881</span>    return rsFatals;<a name="line.2881"></a>
+<span class="sourceLineNo">2882</span>  }<a name="line.2882"></a>
+<span class="sourceLineNo">2883</span><a name="line.2883"></a>
+<span class="sourceLineNo">2884</span>  /**<a name="line.2884"></a>
+<span class="sourceLineNo">2885</span>   * Shutdown the cluster.<a name="line.2885"></a>
+<span class="sourceLineNo">2886</span>   * Master runs a coordinated stop of all RegionServers and then itself.<a name="line.2886"></a>
+<span class="sourceLineNo">2887</span>   */<a name="line.2887"></a>
+<span class="sourceLineNo">2888</span>  public void shutdown() throws IOException {<a name="line.2888"></a>
+<span class="sourceLineNo">2889</span>    if (cpHost != null) {<a name="line.2889"></a>
+<span class="sourceLineNo">2890</span>      cpHost.preShutdown();<a name="line.2890"></a>
+<span class="sourceLineNo">2891</span>    }<a name="line.2891"></a>
+<span class="sourceLineNo">2892</span><a name="line.2892"></a>
+<span class="sourceLineNo">2893</span>    // Tell the servermanager cluster shutdown has been called. This makes it so when Master is<a name="line.2893"></a>
+<span class="sourceLineNo">2894</span>    // last running server, it'll stop itself. Next, we broadcast the cluster shutdown by setting<a name="line.2894"></a>
+<span class="sourceLineNo">2895</span>    // the cluster status as down. RegionServers will notice this change in state and will start<a name="line.2895"></a>
+<span class="sourceLineNo">2896</span>    // shutting themselves down. When last has exited, Master can go down.<a name="line.2896"></a>
+<span class="sourceLineNo">2897</span>    if (this.serverManager != null) {<a name="line.2897"></a>
+<span class="sourceLineNo">2898</span>      this.serverManager.shutdownCluster();<a name="line.2898"></a>
+<span class="sourceLineNo">2899</span>    }<a name="line.2899"></a>
+<span class="sourceLineNo">2900</span>    if (this.clusterStatusTracker != null) {<a name="line.2900"></a>
+<span class="sourceLineNo">2901</span>      try {<a name="line.2901"></a>
+<span class="sourceLineNo">2902</span>        this.clusterStatusTracker.setClusterDown();<a name="line.2902"></a>
+<span class="sourceLineNo">2903</span>      } catch (KeeperException e) {<a name="line.2903"></a>
+<span class="sourceLineNo">2904</span>        LOG.error("ZooKeeper exception trying to set cluster as down in ZK", e);<a name="line.2904"></a>
+<span class="sourceLineNo">2905</span>      }<a name="line.2905"></a>
 <span class="sourceLineNo">2906</span>    }<a name="line.2906"></a>
-<span class="sourceLineNo">2907</span>    // Shutdown our cluster connection. This will kill any hosted RPCs that might be going on;<a name="line.2907"></a>
-<span class="sourceLineNo">2908</span>    // this is what we want especially if the Master is in startup phase doing call outs to<a name="line.2908"></a>
-<span class="sourceLineNo">2909</span>    // hbase:meta, etc. when cluster is down. Without ths connection close, we'd have to wait on<a name="line.2909"></a>
-<span class="sourceLineNo">2910</span>    // the rpc to timeout.<a name="line.2910"></a>
-<span class="sourceLineNo">2911</span>    if (this.asyncClusterConnection != null) {<a name="line.2911"></a>
-<span class="sourceLineNo">2912</span>      this.asyncClusterConnection.close();<a name="line.2912"></a>
-<span class="sourceLineNo">2913</span>    }<a name="line.2913"></a>
-<span class="sourceLineNo">2914</span>  }<a name="line.2914"></a>
-<span class="sourceLineNo">2915</span><a name="line.2915"></a>
-<span class="sourceLineNo">2916</span>  public void stopMaster() throws IOException {<a name="line.2916"></a>
-<span class="sourceLineNo">2917</span>    if (cpHost != null) {<a name="line.2917"></a>
-<span class="sourceLineNo">2918</span>      cpHost.preStopMaster();<a name="line.2918"></a>
-<span class="sourceLineNo">2919</span>    }<a name="line.2919"></a>
-<span class="sourceLineNo">2920</span>    stop("Stopped by " + Thread.currentThread().getName());<a name="line.2920"></a>
-<span class="sourceLineNo">2921</span>  }<a name="line.2921"></a>
-<span class="sourceLineNo">2922</span><a name="line.2922"></a>
-<span class="sourceLineNo">2923</span>  @Override<a name="line.2923"></a>
-<span class="sourceLineNo">2924</span>  public void stop(String msg) {<a name="line.2924"></a>
-<span class="sourceLineNo">2925</span>    if (!isStopped()) {<a name="line.2925"></a>
-<span class="sourceLineNo">2926</span>      super.stop(msg);<a name="line.2926"></a>
-<span class="sourceLineNo">2927</span>      if (this.activeMasterManager != null) {<a name="line.2927"></a>
-<span class="sourceLineNo">2928</span>        this.activeMasterManager.stop();<a name="line.2928"></a>
-<span class="sourceLineNo">2929</span>      }<a name="line.2929"></a>
-<span class="sourceLineNo">2930</span>    }<a name="line.2930"></a>
-<span class="sourceLineNo">2931</span>  }<a name="line.2931"></a>
-<span class="sourceLineNo">2932</span><a name="line.2932"></a>
-<span class="sourceLineNo">2933</span>  @InterfaceAudience.Private<a name="line.2933"></a>
-<span class="sourceLineNo">2934</span>  protected void checkServiceStarted() throws ServerNotRunningYetException {<a name="line.2934"></a>
-<span class="sourceLineNo">2935</span>    if (!serviceStarted) {<a name="line.2935"></a>
-<span class="sourceLineNo">2936</span>      throw new ServerNotRunningYetException("Server is not running yet");<a name="line.2936"></a>
-<span class="sourceLineNo">2937</span>    }<a name="line.2937"></a>
-<span class="sourceLineNo">2938</span>  }<a name="line.2938"></a>
-<span class="sourceLineNo">2939</span><a name="line.2939"></a>
-<span class="sourceLineNo">2940</span>  void checkInitialized() throws PleaseHoldException, ServerNotRunningYetException,<a name="line.2940"></a>
-<span class="sourceLineNo">2941</span>      MasterNotRunningException, MasterStoppedException {<a name="line.2941"></a>
-<span class="sourceLineNo">2942</span>    checkServiceStarted();<a name="line.2942"></a>
-<span class="sourceLineNo">2943</span>    if (!isInitialized()) {<a name="line.2943"></a>
-<span class="sourceLineNo">2944</span>      throw new PleaseHoldException("Master is initializing");<a name="line.2944"></a>
-<span class="sourceLineNo">2945</span>    }<a name="line.2945"></a>
-<span class="sourceLineNo">2946</span>    if (isStopped()) {<a name="line.2946"></a>
-<span class="sourceLineNo">2947</span>      throw new MasterStoppedException();<a name="line.2947"></a>
-<span class="sourceLineNo">2948</span>    }<a name="line.2948"></a>
-<span class="sourceLineNo">2949</span>  }<a name="line.2949"></a>
-<span class="sourceLineNo">2950</span><a name="line.2950"></a>
-<span class="sourceLineNo">2951</span>  /**<a name="line.2951"></a>
-<span class="sourceLineNo">2952</span>   * Report whether this master is currently the active master or not.<a name="line.2952"></a>
-<span class="sourceLineNo">2953</span>   * If not active master, we are parked on ZK waiting to become active.<a name="line.2953"></a>
-<span class="sourceLineNo">2954</span>   *<a name="line.2954"></a>
-<span class="sourceLineNo">2955</span>   * This method is used for testing.<a name="line.2955"></a>
-<span class="sourceLineNo">2956</span>   *<a name="line.2956"></a>
-<span class="sourceLineNo">2957</span>   * @return true if active master, false if not.<a name="line.2957"></a>
-<span class="sourceLineNo">2958</span>   */<a name="line.2958"></a>
-<span class="sourceLineNo">2959</span>  @Override<a name="line.2959"></a>
-<span class="sourceLineNo">2960</span>  public boolean isActiveMaster() {<a name="line.2960"></a>
-<span class="sourceLineNo">2961</span>    return activeMaster;<a name="line.2961"></a>
-<span class="sourceLineNo">2962</span>  }<a name="line.2962"></a>
-<span class="sourceLineNo">2963</span><a name="line.2963"></a>
-<span class="sourceLineNo">2964</span>  /**<a name="line.2964"></a>
-<span class="sourceLineNo">2965</span>   * Report whether this master has completed with its initialization and is<a name="line.2965"></a>
-<span class="sourceLineNo">2966</span>   * ready.  If ready, the master is also the active master.  A standby master<a name="line.2966"></a>
-<span class="sourceLineNo">2967</span>   * is never ready.<a name="line.2967"></a>
-<span class="sourceLineNo">2968</span>   *<a name="line.2968"></a>
-<span class="sourceLineNo">2969</span>   * This method is used for testing.<a name="line.2969"></a>
-<span class="sourceLineNo">2970</span>   *<a name="line.2970"></a>
-<span class="sourceLineNo">2971</span>   * @return true if master is ready to go, false if not.<a name="line.2971"></a>
-<span class="sourceLineNo">2972</span>   */<a name="line.2972"></a>
-<span class="sourceLineNo">2973</span>  @Override<a name="line.2973"></a>
-<span class="sourceLineNo">2974</span>  public boolean isInitialized() {<a name="line.2974"></a>
-<span class="sourceLineNo">2975</span>    return initialized.isReady();<a name="line.2975"></a>
-<span class="sourceLineNo">2976</span>  }<a name="line.2976"></a>
-<span class="sourceLineNo">2977</span><a name="line.2977"></a>
-<span class="sourceLineNo">2978</span>  /**<a name="line.2978"></a>
-<span class="sourceLineNo">2979</span>   * Report whether this master is started<a name="line.2979"></a>
-<span class="sourceLineNo">2980</span>   *<a name="line.2980"></a>
-<span class="sourceLineNo">2981</span>   * This method is used for testing.<a name="line.2981"></a>
-<span class="sourceLineNo">2982</span>   *<a name="line.2982"></a>
-<span class="sourceLineNo">2983</span>   * @return true if master is ready to go, false if not.<a name="line.2983"></a>
-<span class="sourceLineNo">2984</span>   */<a name="line.2984"></a>
-<span class="sourceLineNo">2985</span><a name="line.2985"></a>
-<span class="sourceLineNo">2986</span>  @Override<a name="line.2986"></a>
-<span class="sourceLineNo">2987</span>  public boolean isOnline() {<a name="line.2987"></a>
-<span class="sourceLineNo">2988</span>    return serviceStarted;<a name="line.2988"></a>
-<span class="sourceLineNo">2989</span>  }<a name="line.2989"></a>
+<span class="sourceLineNo">2907</span>    // Stop the procedure executor. Will stop any ongoing assign, unassign, server crash etc.,<a name="line.2907"></a>
+<span class="sourceLineNo">2908</span>    // processing so we can go down.<a name="line.2908"></a>
+<span class="sourceLineNo">2909</span>    if (this.procedureExecutor != null) {<a name="line.2909"></a>
+<span class="sourceLineNo">2910</span>      this.procedureExecutor.stop();<a name="line.2910"></a>
+<span class="sourceLineNo">2911</span>    }<a name="line.2911"></a>
+<span class="sourceLineNo">2912</span>    // Shutdown our cluster connection. This will kill any hosted RPCs that might be going on;<a name="line.2912"></a>
+<span class="sourceLineNo">2913</span>    // this is what we want especially if the Master is in startup phase doing call outs to<a name="line.2913"></a>
+<span class="sourceLineNo">2914</span>    // hbase:meta, etc. when cluster is down. Without ths connection close, we'd have to wait on<a name="line.2914"></a>
+<span class="sourceLineNo">2915</span>    // the rpc to timeout.<a name="line.2915"></a>
+<span class="sourceLineNo">2916</span>    if (this.asyncClusterConnection != null) {<a name="line.2916"></a>
+<span class="sourceLineNo">2917</span>      this.asyncClusterConnection.close();<a name="line.2917"></a>
+<span class="sourceLineNo">2918</span>    }<a name="line.2918"></a>
+<span class="sourceLineNo">2919</span>  }<a name="line.2919"></a>
+<span class="sourceLineNo">2920</span><a name="line.2920"></a>
+<span class="sourceLineNo">2921</span>  public void stopMaster() throws IOException {<a name="line.2921"></a>
+<span class="sourceLineNo">2922</span>    if (cpHost != null) {<a name="line.2922"></a>
+<span class="sourceLineNo">2923</span>      cpHost.preStopMaster();<a name="line.2923"></a>
+<span class="sourceLineNo">2924</span>    }<a name="line.2924"></a>
+<span class="sourceLineNo">2925</span>    stop("Stopped by " + Thread.currentThread().getName());<a name="line.2925"></a>
+<span class="sourceLineNo">2926</span>  }<a name="line.2926"></a>
+<span class="sourceLineNo">2927</span><a name="line.2927"></a>
+<span class="sourceLineNo">2928</span>  @Override<a name="line.2928"></a>
+<span class="sourceLineNo">2929</span>  public void stop(String msg) {<a name="line.2929"></a>
+<span class="sourceLineNo">2930</span>    if (!isStopped()) {<a name="line.2930"></a>
+<span class="sourceLineNo">2931</span>      super.stop(msg);<a name="line.2931"></a>
+<span class="sourceLineNo">2932</span>      if (this.activeMasterManager != null) {<a name="line.2932"></a>
+<span class="sourceLineNo">2933</span>        this.activeMasterManager.stop();<a name="line.2933"></a>
+<span class="sourceLineNo">2934</span>      }<a name="line.2934"></a>
+<span class="sourceLineNo">2935</span>    }<a name="line.2935"></a>
+<span class="sourceLineNo">2936</span>  }<a name="line.2936"></a>
+<span class="sourceLineNo">2937</span><a name="line.2937"></a>
+<span class="sourceLineNo">2938</span>  @InterfaceAudience.Private<a name="line.2938"></a>
+<span class="sourceLineNo">2939</span>  protected void checkServiceStarted() throws ServerNotRunningYetException {<a name="line.2939"></a>
+<span class="sourceLineNo">2940</span>    if (!serviceStarted) {<a name="line.2940"></a>
+<span class="sourceLineNo">2941</span>      throw new ServerNotRunningYetException("Server is not running yet");<a name="line.2941"></a>
+<span class="sourceLineNo">2942</span>    }<a name="line.2942"></a>
+<span class="sourceLineNo">2943</span>  }<a name="line.2943"></a>
+<span class="sourceLineNo">2944</span><a name="line.2944"></a>
+<span class="sourceLineNo">2945</span>  void checkInitialized() throws PleaseHoldException, ServerNotRunningYetException,<a name="line.2945"></a>
+<span class="sourceLineNo">2946</span>      MasterNotRunningException, MasterStoppedException {<a name="line.2946"></a>
+<span class="sourceLineNo">2947</span>    checkServiceStarted();<a name="line.2947"></a>
+<span class="sourceLineNo">2948</span>    if (!isInitialized()) {<a name="line.2948"></a>
+<span class="sourceLineNo">2949</span>      throw new PleaseHoldException("Master is initializing");<a name="line.2949"></a>
+<span class="sourceLineNo">2950</span>    }<a name="line.2950"></a>
+<span class="sourceLineNo">2951</span>    if (isStopped()) {<a name="line.2951"></a>
+<span class="sourceLineNo">2952</span>      throw new MasterStoppedException();<a name="line.2952"></a>
+<span class="sourceLineNo">2953</span>    }<a name="line.2953"></a>
+<span class="sourceLineNo">2954</span>  }<a name="line.2954"></a>
+<span class="sourceLineNo">2955</span><a name="line.2955"></a>
+<span class="sourceLineNo">2956</span>  /**<a name="line.2956"></a>
+<span class="sourceLineNo">2957</span>   * Report whether this master is currently the active master or not.<a name="line.2957"></a>
+<span class="sourceLineNo">2958</span>   * If not active master, we are parked on ZK waiting to become active.<a name="line.2958"></a>
+<span class="sourceLineNo">2959</span>   *<a name="line.2959"></a>
+<span class="sourceLineNo">2960</span>   * This method is used for testing.<a name="line.2960"></a>
+<span class="sourceLineNo">2961</span>   *<a name="line.2961"></a>
+<span class="sourceLineNo">2962</span>   * @return true if active master, false if not.<a name="line.2962"></a>
+<span class="sourceLineNo">2963</span>   */<a name="line.2963"></a>
+<span class="sourceLineNo">2964</span>  @Override<a name="line.2964"></a>
+<span class="sourceLineNo">2965</span>  public boolean isActiveMaster() {<a name="line.2965"></a>
+<span class="sourceLineNo">2966</span>    return activeMaster;<a name="line.2966"></a>
+<span class="sourceLineNo">2967</span>  }<a name="line.2967"></a>
+<span class="sourceLineNo">2968</span><a name="line.2968"></a>
+<span class="sourceLineNo">2969</span>  /**<a name="line.2969"></a>
+<span class="sourceLineNo">2970</span>   * Report whether this master has completed with its initialization and is<a name="line.2970"></a>
+<span class="sourceLineNo">2971</span>   * ready.  If ready, the master is also the active master.  A standby master<a name="line.2971"></a>
+<span class="sourceLineNo">2972</span>   * is never ready.<a name="line.2972"></a>
+<span class="sourceLineNo">2973</span>   *<a name="line.2973"></a>
+<span class="sourceLineNo">2974</span>   * This method is used for testing.<a name="line.2974"></a>
+<span class="sourceLineNo">2975</span>   *<a name="line.2975"></a>
+<span class="sourceLineNo">2976</span>   * @return true if master is ready to go, false if not.<a name="line.2976"></a>
+<span class="sourceLineNo">2977</span>   */<a name="line.2977"></a>
+<span class="sourceLineNo">2978</span>  @Override<a name="line.2978"></a>
+<span class="sourceLineNo">2979</span>  public boolean isInitialized() {<a name="line.2979"></a>
+<span class="sourceLineNo">2980</span>    return initialized.isReady();<a name="line.2980"></a>
+<span class="sourceLineNo">2981</span>  }<a name="line.2981"></a>
+<span class="sourceLineNo">2982</span><a name="line.2982"></a>
+<span class="sourceLineNo">2983</span>  /**<a name="line.2983"></a>
+<span class="sourceLineNo">2984</span>   * Report whether this master is started<a name="line.2984"></a>
+<span class="sourceLineNo">2985</span>   *<a name="line.2985"></a>
+<span class="sourceLineNo">2986</span>   * This method is used for testing.<a name="line.2986"></a>
+<span class="sourceLineNo">2987</span>   *<a name="line.2987"></a>
+<span class="sourceLineNo">2988</span>   * @return true if master is ready to go, false if not.<a name="line.2988"></a>
+<span class="sourceLineNo">2989</span>   */<a name="line.2989"></a>
 <span class="sourceLineNo">2990</span><a name="line.2990"></a>
-<span class="sourceLineNo">2991</span>  /**<a name="line.2991"></a>
-<span class="sourceLineNo">2992</span>   * Report whether this master is in maintenance mode.<a name="line.2992"></a>
-<span class="sourceLineNo">2993</span>   *<a name="line.2993"></a>
-<span class="sourceLineNo">2994</span>   * @return true if master is in maintenanceMode<a name="line.2994"></a>
-<span class="sourceLineNo">2995</span>   */<a name="line.2995"></a>
-<span class="sourceLineNo">2996</span>  @Override<a name="line.2996"></a>
-<span class="sourceLineNo">2997</span>  public boolean isInMaintenanceMode() {<a name="line.2997"></a>
-<span class="sourceLineNo">2998</span>    return maintenanceMode;<a name="line.2998"></a>
-<span class="sourceLineNo">2999</span>  }<a name="line.2999"></a>
-<span class="sourceLineNo">3000</span><a name="line.3000"></a>
-<span class="sourceLineNo">3001</span>  @InterfaceAudience.Private<a name="line.3001"></a>
-<span class="sourceLineNo">3002</span>  public void setInitialized(boolean isInitialized) {<a name="line.3002"></a>
-<span class="sourceLineNo">3003</span>    procedureExecutor.getEnvironment().setEventReady(initialized, isInitialized);<a name="line.3003"></a>
+<span class="sourceLineNo">2991</span>  @Override<a name="line.2991"></a>
+<span class="sourceLineNo">2992</span>  public boolean isOnline() {<a name="line.2992"></a>
+<span class="sourceLineNo">2993</span>    return serviceStarted;<a name="line.2993"></a>
+<span class="sourceLineNo">2994</span>  }<a name="line.2994"></a>
+<span class="sourceLineNo">2995</span><a name="line.2995"></a>
+<span class="sourceLineNo">2996</span>  /**<a name="line.2996"></a>
+<span class="sourceLineNo">2997</span>   * Report whether this master is in maintenance mode.<a name="line.2997"></a>
+<span class="sourceLineNo">2998</span>   *<a name="line.2998"></a>
+<span class="sourceLineNo">2999</span>   * @return true if master is in maintenanceMode<a name="line.2999"></a>
+<span class="sourceLineNo">3000</span>   */<a name="line.3000"></a>
+<span class="sourceLineNo">3001</span>  @Override<a name="line.3001"></a>
+<span class="sourceLineNo">3002</span>  public boolean isInMaintenanceMode() {<a name="line.3002"></a>
+<span class="sourceLineNo">3003</span>    return maintenanceMode;<a name="line.3003"></a>
 <span class="sourceLineNo">3004</span>  }<a name="line.3004"></a>
 <span class="sourceLineNo">3005</span><a name="line.3005"></a>
-<span class="sourceLineNo">3006</span>  @Override<a name="line.3006"></a>
-<span class="sourceLineNo">3007</span>  public ProcedureEvent&lt;?&gt; getInitializedEvent() {<a name="line.3007"></a>
-<span class="sourceLineNo">3008</span>    return initialized;<a name="line.3008"></a>
+<span class="sourceLineNo">3006</span>  @InterfaceAudience.Private<a name="line.3006"></a>
+<span class="sourceLineNo">3007</span>  public void setInitialized(boolean isInitialized) {<a name="line.3007"></a>
+<span class="sourceLineNo">3008</span>    procedureExecutor.getEnvironment().setEventReady(initialized, isInitialized);<a name="line.3008"></a>
 <span class="sourceLineNo">3009</span>  }<a name="line.3009"></a>
 <span class="sourceLineNo">3010</span><a name="line.3010"></a>
-<span class="sourceLineNo">3011</span>  /**<a name="line.3011"></a>
-<span class="sourceLineNo">3012</span>   * Compute the average load across all region servers.<a name="line.3012"></a>
-<span class="sourceLineNo">3013</span>   * Currently, this uses a very naive computation - just uses the number of<a name="line.3013"></a>
-<span class="sourceLineNo">3014</span>   * regions being served, ignoring stats about number of requests.<a name="line.3014"></a>
-<span class="sourceLineNo">3015</span>   * @return the average load<a name="line.3015"></a>
-<span class="sourceLineNo">3016</span>   */<a name="line.3016"></a>
-<span class="sourceLineNo">3017</span>  public double getAverageLoad() {<a name="line.3017"></a>
-<span class="sourceLineNo">3018</span>    if (this.assignmentManager == null) {<a name="line.3018"></a>
-<span class="sourceLineNo">3019</span>      return 0;<a name="line.3019"></a>
-<span class="sourceLineNo">3020</span>    }<a name="line.3020"></a>
-<span class="sourceLineNo">3021</span><a name="line.3021"></a>
-<span class="sourceLineNo">3022</span>    RegionStates regionStates = this.assignmentManager.getRegionStates();<a name="line.3022"></a>
-<span class="sourceLineNo">3023</span>    if (regionStates == null) {<a name="line.3023"></a>
+<span class="sourceLineNo">3011</span>  @Override<a name="line.3011"></a>
+<span class="sourceLineNo">3012</span>  public ProcedureEvent&lt;?&gt; getInitializedEvent() {<a name="line.3012"></a>
+<span class="sourceLineNo">3013</span>    return initialized;<a name="line.3013"></a>
+<span class="sourceLineNo">3014</span>  }<a name="line.3014"></a>
+<span class="sourceLineNo">3015</span><a name="line.3015"></a>
+<span class="sourceLineNo">3016</span>  /**<a name="line.3016"></a>
+<span class="sourceLineNo">3017</span>   * Compute the average load across all region servers.<a name="line.3017"></a>
+<span class="sourceLineNo">3018</span>   * Currently, this uses a very naive computation - just uses the number of<a name="line.3018"></a>
+<span class="sourceLineNo">3019</span>   * regions being served, ignoring stats about number of requests.<a name="line.3019"></a>
+<span class="sourceLineNo">3020</span>   * @return the average load<a name="line.3020"></a>
+<span class="sourceLineNo">3021</span>   */<a name="line.3021"></a>
+<span class="sourceLineNo">3022</span>  public double getAverageLoad() {<a name="line.3022"></a>
+<span class="sourceLineNo">3023</span>    if (this.assignmentManager == null) {<a name="line.3023"></a>
 <span class="sourceLineNo">3024</span>      return 0;<a name="line.3024"></a>
 <span class="sourceLineNo">3025</span>    }<a name="line.3025"></a>
-<span class="sourceLineNo">3026</span>    return regionStates.getAverageLoad();<a name="line.3026"></a>
-<span class="sourceLineNo">3027</span>  }<a name="line.3027"></a>
-<span class="sourceLineNo">3028</span><a name="line.3028"></a>
-<span class="sourceLineNo">3029</span>  @Override<a name="line.3029"></a>
-<span class="sourceLineNo">3030</span>  public boolean registerService(Service instance) {<a name="line.3030"></a>
-<span class="sourceLineNo">3031</span>    /*<a name="line.3031"></a>
-<span class="sourceLineNo">3032</span>     * No stacking of instances is allowed for a single service name<a name="line.3032"></a>
-<span class="sourceLineNo">3033</span>     */<a name="line.3033"></a>
-<span class="sourceLineNo">3034</span>    Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();<a name="line.3034"></a>
-<span class="sourceLineNo">3035</span>    String serviceName = CoprocessorRpcUtils.getServiceName(serviceDesc);<a name="line.3035"></a>
-<span class="sourceLineNo">3036</span>    if (coprocessorServiceHandlers.containsKey(serviceName)) {<a name="line.3036"></a>
-<span class="sourceLineNo">3037</span>      LOG.error("Coprocessor service "+serviceName+<a name="line.3037"></a>
-<span class="sourceLineNo">3038</span>          " already registered, rejecting request from "+instance<a name="line.3038"></a>
-<span class="sourceLineNo">3039</span>      );<a name="line.3039"></a>
-<span class="sourceLineNo">3040</span>      return false;<a name="line.3040"></a>
-<span class="sourceLineNo">3041</span>    }<a name="line.3041"></a>
-<span class="sourceLineNo">3042</span><a name="line.3042"></a>
-<span class="sourceLineNo">3043</span>    coprocessorServiceHandlers.put(serviceName, instance);<a name="line.3043"></a>
-<span class="sourceLineNo">3044</span>    if (LOG.isDebugEnabled()) {<a name="line.3044"></a>
-<span class="sourceLineNo">3045</span>      LOG.debug("Registered master coprocessor service: service="+serviceName);<a name="line.3045"></a>
+<span class="sourceLineNo">3026</span><a name="line.3026"></a>
+<span class="sourceLineNo">3027</span>    RegionStates regionStates = this.assignmentManager.getRegionStates();<a name="line.3027"></a>
+<span class="sourceLineNo">3028</span>    if (regionStates == null) {<a name="line.3028"></a>
+<span class="sourceLineNo">3029</span>      return 0;<a name="line.3029"></a>
+<span class="sourceLineNo">3030</span>    }<a name="line.3030"></a>
+<span class="sourceLineNo">3031</span>    return regionStates.getAverageLoad();<a name="line.3031"></a>
+<span class="sourceLineNo">3032</span>  }<a name="line.3032"></a>
+<span class="sourceLineNo">3033</span><a name="line.3033"></a>
+<span class="sourceLineNo">3034</span>  @Override<a name="line.3034"></a>
+<span class="sourceLineNo">3035</span>  public boolean registerService(Service instance) {<a name="line.3035"></a>
+<span class="sourceLineNo">3036</span>    /*<a name="line.3036"></a>
+<span class="sourceLineNo">3037</span>     * No stacking of instances is allowed for a single service name<a name="line.3037"></a>
+<span class="sourceLineNo">3038</span>     */<a name="line.3038"></a>
+<span class="sourceLineNo">3039</span>    Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();<a name="line.3039"></a>
+<span class="sourceLineNo">3040</span>    String serviceName = CoprocessorRpcUtils.getServiceName(serviceDesc);<a name="line.3040"></a>
+<span class="sourceLineNo">3041</span>    if (coprocessorServiceHandlers.containsKey(serviceName)) {<a name="line.3041"></a>
+<span class="sourceLineNo">3042</span>      LOG.error("Coprocessor service "+serviceName+<a name="line.3042"></a>
+<span class="sourceLineNo">3043</span>          " already registered, rejecting request from "+instance<a name="line.3043"></a>
+<span class="sourceLineNo">3044</span>      );<a name="line.3044"></a>
+<span class="sourceLineNo">3045</span>      return false;<a name="line.3045"></a>
 <span class="sourceLineNo">3046</span>    }<a name="line.3046"></a>
-<span class="sourceLineNo">3047</span>    return true;<a name="line.3047"></a>
-<span class="sourceLineNo">3048</span>  }<a name="line.3048"></a>
-<span class="sourceLineNo">3049</span><a name="line.3049"></a>
-<span class="sourceLineNo">3050</span>  /**<a name="line.3050"></a>
-<span class="sourceLineNo">3051</span>   * Utility for constructing an instance of the passed HMaster class.<a name="line.3051"></a>
-<span class="sourceLineNo">3052</span>   * @param masterClass<a name="line.3052"></a>
-<span class="sourceLineNo">3053</span>   * @return HMaster instance.<a name="line.3053"></a>
-<span class="sourceLineNo">3054</span>   */<a name="line.3054"></a>
-<span class="sourceLineNo">3055</span>  public static HMaster constructMaster(Class&lt;? extends HMaster&gt; masterClass,<a name="line.3055"></a>
-<span class="sourceLineNo">3056</span>      final Configuration conf)  {<a name="line.3056"></a>
-<span class="sourceLineNo">3057</span>    try {<a name="line.3057"></a>
-<span class="sourceLineNo">3058</span>      Constructor&lt;? extends HMaster&gt; c = masterClass.getConstructor(Configuration.class);<a name="line.3058"></a>
-<span class="sourceLineNo">3059</span>      return c.newInstance(conf);<a name="line.3059"></a>
-<span class="sourceLineNo">3060</span>    } catch(Exception e) {<a name="line.3060"></a>
-<span class="sourceLineNo">3061</span>      Throwable error = e;<a name="line.3061"></a>
-<span class="sourceLineNo">3062</span>      if (e instanceof InvocationTargetException &amp;&amp;<a name="line.3062"></a>
-<span class="sourceLineNo">3063</span>          ((InvocationTargetException)e).getTargetException() != null) {<a name="line.3063"></a>
-<span class="sourceLineNo">3064</span>        error = ((InvocationTargetException)e).getTargetException();<a name="line.3064"></a>
-<span class="sourceLineNo">3065</span>      }<a name="line.3065"></a>
-<span class="sourceLineNo">3066</span>      throw new RuntimeException("Failed construction of Master: " + masterClass.toString() + ". "<a name="line.3066"></a>
-<span class="sourceLineNo">3067</span>        , error);<a name="line.3067"></a>
-<span class="sourceLineNo">3068</span>    }<a name="line.3068"></a>
-<span class="sourceLineNo">3069</span>  }<a name="line.3069"></a>
-<span class="sourceLineNo">3070</span><a name="line.3070"></a>
-<span class="sourceLineNo">3071</span>  /**<a name="line.3071"></a>
-<span class="sourceLineNo">3072</span>   * @see org.apache.hadoop.hbase.master.HMasterCommandLine<a name="line.3072"></a>
-<span class="sourceLineNo">3073</span>   */<a name="line.3073"></a>
-<span class="sourceLineNo">3074</span>  public static void main(String [] args) {<a name="line.3074"></a>
-<span class="sourceLineNo">3075</span>    LOG.info("STARTING service " + HMaster.class.getSimpleName());<a name="line.3075"></a>
-<span class="sourceLineNo">3076</span>    VersionInfo.logVersion();<a name="line.3076"></a>
-<span class="sourceLineNo">3077</span>    new HMasterCommandLine(HMaster.class).doMain(args);<a name="line.3077"></a>
-<span class="sourceLineNo">3078</span>  }<a name="line.3078"></a>
-<span class="sourceLineNo">3079</span><a name="line.3079"></a>
-<span class="sourceLineNo">3080</span>  public HFileCleaner getHFileCleaner() {<a name="line.3080"></a>
-<span class="sourceLineNo">3081</span>    return this.hfileCleaner;<a name="line.3081"></a>
-<span class="sourceLineNo">3082</span>  }<a name="line.3082"></a>
-<span class="sourceLineNo">3083</span><a name="line.3083"></a>
-<span class="sourceLineNo">3084</span>  public LogCleaner getLogCleaner() {<a name="line.3084"></a>
-<span class="sourceLineNo">3085</span>    return this.logCleaner;<a name="line.3085"></a>
-<span class="sourceLineNo">3086</span>  }<a name="line.3086"></a>
-<span class="sourceLineNo">3087</span><a name="line.3087"></a>
-<span class="sourceLineNo">3088</span>  /**<a name="line.3088"></a>
-<span class="sourceLineNo">3089</span>   * @return the underlying snapshot manager<a name="line.3089"></a>
-<span class="sourceLineNo">3090</span>   */<a name="line.3090"></a>
-<span class="sourceLineNo">3091</span>  @Override<a name="line.3091"></a>
-<span class="sourceLineNo">3092</span>  public SnapshotManager getSnapshotManager() {<a name="line.3092"></a>
-<span class="sourceLineNo">3093</span>    return this.snapshotManager;<a name="line.3093"></a>
-<span class="sourceLineNo">3094</span>  }<a name="line.3094"></a>
-<span class="sourceLineNo">3095</span><a name="line.3095"></a>
-<span class="sourceLineNo">3096</span>  /**<a name="line.3096"></a>
-<span class="sourceLineNo">3097</span>   * @return the underlying MasterProcedureManagerHost<a name="line.3097"></a>
-<span class="sourceLineNo">3098</span>   */<a name="line.3098"></a>
-<span class="sourceLineNo">3099</span>  @Override<a name="line.3099"></a>
-<span class="sourceLineNo">3100</span>  public MasterProcedureManagerHost getMasterProcedureManagerHost() {<a name="line.3100"></a>
-<span class="sourceLineNo">3101</span>    return mpmHost;<a name="line.3101"></a>
-<span class="sourceLineNo">3102</span>  }<a name="line.3102"></a>
-<span class="sourceLineNo">3103</span><a name="line.3103"></a>
+<span class="sourceLineNo">3047</span><a name="line.3047"></a>
+<span class="sourceLineNo">3048</span>    coprocessorServiceHandlers.put(serviceName, instance);<a name="line.3048"></a>
+<span class="sourceLineNo">3049</span>    if (LOG.isDebugEnabled()) {<a name="line.3049"></a>
+<span class="sourceLineNo">3050</span>      LOG.debug("Registered master coprocessor service: service="+serviceName);<a name="line.3050"></a>
+<span class="sourceLineNo">3051</span>    }<a name="line.3051"></a>
+<span class="sourceLineNo">3052</span>    return true;<a name="line.3052"></a>
+<span class="sourceLineNo">3053</span>  }<a name="line.3053"></a>
+<span class="sourceLineNo">3054</span><a name="line.3054"></a>
+<span class="sourceLineNo">3055</span>  /**<a name="line.3055"></a>
+<span class="sourceLineNo">3056</span>   * Utility for constructing an instance of the passed HMaster class.<a name="line.3056"></a>
+<span class="sourceLineNo">3057</span>   * @param masterClass<a name="line.3057"></a>
+<span class="sourceLineNo">3058</span>   * @return HMaster instance.<a name="line.3058"></a>
+<span class="sourceLineNo">3059</span>   */<a name="line.3059"></a>
+<span class="sourceLineNo">3060</span>  public static HMaster constructMaster(Class&lt;? extends HMaster&gt; masterClass,<a name="line.3060"></a>
+<span class="sourceLineNo">3061</span>      final Configuration conf)  {<a name="line.3061"></a>
+<span class="sourceLineNo">3062</span>    try {<a name="line.3062"></a>
+<span class="sourceLineNo">3063</span>      Constructor&lt;? extends HMaster&gt; c = masterClass.getConstructor(Configuration.class);<a name="line.3063"></a>
+<span class="sourceLineNo">3064</span>      return c.newInstance(conf);<a name="line.3064"></a>
+<span class="sourceLineNo">3065</span>    } catch(Exception e) {<a name="line.3065"></a>
+<span class="sourceLineNo">3066</span>      Throwable error = e;<a name="line.3066"></a>
+<span class="sourceLineNo">3067</span>      if (e instanceof InvocationTargetException &amp;&amp;<a name="line.3067"></a>
+<span class="sourceLineNo">3068</span>          ((InvocationTargetException)e).getTargetException() != null) {<a name="line.3068"></a>
+<span class="sourceLineNo">3069</span>        error = ((InvocationTargetException)e).getTargetException();<a name="line.3069"></a>
+<span class="sourceLineNo">3070</span>      }<a name="line.3070"></a>
+<span class="sourceLineNo">3071</span>      throw new RuntimeException("Failed construction of Master: " + masterClass.toString() + ". "<a name="line.3071"></a>
+<span class="sourceLineNo">3072</span>        , error);<a name="line.3072"></a>
+<span class="sourceLineNo">3073</span>    }<a name="line.3073"></a>
+<span class="sourceLineNo">3074</span>  }<a name="line.3074"></a>
+<span class="sourceLineNo">3075</span><a name="line.3075"></a>
+<span class="sourceLineNo">3076</span>  /**<a name="line.3076"></a>
+<span class="sourceLineNo">3077</span>   * @see org.apache.hadoop.hbase.master.HMasterCommandLine<a name="line.3077"></a>
+<span class="sourceLineNo">3078</span>   */<a name="line.3078"></a>
+<span class="sourceLineNo">3079</span>  public static void main(String [] args) {<a name="line.3079"></a>
+<span class="sourceLineNo">3080</span>    LOG.info("STARTING service " + HMaster.class.getSimpleName());<a name="line.3080"></a>
+<span class="sourceLineNo">3081</span>    VersionInfo.logVersion();<a name="line.3081"></a>
+<span class="sourceLineNo">3082</span>    new HMasterCommandLine(HMaster.class).doMain(args);<a name="line.3082"></a>
+<span class="sourceLineNo">3083</span>  }<a name="line.3083"></a>
+<span class="sourceLineNo">3084</span><a name="line.3084"></a>
+<span class="sourceLineNo">3085</span>  public HFileCleaner getHFileCleaner() {<a name="line.3085"></a>
+<span class="sourceLineNo">3086</span>    return this.hfileCleaner;<a name="line.3086"></a>
+<span class="sourceLineNo">3087</span>  }<a name="line.3087"></a>
+<span class="sourceLineNo">3088</span><a name="line.3088"></a>
+<span class="sourceLineNo">3089</span>  public LogCleaner getLogCleaner() {<a name="line.3089"></a>
+<span class="sourceLineNo">3090</span>    return this.logCleaner;<a name="line.3090"></a>
+<span class="sourceLineNo">3091</span>  }<a name="line.3091"></a>
+<span class="sourceLineNo">3092</span><a name="line.3092"></a>
+<span class="sourceLineNo">3093</span>  /**<a name="line.3093"></a>
+<span class="sourceLineNo">3094</span>   * @return the underlying snapshot manager<a name="line.3094"></a>
+<span class="sourceLineNo">3095</span>   */<a name="line.3095"></a>
+<span class="sourceLineNo">3096</span>  @Override<a name="line.3096"></a>
+<span class="sourceLineNo">3097</span>  public SnapshotManager getSnapshotManager() {<a name="line.3097"></a>
+<span class="sourceLineNo">3098</span>    return this.snapshotManager;<a name="line.3098"></a>
+<span class="sourceLineNo">3099</span>  }<a name="line.3099"></a>
+<span class="sourceLineNo">3100</span><a name="line.3100"></a>
+<span class="sourceLineNo">3101</span>  /**<a name="line.3101"></a>
+<span class="sourceLineNo">3102</span>   * @return the underlying MasterProcedureManagerHost<a name="line.3102"></a>
+<span class="sourceLineNo">3103</span>   */<a name="line.3103"></a>
 <span class="sourceLineNo">3104</span>  @Override<a name="line.3104"></a>
-<span class="sourceLineNo">3105</span>  public ClusterSchema getClusterSchema() {<a name="line.3105"></a>
-<span class="sourceLineNo">3106</span>    return this.clusterSchemaService;<a name="line.3106"></a>
+<span class="sourceLineNo">3105</span>  public MasterProcedureManagerHost getMasterProcedureManagerHost() {<a name="line.3105"></a>
+<span class="sourceLineNo">3106</span>    return mpmHost;<a name="line.3106"></a>
 <span class="sourceLineNo">3107</span>  }<a name="line.3107"></a>
 <span class="sourceLineNo">3108</span><a name="line.3108"></a>
-<span class="sourceLineNo">3109</span>  /**<a name="line.3109"></a>
-<span class="sourceLineNo">3110</span>   * Create a new Namespace.<a name="line.3110"></a>
-<span class="sourceLineNo">3111</span>   * @param namespaceDescriptor descriptor for new Namespace<a name="line.3111"></a>
-<span class="sourceLineNo">3112</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3112"></a>
-<span class="sourceLineNo">3113</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3113"></a>
-<span class="sourceLineNo">3114</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3114"></a>
-<span class="sourceLineNo">3115</span>   * @return procedure id<a name="line.3115"></a>
-<span class="sourceLineNo">3116</span>   */<a name="line.3116"></a>
-<span class="sourceLineNo">3117</span>  long createNamespace(final NamespaceDescriptor namespaceDescriptor, final long nonceGroup,<a name="line.3117"></a>
-<span class="sourceLineNo">3118</span>      final long nonce) throws IOException {<a name="line.3118"></a>
-<span class="sourceLineNo">3119</span>    checkInitialized();<a name="line.3119"></a>
-<span class="sourceLineNo">3120</span><a name="line.3120"></a>
-<span class="sourceLineNo">3121</span>    TableName.isLegalNamespaceName(Bytes.toBytes(namespaceDescriptor.getName()));<a name="line.3121"></a>
-<span class="sourceLineNo">3122</span><a name="line.3122"></a>
-<span class="sourceLineNo">3123</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3123"></a>
-<span class="sourceLineNo">3124</span>          nonceGroup, nonce) {<a name="line.3124"></a>
-<span class="sourceLineNo">3125</span>      @Override<a name="line.3125"></a>
-<span class="sourceLineNo">3126</span>      protected void run() throws IOException {<a name="line.3126"></a>
-<span class="sourceLineNo">3127</span>        getMaster().getMasterCoprocessorHost().preCreateNamespace(namespaceDescriptor);<a name="line.3127"></a>
-<span class="sourceLineNo">3128</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3128"></a>
-<span class="sourceLineNo">3129</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3129"></a>
-<span class="sourceLineNo">3130</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3130"></a>
-<span class="sourceLineNo">3131</span>        LOG.info(getClientIdAuditPrefix() + " creating " + namespaceDescriptor);<a name="line.3131"></a>
-<span class="sourceLineNo">3132</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3132"></a>
-<span class="sourceLineNo">3133</span>        // continuing.<a name="line.3133"></a>
-<span class="sourceLineNo">3134</span>        setProcId(getClusterSchema().createNamespace(namespaceDescriptor, getNonceKey(), latch));<a name="line.3134"></a>
-<span class="sourceLineNo">3135</span>        latch.await();<a name="line.3135"></a>
-<span class="sourceLineNo">3136</span>        getMaster().getMasterCoprocessorHost().postCreateNamespace(namespaceDescriptor);<a name="line.3136"></a>
-<span class="sourceLineNo">3137</span>      }<a name="line.3137"></a>
-<span class="sourceLineNo">3138</span><a name="line.3138"></a>
-<span class="sourceLineNo">3139</span>      @Override<a name="line.3139"></a>
-<span class="sourceLineNo">3140</span>      protected String getDescription() {<a name="line.3140"></a>
-<span class="sourceLineNo">3141</span>        return "CreateNamespaceProcedure";<a name="line.3141"></a>
+<span class="sourceLineNo">3109</span>  @Override<a name="line.3109"></a>
+<span class="sourceLineNo">3110</span>  public ClusterSchema getClusterSchema() {<a name="line.3110"></a>
+<span class="sourceLineNo">3111</span>    return this.clusterSchemaService;<a name="line.3111"></a>
+<span class="sourceLineNo">3112</span>  }<a name="line.3112"></a>
+<span class="sourceLineNo">3113</span><a name="line.3113"></a>
+<span class="sourceLineNo">3114</span>  /**<a name="line.3114"></a>
+<span class="sourceLineNo">3115</span>   * Create a new Namespace.<a name="line.3115"></a>
+<span class="sourceLineNo">3116</span>   * @param namespaceDescriptor descriptor for new Namespace<a name="line.3116"></a>
+<span class="sourceLineNo">3117</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3117"></a>
+<span class="sourceLineNo">3118</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3118"></a>
+<span class="sourceLineNo">3119</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3119"></a>
+<span class="sourceLineNo">3120</span>   * @return procedure id<a name="line.3120"></a>
+<span class="sourceLineNo">3121</span>   */<a name="line.3121"></a>
+<span class="sourceLineNo">3122</span>  long createNamespace(final NamespaceDescriptor namespaceDescriptor, final long nonceGroup,<a name="line.3122"></a>
+<span class="sourceLineNo">3123</span>      final long nonce) throws IOException {<a name="line.3123"></a>
+<span class="sourceLineNo">3124</span>    checkInitialized();<a name="line.3124"></a>
+<span class="sourceLineNo">3125</span><a name="line.3125"></a>
+<span class="sourceLineNo">3126</span>    TableName.isLegalNamespaceName(Bytes.toBytes(namespaceDescriptor.getName()));<a name="line.3126"></a>
+<span class="sourceLineNo">3127</span><a name="line.3127"></a>
+<span class="sourceLineNo">3128</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3128"></a>
+<span class="sourceLineNo">3129</span>          nonceGroup, nonce) {<a name="line.3129"></a>
... 12058 lines suppressed ...