You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hbase.apache.org by gi...@apache.org on 2020/10/15 20:18:35 UTC

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

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 1e772ac  Published site at 70d2f37ee38bd89f00279d319ae99bd76108fe2d.
1e772ac is described below

commit 1e772ac59b8d423b37a348f0631e43daf773194b
Author: jenkins <bu...@apache.org>
AuthorDate: Thu Oct 15 20:18:19 2020 +0000

    Published site at 70d2f37ee38bd89f00279d319ae99bd76108fe2d.
---
 acid-semantics.html                                |    2 +-
 apache_hbase_reference_guide.pdf                   |    4 +-
 book.html                                          |    2 +-
 bulk-loads.html                                    |    2 +-
 checkstyle-aggregate.html                          |  176 +-
 coc.html                                           |    2 +-
 dependencies.html                                  |    2 +-
 dependency-convergence.html                        |    2 +-
 dependency-info.html                               |    2 +-
 dependency-management.html                         |    2 +-
 devapidocs/index-all.html                          |    8 +-
 .../master/HMaster.MasterStoppedException.html     |    4 +-
 .../master/HMaster.TableDescriptorGetter.html      |    4 +-
 .../org/apache/hadoop/hbase/master/HMaster.html    |  318 +-
 .../hbase/master/region/MasterRegionWALRoller.html |   38 +-
 .../hadoop/hbase/regionserver/LogRoller.html       |    2 +-
 .../wal/AbstractWALRoller.RollController.html      |   20 +-
 .../apache/hadoop/hbase/wal/AbstractWALRoller.html |   53 +-
 .../org/apache/hadoop/hbase/wal/class-use/WAL.html |   29 +-
 .../master/HMaster.InitializationMonitor.html      | 5340 ++++++++++----------
 .../master/HMaster.MasterStoppedException.html     | 5340 ++++++++++----------
 .../hbase/master/HMaster.RedirectServlet.html      | 5340 ++++++++++----------
 .../master/HMaster.TableDescriptorGetter.html      | 5340 ++++++++++----------
 .../org/apache/hadoop/hbase/master/HMaster.html    | 5340 ++++++++++----------
 .../hbase/master/region/MasterRegionWALRoller.html |  158 +-
 .../wal/AbstractWALRoller.RollController.html      |  518 +-
 .../apache/hadoop/hbase/wal/AbstractWALRoller.html |  518 +-
 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 +-
 47 files changed, 14304 insertions(+), 14302 deletions(-)

diff --git a/acid-semantics.html b/acid-semantics.html
index 740bd01..5da9e83 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -467,7 +467,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 3078b19..a559ee9 100644
--- a/apache_hbase_reference_guide.pdf
+++ b/apache_hbase_reference_guide.pdf
@@ -5,8 +5,8 @@
 /Author (Apache HBase Team)
 /Creator (Asciidoctor PDF 1.5.0.rc.2, based on Prawn 2.2.2)
 /Producer (Apache HBase Team)
-/ModDate (D:20201014200728+00'00')
-/CreationDate (D:20201014201927+00'00')
+/ModDate (D:20201015200517+00'00')
+/CreationDate (D:20201015201522+00'00')
 >>
 endobj
 2 0 obj
diff --git a/book.html b/book.html
index 8505310..a0d8ad5 100644
--- a/book.html
+++ b/book.html
@@ -46069,7 +46069,7 @@ org/apache/hadoop/hbase/security/access/AccessControlClient.revoke:(Lorg/apache/
 <div id="footer">
 <div id="footer-text">
 Version 3.0.0-SNAPSHOT<br>
-Last updated 2020-10-14 20:07:28 UTC
+Last updated 2020-10-15 20:05:17 UTC
 </div>
 </div>
 <script type="text/x-mathjax-config">
diff --git a/bulk-loads.html b/bulk-loads.html
index c57dc88..fe4d54e 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -172,7 +172,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 6854b3a..acc89b3 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -38117,524 +38117,524 @@
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>MethodLength</td>
-<td>Method length is 325 lines (max allowed is 150).</td>
+<td>Method length is 327 lines (max allowed is 150).</td>
 <td>892</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>1557</td></tr>
+<td>1559</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>1729</td></tr>
+<td>1733</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>1784</td></tr>
+<td>1788</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>1978</td></tr>
+<td>1982</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>1989</td></tr>
+<td>1993</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>1991</td></tr>
+<td>1995</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>1992</td></tr>
+<td>1996</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>1995</td></tr>
+<td>1999</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>1996</td></tr>
+<td>2000</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>1998</td></tr>
+<td>2002</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>2000</td></tr>
+<td>2004</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>2001</td></tr>
+<td>2005</td></tr>
 <tr class="a">
 <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>2002</td></tr>
+<td>2006</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 116).</td>
-<td>2030</td></tr>
+<td>2034</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 105).</td>
-<td>2032</td></tr>
+<td>2036</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>2241</td></tr>
+<td>2245</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>2243</td></tr>
+<td>2247</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>2245</td></tr>
+<td>2249</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>2251</td></tr>
+<td>2255</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>2252</td></tr>
+<td>2256</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>2254</td></tr>
+<td>2258</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>2256</td></tr>
+<td>2260</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>2257</td></tr>
+<td>2261</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>2259</td></tr>
+<td>2263</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>2261</td></tr>
+<td>2265</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>2262</td></tr>
+<td>2266</td></tr>
 <tr class="a">
 <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>2263</td></tr>
+<td>2267</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>2276</td></tr>
+<td>2280</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>2278</td></tr>
+<td>2282</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>2280</td></tr>
+<td>2284</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>2281</td></tr>
+<td>2285</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>2282</td></tr>
+<td>2286</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>2284</td></tr>
+<td>2288</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>2286</td></tr>
+<td>2290</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>2287</td></tr>
+<td>2291</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>2289</td></tr>
+<td>2293</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>2291</td></tr>
+<td>2295</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>2292</td></tr>
+<td>2296</td></tr>
 <tr class="a">
 <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>2293</td></tr>
+<td>2297</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>2376</td></tr>
+<td>2380</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>2378</td></tr>
+<td>2382</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>2384</td></tr>
+<td>2388</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2385</td></tr>
+<td>2389</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2386</td></tr>
+<td>2390</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' child has incorrect indentation level 16, expected level should be one of the following: 18, 20.</td>
-<td>2393</td></tr>
+<td>2397</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 14, expected level should be one of the following: 16, 18.</td>
-<td>2395</td></tr>
+<td>2399</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 12, expected level should be one of the following: 14, 16.</td>
-<td>2396</td></tr>
+<td>2400</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2397</td></tr>
+<td>2401</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' child has incorrect indentation level 12, expected level should be one of the following: 14, 16.</td>
-<td>2398</td></tr>
+<td>2402</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 10, expected level should be one of the following: 12, 14.</td>
-<td>2399</td></tr>
+<td>2403</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 8, expected level should be one of the following: 10, 12.</td>
-<td>2400</td></tr>
+<td>2404</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>2402</td></tr>
+<td>2406</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>2409</td></tr>
+<td>2413</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>2410</td></tr>
+<td>2414</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>2412</td></tr>
+<td>2416</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>2414</td></tr>
+<td>2418</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>2415</td></tr>
+<td>2419</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>2417</td></tr>
+<td>2421</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>2419</td></tr>
+<td>2423</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>2420</td></tr>
+<td>2424</td></tr>
 <tr class="a">
 <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>2421</td></tr>
+<td>2425</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>2431</td></tr>
+<td>2435</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>2433</td></tr>
+<td>2437</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>2435</td></tr>
+<td>2439</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>2445</td></tr>
+<td>2449</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>2446</td></tr>
+<td>2450</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>2448</td></tr>
+<td>2452</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>2450</td></tr>
+<td>2454</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>2451</td></tr>
+<td>2455</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>2453</td></tr>
+<td>2457</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>2455</td></tr>
+<td>2459</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>2456</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>'object def rcurly' has incorrect indentation level 4, expected level should be one of the following: 6, 8.</td>
-<td>2457</td></tr>
+<td>2461</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>2520</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 rcurly' has incorrect indentation level 6, expected level should be one of the following: 8, 10.</td>
-<td>2524</td></tr>
+<td>2528</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>2526</td></tr>
+<td>2530</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>2528</td></tr>
+<td>2532</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>2529</td></tr>
+<td>2533</td></tr>
 <tr class="a">
 <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>2530</td></tr>
+<td>2534</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>2957</td></tr>
+<td>2961</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>3133</td></tr>
+<td>3137</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>3135</td></tr>
+<td>3139</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>3247</td></tr>
+<td>3251</td></tr>
 <tr class="b">
 <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>3277</td></tr>
+<td>3281</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>3289</td></tr>
+<td>3293</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>3318</td></tr></table></div>
+<td>3322</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">
@@ -75963,7 +75963,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 b3c7eee..496c127 100644
--- a/coc.html
+++ b/coc.html
@@ -241,7 +241,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 1d89cf2..619a842 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -313,7 +313,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 6382ff3..a75b89a 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -824,7 +824,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 d259e8f..f9c4b4e 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -194,7 +194,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 1ba11b8..fda194e 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -1019,7 +1019,7 @@
         <div class="row">
             <p>Copyright &copy;2007&#x2013;2020
 <a href="https://www.apache.org/">The Apache Software Foundation</a>.
-All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-14</li>
+All rights reserved.        <li id="publishDate" class="pull-right">Last Published: 2020-10-15</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 a75e69d..6b6f475 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -2957,12 +2957,10 @@
 <div class="block">Called when the procedure is ready to be added to the queue after
  the loading/replay operation.</div>
 </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll(WAL)</a></span> - Method in class org.apache.hadoop.hbase.master.region.<a href="org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionWALRoller</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive(Path, Path)</a></span> - Method in class org.apache.hadoop.hbase.master.region.<a href="org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionWALRoller</a></dt>
+<dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive(Path, Path)</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a></dt>
 <dd>&nbsp;</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll(WAL)</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a></dt>
-<dd>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
-</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/CacheStats.html#ageAtEviction">ageAtEviction</a></span> - Variable in class org.apache.hadoop.hbase.io.hfile.<a href="org/apache/hadoop/hbase/io/hfile/CacheStats.html" title="class in org.apache.hadoop.hbase.io.hfile">CacheStats</a></dt>
 <dd>
 <div class="block">Keep running age at eviction time</div>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html b/devapidocs/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
index f62de6e..174eca4 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
@@ -136,7 +136,7 @@
 </dl>
 <hr>
 <br>
-<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2852">HMaster.MasterStoppedException</a>
+<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2856">HMaster.MasterStoppedException</a>
 extends <a href="../../../../../org/apache/hadoop/hbase/DoNotRetryIOException.html" title="class in org.apache.hadoop.hbase">DoNotRetryIOException</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -205,7 +205,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/DoNotRetryIOException.ht
 <ul class="blockListLast">
 <li class="blockList">
 <h4>MasterStoppedException</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html#line.2853">MasterStoppedException</a>()</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html#line.2857">MasterStoppedException</a>()</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html b/devapidocs/org/apache/hadoop/hbase/master/HMaster.TableDescriptorGetter.html
index 916ecfd..d90ee0c 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.2320">HMaster.TableDescriptorGetter</a></pre>
+<pre>protected static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2324">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.2321">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.2325">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 cd855f2..3941f9b 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/HMaster.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/HMaster.html
@@ -2567,7 +2567,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>waitForMetaOnline</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1225">waitForMetaOnline</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1227">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>
@@ -2582,7 +2582,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1233">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.1235">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
@@ -2596,7 +2596,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1268">waitForNamespaceOnline</a>()
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1270">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/>
@@ -2617,7 +2617,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>updateConfigurationForQuotasObserver</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1296">updateConfigurationForQuotasObserver</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1298">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>
@@ -2628,7 +2628,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1313">initMobCleaner</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1315">initMobCleaner</a>()</pre>
 </li>
 </ul>
 <a name="createServerManager-org.apache.hadoop.hbase.master.MasterServices-">
@@ -2637,7 +2637,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>createServerManager</h4>
-<pre>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.1329">createServerManager</a>(<a href="../../../../../org/apache/hadoop/hbase/master/MasterServices.html" title="interface in org.apache.hadoop.hbase.master">MasterServices</a>&nbsp;master)
+<pre>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.1331">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.
@@ -2657,7 +2657,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1336">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.1338">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>
@@ -2673,7 +2673,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>initClusterSchemaService</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1343">initClusterSchemaService</a>()
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1345">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>
@@ -2689,7 +2689,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1355">initQuotaManager</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1357">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>
@@ -2703,7 +2703,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1361">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.1363">createQuotaSnapshotNotifier</a>()</pre>
 </li>
 </ul>
 <a name="isCatalogJanitorEnabled--">
@@ -2712,7 +2712,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>isCatalogJanitorEnabled</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1367">isCatalogJanitorEnabled</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1369">isCatalogJanitorEnabled</a>()</pre>
 </li>
 </ul>
 <a name="isCleanerChoreEnabled--">
@@ -2721,7 +2721,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>isCleanerChoreEnabled</h4>
-<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1371">isCleanerChoreEnabled</a>()</pre>
+<pre>boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1373">isCleanerChoreEnabled</a>()</pre>
 </li>
 </ul>
 <a name="getServerManager--">
@@ -2730,7 +2730,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1386">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.1388">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>
@@ -2745,7 +2745,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1391">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.1393">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>
@@ -2760,7 +2760,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1396">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.1398">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>
@@ -2775,7 +2775,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1401">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.1403">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>
@@ -2790,7 +2790,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1406">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.1408">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>
@@ -2805,7 +2805,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1417">startServiceThreads</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1419">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>
@@ -2819,7 +2819,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1496">stopServiceThreads</a>()</pre>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1498">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>
@@ -2835,7 +2835,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1554">createProcedureExecutor</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1556">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>
@@ -2849,7 +2849,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>startProcedureExecutor</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1585">startProcedureExecutor</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1587">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>
@@ -2863,7 +2863,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>switchSnapshotCleanup</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1594">switchSnapshotCleanup</a>(boolean&nbsp;on,
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1596">switchSnapshotCleanup</a>(boolean&nbsp;on,
                            boolean&nbsp;synchronous)</pre>
 <div class="block">Turn on/off Snapshot Cleanup Chore</div>
 <dl>
@@ -2878,7 +2878,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1604">switchSnapshotCleanup</a>(boolean&nbsp;on)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1606">switchSnapshotCleanup</a>(boolean&nbsp;on)</pre>
 </li>
 </ul>
 <a name="stopProcedureExecutor--">
@@ -2887,7 +2887,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1620">stopProcedureExecutor</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1622">stopProcedureExecutor</a>()</pre>
 </li>
 </ul>
 <a name="stopChores--">
@@ -2896,7 +2896,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1635">stopChores</a>()</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1637">stopChores</a>()</pre>
 </li>
 </ul>
 <a name="getRemoteInetAddress-int-long-">
@@ -2905,7 +2905,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1658">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.1662">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>
@@ -2922,7 +2922,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1678">getMaxBalancingTime</a>()</pre>
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1682">getMaxBalancingTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>Maximum time we should run balancer for</dd>
@@ -2935,7 +2935,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1689">getMaxRegionsInTransition</a>()</pre>
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1693">getMaxRegionsInTransition</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>Maximum number of regions in transition</dd>
@@ -2948,7 +2948,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1701">balanceThrottling</a>(long&nbsp;nextBalanceStartTime,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1705">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
@@ -2967,7 +2967,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>balance</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1732">balance</a>()
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1736">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>
@@ -2981,7 +2981,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1742">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.1746">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>
@@ -2999,7 +2999,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>balance</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1759">balance</a>(boolean&nbsp;force)
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1763">balance</a>(boolean&nbsp;force)
                 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>
@@ -3013,7 +3013,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1842">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.1846">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>
@@ -3031,7 +3031,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1888">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.1892">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>
@@ -3046,7 +3046,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1893">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.1897">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>
@@ -3071,7 +3071,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1925">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.1929">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>
@@ -3086,7 +3086,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1936">setCatalogJanitorEnabled</a>(boolean&nbsp;b)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.1940">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>
@@ -3102,7 +3102,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1941">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.1945">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)
@@ -3130,7 +3130,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.1976">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.1980">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)
@@ -3158,7 +3158,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2005">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.2009">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>
@@ -3168,7 +3168,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>move</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2018">move</a>(byte[]&nbsp;encodedRegionName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2022">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>
@@ -3183,7 +3183,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2110">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.2114">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)
@@ -3208,7 +3208,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2152">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.2156">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>
@@ -3229,7 +3229,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2175">startActiveMasterManager</a>(int&nbsp;infoPort)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2179">startActiveMasterManager</a>(int&nbsp;infoPort)
                                throws org.apache.zookeeper.KeeperException</pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -3243,7 +3243,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2228">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.2232">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-">
@@ -3252,7 +3252,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2233">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.2237">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>
@@ -3274,7 +3274,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2267">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.2271">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)
@@ -3298,7 +3298,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2297">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.2301">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)
@@ -3322,7 +3322,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2325">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.2329">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)
@@ -3346,7 +3346,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2345">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.2349">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)
@@ -3370,7 +3370,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2370">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.2374">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>
@@ -3392,7 +3392,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2425">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.2429">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>
@@ -3414,7 +3414,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2460">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.2464">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,
@@ -3432,7 +3432,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2497">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.2501">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)
@@ -3456,7 +3456,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2509">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.2513">restoreSnapshot</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription&nbsp;snapshotDesc,
                             long&nbsp;nonceGroup,
                             long&nbsp;nonce,
                             boolean&nbsp;restoreAcl)
@@ -3473,7 +3473,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2533">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.2537">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>
@@ -3489,7 +3489,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2541">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.2545">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>
@@ -3513,7 +3513,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2553">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.2557">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>
@@ -3527,7 +3527,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2557">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.2561">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>
@@ -3541,7 +3541,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2643">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.2647">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>
@@ -3557,7 +3557,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2647">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.2651">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>
@@ -3571,7 +3571,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>getBackupMasters</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/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.2658">getBackupMasters</a>()</pre>
+<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/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.2662">getBackupMasters</a>()</pre>
 </li>
 </ul>
 <a name="getLoadedCoprocessors--">
@@ -3580,7 +3580,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2668">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.2672">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>
@@ -3596,7 +3596,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2675">getMasterStartTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2679">getMasterStartTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster was started.</dd>
@@ -3609,7 +3609,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2682">getMasterActiveTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2686">getMasterActiveTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster became the active master.</dd>
@@ -3622,7 +3622,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2689">getMasterFinishedInitializationTime</a>()</pre>
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2693">getMasterFinishedInitializationTime</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>timestamp in millis when HMaster finished becoming the active master</dd>
@@ -3635,7 +3635,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2693">getNumWALFiles</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2697">getNumWALFiles</a>()</pre>
 </li>
 </ul>
 <a name="getProcedureStore--">
@@ -3644,7 +3644,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2697">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.2701">getProcedureStore</a>()</pre>
 </li>
 </ul>
 <a name="getRegionServerInfoPort-org.apache.hadoop.hbase.ServerName-">
@@ -3653,7 +3653,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2701">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.2705">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-">
@@ -3662,7 +3662,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2708">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.2712">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>
@@ -3675,7 +3675,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2715">checkIfShouldMoveSystemRegionAsync</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2719">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
@@ -3692,7 +3692,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2722">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.2726">getMasterCoprocessors</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>array of coprocessor SimpleNames.</dd>
@@ -3705,7 +3705,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2728">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.2732">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
@@ -3728,7 +3728,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2753">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.2757">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>
@@ -3745,7 +3745,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2758">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.2762">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>
@@ -3760,7 +3760,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2763">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.2767">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>
@@ -3775,7 +3775,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2768">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.2772">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>
@@ -3790,7 +3790,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2773">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.2777">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>
@@ -3807,7 +3807,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2778">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.2782">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>
@@ -3822,7 +3822,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2783">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.2787">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>
@@ -3837,7 +3837,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2787">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.2791">getRegionServerFatalLogBuffer</a>()</pre>
 </li>
 </ul>
 <a name="shutdown--">
@@ -3846,7 +3846,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2795">shutdown</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2799">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>
@@ -3862,7 +3862,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2828">stopMaster</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2832">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>
@@ -3876,7 +3876,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2836">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.2840">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>
@@ -3896,7 +3896,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>checkServiceStarted</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2846">checkServiceStarted</a>()
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2850">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>
@@ -3910,7 +3910,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>checkInitialized</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2858">checkInitialized</a>()
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2862">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>,
@@ -3930,7 +3930,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2878">isActiveMaster</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2882">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.
 
@@ -3949,7 +3949,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2892">isInitialized</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2896">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.
@@ -3969,7 +3969,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2902">isInMaintenanceMode</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2906">isInMaintenanceMode</a>()</pre>
 <div class="block">Report whether this master is in maintenance mode.</div>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -3985,7 +3985,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>setInitialized</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2907">setInitialized</a>(boolean&nbsp;isInitialized)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2911">setInitialized</a>(boolean&nbsp;isInitialized)</pre>
 </li>
 </ul>
 <a name="getInitializedEvent--">
@@ -3994,7 +3994,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2912">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.2916">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>
@@ -4009,7 +4009,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2922">getAverageLoad</a>()</pre>
+<pre>public&nbsp;double&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.2926">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>
@@ -4025,7 +4025,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2935">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.2939">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>
@@ -4049,7 +4049,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2960">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.2964">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>
@@ -4066,7 +4066,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2979">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.2983">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>
@@ -4079,7 +4079,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2985">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.2989">getHFileCleaner</a>()</pre>
 </li>
 </ul>
 <a name="getLogCleaner--">
@@ -4088,7 +4088,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2989">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.2993">getLogCleaner</a>()</pre>
 </li>
 </ul>
 <a name="getSnapshotManager--">
@@ -4097,7 +4097,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.2997">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.3001">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>
@@ -4112,7 +4112,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3005">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.3009">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>
@@ -4127,7 +4127,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3010">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.3014">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>
@@ -4142,7 +4142,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>createNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3022">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.3026">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>
@@ -4166,7 +4166,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>modifyNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3058">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.3062">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>
@@ -4189,7 +4189,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteNamespace</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3096">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.3100">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>
@@ -4212,7 +4212,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3131">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.3135">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>
@@ -4231,7 +4231,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3143">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.3147">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>
@@ -4248,7 +4248,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3160">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.3164">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>
@@ -4265,7 +4265,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3176">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.3180">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>
@@ -4287,7 +4287,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3182">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.3186">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>
@@ -4309,7 +4309,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3188">abortProcedure</a>(long&nbsp;procId,
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3192">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>
@@ -4333,7 +4333,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3204">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.3208">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>
@@ -4353,7 +4353,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3220">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.3224">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>
@@ -4373,7 +4373,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3245">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.3249">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)
@@ -4398,7 +4398,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3266">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.3270">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>
@@ -4421,7 +4421,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3286">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.3290">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,
@@ -4442,7 +4442,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3327">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.3331">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>
@@ -4458,7 +4458,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3345">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.3349">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>
@@ -4479,7 +4479,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3351">getLastMajorCompactionTimestampForRegion</a>(byte[]&nbsp;regionName)
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3355">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>
@@ -4498,7 +4498,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3365">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.3369">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
@@ -4518,7 +4518,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3373">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.3377">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>
@@ -4532,7 +4532,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3390">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.3394">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>
@@ -4546,7 +4546,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3416">isBalancerOn</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3420">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>
@@ -4563,7 +4563,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3426">isNormalizerOn</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3430">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>
@@ -4574,7 +4574,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3438">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.3442">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>
@@ -4593,7 +4593,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3451">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.3455">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
@@ -4610,7 +4610,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3456">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.3460">getSplitOrMergeTracker</a>()</pre>
 </li>
 </ul>
 <a name="getLoadBalancer--">
@@ -4619,7 +4619,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3461">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.3465">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>
@@ -4634,7 +4634,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3466">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.3470">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>
@@ -4649,7 +4649,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3470">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.3474">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>
@@ -4663,7 +4663,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3477">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.3481">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>,
@@ -4689,7 +4689,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3485">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.3489">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>
@@ -4711,7 +4711,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3491">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.3495">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>
@@ -4733,7 +4733,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3497">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.3501">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>
@@ -4755,7 +4755,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3503">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.3507">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>
@@ -4779,7 +4779,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3518">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.3522">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>
@@ -4803,7 +4803,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3526">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.3530">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>
@@ -4827,7 +4827,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3542">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.3546">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>
@@ -4851,7 +4851,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3556">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.3560">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
@@ -4870,7 +4870,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3595">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.3599">listDecommissionedRegionServers</a>()</pre>
 <div class="block">List region servers marked as decommissioned (previously called 'draining') to not get regions
  assigned to them.</div>
 <dl>
@@ -4885,7 +4885,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3604">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.3608">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
@@ -4904,7 +4904,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3643">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.3647">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>
@@ -4919,7 +4919,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3647">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.3651">getQuotaObserverChore</a>()</pre>
 </li>
 </ul>
 <a name="getSpaceQuotaSnapshotNotifier--">
@@ -4928,7 +4928,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3651">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.3655">getSpaceQuotaSnapshotNotifier</a>()</pre>
 </li>
 </ul>
 <a name="getRemoteProcedure-long-">
@@ -4937,7 +4937,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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-">
@@ -4946,7 +4946,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3665">remoteProcedureCompleted</a>(long&nbsp;procId)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3669">remoteProcedureCompleted</a>(long&nbsp;procId)</pre>
 </li>
 </ul>
 <a name="remoteProcedureFailed-long-org.apache.hadoop.hbase.procedure2.RemoteProcedureException-">
@@ -4955,7 +4955,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3673">remoteProcedureFailed</a>(long&nbsp;procId,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3677">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>
@@ -4965,7 +4965,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>reopenRegions</h4>
-<pre>long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3692">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.3696">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)
@@ -4991,7 +4991,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3714">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.3718">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>
@@ -5006,7 +5006,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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-">
@@ -5015,7 +5015,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>decorateMasterConfiguration</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3748">decorateMasterConfiguration</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3752">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>
@@ -5025,7 +5025,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3763">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.3767">getSnapshotQuotaObserverChore</a>()</pre>
 </li>
 </ul>
 <a name="getSyncReplicationReplayWALManager--">
@@ -5034,7 +5034,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3768">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.3772">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>
@@ -5049,7 +5049,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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>
@@ -5062,7 +5062,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3780">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.3784">getHbckChore</a>()</pre>
 </li>
 </ul>
 <a name="getClusterId--">
@@ -5071,7 +5071,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3785">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.3789">getClusterId</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegionServer.html#getClusterId--">getClusterId</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>
@@ -5084,7 +5084,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3792">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.3796">getActiveMaster</a>()</pre>
 </li>
 </ul>
 <a name="runReplicationBarrierCleaner--">
@@ -5093,7 +5093,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3797">runReplicationBarrierCleaner</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3801">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>
@@ -5108,7 +5108,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockList">
 <li class="blockList">
 <h4>getMetaRegionLocationCache</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetaRegionLocationCache.html" title="class in org.apache.hadoop.hbase.master">MetaRegionLocationCache</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3804">getMetaRegionLocationCache</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/master/MetaRegionLocationCache.html" title="class in org.apache.hadoop.hbase.master">MetaRegionLocationCache</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/master/HMaster.html#line.3808">getMetaRegionLocationCache</a>()</pre>
 </li>
 </ul>
 <a name="getRSGroupInfoManager--">
@@ -5117,7 +5117,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <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.3809">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.3813">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>
@@ -5132,7 +5132,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/master/MasterServices
 <ul class="blockListLast">
 <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.3819">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.3823">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>
diff --git a/devapidocs/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html b/devapidocs/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html
index a5a0732..67ee4b5 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html
@@ -124,7 +124,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public final class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.47">MasterRegionWALRoller</a>
+public final class <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.46">MasterRegionWALRoller</a>
 extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&gt;</pre>
 <div class="block">As long as there is no RegionServerServices for a master local region, we need implement log
  roller logic by our own.
@@ -252,9 +252,8 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 </tr>
 <tr id="i0" class="altColor">
 <td class="colFirst"><code>protected void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
-</td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive</a></span>(org.apache.hadoop.fs.Path&nbsp;oldPath,
+               org.apache.hadoop.fs.Path&nbsp;newPath)</code>&nbsp;</td>
 </tr>
 <tr id="i1" class="rowColor">
 <td class="colFirst"><code>(package private) static <a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionWALRoller</a></code></td>
@@ -319,7 +318,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <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/region/MasterRegionWALRoller.html#line.49">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.48">LOG</a></pre>
 </li>
 </ul>
 <a name="flusherAndCompactor">
@@ -328,7 +327,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>flusherAndCompactor</h4>
-<pre>private volatile&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionFlusherAndCompactor.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionFlusherAndCompactor</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.51">flusherAndCompactor</a></pre>
+<pre>private volatile&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionFlusherAndCompactor.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionFlusherAndCompactor</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.50">flusherAndCompactor</a></pre>
 </li>
 </ul>
 <a name="fs">
@@ -337,7 +336,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>fs</h4>
-<pre>private final&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.53">fs</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.fs.FileSystem <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.52">fs</a></pre>
 </li>
 </ul>
 <a name="walArchiveDir">
@@ -346,7 +345,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>walArchiveDir</h4>
-<pre>private final&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.55">walArchiveDir</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.54">walArchiveDir</a></pre>
 </li>
 </ul>
 <a name="globalWALArchiveDir">
@@ -355,7 +354,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>globalWALArchiveDir</h4>
-<pre>private final&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.57">globalWALArchiveDir</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.fs.Path <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.56">globalWALArchiveDir</a></pre>
 </li>
 </ul>
 <a name="archivedWALSuffix">
@@ -364,7 +363,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockListLast">
 <li class="blockList">
 <h4>archivedWALSuffix</h4>
-<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.59">archivedWALSuffix</a></pre>
+<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.58">archivedWALSuffix</a></pre>
 </li>
 </ul>
 </li>
@@ -381,7 +380,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockListLast">
 <li class="blockList">
 <h4>MasterRegionWALRoller</h4>
-<pre>private&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.61">MasterRegionWALRoller</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>private&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.60">MasterRegionWALRoller</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,
                               org.apache.hadoop.conf.Configuration&nbsp;conf,
                               <a href="../../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&nbsp;abortable,
                               org.apache.hadoop.fs.FileSystem&nbsp;fs,
@@ -398,18 +397,17 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <!--   -->
 </a>
 <h3>Method Detail</h3>
-<a name="afterRoll-org.apache.hadoop.hbase.wal.WAL-">
+<a name="afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
-<h4>afterRoll</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.71">afterRoll</a>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from class:&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">AbstractWALRoller</a></code></span></div>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
+<h4>afterWALArchive</h4>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.70">afterWALArchive</a>(org.apache.hadoop.fs.Path&nbsp;oldPath,
+                               org.apache.hadoop.fs.Path&nbsp;newPath)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
-<dd><code><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&gt;</code></dd>
+<dd><code><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive</a></code>&nbsp;in class&nbsp;<code><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a>&lt;<a href="../../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&gt;</co [...]
 </dl>
 </li>
 </ul>
@@ -419,7 +417,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>scheduleFlush</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.83">scheduleFlush</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;encodedRegionName,
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.85">scheduleFlush</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;encodedRegionName,
                              <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;families)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -436,7 +434,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockList">
 <li class="blockList">
 <h4>setFlusherAndCompactor</h4>
-<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.90">setFlusherAndCompactor</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionFlusherAndCompactor.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionFlusherAndCompactor</a>&nbsp;flusherAndCompactor)</pre>
+<pre>void&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.92">setFlusherAndCompactor</a>(<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionFlusherAndCompactor.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionFlusherAndCompactor</a>&nbsp;flusherAndCompactor)</pre>
 </li>
 </ul>
 <a name="create-java.lang.String-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.Abortable-org.apache.hadoop.fs.FileSystem-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-java.lang.String-long-long-">
@@ -445,7 +443,7 @@ extends <a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller
 <ul class="blockListLast">
 <li class="blockList">
 <h4>create</h4>
-<pre>static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionWALRoller</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.94">create</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>static&nbsp;<a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html" title="class in org.apache.hadoop.hbase.master.region">MasterRegionWALRoller</a>&nbsp;<a href="../../../../../../src-html/org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#line.96">create</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,
                                     org.apache.hadoop.conf.Configuration&nbsp;conf,
                                     <a href="../../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&nbsp;abortable,
                                     org.apache.hadoop.fs.FileSystem&nbsp;fs,
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/LogRoller.html b/devapidocs/org/apache/hadoop/hbase/regionserver/LogRoller.html
index c0bbaa0..d37807d 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/LogRoller.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/LogRoller.html
@@ -238,7 +238,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.ht
 <!--   -->
 </a>
 <h3>Methods inherited from class&nbsp;org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller</a></h3>
-<code><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#addWAL-org.apache.hadoop.hbase.wal.WAL-">addWAL</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#close--">close</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#requestRollAll--">requestRollAll</a>, <a href="../../. [...]
+<code><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#addWAL-org.apache.hadoop.hbase.wal.WAL-">addWAL</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#close--">close</a>, <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#requestRollAll--">requ [...]
 </ul>
 <ul class="blockList">
 <li class="blockList"><a name="methods.inherited.from.class.java.lang.Thread">
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html b/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html
index 68ff8c3..52cae36 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html
@@ -113,7 +113,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>protected class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.254">AbstractWALRoller.RollController</a>
+<pre>protected class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.256">AbstractWALRoller.RollController</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
 <div class="block">Independently control the roll of each wal. When use multiwal,
  can avoid all wal roll together. see HBASE-24665 for detail</div>
@@ -227,7 +227,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>wal</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.255">wal</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.257">wal</a></pre>
 </li>
 </ul>
 <a name="rollRequest">
@@ -236,7 +236,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>rollRequest</h4>
-<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.256">rollRequest</a></pre>
+<pre>private final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.258">rollRequest</a></pre>
 </li>
 </ul>
 <a name="lastRollTime">
@@ -245,7 +245,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>lastRollTime</h4>
-<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.257">lastRollTime</a></pre>
+<pre>private&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.259">lastRollTime</a></pre>
 </li>
 </ul>
 </li>
@@ -262,7 +262,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>RollController</h4>
-<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.259">RollController</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
+<pre><a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.261">RollController</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
 </li>
 </ul>
 </li>
@@ -279,7 +279,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>requestRoll</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.265">requestRoll</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.267">requestRoll</a>()</pre>
 </li>
 </ul>
 <a name="rollWal-long-">
@@ -288,7 +288,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>rollWal</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;byte[],<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;&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.269">rollWal</a>(long&nbsp;now)
+<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;byte[],<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;&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.271">rollWal</a>(long&nbsp;now)
                                  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>
@@ -302,7 +302,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>isRollRequested</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.276">isRollRequested</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.278">isRollRequested</a>()</pre>
 </li>
 </ul>
 <a name="needsPeriodicRoll-long-">
@@ -311,7 +311,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>needsPeriodicRoll</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.280">needsPeriodicRoll</a>(long&nbsp;now)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.282">needsPeriodicRoll</a>(long&nbsp;now)</pre>
 </li>
 </ul>
 <a name="needsRoll-long-">
@@ -320,7 +320,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>needsRoll</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.284">needsRoll</a>(long&nbsp;now)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html#line.286">needsRoll</a>(long&nbsp;now)</pre>
 </li>
 </ul>
 </li>
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.html b/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.html
index 6dfbd00..0c37b68 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/AbstractWALRoller.html
@@ -123,7 +123,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public abstract class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.55">AbstractWALRoller</a>&lt;T extends <a href="../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&gt;
+public abstract class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.56">AbstractWALRoller</a>&lt;T extends <a href="../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a>&gt;
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Thread.html?is-external=true" title="class or interface in java.lang">Thread</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.html?is-external=true" title="class or interface in java.io">Closeable</a></pre>
 <div class="block">Runs periodically to determine if the WAL should be rolled.
@@ -267,9 +267,8 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 </tr>
 <tr id="i2" class="altColor">
 <td class="colFirst"><code>protected void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a></span>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
-</td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">afterWALArchive</a></span>(org.apache.hadoop.fs.Path&nbsp;oldPath,
+               org.apache.hadoop.fs.Path&nbsp;newPath)</code>&nbsp;</td>
 </tr>
 <tr id="i3" class="rowColor">
 <td class="colFirst"><code>private void</code></td>
@@ -343,7 +342,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.57">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.58">LOG</a></pre>
 </li>
 </ul>
 <a name="WAL_ROLL_PERIOD_KEY">
@@ -352,7 +351,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>WAL_ROLL_PERIOD_KEY</h4>
-<pre>protected 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/wal/AbstractWALRoller.html#line.59">WAL_ROLL_PERIOD_KEY</a></pre>
+<pre>protected 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/wal/AbstractWALRoller.html#line.60">WAL_ROLL_PERIOD_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.wal.AbstractWALRoller.WAL_ROLL_PERIOD_KEY">Constant Field Values</a></dd>
@@ -365,7 +364,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>wals</h4>
-<pre>protected final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ConcurrentMap.html?is-external=true" title="class or interface in java.util.concurrent">ConcurrentMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>,<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller.RollControll [...]
+<pre>protected final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ConcurrentMap.html?is-external=true" title="class or interface in java.util.concurrent">ConcurrentMap</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>,<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.RollController.html" title="class in org.apache.hadoop.hbase.wal">AbstractWALRoller.RollControll [...]
 </li>
 </ul>
 <a name="abortable">
@@ -374,7 +373,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>abortable</h4>
-<pre>protected final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="type parameter in AbstractWALRoller">T</a> extends <a href="../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.62">abortable</a></pre>
+<pre>protected final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="type parameter in AbstractWALRoller">T</a> extends <a href="../../../../../org/apache/hadoop/hbase/Abortable.html" title="interface in org.apache.hadoop.hbase">Abortable</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.63">abortable</a></pre>
 </li>
 </ul>
 <a name="rollPeriod">
@@ -383,7 +382,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>rollPeriod</h4>
-<pre>private final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.64">rollPeriod</a></pre>
+<pre>private final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.65">rollPeriod</a></pre>
 </li>
 </ul>
 <a name="threadWakeFrequency">
@@ -392,7 +391,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>threadWakeFrequency</h4>
-<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.65">threadWakeFrequency</a></pre>
+<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.66">threadWakeFrequency</a></pre>
 </li>
 </ul>
 <a name="checkLowReplicationInterval">
@@ -401,7 +400,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkLowReplicationInterval</h4>
-<pre>private final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.67">checkLowReplicationInterval</a></pre>
+<pre>private final&nbsp;long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.68">checkLowReplicationInterval</a></pre>
 </li>
 </ul>
 <a name="running">
@@ -410,7 +409,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>running</h4>
-<pre>private volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.69">running</a></pre>
+<pre>private volatile&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.70">running</a></pre>
 </li>
 </ul>
 </li>
@@ -429,7 +428,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>AbstractWALRoller</h4>
-<pre>protected&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.103">AbstractWALRoller</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>protected&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.109">AbstractWALRoller</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,
                             org.apache.hadoop.conf.Configuration&nbsp;conf,
                             <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html" title="type parameter in AbstractWALRoller">T</a>&nbsp;abortable)</pre>
 </li>
@@ -448,7 +447,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>addWAL</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.71">addWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.72">addWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
 </li>
 </ul>
 <a name="requestRollAll--">
@@ -457,7 +456,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>requestRollAll</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.94">requestRollAll</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.100">requestRollAll</a>()</pre>
 </li>
 </ul>
 <a name="checkLowReplication-long-">
@@ -466,7 +465,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>checkLowReplication</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.115">checkLowReplication</a>(long&nbsp;now)</pre>
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.121">checkLowReplication</a>(long&nbsp;now)</pre>
 <div class="block">we need to check low replication in period, see HBASE-18132</div>
 </li>
 </ul>
@@ -476,7 +475,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>abort</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.130">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>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.136">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>
 </li>
 </ul>
@@ -486,7 +485,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>run</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.148">run</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.154">run</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable.html?is-external=true#run--" title="class or interface in java.lang">run</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable.html?is-external=true" title="class or interface in java.lang">Runnable</a></code></dd>
@@ -495,14 +494,14 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 </dl>
 </li>
 </ul>
-<a name="afterRoll-org.apache.hadoop.hbase.wal.WAL-">
+<a name="afterWALArchive-org.apache.hadoop.fs.Path-org.apache.hadoop.fs.Path-">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
-<h4>afterRoll</h4>
-<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.212">afterRoll</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</pre>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
+<h4>afterWALArchive</h4>
+<pre>protected&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.214">afterWALArchive</a>(org.apache.hadoop.fs.Path&nbsp;oldPath,
+                               org.apache.hadoop.fs.Path&nbsp;newPath)</pre>
 </li>
 </ul>
 <a name="scheduleFlush-java.lang.String-java.util.List-">
@@ -511,7 +510,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>scheduleFlush</h4>
-<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.219">scheduleFlush</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;encodedRegionName,
+<pre>protected abstract&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.221">scheduleFlush</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;encodedRegionName,
                                       <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;families)</pre>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -526,7 +525,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>isWaiting</h4>
-<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.221">isWaiting</a>()</pre>
+<pre>private&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.223">isWaiting</a>()</pre>
 </li>
 </ul>
 <a name="walRollFinished--">
@@ -535,7 +534,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>walRollFinished</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.229">walRollFinished</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.231">walRollFinished</a>()</pre>
 <dl>
 <dt><span class="returnLabel">Returns:</span></dt>
 <dd>true if all WAL roll finished</dd>
@@ -548,7 +547,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockList">
 <li class="blockList">
 <h4>waitUntilWalRollFinished</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.238">waitUntilWalRollFinished</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.240">waitUntilWalRollFinished</a>()
                               throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a></pre>
 <div class="block">Wait until all wals have been rolled after calling <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#requestRollAll--"><code>requestRollAll()</code></a>.</div>
 <dl>
@@ -563,7 +562,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.
 <ul class="blockListLast">
 <li class="blockList">
 <h4>close</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.245">close</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractWALRoller.html#line.247">close</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.html?is-external=true#close--" title="class or interface in java.io">close</a></code>&nbsp;in interface&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/io/Closeable.html?is-external=true" title="class or interface in java.io">Closeable</a></code></dd>
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/class-use/WAL.html b/devapidocs/org/apache/hadoop/hbase/wal/class-use/WAL.html
index 9b7a87b..29d5a01 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/class-use/WAL.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/class-use/WAL.html
@@ -149,19 +149,6 @@
 </tr>
 </tbody>
 </table>
-<table class="useSummary" border="0" cellpadding="3" cellspacing="0" summary="Use table, listing methods, and an explanation">
-<caption><span>Methods in <a href="../../../../../../org/apache/hadoop/hbase/master/region/package-summary.html">org.apache.hadoop.hbase.master.region</a> with parameters of type <a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a></span><span class="tabEnd">&nbsp;</span></caption>
-<tr>
-<th class="colFirst" scope="col">Modifier and Type</th>
-<th class="colLast" scope="col">Method and Description</th>
-</tr>
-<tbody>
-<tr class="altColor">
-<td class="colFirst"><code>protected void</code></td>
-<td class="colLast"><span class="typeNameLabel">MasterRegionWALRoller.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/master/region/MasterRegionWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>&nbsp;</td>
-</tr>
-</tbody>
-</table>
 </li>
 <li class="blockList"><a name="org.apache.hadoop.hbase.regionserver">
 <!--   -->
@@ -743,42 +730,36 @@
 <td class="colLast"><span class="typeNameLabel">AbstractWALRoller.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#addWAL-org.apache.hadoop.hbase.wal.WAL-">addWAL</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>&nbsp;</td>
 </tr>
 <tr class="rowColor">
-<td class="colFirst"><code>protected void</code></td>
-<td class="colLast"><span class="typeNameLabel">AbstractWALRoller.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractWALRoller.html#afterRoll-org.apache.hadoop.hbase.wal.WAL-">afterRoll</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
-<div class="block">Called after we finish rolling the give <code>wal</code>.</div>
-</td>
-</tr>
-<tr class="altColor">
 <td class="colFirst"><code>static long</code></td>
 <td class="colLast"><span class="typeNameLabel">AbstractFSWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#extractFileNumFromWAL-org.apache.hadoop.hbase.wal.WAL-">extractFileNumFromWAL</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
 <div class="block">It returns the file create timestamp (the 'FileNum') from the file name.</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>static org.apache.hadoop.fs.Path</code></td>
 <td class="colLast"><span class="typeNameLabel">AbstractFSWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#getCurrentFileName-org.apache.hadoop.hbase.wal.WAL-">getCurrentFileName</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
 <div class="block">return the current filename from the current wal.</div>
 </td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>static long</code></td>
 <td class="colLast"><span class="typeNameLabel">AbstractFSWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#getLogFileSize-org.apache.hadoop.hbase.wal.WAL-">getLogFileSize</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
 <div class="block">returns the size of rolled WAL files.</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>static int</code></td>
 <td class="colLast"><span class="typeNameLabel">AbstractFSWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#getNumRolledLogFiles-org.apache.hadoop.hbase.wal.WAL-">getNumRolledLogFiles</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
 <div class="block">returns the number of rolled WAL files.</div>
 </td>
 </tr>
-<tr class="altColor">
+<tr class="rowColor">
 <td class="colFirst"><code>(package private) static void</code></td>
 <td class="colLast"><span class="typeNameLabel">AbstractFSWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#requestLogRoll-org.apache.hadoop.hbase.wal.WAL-">requestLogRoll</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>
 <div class="block">request a log roll, but don't actually do it.</div>
 </td>
 </tr>
-<tr class="rowColor">
+<tr class="altColor">
 <td class="colFirst"><code>private void</code></td>
 <td class="colLast"><span class="typeNameLabel">SyncReplicationWALProvider.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/wal/SyncReplicationWALProvider.html#safeClose-org.apache.hadoop.hbase.wal.WAL-">safeClose</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>&nbsp;wal)</code>&nbsp;</td>
 </tr>
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.InitializationMonitor.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.InitializationMonitor.html
index 36df221..ed58524 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.InitializationMonitor.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.InitializationMonitor.html
@@ -1131,2736 +1131,2740 @@
 <span class="sourceLineNo">1123</span>    getChoreService().scheduleChore(clusterStatusChore);<a name="line.1123"></a>
 <span class="sourceLineNo">1124</span>    this.balancerChore = new BalancerChore(this);<a name="line.1124"></a>
 <span class="sourceLineNo">1125</span>    getChoreService().scheduleChore(balancerChore);<a name="line.1125"></a>
-<span class="sourceLineNo">1126</span>    getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1126"></a>
-<span class="sourceLineNo">1127</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1127"></a>
-<span class="sourceLineNo">1128</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1128"></a>
-<span class="sourceLineNo">1129</span>    this.hbckChore = new HbckChore(this);<a name="line.1129"></a>
-<span class="sourceLineNo">1130</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1130"></a>
-<span class="sourceLineNo">1131</span>    this.serverManager.startChore();<a name="line.1131"></a>
-<span class="sourceLineNo">1132</span><a name="line.1132"></a>
-<span class="sourceLineNo">1133</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1133"></a>
-<span class="sourceLineNo">1134</span>    if (!waitForNamespaceOnline()) {<a name="line.1134"></a>
-<span class="sourceLineNo">1135</span>      return;<a name="line.1135"></a>
-<span class="sourceLineNo">1136</span>    }<a name="line.1136"></a>
-<span class="sourceLineNo">1137</span>    status.setStatus("Starting cluster schema service");<a name="line.1137"></a>
-<span class="sourceLineNo">1138</span>    initClusterSchemaService();<a name="line.1138"></a>
-<span class="sourceLineNo">1139</span><a name="line.1139"></a>
-<span class="sourceLineNo">1140</span>    if (this.cpHost != null) {<a name="line.1140"></a>
-<span class="sourceLineNo">1141</span>      try {<a name="line.1141"></a>
-<span class="sourceLineNo">1142</span>        this.cpHost.preMasterInitialization();<a name="line.1142"></a>
-<span class="sourceLineNo">1143</span>      } catch (IOException e) {<a name="line.1143"></a>
-<span class="sourceLineNo">1144</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<a name="line.1144"></a>
-<span class="sourceLineNo">1145</span>      }<a name="line.1145"></a>
-<span class="sourceLineNo">1146</span>    }<a name="line.1146"></a>
-<span class="sourceLineNo">1147</span><a name="line.1147"></a>
-<span class="sourceLineNo">1148</span>    status.markComplete("Initialization successful");<a name="line.1148"></a>
-<span class="sourceLineNo">1149</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1149"></a>
-<span class="sourceLineNo">1150</span>       (System.currentTimeMillis() - masterActiveTime) / 1000.0f));<a name="line.1150"></a>
-<span class="sourceLineNo">1151</span>    this.masterFinishedInitializationTime = System.currentTimeMillis();<a name="line.1151"></a>
-<span class="sourceLineNo">1152</span>    configurationManager.registerObserver(this.balancer);<a name="line.1152"></a>
-<span class="sourceLineNo">1153</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1153"></a>
-<span class="sourceLineNo">1154</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1154"></a>
-<span class="sourceLineNo">1155</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1155"></a>
-<span class="sourceLineNo">1156</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1156"></a>
-<span class="sourceLineNo">1157</span>    // Set master as 'initialized'.<a name="line.1157"></a>
-<span class="sourceLineNo">1158</span>    setInitialized(true);<a name="line.1158"></a>
-<span class="sourceLineNo">1159</span><a name="line.1159"></a>
-<span class="sourceLineNo">1160</span>    if (maintenanceMode) {<a name="line.1160"></a>
-<span class="sourceLineNo">1161</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1161"></a>
-<span class="sourceLineNo">1162</span>      return;<a name="line.1162"></a>
-<span class="sourceLineNo">1163</span>    }<a name="line.1163"></a>
-<span class="sourceLineNo">1164</span><a name="line.1164"></a>
-<span class="sourceLineNo">1165</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1165"></a>
-<span class="sourceLineNo">1166</span>    status.setStatus("Starting quota manager");<a name="line.1166"></a>
-<span class="sourceLineNo">1167</span>    initQuotaManager();<a name="line.1167"></a>
-<span class="sourceLineNo">1168</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1168"></a>
-<span class="sourceLineNo">1169</span>      // Create the quota snapshot notifier<a name="line.1169"></a>
-<span class="sourceLineNo">1170</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1170"></a>
-<span class="sourceLineNo">1171</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1171"></a>
-<span class="sourceLineNo">1172</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1172"></a>
-<span class="sourceLineNo">1173</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1173"></a>
-<span class="sourceLineNo">1174</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1174"></a>
-<span class="sourceLineNo">1175</span><a name="line.1175"></a>
-<span class="sourceLineNo">1176</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1176"></a>
-<span class="sourceLineNo">1177</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1177"></a>
-<span class="sourceLineNo">1178</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1178"></a>
-<span class="sourceLineNo">1179</span>    }<a name="line.1179"></a>
-<span class="sourceLineNo">1180</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1180"></a>
-<span class="sourceLineNo">1181</span>    slowLogMasterService.init();<a name="line.1181"></a>
-<span class="sourceLineNo">1182</span><a name="line.1182"></a>
-<span class="sourceLineNo">1183</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1183"></a>
-<span class="sourceLineNo">1184</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1184"></a>
-<span class="sourceLineNo">1185</span>    // master initialization. See HBASE-5916.<a name="line.1185"></a>
-<span class="sourceLineNo">1186</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1186"></a>
-<span class="sourceLineNo">1187</span><a name="line.1187"></a>
-<span class="sourceLineNo">1188</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1188"></a>
-<span class="sourceLineNo">1189</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1189"></a>
-<span class="sourceLineNo">1190</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1190"></a>
-<span class="sourceLineNo">1191</span><a name="line.1191"></a>
-<span class="sourceLineNo">1192</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1192"></a>
-<span class="sourceLineNo">1193</span>    initMobCleaner();<a name="line.1193"></a>
-<span class="sourceLineNo">1194</span><a name="line.1194"></a>
-<span class="sourceLineNo">1195</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1195"></a>
-<span class="sourceLineNo">1196</span>    if (this.cpHost != null) {<a name="line.1196"></a>
-<span class="sourceLineNo">1197</span>      // don't let cp initialization errors kill the master<a name="line.1197"></a>
-<span class="sourceLineNo">1198</span>      try {<a name="line.1198"></a>
-<span class="sourceLineNo">1199</span>        this.cpHost.postStartMaster();<a name="line.1199"></a>
-<span class="sourceLineNo">1200</span>      } catch (IOException ioe) {<a name="line.1200"></a>
-<span class="sourceLineNo">1201</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1201"></a>
-<span class="sourceLineNo">1202</span>      }<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>    zombieDetector.interrupt();<a name="line.1205"></a>
+<span class="sourceLineNo">1126</span>    if (regionNormalizerManager != null) {<a name="line.1126"></a>
+<span class="sourceLineNo">1127</span>      getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1127"></a>
+<span class="sourceLineNo">1128</span>    }<a name="line.1128"></a>
+<span class="sourceLineNo">1129</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1129"></a>
+<span class="sourceLineNo">1130</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1130"></a>
+<span class="sourceLineNo">1131</span>    this.hbckChore = new HbckChore(this);<a name="line.1131"></a>
+<span class="sourceLineNo">1132</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1132"></a>
+<span class="sourceLineNo">1133</span>    this.serverManager.startChore();<a name="line.1133"></a>
+<span class="sourceLineNo">1134</span><a name="line.1134"></a>
+<span class="sourceLineNo">1135</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1135"></a>
+<span class="sourceLineNo">1136</span>    if (!waitForNamespaceOnline()) {<a name="line.1136"></a>
+<span class="sourceLineNo">1137</span>      return;<a name="line.1137"></a>
+<span class="sourceLineNo">1138</span>    }<a name="line.1138"></a>
+<span class="sourceLineNo">1139</span>    status.setStatus("Starting cluster schema service");<a name="line.1139"></a>
+<span class="sourceLineNo">1140</span>    initClusterSchemaService();<a name="line.1140"></a>
+<span class="sourceLineNo">1141</span><a name="line.1141"></a>
+<span class="sourceLineNo">1142</span>    if (this.cpHost != null) {<a name="line.1142"></a>
+<span class="sourceLineNo">1143</span>      try {<a name="line.1143"></a>
+<span class="sourceLineNo">1144</span>        this.cpHost.preMasterInitialization();<a name="line.1144"></a>
+<span class="sourceLineNo">1145</span>      } catch (IOException e) {<a name="line.1145"></a>
+<span class="sourceLineNo">1146</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<a name="line.1146"></a>
+<span class="sourceLineNo">1147</span>      }<a name="line.1147"></a>
+<span class="sourceLineNo">1148</span>    }<a name="line.1148"></a>
+<span class="sourceLineNo">1149</span><a name="line.1149"></a>
+<span class="sourceLineNo">1150</span>    status.markComplete("Initialization successful");<a name="line.1150"></a>
+<span class="sourceLineNo">1151</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1151"></a>
+<span class="sourceLineNo">1152</span>       (System.currentTimeMillis() - masterActiveTime) / 1000.0f));<a name="line.1152"></a>
+<span class="sourceLineNo">1153</span>    this.masterFinishedInitializationTime = System.currentTimeMillis();<a name="line.1153"></a>
+<span class="sourceLineNo">1154</span>    configurationManager.registerObserver(this.balancer);<a name="line.1154"></a>
+<span class="sourceLineNo">1155</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1155"></a>
+<span class="sourceLineNo">1156</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1156"></a>
+<span class="sourceLineNo">1157</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1157"></a>
+<span class="sourceLineNo">1158</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1158"></a>
+<span class="sourceLineNo">1159</span>    // Set master as 'initialized'.<a name="line.1159"></a>
+<span class="sourceLineNo">1160</span>    setInitialized(true);<a name="line.1160"></a>
+<span class="sourceLineNo">1161</span><a name="line.1161"></a>
+<span class="sourceLineNo">1162</span>    if (maintenanceMode) {<a name="line.1162"></a>
+<span class="sourceLineNo">1163</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1163"></a>
+<span class="sourceLineNo">1164</span>      return;<a name="line.1164"></a>
+<span class="sourceLineNo">1165</span>    }<a name="line.1165"></a>
+<span class="sourceLineNo">1166</span><a name="line.1166"></a>
+<span class="sourceLineNo">1167</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1167"></a>
+<span class="sourceLineNo">1168</span>    status.setStatus("Starting quota manager");<a name="line.1168"></a>
+<span class="sourceLineNo">1169</span>    initQuotaManager();<a name="line.1169"></a>
+<span class="sourceLineNo">1170</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1170"></a>
+<span class="sourceLineNo">1171</span>      // Create the quota snapshot notifier<a name="line.1171"></a>
+<span class="sourceLineNo">1172</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1172"></a>
+<span class="sourceLineNo">1173</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1173"></a>
+<span class="sourceLineNo">1174</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1174"></a>
+<span class="sourceLineNo">1175</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1175"></a>
+<span class="sourceLineNo">1176</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1176"></a>
+<span class="sourceLineNo">1177</span><a name="line.1177"></a>
+<span class="sourceLineNo">1178</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1178"></a>
+<span class="sourceLineNo">1179</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1179"></a>
+<span class="sourceLineNo">1180</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1180"></a>
+<span class="sourceLineNo">1181</span>    }<a name="line.1181"></a>
+<span class="sourceLineNo">1182</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1182"></a>
+<span class="sourceLineNo">1183</span>    slowLogMasterService.init();<a name="line.1183"></a>
+<span class="sourceLineNo">1184</span><a name="line.1184"></a>
+<span class="sourceLineNo">1185</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1185"></a>
+<span class="sourceLineNo">1186</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1186"></a>
+<span class="sourceLineNo">1187</span>    // master initialization. See HBASE-5916.<a name="line.1187"></a>
+<span class="sourceLineNo">1188</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1188"></a>
+<span class="sourceLineNo">1189</span><a name="line.1189"></a>
+<span class="sourceLineNo">1190</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1190"></a>
+<span class="sourceLineNo">1191</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1191"></a>
+<span class="sourceLineNo">1192</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1192"></a>
+<span class="sourceLineNo">1193</span><a name="line.1193"></a>
+<span class="sourceLineNo">1194</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1194"></a>
+<span class="sourceLineNo">1195</span>    initMobCleaner();<a name="line.1195"></a>
+<span class="sourceLineNo">1196</span><a name="line.1196"></a>
+<span class="sourceLineNo">1197</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1197"></a>
+<span class="sourceLineNo">1198</span>    if (this.cpHost != null) {<a name="line.1198"></a>
+<span class="sourceLineNo">1199</span>      // don't let cp initialization errors kill the master<a name="line.1199"></a>
+<span class="sourceLineNo">1200</span>      try {<a name="line.1200"></a>
+<span class="sourceLineNo">1201</span>        this.cpHost.postStartMaster();<a name="line.1201"></a>
+<span class="sourceLineNo">1202</span>      } catch (IOException ioe) {<a name="line.1202"></a>
+<span class="sourceLineNo">1203</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1203"></a>
+<span class="sourceLineNo">1204</span>      }<a name="line.1204"></a>
+<span class="sourceLineNo">1205</span>    }<a name="line.1205"></a>
 <span class="sourceLineNo">1206</span><a name="line.1206"></a>
-<span class="sourceLineNo">1207</span>    /*<a name="line.1207"></a>
-<span class="sourceLineNo">1208</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1208"></a>
-<span class="sourceLineNo">1209</span>     * in activeMasterManager thread, it should be fine.<a name="line.1209"></a>
-<span class="sourceLineNo">1210</span>     */<a name="line.1210"></a>
-<span class="sourceLineNo">1211</span>    long start = System.currentTimeMillis();<a name="line.1211"></a>
-<span class="sourceLineNo">1212</span>    this.balancer.postMasterStartupInitialize();<a name="line.1212"></a>
-<span class="sourceLineNo">1213</span>    if (LOG.isDebugEnabled()) {<a name="line.1213"></a>
-<span class="sourceLineNo">1214</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1214"></a>
-<span class="sourceLineNo">1215</span>          (System.currentTimeMillis() - start) / 1000) + " seconds");<a name="line.1215"></a>
-<span class="sourceLineNo">1216</span>    }<a name="line.1216"></a>
-<span class="sourceLineNo">1217</span>  }<a name="line.1217"></a>
-<span class="sourceLineNo">1218</span><a name="line.1218"></a>
-<span class="sourceLineNo">1219</span>  /**<a name="line.1219"></a>
-<span class="sourceLineNo">1220</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1220"></a>
-<span class="sourceLineNo">1221</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1221"></a>
-<span class="sourceLineNo">1222</span>   *   and we will hold here until operator intervention.<a name="line.1222"></a>
-<span class="sourceLineNo">1223</span>   */<a name="line.1223"></a>
-<span class="sourceLineNo">1224</span>  @VisibleForTesting<a name="line.1224"></a>
-<span class="sourceLineNo">1225</span>  public boolean waitForMetaOnline() {<a name="line.1225"></a>
-<span class="sourceLineNo">1226</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.1226"></a>
-<span class="sourceLineNo">1227</span>  }<a name="line.1227"></a>
-<span class="sourceLineNo">1228</span><a name="line.1228"></a>
-<span class="sourceLineNo">1229</span>  /**<a name="line.1229"></a>
-<span class="sourceLineNo">1230</span>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1230"></a>
-<span class="sourceLineNo">1231</span>   *   we just block in here holding up all forward-progess).<a name="line.1231"></a>
-<span class="sourceLineNo">1232</span>   */<a name="line.1232"></a>
-<span class="sourceLineNo">1233</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1233"></a>
-<span class="sourceLineNo">1234</span>    RetryCounter rc = null;<a name="line.1234"></a>
-<span class="sourceLineNo">1235</span>    while (!isStopped()) {<a name="line.1235"></a>
-<span class="sourceLineNo">1236</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1236"></a>
-<span class="sourceLineNo">1237</span>      if (rs.isOpened()) {<a name="line.1237"></a>
-<span class="sourceLineNo">1238</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1238"></a>
-<span class="sourceLineNo">1239</span>          return true;<a name="line.1239"></a>
-<span class="sourceLineNo">1240</span>        }<a name="line.1240"></a>
-<span class="sourceLineNo">1241</span>      }<a name="line.1241"></a>
-<span class="sourceLineNo">1242</span>      // Region is not OPEN.<a name="line.1242"></a>
-<span class="sourceLineNo">1243</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1243"></a>
-<span class="sourceLineNo">1244</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1244"></a>
-<span class="sourceLineNo">1245</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1245"></a>
-<span class="sourceLineNo">1246</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1246"></a>
-<span class="sourceLineNo">1247</span>      // then how to assign including how to break region lock if one held.<a name="line.1247"></a>
-<span class="sourceLineNo">1248</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1248"></a>
-<span class="sourceLineNo">1249</span>          "progress, in holding-pattern until region onlined.",<a name="line.1249"></a>
-<span class="sourceLineNo">1250</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1250"></a>
-<span class="sourceLineNo">1251</span>      // Check once-a-minute.<a name="line.1251"></a>
-<span class="sourceLineNo">1252</span>      if (rc == null) {<a name="line.1252"></a>
-<span class="sourceLineNo">1253</span>        rc = new RetryCounterFactory(1000).create();<a name="line.1253"></a>
-<span class="sourceLineNo">1254</span>      }<a name="line.1254"></a>
-<span class="sourceLineNo">1255</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1255"></a>
-<span class="sourceLineNo">1256</span>    }<a name="line.1256"></a>
-<span class="sourceLineNo">1257</span>    return false;<a name="line.1257"></a>
-<span class="sourceLineNo">1258</span>  }<a name="line.1258"></a>
-<span class="sourceLineNo">1259</span><a name="line.1259"></a>
-<span class="sourceLineNo">1260</span>  /**<a name="line.1260"></a>
-<span class="sourceLineNo">1261</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1261"></a>
-<span class="sourceLineNo">1262</span>   * &lt;p/&gt;<a name="line.1262"></a>
-<span class="sourceLineNo">1263</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1263"></a>
-<span class="sourceLineNo">1264</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1264"></a>
-<span class="sourceLineNo">1265</span>   * no namespace table/region.<a name="line.1265"></a>
-<span class="sourceLineNo">1266</span>   * @return True if namespace table is up/online.<a name="line.1266"></a>
-<span class="sourceLineNo">1267</span>   */<a name="line.1267"></a>
-<span class="sourceLineNo">1268</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1268"></a>
-<span class="sourceLineNo">1269</span>    TableState nsTableState =<a name="line.1269"></a>
-<span class="sourceLineNo">1270</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1270"></a>
-<span class="sourceLineNo">1271</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1271"></a>
-<span class="sourceLineNo">1272</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1272"></a>
-<span class="sourceLineNo">1273</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1273"></a>
-<span class="sourceLineNo">1274</span>      return true;<a name="line.1274"></a>
-<span class="sourceLineNo">1275</span>    }<a name="line.1275"></a>
-<span class="sourceLineNo">1276</span>    List&lt;RegionInfo&gt; ris =<a name="line.1276"></a>
-<span class="sourceLineNo">1277</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1277"></a>
-<span class="sourceLineNo">1278</span>    if (ris.isEmpty()) {<a name="line.1278"></a>
-<span class="sourceLineNo">1279</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1279"></a>
-<span class="sourceLineNo">1280</span>      return true;<a name="line.1280"></a>
-<span class="sourceLineNo">1281</span>    }<a name="line.1281"></a>
-<span class="sourceLineNo">1282</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1282"></a>
-<span class="sourceLineNo">1283</span>    for (RegionInfo ri : ris) {<a name="line.1283"></a>
-<span class="sourceLineNo">1284</span>      if (!isRegionOnline(ri)) {<a name="line.1284"></a>
-<span class="sourceLineNo">1285</span>        return false;<a name="line.1285"></a>
-<span class="sourceLineNo">1286</span>      }<a name="line.1286"></a>
-<span class="sourceLineNo">1287</span>    }<a name="line.1287"></a>
-<span class="sourceLineNo">1288</span>    return true;<a name="line.1288"></a>
-<span class="sourceLineNo">1289</span>  }<a name="line.1289"></a>
-<span class="sourceLineNo">1290</span><a name="line.1290"></a>
-<span class="sourceLineNo">1291</span>  /**<a name="line.1291"></a>
-<span class="sourceLineNo">1292</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1292"></a>
-<span class="sourceLineNo">1293</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1293"></a>
-<span class="sourceLineNo">1294</span>   */<a name="line.1294"></a>
-<span class="sourceLineNo">1295</span>  @VisibleForTesting<a name="line.1295"></a>
-<span class="sourceLineNo">1296</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1296"></a>
-<span class="sourceLineNo">1297</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1297"></a>
-<span class="sourceLineNo">1298</span>    if (!conf.getBoolean(<a name="line.1298"></a>
-<span class="sourceLineNo">1299</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1299"></a>
-<span class="sourceLineNo">1300</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1300"></a>
-<span class="sourceLineNo">1301</span>      return;<a name="line.1301"></a>
-<span class="sourceLineNo">1302</span>    }<a name="line.1302"></a>
-<span class="sourceLineNo">1303</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1303"></a>
-<span class="sourceLineNo">1304</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1304"></a>
-<span class="sourceLineNo">1305</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1305"></a>
-<span class="sourceLineNo">1306</span>    if (length &gt; 0) {<a name="line.1306"></a>
-<span class="sourceLineNo">1307</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1307"></a>
-<span class="sourceLineNo">1308</span>    }<a name="line.1308"></a>
-<span class="sourceLineNo">1309</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1309"></a>
-<span class="sourceLineNo">1310</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1310"></a>
-<span class="sourceLineNo">1311</span>  }<a name="line.1311"></a>
-<span class="sourceLineNo">1312</span><a name="line.1312"></a>
-<span class="sourceLineNo">1313</span>  private void initMobCleaner() {<a name="line.1313"></a>
-<span class="sourceLineNo">1314</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1314"></a>
-<span class="sourceLineNo">1315</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1315"></a>
-<span class="sourceLineNo">1316</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1316"></a>
-<span class="sourceLineNo">1317</span>    getChoreService().scheduleChore(mobFileCompactionChore);<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>   * &lt;p&gt;<a name="line.1321"></a>
-<span class="sourceLineNo">1322</span>   * Create a {@link ServerManager} instance.<a name="line.1322"></a>
-<span class="sourceLineNo">1323</span>   * &lt;/p&gt;<a name="line.1323"></a>
-<span class="sourceLineNo">1324</span>   * &lt;p&gt;<a name="line.1324"></a>
-<span class="sourceLineNo">1325</span>   * Will be overridden in tests.<a name="line.1325"></a>
-<span class="sourceLineNo">1326</span>   * &lt;/p&gt;<a name="line.1326"></a>
-<span class="sourceLineNo">1327</span>   */<a name="line.1327"></a>
-<span class="sourceLineNo">1328</span>  @VisibleForTesting<a name="line.1328"></a>
-<span class="sourceLineNo">1329</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1329"></a>
-<span class="sourceLineNo">1330</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1330"></a>
-<span class="sourceLineNo">1331</span>    // w/ a mocked up ServerManager.<a name="line.1331"></a>
-<span class="sourceLineNo">1332</span>    setupClusterConnection();<a name="line.1332"></a>
-<span class="sourceLineNo">1333</span>    return new ServerManager(master);<a name="line.1333"></a>
-<span class="sourceLineNo">1334</span>  }<a name="line.1334"></a>
-<span class="sourceLineNo">1335</span><a name="line.1335"></a>
-<span class="sourceLineNo">1336</span>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1336"></a>
-<span class="sourceLineNo">1337</span>      throws IOException, InterruptedException {<a name="line.1337"></a>
-<span class="sourceLineNo">1338</span>    this.serverManager.waitForRegionServers(status);<a name="line.1338"></a>
-<span class="sourceLineNo">1339</span>  }<a name="line.1339"></a>
-<span class="sourceLineNo">1340</span><a name="line.1340"></a>
-<span class="sourceLineNo">1341</span>  // Will be overridden in tests<a name="line.1341"></a>
-<span class="sourceLineNo">1342</span>  @VisibleForTesting<a name="line.1342"></a>
-<span class="sourceLineNo">1343</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1343"></a>
-<span class="sourceLineNo">1344</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1344"></a>
-<span class="sourceLineNo">1345</span>    this.clusterSchemaService.startAsync();<a name="line.1345"></a>
-<span class="sourceLineNo">1346</span>    try {<a name="line.1346"></a>
-<span class="sourceLineNo">1347</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1347"></a>
-<span class="sourceLineNo">1348</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1348"></a>
-<span class="sourceLineNo">1349</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1349"></a>
-<span class="sourceLineNo">1350</span>    } catch (TimeoutException toe) {<a name="line.1350"></a>
-<span class="sourceLineNo">1351</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<a name="line.1351"></a>
-<span class="sourceLineNo">1352</span>    }<a name="line.1352"></a>
-<span class="sourceLineNo">1353</span>  }<a name="line.1353"></a>
-<span class="sourceLineNo">1354</span><a name="line.1354"></a>
-<span class="sourceLineNo">1355</span>  private void initQuotaManager() throws IOException {<a name="line.1355"></a>
-<span class="sourceLineNo">1356</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1356"></a>
-<span class="sourceLineNo">1357</span>    quotaManager.start();<a name="line.1357"></a>
-<span class="sourceLineNo">1358</span>    this.quotaManager = quotaManager;<a name="line.1358"></a>
-<span class="sourceLineNo">1359</span>  }<a name="line.1359"></a>
-<span class="sourceLineNo">1360</span><a name="line.1360"></a>
-<span class="sourceLineNo">1361</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1361"></a>
-<span class="sourceLineNo">1362</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1362"></a>
-<span class="sourceLineNo">1363</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1363"></a>
-<span class="sourceLineNo">1364</span>    return notifier;<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>  boolean isCatalogJanitorEnabled() {<a name="line.1367"></a>
-<span class="sourceLineNo">1368</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<a name="line.1368"></a>
-<span class="sourceLineNo">1369</span>  }<a name="line.1369"></a>
-<span class="sourceLineNo">1370</span><a name="line.1370"></a>
-<span class="sourceLineNo">1371</span>  boolean isCleanerChoreEnabled() {<a name="line.1371"></a>
-<span class="sourceLineNo">1372</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1372"></a>
-<span class="sourceLineNo">1373</span><a name="line.1373"></a>
-<span class="sourceLineNo">1374</span>    if (hfileCleaner != null) {<a name="line.1374"></a>
-<span class="sourceLineNo">1375</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<a name="line.1375"></a>
-<span class="sourceLineNo">1376</span>    }<a name="line.1376"></a>
-<span class="sourceLineNo">1377</span><a name="line.1377"></a>
-<span class="sourceLineNo">1378</span>    if (logCleaner != null) {<a name="line.1378"></a>
-<span class="sourceLineNo">1379</span>      logCleanerFlag = logCleaner.getEnabled();<a name="line.1379"></a>
-<span class="sourceLineNo">1380</span>    }<a name="line.1380"></a>
-<span class="sourceLineNo">1381</span><a name="line.1381"></a>
-<span class="sourceLineNo">1382</span>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<a name="line.1382"></a>
-<span class="sourceLineNo">1383</span>  }<a name="line.1383"></a>
-<span class="sourceLineNo">1384</span><a name="line.1384"></a>
-<span class="sourceLineNo">1385</span>  @Override<a name="line.1385"></a>
-<span class="sourceLineNo">1386</span>  public ServerManager getServerManager() {<a name="line.1386"></a>
-<span class="sourceLineNo">1387</span>    return this.serverManager;<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>  @Override<a name="line.1390"></a>
-<span class="sourceLineNo">1391</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1391"></a>
-<span class="sourceLineNo">1392</span>    return this.fileSystemManager;<a name="line.1392"></a>
-<span class="sourceLineNo">1393</span>  }<a name="line.1393"></a>
-<span class="sourceLineNo">1394</span><a name="line.1394"></a>
-<span class="sourceLineNo">1395</span>  @Override<a name="line.1395"></a>
-<span class="sourceLineNo">1396</span>  public MasterWalManager getMasterWalManager() {<a name="line.1396"></a>
-<span class="sourceLineNo">1397</span>    return this.walManager;<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>  @Override<a name="line.1400"></a>
-<span class="sourceLineNo">1401</span>  public SplitWALManager getSplitWALManager() {<a name="line.1401"></a>
-<span class="sourceLineNo">1402</span>    return splitWALManager;<a name="line.1402"></a>
-<span class="sourceLineNo">1403</span>  }<a name="line.1403"></a>
-<span class="sourceLineNo">1404</span><a name="line.1404"></a>
-<span class="sourceLineNo">1405</span>  @Override<a name="line.1405"></a>
-<span class="sourceLineNo">1406</span>  public TableStateManager getTableStateManager() {<a name="line.1406"></a>
-<span class="sourceLineNo">1407</span>    return tableStateManager;<a name="line.1407"></a>
-<span class="sourceLineNo">1408</span>  }<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>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1411"></a>
-<span class="sourceLineNo">1412</span>   * then they just die with a logged message.  This should be fine because<a name="line.1412"></a>
-<span class="sourceLineNo">1413</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1413"></a>
-<span class="sourceLineNo">1414</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1414"></a>
-<span class="sourceLineNo">1415</span>   *  need to install an unexpected exception handler.<a name="line.1415"></a>
-<span class="sourceLineNo">1416</span>   */<a name="line.1416"></a>
-<span class="sourceLineNo">1417</span>  private void startServiceThreads() throws IOException {<a name="line.1417"></a>
-<span class="sourceLineNo">1418</span>    // Start the executor service pools<a name="line.1418"></a>
-<span class="sourceLineNo">1419</span>    this.executorService.startExecutorService(ExecutorType.MASTER_OPEN_REGION, conf.getInt(<a name="line.1419"></a>
-<span class="sourceLineNo">1420</span>      HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT));<a name="line.1420"></a>
-<span class="sourceLineNo">1421</span>    this.executorService.startExecutorService(ExecutorType.MASTER_CLOSE_REGION, conf.getInt(<a name="line.1421"></a>
-<span class="sourceLineNo">1422</span>      HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT));<a name="line.1422"></a>
-<span class="sourceLineNo">1423</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SERVER_OPERATIONS,<a name="line.1423"></a>
-<span class="sourceLineNo">1424</span>      conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1424"></a>
-<span class="sourceLineNo">1425</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1425"></a>
-<span class="sourceLineNo">1426</span>    this.executorService.startExecutorService(ExecutorType.MASTER_META_SERVER_OPERATIONS,<a name="line.1426"></a>
-<span class="sourceLineNo">1427</span>      conf.getInt(HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1427"></a>
-<span class="sourceLineNo">1428</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1428"></a>
-<span class="sourceLineNo">1429</span>    this.executorService.startExecutorService(ExecutorType.M_LOG_REPLAY_OPS, conf.getInt(<a name="line.1429"></a>
-<span class="sourceLineNo">1430</span>      HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT));<a name="line.1430"></a>
-<span class="sourceLineNo">1431</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SNAPSHOT_OPERATIONS, conf.getInt(<a name="line.1431"></a>
-<span class="sourceLineNo">1432</span>      SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT));<a name="line.1432"></a>
-<span class="sourceLineNo">1433</span><a name="line.1433"></a>
-<span class="sourceLineNo">1434</span>    // We depend on there being only one instance of this executor running<a name="line.1434"></a>
-<span class="sourceLineNo">1435</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1435"></a>
-<span class="sourceLineNo">1436</span>    // tables.<a name="line.1436"></a>
-<span class="sourceLineNo">1437</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1437"></a>
-<span class="sourceLineNo">1438</span>    // AccessController#postCompletedCreateTableAction<a name="line.1438"></a>
-<span class="sourceLineNo">1439</span>    this.executorService.startExecutorService(ExecutorType.MASTER_TABLE_OPERATIONS, 1);<a name="line.1439"></a>
-<span class="sourceLineNo">1440</span>    startProcedureExecutor();<a name="line.1440"></a>
-<span class="sourceLineNo">1441</span><a name="line.1441"></a>
-<span class="sourceLineNo">1442</span>    // Create cleaner thread pool<a name="line.1442"></a>
-<span class="sourceLineNo">1443</span>    cleanerPool = new DirScanPool(conf);<a name="line.1443"></a>
-<span class="sourceLineNo">1444</span>    // Start log cleaner thread<a name="line.1444"></a>
-<span class="sourceLineNo">1445</span>    int cleanerInterval =<a name="line.1445"></a>
-<span class="sourceLineNo">1446</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1446"></a>
-<span class="sourceLineNo">1447</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1447"></a>
-<span class="sourceLineNo">1448</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool);<a name="line.1448"></a>
-<span class="sourceLineNo">1449</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1449"></a>
-<span class="sourceLineNo">1450</span><a name="line.1450"></a>
-<span class="sourceLineNo">1451</span>    // start the hfile archive cleaner thread<a name="line.1451"></a>
-<span class="sourceLineNo">1452</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1452"></a>
-<span class="sourceLineNo">1453</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1453"></a>
-<span class="sourceLineNo">1454</span>    params.put(MASTER, this);<a name="line.1454"></a>
-<span class="sourceLineNo">1455</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1455"></a>
-<span class="sourceLineNo">1456</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1456"></a>
-<span class="sourceLineNo">1457</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1457"></a>
-<span class="sourceLineNo">1458</span><a name="line.1458"></a>
-<span class="sourceLineNo">1459</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1459"></a>
-<span class="sourceLineNo">1460</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1460"></a>
-<span class="sourceLineNo">1461</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1461"></a>
-<span class="sourceLineNo">1462</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1462"></a>
-<span class="sourceLineNo">1463</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1463"></a>
-<span class="sourceLineNo">1464</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1464"></a>
-<span class="sourceLineNo">1465</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1465"></a>
-<span class="sourceLineNo">1466</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1466"></a>
-<span class="sourceLineNo">1467</span>    } else {<a name="line.1467"></a>
-<span class="sourceLineNo">1468</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1468"></a>
-<span class="sourceLineNo">1469</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1469"></a>
-<span class="sourceLineNo">1470</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1470"></a>
-<span class="sourceLineNo">1471</span>    }<a name="line.1471"></a>
-<span class="sourceLineNo">1472</span><a name="line.1472"></a>
-<span class="sourceLineNo">1473</span>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1473"></a>
+<span class="sourceLineNo">1207</span>    zombieDetector.interrupt();<a name="line.1207"></a>
+<span class="sourceLineNo">1208</span><a name="line.1208"></a>
+<span class="sourceLineNo">1209</span>    /*<a name="line.1209"></a>
+<span class="sourceLineNo">1210</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1210"></a>
+<span class="sourceLineNo">1211</span>     * in activeMasterManager thread, it should be fine.<a name="line.1211"></a>
+<span class="sourceLineNo">1212</span>     */<a name="line.1212"></a>
+<span class="sourceLineNo">1213</span>    long start = System.currentTimeMillis();<a name="line.1213"></a>
+<span class="sourceLineNo">1214</span>    this.balancer.postMasterStartupInitialize();<a name="line.1214"></a>
+<span class="sourceLineNo">1215</span>    if (LOG.isDebugEnabled()) {<a name="line.1215"></a>
+<span class="sourceLineNo">1216</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1216"></a>
+<span class="sourceLineNo">1217</span>          (System.currentTimeMillis() - start) / 1000) + " seconds");<a name="line.1217"></a>
+<span class="sourceLineNo">1218</span>    }<a name="line.1218"></a>
+<span class="sourceLineNo">1219</span>  }<a name="line.1219"></a>
+<span class="sourceLineNo">1220</span><a name="line.1220"></a>
+<span class="sourceLineNo">1221</span>  /**<a name="line.1221"></a>
+<span class="sourceLineNo">1222</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1222"></a>
+<span class="sourceLineNo">1223</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1223"></a>
+<span class="sourceLineNo">1224</span>   *   and we will hold here until operator intervention.<a name="line.1224"></a>
+<span class="sourceLineNo">1225</span>   */<a name="line.1225"></a>
+<span class="sourceLineNo">1226</span>  @VisibleForTesting<a name="line.1226"></a>
+<span class="sourceLineNo">1227</span>  public boolean waitForMetaOnline() {<a name="line.1227"></a>
+<span class="sourceLineNo">1228</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.1228"></a>
+<span class="sourceLineNo">1229</span>  }<a name="line.1229"></a>
+<span class="sourceLineNo">1230</span><a name="line.1230"></a>
+<span class="sourceLineNo">1231</span>  /**<a name="line.1231"></a>
+<span class="sourceLineNo">1232</span>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1232"></a>
+<span class="sourceLineNo">1233</span>   *   we just block in here holding up all forward-progess).<a name="line.1233"></a>
+<span class="sourceLineNo">1234</span>   */<a name="line.1234"></a>
+<span class="sourceLineNo">1235</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1235"></a>
+<span class="sourceLineNo">1236</span>    RetryCounter rc = null;<a name="line.1236"></a>
+<span class="sourceLineNo">1237</span>    while (!isStopped()) {<a name="line.1237"></a>
+<span class="sourceLineNo">1238</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1238"></a>
+<span class="sourceLineNo">1239</span>      if (rs.isOpened()) {<a name="line.1239"></a>
+<span class="sourceLineNo">1240</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1240"></a>
+<span class="sourceLineNo">1241</span>          return true;<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>      // Region is not OPEN.<a name="line.1244"></a>
+<span class="sourceLineNo">1245</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1245"></a>
+<span class="sourceLineNo">1246</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1246"></a>
+<span class="sourceLineNo">1247</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1247"></a>
+<span class="sourceLineNo">1248</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1248"></a>
+<span class="sourceLineNo">1249</span>      // then how to assign including how to break region lock if one held.<a name="line.1249"></a>
+<span class="sourceLineNo">1250</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1250"></a>
+<span class="sourceLineNo">1251</span>          "progress, in holding-pattern until region onlined.",<a name="line.1251"></a>
+<span class="sourceLineNo">1252</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1252"></a>
+<span class="sourceLineNo">1253</span>      // Check once-a-minute.<a name="line.1253"></a>
+<span class="sourceLineNo">1254</span>      if (rc == null) {<a name="line.1254"></a>
+<span class="sourceLineNo">1255</span>        rc = new RetryCounterFactory(1000).create();<a name="line.1255"></a>
+<span class="sourceLineNo">1256</span>      }<a name="line.1256"></a>
+<span class="sourceLineNo">1257</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1257"></a>
+<span class="sourceLineNo">1258</span>    }<a name="line.1258"></a>
+<span class="sourceLineNo">1259</span>    return false;<a name="line.1259"></a>
+<span class="sourceLineNo">1260</span>  }<a name="line.1260"></a>
+<span class="sourceLineNo">1261</span><a name="line.1261"></a>
+<span class="sourceLineNo">1262</span>  /**<a name="line.1262"></a>
+<span class="sourceLineNo">1263</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1263"></a>
+<span class="sourceLineNo">1264</span>   * &lt;p/&gt;<a name="line.1264"></a>
+<span class="sourceLineNo">1265</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1265"></a>
+<span class="sourceLineNo">1266</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1266"></a>
+<span class="sourceLineNo">1267</span>   * no namespace table/region.<a name="line.1267"></a>
+<span class="sourceLineNo">1268</span>   * @return True if namespace table is up/online.<a name="line.1268"></a>
+<span class="sourceLineNo">1269</span>   */<a name="line.1269"></a>
+<span class="sourceLineNo">1270</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1270"></a>
+<span class="sourceLineNo">1271</span>    TableState nsTableState =<a name="line.1271"></a>
+<span class="sourceLineNo">1272</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1272"></a>
+<span class="sourceLineNo">1273</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1273"></a>
+<span class="sourceLineNo">1274</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1274"></a>
+<span class="sourceLineNo">1275</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1275"></a>
+<span class="sourceLineNo">1276</span>      return true;<a name="line.1276"></a>
+<span class="sourceLineNo">1277</span>    }<a name="line.1277"></a>
+<span class="sourceLineNo">1278</span>    List&lt;RegionInfo&gt; ris =<a name="line.1278"></a>
+<span class="sourceLineNo">1279</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1279"></a>
+<span class="sourceLineNo">1280</span>    if (ris.isEmpty()) {<a name="line.1280"></a>
+<span class="sourceLineNo">1281</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1281"></a>
+<span class="sourceLineNo">1282</span>      return true;<a name="line.1282"></a>
+<span class="sourceLineNo">1283</span>    }<a name="line.1283"></a>
+<span class="sourceLineNo">1284</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1284"></a>
+<span class="sourceLineNo">1285</span>    for (RegionInfo ri : ris) {<a name="line.1285"></a>
+<span class="sourceLineNo">1286</span>      if (!isRegionOnline(ri)) {<a name="line.1286"></a>
+<span class="sourceLineNo">1287</span>        return false;<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>    return true;<a name="line.1290"></a>
+<span class="sourceLineNo">1291</span>  }<a name="line.1291"></a>
+<span class="sourceLineNo">1292</span><a name="line.1292"></a>
+<span class="sourceLineNo">1293</span>  /**<a name="line.1293"></a>
+<span class="sourceLineNo">1294</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1294"></a>
+<span class="sourceLineNo">1295</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1295"></a>
+<span class="sourceLineNo">1296</span>   */<a name="line.1296"></a>
+<span class="sourceLineNo">1297</span>  @VisibleForTesting<a name="line.1297"></a>
+<span class="sourceLineNo">1298</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1298"></a>
+<span class="sourceLineNo">1299</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1299"></a>
+<span class="sourceLineNo">1300</span>    if (!conf.getBoolean(<a name="line.1300"></a>
+<span class="sourceLineNo">1301</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1301"></a>
+<span class="sourceLineNo">1302</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1302"></a>
+<span class="sourceLineNo">1303</span>      return;<a name="line.1303"></a>
+<span class="sourceLineNo">1304</span>    }<a name="line.1304"></a>
+<span class="sourceLineNo">1305</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1305"></a>
+<span class="sourceLineNo">1306</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1306"></a>
+<span class="sourceLineNo">1307</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1307"></a>
+<span class="sourceLineNo">1308</span>    if (length &gt; 0) {<a name="line.1308"></a>
+<span class="sourceLineNo">1309</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1309"></a>
+<span class="sourceLineNo">1310</span>    }<a name="line.1310"></a>
+<span class="sourceLineNo">1311</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1311"></a>
+<span class="sourceLineNo">1312</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1312"></a>
+<span class="sourceLineNo">1313</span>  }<a name="line.1313"></a>
+<span class="sourceLineNo">1314</span><a name="line.1314"></a>
+<span class="sourceLineNo">1315</span>  private void initMobCleaner() {<a name="line.1315"></a>
+<span class="sourceLineNo">1316</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1316"></a>
+<span class="sourceLineNo">1317</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1317"></a>
+<span class="sourceLineNo">1318</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1318"></a>
+<span class="sourceLineNo">1319</span>    getChoreService().scheduleChore(mobFileCompactionChore);<a name="line.1319"></a>
+<span class="sourceLineNo">1320</span>  }<a name="line.1320"></a>
+<span class="sourceLineNo">1321</span><a name="line.1321"></a>
+<span class="sourceLineNo">1322</span>  /**<a name="line.1322"></a>
+<span class="sourceLineNo">1323</span>   * &lt;p&gt;<a name="line.1323"></a>
+<span class="sourceLineNo">1324</span>   * Create a {@link ServerManager} instance.<a name="line.1324"></a>
+<span class="sourceLineNo">1325</span>   * &lt;/p&gt;<a name="line.1325"></a>
+<span class="sourceLineNo">1326</span>   * &lt;p&gt;<a name="line.1326"></a>
+<span class="sourceLineNo">1327</span>   * Will be overridden in tests.<a name="line.1327"></a>
+<span class="sourceLineNo">1328</span>   * &lt;/p&gt;<a name="line.1328"></a>
+<span class="sourceLineNo">1329</span>   */<a name="line.1329"></a>
+<span class="sourceLineNo">1330</span>  @VisibleForTesting<a name="line.1330"></a>
+<span class="sourceLineNo">1331</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1331"></a>
+<span class="sourceLineNo">1332</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1332"></a>
+<span class="sourceLineNo">1333</span>    // w/ a mocked up ServerManager.<a name="line.1333"></a>
+<span class="sourceLineNo">1334</span>    setupClusterConnection();<a name="line.1334"></a>
+<span class="sourceLineNo">1335</span>    return new ServerManager(master);<a name="line.1335"></a>
+<span class="sourceLineNo">1336</span>  }<a name="line.1336"></a>
+<span class="sourceLineNo">1337</span><a name="line.1337"></a>
+<span class="sourceLineNo">1338</span>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1338"></a>
+<span class="sourceLineNo">1339</span>      throws IOException, InterruptedException {<a name="line.1339"></a>
+<span class="sourceLineNo">1340</span>    this.serverManager.waitForRegionServers(status);<a name="line.1340"></a>
+<span class="sourceLineNo">1341</span>  }<a name="line.1341"></a>
+<span class="sourceLineNo">1342</span><a name="line.1342"></a>
+<span class="sourceLineNo">1343</span>  // Will be overridden in tests<a name="line.1343"></a>
+<span class="sourceLineNo">1344</span>  @VisibleForTesting<a name="line.1344"></a>
+<span class="sourceLineNo">1345</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1345"></a>
+<span class="sourceLineNo">1346</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1346"></a>
+<span class="sourceLineNo">1347</span>    this.clusterSchemaService.startAsync();<a name="line.1347"></a>
+<span class="sourceLineNo">1348</span>    try {<a name="line.1348"></a>
+<span class="sourceLineNo">1349</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1349"></a>
+<span class="sourceLineNo">1350</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1350"></a>
+<span class="sourceLineNo">1351</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1351"></a>
+<span class="sourceLineNo">1352</span>    } catch (TimeoutException toe) {<a name="line.1352"></a>
+<span class="sourceLineNo">1353</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<a name="line.1353"></a>
+<span class="sourceLineNo">1354</span>    }<a name="line.1354"></a>
+<span class="sourceLineNo">1355</span>  }<a name="line.1355"></a>
+<span class="sourceLineNo">1356</span><a name="line.1356"></a>
+<span class="sourceLineNo">1357</span>  private void initQuotaManager() throws IOException {<a name="line.1357"></a>
+<span class="sourceLineNo">1358</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1358"></a>
+<span class="sourceLineNo">1359</span>    quotaManager.start();<a name="line.1359"></a>
+<span class="sourceLineNo">1360</span>    this.quotaManager = quotaManager;<a name="line.1360"></a>
+<span class="sourceLineNo">1361</span>  }<a name="line.1361"></a>
+<span class="sourceLineNo">1362</span><a name="line.1362"></a>
+<span class="sourceLineNo">1363</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1363"></a>
+<span class="sourceLineNo">1364</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1364"></a>
+<span class="sourceLineNo">1365</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1365"></a>
+<span class="sourceLineNo">1366</span>    return notifier;<a name="line.1366"></a>
+<span class="sourceLineNo">1367</span>  }<a name="line.1367"></a>
+<span class="sourceLineNo">1368</span><a name="line.1368"></a>
+<span class="sourceLineNo">1369</span>  boolean isCatalogJanitorEnabled() {<a name="line.1369"></a>
+<span class="sourceLineNo">1370</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<a name="line.1370"></a>
+<span class="sourceLineNo">1371</span>  }<a name="line.1371"></a>
+<span class="sourceLineNo">1372</span><a name="line.1372"></a>
+<span class="sourceLineNo">1373</span>  boolean isCleanerChoreEnabled() {<a name="line.1373"></a>
+<span class="sourceLineNo">1374</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1374"></a>
+<span class="sourceLineNo">1375</span><a name="line.1375"></a>
+<span class="sourceLineNo">1376</span>    if (hfileCleaner != null) {<a name="line.1376"></a>
+<span class="sourceLineNo">1377</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<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>    if (logCleaner != null) {<a name="line.1380"></a>
+<span class="sourceLineNo">1381</span>      logCleanerFlag = logCleaner.getEnabled();<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>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<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>  @Override<a name="line.1387"></a>
+<span class="sourceLineNo">1388</span>  public ServerManager getServerManager() {<a name="line.1388"></a>
+<span class="sourceLineNo">1389</span>    return this.serverManager;<a name="line.1389"></a>
+<span class="sourceLineNo">1390</span>  }<a name="line.1390"></a>
+<span class="sourceLineNo">1391</span><a name="line.1391"></a>
+<span class="sourceLineNo">1392</span>  @Override<a name="line.1392"></a>
+<span class="sourceLineNo">1393</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1393"></a>
+<span class="sourceLineNo">1394</span>    return this.fileSystemManager;<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>  @Override<a name="line.1397"></a>
+<span class="sourceLineNo">1398</span>  public MasterWalManager getMasterWalManager() {<a name="line.1398"></a>
+<span class="sourceLineNo">1399</span>    return this.walManager;<a name="line.1399"></a>
+<span class="sourceLineNo">1400</span>  }<a name="line.1400"></a>
+<span class="sourceLineNo">1401</span><a name="line.1401"></a>
+<span class="sourceLineNo">1402</span>  @Override<a name="line.1402"></a>
+<span class="sourceLineNo">1403</span>  public SplitWALManager getSplitWALManager() {<a name="line.1403"></a>
+<span class="sourceLineNo">1404</span>    return splitWALManager;<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>  @Override<a name="line.1407"></a>
+<span class="sourceLineNo">1408</span>  public TableStateManager getTableStateManager() {<a name="line.1408"></a>
+<span class="sourceLineNo">1409</span>    return tableStateManager;<a name="line.1409"></a>
+<span class="sourceLineNo">1410</span>  }<a name="line.1410"></a>
+<span class="sourceLineNo">1411</span><a name="line.1411"></a>
+<span class="sourceLineNo">1412</span>  /*<a name="line.1412"></a>
+<span class="sourceLineNo">1413</span>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1413"></a>
+<span class="sourceLineNo">1414</span>   * then they just die with a logged message.  This should be fine because<a name="line.1414"></a>
+<span class="sourceLineNo">1415</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1415"></a>
+<span class="sourceLineNo">1416</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1416"></a>
+<span class="sourceLineNo">1417</span>   *  need to install an unexpected exception handler.<a name="line.1417"></a>
+<span class="sourceLineNo">1418</span>   */<a name="line.1418"></a>
+<span class="sourceLineNo">1419</span>  private void startServiceThreads() throws IOException {<a name="line.1419"></a>
+<span class="sourceLineNo">1420</span>    // Start the executor service pools<a name="line.1420"></a>
+<span class="sourceLineNo">1421</span>    this.executorService.startExecutorService(ExecutorType.MASTER_OPEN_REGION, conf.getInt(<a name="line.1421"></a>
+<span class="sourceLineNo">1422</span>      HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT));<a name="line.1422"></a>
+<span class="sourceLineNo">1423</span>    this.executorService.startExecutorService(ExecutorType.MASTER_CLOSE_REGION, conf.getInt(<a name="line.1423"></a>
+<span class="sourceLineNo">1424</span>      HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT));<a name="line.1424"></a>
+<span class="sourceLineNo">1425</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SERVER_OPERATIONS,<a name="line.1425"></a>
+<span class="sourceLineNo">1426</span>      conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1426"></a>
+<span class="sourceLineNo">1427</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1427"></a>
+<span class="sourceLineNo">1428</span>    this.executorService.startExecutorService(ExecutorType.MASTER_META_SERVER_OPERATIONS,<a name="line.1428"></a>
+<span class="sourceLineNo">1429</span>      conf.getInt(HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1429"></a>
+<span class="sourceLineNo">1430</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1430"></a>
+<span class="sourceLineNo">1431</span>    this.executorService.startExecutorService(ExecutorType.M_LOG_REPLAY_OPS, conf.getInt(<a name="line.1431"></a>
+<span class="sourceLineNo">1432</span>      HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT));<a name="line.1432"></a>
+<span class="sourceLineNo">1433</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SNAPSHOT_OPERATIONS, conf.getInt(<a name="line.1433"></a>
+<span class="sourceLineNo">1434</span>      SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT));<a name="line.1434"></a>
+<span class="sourceLineNo">1435</span><a name="line.1435"></a>
+<span class="sourceLineNo">1436</span>    // We depend on there being only one instance of this executor running<a name="line.1436"></a>
+<span class="sourceLineNo">1437</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1437"></a>
+<span class="sourceLineNo">1438</span>    // tables.<a name="line.1438"></a>
+<span class="sourceLineNo">1439</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1439"></a>
+<span class="sourceLineNo">1440</span>    // AccessController#postCompletedCreateTableAction<a name="line.1440"></a>
+<span class="sourceLineNo">1441</span>    this.executorService.startExecutorService(ExecutorType.MASTER_TABLE_OPERATIONS, 1);<a name="line.1441"></a>
+<span class="sourceLineNo">1442</span>    startProcedureExecutor();<a name="line.1442"></a>
+<span class="sourceLineNo">1443</span><a name="line.1443"></a>
+<span class="sourceLineNo">1444</span>    // Create cleaner thread pool<a name="line.1444"></a>
+<span class="sourceLineNo">1445</span>    cleanerPool = new DirScanPool(conf);<a name="line.1445"></a>
+<span class="sourceLineNo">1446</span>    // Start log cleaner thread<a name="line.1446"></a>
+<span class="sourceLineNo">1447</span>    int cleanerInterval =<a name="line.1447"></a>
+<span class="sourceLineNo">1448</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1448"></a>
+<span class="sourceLineNo">1449</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1449"></a>
+<span class="sourceLineNo">1450</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool);<a name="line.1450"></a>
+<span class="sourceLineNo">1451</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1451"></a>
+<span class="sourceLineNo">1452</span><a name="line.1452"></a>
+<span class="sourceLineNo">1453</span>    // start the hfile archive cleaner thread<a name="line.1453"></a>
+<span class="sourceLineNo">1454</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1454"></a>
+<span class="sourceLineNo">1455</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1455"></a>
+<span class="sourceLineNo">1456</span>    params.put(MASTER, this);<a name="line.1456"></a>
+<span class="sourceLineNo">1457</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1457"></a>
+<span class="sourceLineNo">1458</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1458"></a>
+<span class="sourceLineNo">1459</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1459"></a>
+<span class="sourceLineNo">1460</span><a name="line.1460"></a>
+<span class="sourceLineNo">1461</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1461"></a>
+<span class="sourceLineNo">1462</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1462"></a>
+<span class="sourceLineNo">1463</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1463"></a>
+<span class="sourceLineNo">1464</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1464"></a>
+<span class="sourceLineNo">1465</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1465"></a>
+<span class="sourceLineNo">1466</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1466"></a>
+<span class="sourceLineNo">1467</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1467"></a>
+<span class="sourceLineNo">1468</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1468"></a>
+<span class="sourceLineNo">1469</span>    } else {<a name="line.1469"></a>
+<span class="sourceLineNo">1470</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1470"></a>
+<span class="sourceLineNo">1471</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1471"></a>
+<span class="sourceLineNo">1472</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1472"></a>
+<span class="sourceLineNo">1473</span>    }<a name="line.1473"></a>
 <span class="sourceLineNo">1474</span><a name="line.1474"></a>
-<span class="sourceLineNo">1475</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1475"></a>
-<span class="sourceLineNo">1476</span>      replicationPeerManager);<a name="line.1476"></a>
-<span class="sourceLineNo">1477</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1477"></a>
-<span class="sourceLineNo">1478</span><a name="line.1478"></a>
-<span class="sourceLineNo">1479</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1479"></a>
-<span class="sourceLineNo">1480</span>        .isSnapshotCleanupEnabled();<a name="line.1480"></a>
-<span class="sourceLineNo">1481</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1481"></a>
-<span class="sourceLineNo">1482</span>    if (isSnapshotChoreEnabled) {<a name="line.1482"></a>
-<span class="sourceLineNo">1483</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1483"></a>
-<span class="sourceLineNo">1484</span>    } else {<a name="line.1484"></a>
-<span class="sourceLineNo">1485</span>      if (LOG.isTraceEnabled()) {<a name="line.1485"></a>
-<span class="sourceLineNo">1486</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1486"></a>
-<span class="sourceLineNo">1487</span>      }<a name="line.1487"></a>
-<span class="sourceLineNo">1488</span>    }<a name="line.1488"></a>
-<span class="sourceLineNo">1489</span>    serviceStarted = true;<a name="line.1489"></a>
-<span class="sourceLineNo">1490</span>    if (LOG.isTraceEnabled()) {<a name="line.1490"></a>
-<span class="sourceLineNo">1491</span>      LOG.trace("Started service threads");<a name="line.1491"></a>
-<span class="sourceLineNo">1492</span>    }<a name="line.1492"></a>
-<span class="sourceLineNo">1493</span>  }<a name="line.1493"></a>
-<span class="sourceLineNo">1494</span><a name="line.1494"></a>
-<span class="sourceLineNo">1495</span>  @Override<a name="line.1495"></a>
-<span class="sourceLineNo">1496</span>  protected void stopServiceThreads() {<a name="line.1496"></a>
-<span class="sourceLineNo">1497</span>    if (masterJettyServer != null) {<a name="line.1497"></a>
-<span class="sourceLineNo">1498</span>      LOG.info("Stopping master jetty server");<a name="line.1498"></a>
-<span class="sourceLineNo">1499</span>      try {<a name="line.1499"></a>
-<span class="sourceLineNo">1500</span>        masterJettyServer.stop();<a name="line.1500"></a>
-<span class="sourceLineNo">1501</span>      } catch (Exception e) {<a name="line.1501"></a>
-<span class="sourceLineNo">1502</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1502"></a>
-<span class="sourceLineNo">1503</span>      }<a name="line.1503"></a>
-<span class="sourceLineNo">1504</span>    }<a name="line.1504"></a>
-<span class="sourceLineNo">1505</span>    stopChores();<a name="line.1505"></a>
-<span class="sourceLineNo">1506</span><a name="line.1506"></a>
-<span class="sourceLineNo">1507</span>    super.stopServiceThreads();<a name="line.1507"></a>
-<span class="sourceLineNo">1508</span>    if (cleanerPool != null) {<a name="line.1508"></a>
-<span class="sourceLineNo">1509</span>      cleanerPool.shutdownNow();<a name="line.1509"></a>
-<span class="sourceLineNo">1510</span>      cleanerPool = null;<a name="line.1510"></a>
-<span class="sourceLineNo">1511</span>    }<a name="line.1511"></a>
-<span class="sourceLineNo">1512</span><a name="line.1512"></a>
-<span class="sourceLineNo">1513</span>    LOG.debug("Stopping service threads");<a name="line.1513"></a>
+<span class="sourceLineNo">1475</span>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1475"></a>
+<span class="sourceLineNo">1476</span><a name="line.1476"></a>
+<span class="sourceLineNo">1477</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1477"></a>
+<span class="sourceLineNo">1478</span>      replicationPeerManager);<a name="line.1478"></a>
+<span class="sourceLineNo">1479</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1479"></a>
+<span class="sourceLineNo">1480</span><a name="line.1480"></a>
+<span class="sourceLineNo">1481</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1481"></a>
+<span class="sourceLineNo">1482</span>        .isSnapshotCleanupEnabled();<a name="line.1482"></a>
+<span class="sourceLineNo">1483</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1483"></a>
+<span class="sourceLineNo">1484</span>    if (isSnapshotChoreEnabled) {<a name="line.1484"></a>
+<span class="sourceLineNo">1485</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1485"></a>
+<span class="sourceLineNo">1486</span>    } else {<a name="line.1486"></a>
+<span class="sourceLineNo">1487</span>      if (LOG.isTraceEnabled()) {<a name="line.1487"></a>
+<span class="sourceLineNo">1488</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1488"></a>
+<span class="sourceLineNo">1489</span>      }<a name="line.1489"></a>
+<span class="sourceLineNo">1490</span>    }<a name="line.1490"></a>
+<span class="sourceLineNo">1491</span>    serviceStarted = true;<a name="line.1491"></a>
+<span class="sourceLineNo">1492</span>    if (LOG.isTraceEnabled()) {<a name="line.1492"></a>
+<span class="sourceLineNo">1493</span>      LOG.trace("Started service threads");<a name="line.1493"></a>
+<span class="sourceLineNo">1494</span>    }<a name="line.1494"></a>
+<span class="sourceLineNo">1495</span>  }<a name="line.1495"></a>
+<span class="sourceLineNo">1496</span><a name="line.1496"></a>
+<span class="sourceLineNo">1497</span>  @Override<a name="line.1497"></a>
+<span class="sourceLineNo">1498</span>  protected void stopServiceThreads() {<a name="line.1498"></a>
+<span class="sourceLineNo">1499</span>    if (masterJettyServer != null) {<a name="line.1499"></a>
+<span class="sourceLineNo">1500</span>      LOG.info("Stopping master jetty server");<a name="line.1500"></a>
+<span class="sourceLineNo">1501</span>      try {<a name="line.1501"></a>
+<span class="sourceLineNo">1502</span>        masterJettyServer.stop();<a name="line.1502"></a>
+<span class="sourceLineNo">1503</span>      } catch (Exception e) {<a name="line.1503"></a>
+<span class="sourceLineNo">1504</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1504"></a>
+<span class="sourceLineNo">1505</span>      }<a name="line.1505"></a>
+<span class="sourceLineNo">1506</span>    }<a name="line.1506"></a>
+<span class="sourceLineNo">1507</span>    stopChores();<a name="line.1507"></a>
+<span class="sourceLineNo">1508</span><a name="line.1508"></a>
+<span class="sourceLineNo">1509</span>    super.stopServiceThreads();<a name="line.1509"></a>
+<span class="sourceLineNo">1510</span>    if (cleanerPool != null) {<a name="line.1510"></a>
+<span class="sourceLineNo">1511</span>      cleanerPool.shutdownNow();<a name="line.1511"></a>
+<span class="sourceLineNo">1512</span>      cleanerPool = null;<a name="line.1512"></a>
+<span class="sourceLineNo">1513</span>    }<a name="line.1513"></a>
 <span class="sourceLineNo">1514</span><a name="line.1514"></a>
-<span class="sourceLineNo">1515</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1515"></a>
-<span class="sourceLineNo">1516</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1516"></a>
-<span class="sourceLineNo">1517</span>    // example.<a name="line.1517"></a>
-<span class="sourceLineNo">1518</span>    stopProcedureExecutor();<a name="line.1518"></a>
-<span class="sourceLineNo">1519</span><a name="line.1519"></a>
-<span class="sourceLineNo">1520</span>    if (regionNormalizerManager != null) {<a name="line.1520"></a>
-<span class="sourceLineNo">1521</span>      regionNormalizerManager.stop();<a name="line.1521"></a>
-<span class="sourceLineNo">1522</span>    }<a name="line.1522"></a>
-<span class="sourceLineNo">1523</span>    if (this.quotaManager != null) {<a name="line.1523"></a>
-<span class="sourceLineNo">1524</span>      this.quotaManager.stop();<a name="line.1524"></a>
-<span class="sourceLineNo">1525</span>    }<a name="line.1525"></a>
-<span class="sourceLineNo">1526</span><a name="line.1526"></a>
-<span class="sourceLineNo">1527</span>    if (this.activeMasterManager != null) {<a name="line.1527"></a>
-<span class="sourceLineNo">1528</span>      this.activeMasterManager.stop();<a name="line.1528"></a>
-<span class="sourceLineNo">1529</span>    }<a name="line.1529"></a>
-<span class="sourceLineNo">1530</span>    if (this.serverManager != null) {<a name="line.1530"></a>
-<span class="sourceLineNo">1531</span>      this.serverManager.stop();<a name="line.1531"></a>
-<span class="sourceLineNo">1532</span>    }<a name="line.1532"></a>
-<span class="sourceLineNo">1533</span>    if (this.assignmentManager != null) {<a name="line.1533"></a>
-<span class="sourceLineNo">1534</span>      this.assignmentManager.stop();<a name="line.1534"></a>
-<span class="sourceLineNo">1535</span>    }<a name="line.1535"></a>
-<span class="sourceLineNo">1536</span><a name="line.1536"></a>
-<span class="sourceLineNo">1537</span>    if (masterRegion != null) {<a name="line.1537"></a>
-<span class="sourceLineNo">1538</span>      masterRegion.close(isAborted());<a name="line.1538"></a>
-<span class="sourceLineNo">1539</span>    }<a name="line.1539"></a>
-<span class="sourceLineNo">1540</span>    if (this.walManager != null) {<a name="line.1540"></a>
-<span class="sourceLineNo">1541</span>      this.walManager.stop();<a name="line.1541"></a>
-<span class="sourceLineNo">1542</span>    }<a name="line.1542"></a>
-<span class="sourceLineNo">1543</span>    if (this.fileSystemManager != null) {<a name="line.1543"></a>
-<span class="sourceLineNo">1544</span>      this.fileSystemManager.stop();<a name="line.1544"></a>
-<span class="sourceLineNo">1545</span>    }<a name="line.1545"></a>
-<span class="sourceLineNo">1546</span>    if (this.mpmHost != null) {<a name="line.1546"></a>
-<span class="sourceLineNo">1547</span>      this.mpmHost.stop("server shutting down.");<a name="line.1547"></a>
-<span class="sourceLineNo">1548</span>    }<a name="line.1548"></a>
-<span class="sourceLineNo">1549</span>    if (this.regionServerTracker != null) {<a name="line.1549"></a>
-<span class="sourceLineNo">1550</span>      this.regionServerTracker.stop();<a name="line.1550"></a>
-<span class="sourceLineNo">1551</span>    }<a name="line.1551"></a>
-<span class="sourceLineNo">1552</span>  }<a name="line.1552"></a>
-<span class="sourceLineNo">1553</span><a name="line.1553"></a>
-<span class="sourceLineNo">1554</span>  private void createProcedureExecutor() throws IOException {<a name="line.1554"></a>
-<span class="sourceLineNo">1555</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1555"></a>
-<span class="sourceLineNo">1556</span>    procedureStore =<a name="line.1556"></a>
-<span class="sourceLineNo">1557</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1557"></a>
-<span class="sourceLineNo">1558</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1558"></a>
-<span class="sourceLineNo">1559</span><a name="line.1559"></a>
-<span class="sourceLineNo">1560</span>      @Override<a name="line.1560"></a>
-<span class="sourceLineNo">1561</span>      public void abortProcess() {<a name="line.1561"></a>
-<span class="sourceLineNo">1562</span>        abort("The Procedure Store lost the lease", null);<a name="line.1562"></a>
-<span class="sourceLineNo">1563</span>      }<a name="line.1563"></a>
-<span class="sourceLineNo">1564</span>    });<a name="line.1564"></a>
-<span class="sourceLineNo">1565</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1565"></a>
-<span class="sourceLineNo">1566</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1566"></a>
-<span class="sourceLineNo">1567</span>    configurationManager.registerObserver(procEnv);<a name="line.1567"></a>
-<span class="sourceLineNo">1568</span><a name="line.1568"></a>
-<span class="sourceLineNo">1569</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1569"></a>
-<span class="sourceLineNo">1570</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1570"></a>
-<span class="sourceLineNo">1571</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1571"></a>
-<span class="sourceLineNo">1572</span>    final boolean abortOnCorruption =<a name="line.1572"></a>
-<span class="sourceLineNo">1573</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1573"></a>
-<span class="sourceLineNo">1574</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1574"></a>
-<span class="sourceLineNo">1575</span>    procedureStore.start(numThreads);<a name="line.1575"></a>
-<span class="sourceLineNo">1576</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1576"></a>
-<span class="sourceLineNo">1577</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1577"></a>
-<span class="sourceLineNo">1578</span>    // details.<a name="line.1578"></a>
-<span class="sourceLineNo">1579</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1579"></a>
-<span class="sourceLineNo">1580</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1580"></a>
-<span class="sourceLineNo">1581</span>      throw new HBaseIOException("Failed start of remote dispatcher");<a name="line.1581"></a>
-<span class="sourceLineNo">1582</span>    }<a name="line.1582"></a>
-<span class="sourceLineNo">1583</span>  }<a name="line.1583"></a>
-<span class="sourceLineNo">1584</span><a name="line.1584"></a>
-<span class="sourceLineNo">1585</span>  private void startProcedureExecutor() throws IOException {<a name="line.1585"></a>
-<span class="sourceLineNo">1586</span>    procedureExecutor.startWorkers();<a name="line.1586"></a>
-<span class="sourceLineNo">1587</span>  }<a name="line.1587"></a>
-<span class="sourceLineNo">1588</span><a name="line.1588"></a>
-<span class="sourceLineNo">1589</span>  /**<a name="line.1589"></a>
-<span class="sourceLineNo">1590</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1590"></a>
-<span class="sourceLineNo">1591</span>   *<a name="line.1591"></a>
-<span class="sourceLineNo">1592</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1592"></a>
-<span class="sourceLineNo">1593</span>   */<a name="line.1593"></a>
-<span class="sourceLineNo">1594</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1594"></a>
-<span class="sourceLineNo">1595</span>    if (synchronous) {<a name="line.1595"></a>
-<span class="sourceLineNo">1596</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1596"></a>
-<span class="sourceLineNo">1597</span>        switchSnapshotCleanup(on);<a name="line.1597"></a>
-<span class="sourceLineNo">1598</span>      }<a name="line.1598"></a>
-<span class="sourceLineNo">1599</span>    } else {<a name="line.1599"></a>
-<span class="sourceLineNo">1600</span>      switchSnapshotCleanup(on);<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><a name="line.1603"></a>
-<span class="sourceLineNo">1604</span>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1604"></a>
-<span class="sourceLineNo">1605</span>    try {<a name="line.1605"></a>
-<span class="sourceLineNo">1606</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1606"></a>
-<span class="sourceLineNo">1607</span>      if (on) {<a name="line.1607"></a>
-<span class="sourceLineNo">1608</span>        if (!getChoreService().isChoreScheduled(this.snapshotCleanerChore)) {<a name="line.1608"></a>
-<span class="sourceLineNo">1609</span>          getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1609"></a>
-<span class="sourceLineNo">1610</span>        }<a name="line.1610"></a>
-<span class="sourceLineNo">1611</span>      } else {<a name="line.1611"></a>
-<span class="sourceLineNo">1612</span>        getChoreService().cancelChore(this.snapshotCleanerChore);<a name="line.1612"></a>
-<span class="sourceLineNo">1613</span>      }<a name="line.1613"></a>
-<span class="sourceLineNo">1614</span>    } catch (KeeperException e) {<a name="line.1614"></a>
-<span class="sourceLineNo">1615</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1615"></a>
-<span class="sourceLineNo">1616</span>    }<a name="line.1616"></a>
-<span class="sourceLineNo">1617</span>  }<a name="line.1617"></a>
-<span class="sourceLineNo">1618</span><a name="line.1618"></a>
-<span class="sourceLineNo">1619</span><a name="line.1619"></a>
-<span class="sourceLineNo">1620</span>  private void stopProcedureExecutor() {<a name="line.1620"></a>
-<span class="sourceLineNo">1621</span>    if (procedureExecutor != null) {<a name="line.1621"></a>
-<span class="sourceLineNo">1622</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1622"></a>
-<span class="sourceLineNo">1623</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1623"></a>
-<span class="sourceLineNo">1624</span>      procedureExecutor.stop();<a name="line.1624"></a>
-<span class="sourceLineNo">1625</span>      procedureExecutor.join();<a name="line.1625"></a>
-<span class="sourceLineNo">1626</span>      procedureExecutor = null;<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>    if (procedureStore != null) {<a name="line.1629"></a>
-<span class="sourceLineNo">1630</span>      procedureStore.stop(isAborted());<a name="line.1630"></a>
-<span class="sourceLineNo">1631</span>      procedureStore = null;<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>  private void stopChores() {<a name="line.1635"></a>
-<span class="sourceLineNo">1636</span>    ChoreService choreService = getChoreService();<a name="line.1636"></a>
-<span class="sourceLineNo">1637</span>    if (choreService != null) {<a name="line.1637"></a>
-<span class="sourceLineNo">1638</span>      choreService.cancelChore(this.mobFileCleanerChore);<a name="line.1638"></a>
-<span class="sourceLineNo">1639</span>      choreService.cancelChore(this.mobFileCompactionChore);<a name="line.1639"></a>
-<span class="sourceLineNo">1640</span>      choreService.cancelChore(this.balancerChore);<a name="line.1640"></a>
-<span class="sourceLineNo">1641</span>      choreService.cancelChore(getRegionNormalizerManager().getRegionNormalizerChore());<a name="line.1641"></a>
-<span class="sourceLineNo">1642</span>      choreService.cancelChore(this.clusterStatusChore);<a name="line.1642"></a>
-<span class="sourceLineNo">1643</span>      choreService.cancelChore(this.catalogJanitorChore);<a name="line.1643"></a>
-<span class="sourceLineNo">1644</span>      choreService.cancelChore(this.clusterStatusPublisherChore);<a name="line.1644"></a>
-<span class="sourceLineNo">1645</span>      choreService.cancelChore(this.snapshotQuotaChore);<a name="line.1645"></a>
-<span class="sourceLineNo">1646</span>      choreService.cancelChore(this.logCleaner);<a name="line.1646"></a>
-<span class="sourceLineNo">1647</span>      choreService.cancelChore(this.hfileCleaner);<a name="line.1647"></a>
-<span class="sourceLineNo">1648</span>      choreService.cancelChore(this.replicationBarrierCleaner);<a name="line.1648"></a>
-<span class="sourceLineNo">1649</span>      choreService.cancelChore(this.snapshotCleanerChore);<a name="line.1649"></a>
-<span class="sourceLineNo">1650</span>      choreService.cancelChore(this.hbckChore);<a name="line.1650"></a>
-<span class="sourceLineNo">1651</span>      choreService.cancelChore(this.regionsRecoveryChore);<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><a name="line.1654"></a>
-<span class="sourceLineNo">1655</span>  /**<a name="line.1655"></a>
-<span class="sourceLineNo">1656</span>   * @return Get remote side's InetAddress<a name="line.1656"></a>
-<span class="sourceLineNo">1657</span>   */<a name="line.1657"></a>
-<span class="sourceLineNo">1658</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1658"></a>
-<span class="sourceLineNo">1659</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1659"></a>
-<span class="sourceLineNo">1660</span>    // Do it out here in its own little method so can fake an address when<a name="line.1660"></a>
-<span class="sourceLineNo">1661</span>    // mocking up in tests.<a name="line.1661"></a>
-<span class="sourceLineNo">1662</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1662"></a>
-<span class="sourceLineNo">1663</span><a name="line.1663"></a>
-<span class="sourceLineNo">1664</span>    // The call could be from the local regionserver,<a name="line.1664"></a>
-<span class="sourceLineNo">1665</span>    // in which case, there is no remote address.<a name="line.1665"></a>
-<span class="sourceLineNo">1666</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1666"></a>
-<span class="sourceLineNo">1667</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1667"></a>
-<span class="sourceLineNo">1668</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1668"></a>
-<span class="sourceLineNo">1669</span>        ia = isa.getAddress();<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>    return ia;<a name="line.1672"></a>
-<span class="sourceLineNo">1673</span>  }<a name="line.1673"></a>
-<span class="sourceLineNo">1674</span><a name="line.1674"></a>
-<span class="sourceLineNo">1675</span>  /**<a name="line.1675"></a>
-<span class="sourceLineNo">1676</span>   * @return Maximum time we should run balancer for<a name="line.1676"></a>
-<span class="sourceLineNo">1677</span>   */<a name="line.1677"></a>
-<span class="sourceLineNo">1678</span>  private int getMaxBalancingTime() {<a name="line.1678"></a>
-<span class="sourceLineNo">1679</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1679"></a>
-<span class="sourceLineNo">1680</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1680"></a>
-<span class="sourceLineNo">1681</span>      getConfiguration()<a name="line.1681"></a>
-<span class="sourceLineNo">1682</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1682"></a>
-<span class="sourceLineNo">1683</span>    return maxBalancingTime;<a name="line.1683"></a>
-<span class="sourceLineNo">1684</span>  }<a name="line.1684"></a>
-<span class="sourceLineNo">1685</span><a name="line.1685"></a>
-<span class="sourceLineNo">1686</span>  /**<a name="line.1686"></a>
-<span class="sourceLineNo">1687</span>   * @return Maximum number of regions in transition<a name="line.1687"></a>
-<span class="sourceLineNo">1688</span>   */<a name="line.1688"></a>
-<span class="sourceLineNo">1689</span>  private int getMaxRegionsInTransition() {<a name="line.1689"></a>
-<span class="sourceLineNo">1690</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1690"></a>
-<span class="sourceLineNo">1691</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<a name="line.1691"></a>
-<span class="sourceLineNo">1692</span>  }<a name="line.1692"></a>
-<span class="sourceLineNo">1693</span><a name="line.1693"></a>
-<span class="sourceLineNo">1694</span>  /**<a name="line.1694"></a>
-<span class="sourceLineNo">1695</span>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1695"></a>
-<span class="sourceLineNo">1696</span>   * number regions in transition to protect availability.<a name="line.1696"></a>
-<span class="sourceLineNo">1697</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1697"></a>
-<span class="sourceLineNo">1698</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1698"></a>
-<span class="sourceLineNo">1699</span>   * @param cutoffTime when to exit balancer<a name="line.1699"></a>
-<span class="sourceLineNo">1700</span>   */<a name="line.1700"></a>
-<span class="sourceLineNo">1701</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1701"></a>
-<span class="sourceLineNo">1702</span>      long cutoffTime) {<a name="line.1702"></a>
-<span class="sourceLineNo">1703</span>    boolean interrupted = false;<a name="line.1703"></a>
-<span class="sourceLineNo">1704</span><a name="line.1704"></a>
-<span class="sourceLineNo">1705</span>    // Sleep to next balance plan start time<a name="line.1705"></a>
-<span class="sourceLineNo">1706</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1706"></a>
-<span class="sourceLineNo">1707</span>    while (!interrupted &amp;&amp; System.currentTimeMillis() &lt; nextBalanceStartTime<a name="line.1707"></a>
-<span class="sourceLineNo">1708</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1708"></a>
-<span class="sourceLineNo">1709</span>      try {<a name="line.1709"></a>
-<span class="sourceLineNo">1710</span>        Thread.sleep(100);<a name="line.1710"></a>
-<span class="sourceLineNo">1711</span>      } catch (InterruptedException ie) {<a name="line.1711"></a>
-<span class="sourceLineNo">1712</span>        interrupted = true;<a name="line.1712"></a>
-<span class="sourceLineNo">1713</span>      }<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>    // Throttling by max number regions in transition<a name="line.1716"></a>
-<span class="sourceLineNo">1717</span>    while (!interrupted<a name="line.1717"></a>
-<span class="sourceLineNo">1718</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1718"></a>
-<span class="sourceLineNo">1719</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1719"></a>
-<span class="sourceLineNo">1720</span>        &gt;= maxRegionsInTransition &amp;&amp; System.currentTimeMillis() &lt;= cutoffTime) {<a name="line.1720"></a>
-<span class="sourceLineNo">1721</span>      try {<a name="line.1721"></a>
-<span class="sourceLineNo">1722</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1722"></a>
-<span class="sourceLineNo">1723</span>        Thread.sleep(100);<a name="line.1723"></a>
-<span class="sourceLineNo">1724</span>      } catch (InterruptedException ie) {<a name="line.1724"></a>
-<span class="sourceLineNo">1725</span>        interrupted = true;<a name="line.1725"></a>
-<span class="sourceLineNo">1726</span>      }<a name="line.1726"></a>
-<span class="sourceLineNo">1727</span>    }<a name="line.1727"></a>
-<span class="sourceLineNo">1728</span><a name="line.1728"></a>
-<span class="sourceLineNo">1729</span>    if (interrupted) Thread.currentThread().interrupt();<a name="line.1729"></a>
-<span class="sourceLineNo">1730</span>  }<a name="line.1730"></a>
-<span class="sourceLineNo">1731</span><a name="line.1731"></a>
-<span class="sourceLineNo">1732</span>  public boolean balance() throws IOException {<a name="line.1732"></a>
-<span class="sourceLineNo">1733</span>    return balance(false);<a name="line.1733"></a>
+<span class="sourceLineNo">1515</span>    LOG.debug("Stopping service threads");<a name="line.1515"></a>
+<span class="sourceLineNo">1516</span><a name="line.1516"></a>
+<span class="sourceLineNo">1517</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1517"></a>
+<span class="sourceLineNo">1518</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1518"></a>
+<span class="sourceLineNo">1519</span>    // example.<a name="line.1519"></a>
+<span class="sourceLineNo">1520</span>    stopProcedureExecutor();<a name="line.1520"></a>
+<span class="sourceLineNo">1521</span><a name="line.1521"></a>
+<span class="sourceLineNo">1522</span>    if (regionNormalizerManager != null) {<a name="line.1522"></a>
+<span class="sourceLineNo">1523</span>      regionNormalizerManager.stop();<a name="line.1523"></a>
+<span class="sourceLineNo">1524</span>    }<a name="line.1524"></a>
+<span class="sourceLineNo">1525</span>    if (this.quotaManager != null) {<a name="line.1525"></a>
+<span class="sourceLineNo">1526</span>      this.quotaManager.stop();<a name="line.1526"></a>
+<span class="sourceLineNo">1527</span>    }<a name="line.1527"></a>
+<span class="sourceLineNo">1528</span><a name="line.1528"></a>
+<span class="sourceLineNo">1529</span>    if (this.activeMasterManager != null) {<a name="line.1529"></a>
+<span class="sourceLineNo">1530</span>      this.activeMasterManager.stop();<a name="line.1530"></a>
+<span class="sourceLineNo">1531</span>    }<a name="line.1531"></a>
+<span class="sourceLineNo">1532</span>    if (this.serverManager != null) {<a name="line.1532"></a>
+<span class="sourceLineNo">1533</span>      this.serverManager.stop();<a name="line.1533"></a>
+<span class="sourceLineNo">1534</span>    }<a name="line.1534"></a>
+<span class="sourceLineNo">1535</span>    if (this.assignmentManager != null) {<a name="line.1535"></a>
+<span class="sourceLineNo">1536</span>      this.assignmentManager.stop();<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>    if (masterRegion != null) {<a name="line.1539"></a>
+<span class="sourceLineNo">1540</span>      masterRegion.close(isAborted());<a name="line.1540"></a>
+<span class="sourceLineNo">1541</span>    }<a name="line.1541"></a>
+<span class="sourceLineNo">1542</span>    if (this.walManager != null) {<a name="line.1542"></a>
+<span class="sourceLineNo">1543</span>      this.walManager.stop();<a name="line.1543"></a>
+<span class="sourceLineNo">1544</span>    }<a name="line.1544"></a>
+<span class="sourceLineNo">1545</span>    if (this.fileSystemManager != null) {<a name="line.1545"></a>
+<span class="sourceLineNo">1546</span>      this.fileSystemManager.stop();<a name="line.1546"></a>
+<span class="sourceLineNo">1547</span>    }<a name="line.1547"></a>
+<span class="sourceLineNo">1548</span>    if (this.mpmHost != null) {<a name="line.1548"></a>
+<span class="sourceLineNo">1549</span>      this.mpmHost.stop("server shutting down.");<a name="line.1549"></a>
+<span class="sourceLineNo">1550</span>    }<a name="line.1550"></a>
+<span class="sourceLineNo">1551</span>    if (this.regionServerTracker != null) {<a name="line.1551"></a>
+<span class="sourceLineNo">1552</span>      this.regionServerTracker.stop();<a name="line.1552"></a>
+<span class="sourceLineNo">1553</span>    }<a name="line.1553"></a>
+<span class="sourceLineNo">1554</span>  }<a name="line.1554"></a>
+<span class="sourceLineNo">1555</span><a name="line.1555"></a>
+<span class="sourceLineNo">1556</span>  private void createProcedureExecutor() throws IOException {<a name="line.1556"></a>
+<span class="sourceLineNo">1557</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1557"></a>
+<span class="sourceLineNo">1558</span>    procedureStore =<a name="line.1558"></a>
+<span class="sourceLineNo">1559</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1559"></a>
+<span class="sourceLineNo">1560</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1560"></a>
+<span class="sourceLineNo">1561</span><a name="line.1561"></a>
+<span class="sourceLineNo">1562</span>      @Override<a name="line.1562"></a>
+<span class="sourceLineNo">1563</span>      public void abortProcess() {<a name="line.1563"></a>
+<span class="sourceLineNo">1564</span>        abort("The Procedure Store lost the lease", null);<a name="line.1564"></a>
+<span class="sourceLineNo">1565</span>      }<a name="line.1565"></a>
+<span class="sourceLineNo">1566</span>    });<a name="line.1566"></a>
+<span class="sourceLineNo">1567</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1567"></a>
+<span class="sourceLineNo">1568</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1568"></a>
+<span class="sourceLineNo">1569</span>    configurationManager.registerObserver(procEnv);<a name="line.1569"></a>
+<span class="sourceLineNo">1570</span><a name="line.1570"></a>
+<span class="sourceLineNo">1571</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1571"></a>
+<span class="sourceLineNo">1572</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1572"></a>
+<span class="sourceLineNo">1573</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1573"></a>
+<span class="sourceLineNo">1574</span>    final boolean abortOnCorruption =<a name="line.1574"></a>
+<span class="sourceLineNo">1575</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1575"></a>
+<span class="sourceLineNo">1576</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1576"></a>
+<span class="sourceLineNo">1577</span>    procedureStore.start(numThreads);<a name="line.1577"></a>
+<span class="sourceLineNo">1578</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1578"></a>
+<span class="sourceLineNo">1579</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1579"></a>
+<span class="sourceLineNo">1580</span>    // details.<a name="line.1580"></a>
+<span class="sourceLineNo">1581</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1581"></a>
+<span class="sourceLineNo">1582</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1582"></a>
+<span class="sourceLineNo">1583</span>      throw new HBaseIOException("Failed start of remote dispatcher");<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><a name="line.1586"></a>
+<span class="sourceLineNo">1587</span>  private void startProcedureExecutor() throws IOException {<a name="line.1587"></a>
+<span class="sourceLineNo">1588</span>    procedureExecutor.startWorkers();<a name="line.1588"></a>
+<span class="sourceLineNo">1589</span>  }<a name="line.1589"></a>
+<span class="sourceLineNo">1590</span><a name="line.1590"></a>
+<span class="sourceLineNo">1591</span>  /**<a name="line.1591"></a>
+<span class="sourceLineNo">1592</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1592"></a>
+<span class="sourceLineNo">1593</span>   *<a name="line.1593"></a>
+<span class="sourceLineNo">1594</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1594"></a>
+<span class="sourceLineNo">1595</span>   */<a name="line.1595"></a>
+<span class="sourceLineNo">1596</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1596"></a>
+<span class="sourceLineNo">1597</span>    if (synchronous) {<a name="line.1597"></a>
+<span class="sourceLineNo">1598</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1598"></a>
+<span class="sourceLineNo">1599</span>        switchSnapshotCleanup(on);<a name="line.1599"></a>
+<span class="sourceLineNo">1600</span>      }<a name="line.1600"></a>
+<span class="sourceLineNo">1601</span>    } else {<a name="line.1601"></a>
+<span class="sourceLineNo">1602</span>      switchSnapshotCleanup(on);<a name="line.1602"></a>
+<span class="sourceLineNo">1603</span>    }<a name="line.1603"></a>
+<span class="sourceLineNo">1604</span>  }<a name="line.1604"></a>
+<span class="sourceLineNo">1605</span><a name="line.1605"></a>
+<span class="sourceLineNo">1606</span>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1606"></a>
+<span class="sourceLineNo">1607</span>    try {<a name="line.1607"></a>
+<span class="sourceLineNo">1608</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1608"></a>
+<span class="sourceLineNo">1609</span>      if (on) {<a name="line.1609"></a>
+<span class="sourceLineNo">1610</span>        if (!getChoreService().isChoreScheduled(this.snapshotCleanerChore)) {<a name="line.1610"></a>
+<span class="sourceLineNo">1611</span>          getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1611"></a>
+<span class="sourceLineNo">1612</span>        }<a name="line.1612"></a>
+<span class="sourceLineNo">1613</span>      } else {<a name="line.1613"></a>
+<span class="sourceLineNo">1614</span>        getChoreService().cancelChore(this.snapshotCleanerChore);<a name="line.1614"></a>
+<span class="sourceLineNo">1615</span>      }<a name="line.1615"></a>
+<span class="sourceLineNo">1616</span>    } catch (KeeperException e) {<a name="line.1616"></a>
+<span class="sourceLineNo">1617</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1617"></a>
+<span class="sourceLineNo">1618</span>    }<a name="line.1618"></a>
+<span class="sourceLineNo">1619</span>  }<a name="line.1619"></a>
+<span class="sourceLineNo">1620</span><a name="line.1620"></a>
+<span class="sourceLineNo">1621</span><a name="line.1621"></a>
+<span class="sourceLineNo">1622</span>  private void stopProcedureExecutor() {<a name="line.1622"></a>
+<span class="sourceLineNo">1623</span>    if (procedureExecutor != null) {<a name="line.1623"></a>
+<span class="sourceLineNo">1624</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1624"></a>
+<span class="sourceLineNo">1625</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1625"></a>
+<span class="sourceLineNo">1626</span>      procedureExecutor.stop();<a name="line.1626"></a>
+<span class="sourceLineNo">1627</span>      procedureExecutor.join();<a name="line.1627"></a>
+<span class="sourceLineNo">1628</span>      procedureExecutor = null;<a name="line.1628"></a>
+<span class="sourceLineNo">1629</span>    }<a name="line.1629"></a>
+<span class="sourceLineNo">1630</span><a name="line.1630"></a>
+<span class="sourceLineNo">1631</span>    if (procedureStore != null) {<a name="line.1631"></a>
+<span class="sourceLineNo">1632</span>      procedureStore.stop(isAborted());<a name="line.1632"></a>
+<span class="sourceLineNo">1633</span>      procedureStore = null;<a name="line.1633"></a>
+<span class="sourceLineNo">1634</span>    }<a name="line.1634"></a>
+<span class="sourceLineNo">1635</span>  }<a name="line.1635"></a>
+<span class="sourceLineNo">1636</span><a name="line.1636"></a>
+<span class="sourceLineNo">1637</span>  private void stopChores() {<a name="line.1637"></a>
+<span class="sourceLineNo">1638</span>    ChoreService choreService = getChoreService();<a name="line.1638"></a>
+<span class="sourceLineNo">1639</span>    if (choreService != null) {<a name="line.1639"></a>
+<span class="sourceLineNo">1640</span>      choreService.cancelChore(this.mobFileCleanerChore);<a name="line.1640"></a>
+<span class="sourceLineNo">1641</span>      choreService.cancelChore(this.mobFileCompactionChore);<a name="line.1641"></a>
+<span class="sourceLineNo">1642</span>      choreService.cancelChore(this.balancerChore);<a name="line.1642"></a>
+<span class="sourceLineNo">1643</span>      if (regionNormalizerManager != null) {<a name="line.1643"></a>
+<span class="sourceLineNo">1644</span>        choreService.cancelChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1644"></a>
+<span class="sourceLineNo">1645</span>      }<a name="line.1645"></a>
+<span class="sourceLineNo">1646</span>      choreService.cancelChore(this.clusterStatusChore);<a name="line.1646"></a>
+<span class="sourceLineNo">1647</span>      choreService.cancelChore(this.catalogJanitorChore);<a name="line.1647"></a>
+<span class="sourceLineNo">1648</span>      choreService.cancelChore(this.clusterStatusPublisherChore);<a name="line.1648"></a>
+<span class="sourceLineNo">1649</span>      choreService.cancelChore(this.snapshotQuotaChore);<a name="line.1649"></a>
+<span class="sourceLineNo">1650</span>      choreService.cancelChore(this.logCleaner);<a name="line.1650"></a>
+<span class="sourceLineNo">1651</span>      choreService.cancelChore(this.hfileCleaner);<a name="line.1651"></a>
+<span class="sourceLineNo">1652</span>      choreService.cancelChore(this.replicationBarrierCleaner);<a name="line.1652"></a>
+<span class="sourceLineNo">1653</span>      choreService.cancelChore(this.snapshotCleanerChore);<a name="line.1653"></a>
+<span class="sourceLineNo">1654</span>      choreService.cancelChore(this.hbckChore);<a name="line.1654"></a>
+<span class="sourceLineNo">1655</span>      choreService.cancelChore(this.regionsRecoveryChore);<a name="line.1655"></a>
+<span class="sourceLineNo">1656</span>    }<a name="line.1656"></a>
+<span class="sourceLineNo">1657</span>  }<a name="line.1657"></a>
+<span class="sourceLineNo">1658</span><a name="line.1658"></a>
+<span class="sourceLineNo">1659</span>  /**<a name="line.1659"></a>
+<span class="sourceLineNo">1660</span>   * @return Get remote side's InetAddress<a name="line.1660"></a>
+<span class="sourceLineNo">1661</span>   */<a name="line.1661"></a>
+<span class="sourceLineNo">1662</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1662"></a>
+<span class="sourceLineNo">1663</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1663"></a>
+<span class="sourceLineNo">1664</span>    // Do it out here in its own little method so can fake an address when<a name="line.1664"></a>
+<span class="sourceLineNo">1665</span>    // mocking up in tests.<a name="line.1665"></a>
+<span class="sourceLineNo">1666</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1666"></a>
+<span class="sourceLineNo">1667</span><a name="line.1667"></a>
+<span class="sourceLineNo">1668</span>    // The call could be from the local regionserver,<a name="line.1668"></a>
+<span class="sourceLineNo">1669</span>    // in which case, there is no remote address.<a name="line.1669"></a>
+<span class="sourceLineNo">1670</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1670"></a>
+<span class="sourceLineNo">1671</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1671"></a>
+<span class="sourceLineNo">1672</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1672"></a>
+<span class="sourceLineNo">1673</span>        ia = isa.getAddress();<a name="line.1673"></a>
+<span class="sourceLineNo">1674</span>      }<a name="line.1674"></a>
+<span class="sourceLineNo">1675</span>    }<a name="line.1675"></a>
+<span class="sourceLineNo">1676</span>    return ia;<a name="line.1676"></a>
+<span class="sourceLineNo">1677</span>  }<a name="line.1677"></a>
+<span class="sourceLineNo">1678</span><a name="line.1678"></a>
+<span class="sourceLineNo">1679</span>  /**<a name="line.1679"></a>
+<span class="sourceLineNo">1680</span>   * @return Maximum time we should run balancer for<a name="line.1680"></a>
+<span class="sourceLineNo">1681</span>   */<a name="line.1681"></a>
+<span class="sourceLineNo">1682</span>  private int getMaxBalancingTime() {<a name="line.1682"></a>
+<span class="sourceLineNo">1683</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1683"></a>
+<span class="sourceLineNo">1684</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1684"></a>
+<span class="sourceLineNo">1685</span>      getConfiguration()<a name="line.1685"></a>
+<span class="sourceLineNo">1686</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1686"></a>
+<span class="sourceLineNo">1687</span>    return maxBalancingTime;<a name="line.1687"></a>
+<span class="sourceLineNo">1688</span>  }<a name="line.1688"></a>
+<span class="sourceLineNo">1689</span><a name="line.1689"></a>
+<span class="sourceLineNo">1690</span>  /**<a name="line.1690"></a>
+<span class="sourceLineNo">1691</span>   * @return Maximum number of regions in transition<a name="line.1691"></a>
+<span class="sourceLineNo">1692</span>   */<a name="line.1692"></a>
+<span class="sourceLineNo">1693</span>  private int getMaxRegionsInTransition() {<a name="line.1693"></a>
+<span class="sourceLineNo">1694</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1694"></a>
+<span class="sourceLineNo">1695</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<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>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1699"></a>
+<span class="sourceLineNo">1700</span>   * number regions in transition to protect availability.<a name="line.1700"></a>
+<span class="sourceLineNo">1701</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1701"></a>
+<span class="sourceLineNo">1702</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1702"></a>
+<span class="sourceLineNo">1703</span>   * @param cutoffTime when to exit balancer<a name="line.1703"></a>
+<span class="sourceLineNo">1704</span>   */<a name="line.1704"></a>
+<span class="sourceLineNo">1705</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1705"></a>
+<span class="sourceLineNo">1706</span>      long cutoffTime) {<a name="line.1706"></a>
+<span class="sourceLineNo">1707</span>    boolean interrupted = false;<a name="line.1707"></a>
+<span class="sourceLineNo">1708</span><a name="line.1708"></a>
+<span class="sourceLineNo">1709</span>    // Sleep to next balance plan start time<a name="line.1709"></a>
+<span class="sourceLineNo">1710</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1710"></a>
+<span class="sourceLineNo">1711</span>    while (!interrupted &amp;&amp; System.currentTimeMillis() &lt; nextBalanceStartTime<a name="line.1711"></a>
+<span class="sourceLineNo">1712</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1712"></a>
+<span class="sourceLineNo">1713</span>      try {<a name="line.1713"></a>
+<span class="sourceLineNo">1714</span>        Thread.sleep(100);<a name="line.1714"></a>
+<span class="sourceLineNo">1715</span>      } catch (InterruptedException ie) {<a name="line.1715"></a>
+<span class="sourceLineNo">1716</span>        interrupted = true;<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>    // Throttling by max number regions in transition<a name="line.1720"></a>
+<span class="sourceLineNo">1721</span>    while (!interrupted<a name="line.1721"></a>
+<span class="sourceLineNo">1722</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1722"></a>
+<span class="sourceLineNo">1723</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1723"></a>
+<span class="sourceLineNo">1724</span>        &gt;= maxRegionsInTransition &amp;&amp; System.currentTimeMillis() &lt;= cutoffTime) {<a name="line.1724"></a>
+<span class="sourceLineNo">1725</span>      try {<a name="line.1725"></a>
+<span class="sourceLineNo">1726</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1726"></a>
+<span class="sourceLineNo">1727</span>        Thread.sleep(100);<a name="line.1727"></a>
+<span class="sourceLineNo">1728</span>      } catch (InterruptedException ie) {<a name="line.1728"></a>
+<span class="sourceLineNo">1729</span>        interrupted = true;<a name="line.1729"></a>
+<span class="sourceLineNo">1730</span>      }<a name="line.1730"></a>
+<span class="sourceLineNo">1731</span>    }<a name="line.1731"></a>
+<span class="sourceLineNo">1732</span><a name="line.1732"></a>
+<span class="sourceLineNo">1733</span>    if (interrupted) Thread.currentThread().interrupt();<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>  /**<a name="line.1736"></a>
-<span class="sourceLineNo">1737</span>   * Checks master state before initiating action over region topology.<a name="line.1737"></a>
-<span class="sourceLineNo">1738</span>   * @param action the name of the action under consideration, for logging.<a name="line.1738"></a>
-<span class="sourceLineNo">1739</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1739"></a>
-<span class="sourceLineNo">1740</span>   */<a name="line.1740"></a>
-<span class="sourceLineNo">1741</span>  @Override<a name="line.1741"></a>
-<span class="sourceLineNo">1742</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1742"></a>
-<span class="sourceLineNo">1743</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1743"></a>
-<span class="sourceLineNo">1744</span>    if (!isInitialized()) {<a name="line.1744"></a>
-<span class="sourceLineNo">1745</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1745"></a>
-<span class="sourceLineNo">1746</span>      return true;<a name="line.1746"></a>
-<span class="sourceLineNo">1747</span>    }<a name="line.1747"></a>
-<span class="sourceLineNo">1748</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1748"></a>
-<span class="sourceLineNo">1749</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1749"></a>
+<span class="sourceLineNo">1736</span>  public boolean balance() throws IOException {<a name="line.1736"></a>
+<span class="sourceLineNo">1737</span>    return balance(false);<a name="line.1737"></a>
+<span class="sourceLineNo">1738</span>  }<a name="line.1738"></a>
+<span class="sourceLineNo">1739</span><a name="line.1739"></a>
+<span class="sourceLineNo">1740</span>  /**<a name="line.1740"></a>
+<span class="sourceLineNo">1741</span>   * Checks master state before initiating action over region topology.<a name="line.1741"></a>
+<span class="sourceLineNo">1742</span>   * @param action the name of the action under consideration, for logging.<a name="line.1742"></a>
+<span class="sourceLineNo">1743</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1743"></a>
+<span class="sourceLineNo">1744</span>   */<a name="line.1744"></a>
+<span class="sourceLineNo">1745</span>  @Override<a name="line.1745"></a>
+<span class="sourceLineNo">1746</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1746"></a>
+<span class="sourceLineNo">1747</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1747"></a>
+<span class="sourceLineNo">1748</span>    if (!isInitialized()) {<a name="line.1748"></a>
+<span class="sourceLineNo">1749</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1749"></a>
 <span class="sourceLineNo">1750</span>      return true;<a name="line.1750"></a>
 <span class="sourceLineNo">1751</span>    }<a name="line.1751"></a>
-<span class="sourceLineNo">1752</span>    if (isInMaintenanceMode()) {<a name="line.1752"></a>
-<span class="sourceLineNo">1753</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1753"></a>
+<span class="sourceLineNo">1752</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1752"></a>
+<span class="sourceLineNo">1753</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1753"></a>
 <span class="sourceLineNo">1754</span>      return true;<a name="line.1754"></a>
 <span class="sourceLineNo">1755</span>    }<a name="line.1755"></a>
-<span class="sourceLineNo">1756</span>    return false;<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>  public boolean balance(boolean force) throws IOException {<a name="line.1759"></a>
-<span class="sourceLineNo">1760</span>    if (loadBalancerTracker == null || !loadBalancerTracker.isBalancerOn()) {<a name="line.1760"></a>
-<span class="sourceLineNo">1761</span>      return false;<a name="line.1761"></a>
-<span class="sourceLineNo">1762</span>    }<a name="line.1762"></a>
-<span class="sourceLineNo">1763</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1763"></a>
-<span class="sourceLineNo">1764</span>      return false;<a name="line.1764"></a>
-<span class="sourceLineNo">1765</span>    }<a name="line.1765"></a>
-<span class="sourceLineNo">1766</span><a name="line.1766"></a>
-<span class="sourceLineNo">1767</span>    synchronized (this.balancer) {<a name="line.1767"></a>
-<span class="sourceLineNo">1768</span>        // Only allow one balance run at at time.<a name="line.1768"></a>
-<span class="sourceLineNo">1769</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1769"></a>
-<span class="sourceLineNo">1770</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1770"></a>
-<span class="sourceLineNo">1771</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1771"></a>
-<span class="sourceLineNo">1772</span>        // ignore the force flag in that case<a name="line.1772"></a>
-<span class="sourceLineNo">1773</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1773"></a>
-<span class="sourceLineNo">1774</span>        String prefix = force &amp;&amp; !metaInTransition ? "R" : "Not r";<a name="line.1774"></a>
-<span class="sourceLineNo">1775</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1775"></a>
-<span class="sourceLineNo">1776</span>        int max = 5;<a name="line.1776"></a>
-<span class="sourceLineNo">1777</span>        boolean truncated = false;<a name="line.1777"></a>
-<span class="sourceLineNo">1778</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1778"></a>
-<span class="sourceLineNo">1779</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1779"></a>
-<span class="sourceLineNo">1780</span>          truncated = true;<a name="line.1780"></a>
-<span class="sourceLineNo">1781</span>        }<a name="line.1781"></a>
-<span class="sourceLineNo">1782</span>        LOG.info(prefix + " not running balancer because " + regionsInTransition.size() +<a name="line.1782"></a>
-<span class="sourceLineNo">1783</span>          " region(s) in transition: " + toPrint + (truncated? "(truncated list)": ""));<a name="line.1783"></a>
-<span class="sourceLineNo">1784</span>        if (!force || metaInTransition) return false;<a name="line.1784"></a>
-<span class="sourceLineNo">1785</span>      }<a name="line.1785"></a>
-<span class="sourceLineNo">1786</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1786"></a>
-<span class="sourceLineNo">1787</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1787"></a>
-<span class="sourceLineNo">1788</span>          this.serverManager.getDeadServers());<a name="line.1788"></a>
-<span class="sourceLineNo">1789</span>        return false;<a name="line.1789"></a>
-<span class="sourceLineNo">1790</span>      }<a name="line.1790"></a>
-<span class="sourceLineNo">1791</span><a name="line.1791"></a>
-<span class="sourceLineNo">1792</span>      if (this.cpHost != null) {<a name="line.1792"></a>
-<span class="sourceLineNo">1793</span>        try {<a name="line.1793"></a>
-<span class="sourceLineNo">1794</span>          if (this.cpHost.preBalance()) {<a name="line.1794"></a>
-<span class="sourceLineNo">1795</span>            LOG.debug("Coprocessor bypassing balancer request");<a name="line.1795"></a>
-<span class="sourceLineNo">1796</span>            return false;<a name="line.1796"></a>
-<span class="sourceLineNo">1797</span>          }<a name="line.1797"></a>
-<span class="sourceLineNo">1798</span>        } catch (IOException ioe) {<a name="line.1798"></a>
-<span class="sourceLineNo">1799</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<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><a name="line.1803"></a>
-<span class="sourceLineNo">1804</span>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1804"></a>
-<span class="sourceLineNo">1805</span>        this.assignmentManager.getRegionStates()<a name="line.1805"></a>
-<span class="sourceLineNo">1806</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1806"></a>
-<span class="sourceLineNo">1807</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1807"></a>
-<span class="sourceLineNo">1808</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<a name="line.1808"></a>
-<span class="sourceLineNo">1809</span>      }<a name="line.1809"></a>
-<span class="sourceLineNo">1810</span><a name="line.1810"></a>
-<span class="sourceLineNo">1811</span>      //Give the balancer the current cluster state.<a name="line.1811"></a>
-<span class="sourceLineNo">1812</span>      this.balancer.setClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1812"></a>
-<span class="sourceLineNo">1813</span><a name="line.1813"></a>
-<span class="sourceLineNo">1814</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<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>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1817"></a>
-<span class="sourceLineNo">1818</span>        return false;<a name="line.1818"></a>
-<span class="sourceLineNo">1819</span>      }<a name="line.1819"></a>
-<span class="sourceLineNo">1820</span><a name="line.1820"></a>
-<span class="sourceLineNo">1821</span>      List&lt;RegionPlan&gt; sucRPs = executeRegionPlansWithThrottling(plans);<a name="line.1821"></a>
-<span class="sourceLineNo">1822</span><a name="line.1822"></a>
-<span class="sourceLineNo">1823</span>      if (this.cpHost != null) {<a name="line.1823"></a>
-<span class="sourceLineNo">1824</span>        try {<a name="line.1824"></a>
-<span class="sourceLineNo">1825</span>          this.cpHost.postBalance(sucRPs);<a name="line.1825"></a>
-<span class="sourceLineNo">1826</span>        } catch (IOException ioe) {<a name="line.1826"></a>
-<span class="sourceLineNo">1827</span>          // balancing already succeeded so don't change the result<a name="line.1827"></a>
-<span class="sourceLineNo">1828</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<a name="line.1828"></a>
-<span class="sourceLineNo">1829</span>        }<a name="line.1829"></a>
-<span class="sourceLineNo">1830</span>      }<a name="line.1830"></a>
-<span class="sourceLineNo">1831</span>    }<a name="line.1831"></a>
-<span class="sourceLineNo">1832</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1832"></a>
-<span class="sourceLineNo">1833</span>    // Return true indicating a success.<a name="line.1833"></a>
-<span class="sourceLineNo">1834</span>    return true;<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>  /**<a name="line.1837"></a>
-<span class="sourceLineNo">1838</span>   * Execute region plans with throttling<a name="line.1838"></a>
-<span class="sourceLineNo">1839</span>   * @param plans to execute<a name="line.1839"></a>
-<span class="sourceLineNo">1840</span>   * @return succeeded plans<a name="line.1840"></a>
-<span class="sourceLineNo">1841</span>   */<a name="line.1841"></a>
-<span class="sourceLineNo">1842</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1842"></a>
-<span class="sourceLineNo">1843</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1843"></a>
-<span class="sourceLineNo">1844</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1844"></a>
-<span class="sourceLineNo">1845</span>    long balanceStartTime = System.currentTimeMillis();<a name="line.1845"></a>
-<span class="sourceLineNo">1846</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1846"></a>
-<span class="sourceLineNo">1847</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1847"></a>
-<span class="sourceLineNo">1848</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1848"></a>
-<span class="sourceLineNo">1849</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1849"></a>
-<span class="sourceLineNo">1850</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1850"></a>
-<span class="sourceLineNo">1851</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1851"></a>
-<span class="sourceLineNo">1852</span>          + maxRegionsInTransition);<a name="line.1852"></a>
-<span class="sourceLineNo">1853</span><a name="line.1853"></a>
-<span class="sourceLineNo">1854</span>      for (RegionPlan plan: plans) {<a name="line.1854"></a>
-<span class="sourceLineNo">1855</span>        LOG.info("balance " + plan);<a name="line.1855"></a>
-<span class="sourceLineNo">1856</span>        //TODO: bulk assign<a name="line.1856"></a>
-<span class="sourceLineNo">1857</span>        try {<a name="line.1857"></a>
-<span class="sourceLineNo">1858</span>          this.assignmentManager.moveAsync(plan);<a name="line.1858"></a>
-<span class="sourceLineNo">1859</span>        } catch (HBaseIOException hioe) {<a name="line.1859"></a>
-<span class="sourceLineNo">1860</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1860"></a>
-<span class="sourceLineNo">1861</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1861"></a>
-<span class="sourceLineNo">1862</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1862"></a>
-<span class="sourceLineNo">1863</span>        }<a name="line.1863"></a>
-<span class="sourceLineNo">1864</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1864"></a>
-<span class="sourceLineNo">1865</span>        rpCount++;<a name="line.1865"></a>
-<span class="sourceLineNo">1866</span>        successRegionPlans.add(plan);<a name="line.1866"></a>
-<span class="sourceLineNo">1867</span><a name="line.1867"></a>
-<span class="sourceLineNo">1868</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1868"></a>
-<span class="sourceLineNo">1869</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1869"></a>
-<span class="sourceLineNo">1870</span>            cutoffTime);<a name="line.1870"></a>
-<span class="sourceLineNo">1871</span>        }<a name="line.1871"></a>
-<span class="sourceLineNo">1872</span><a name="line.1872"></a>
-<span class="sourceLineNo">1873</span>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1873"></a>
-<span class="sourceLineNo">1874</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1874"></a>
-<span class="sourceLineNo">1875</span>          &amp;&amp; System.currentTimeMillis() &gt; cutoffTime) {<a name="line.1875"></a>
-<span class="sourceLineNo">1876</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1876"></a>
-<span class="sourceLineNo">1877</span>          // a security net for now)<a name="line.1877"></a>
-<span class="sourceLineNo">1878</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1878"></a>
-<span class="sourceLineNo">1879</span>              + this.maxBalancingTime);<a name="line.1879"></a>
-<span class="sourceLineNo">1880</span>          break;<a name="line.1880"></a>
-<span class="sourceLineNo">1881</span>        }<a name="line.1881"></a>
-<span class="sourceLineNo">1882</span>      }<a name="line.1882"></a>
-<span class="sourceLineNo">1883</span>    }<a name="line.1883"></a>
-<span class="sourceLineNo">1884</span>    return successRegionPlans;<a name="line.1884"></a>
-<span class="sourceLineNo">1885</span>  }<a name="line.1885"></a>
-<span class="sourceLineNo">1886</span><a name="line.1886"></a>
-<span class="sourceLineNo">1887</span>  @Override<a name="line.1887"></a>
-<span class="sourceLineNo">1888</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1888"></a>
-<span class="sourceLineNo">1889</span>    return regionNormalizerManager;<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>  @Override<a name="line.1892"></a>
-<span class="sourceLineNo">1893</span>  public boolean normalizeRegions(<a name="line.1893"></a>
-<span class="sourceLineNo">1894</span>    final NormalizeTableFilterParams ntfp,<a name="line.1894"></a>
-<span class="sourceLineNo">1895</span>    final boolean isHighPriority<a name="line.1895"></a>
-<span class="sourceLineNo">1896</span>  ) throws IOException {<a name="line.1896"></a>
-<span class="sourceLineNo">1897</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1897"></a>
-<span class="sourceLineNo">1898</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1898"></a>
-<span class="sourceLineNo">1899</span>      return false;<a name="line.1899"></a>
-<span class="sourceLineNo">1900</span>    }<a name="line.1900"></a>
-<span class="sourceLineNo">1901</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1901"></a>
-<span class="sourceLineNo">1902</span>      return false;<a name="line.1902"></a>
-<span class="sourceLineNo">1903</span>    }<a name="line.1903"></a>
-<span class="sourceLineNo">1904</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1904"></a>
-<span class="sourceLineNo">1905</span>      return false;<a name="line.1905"></a>
-<span class="sourceLineNo">1906</span>    }<a name="line.1906"></a>
-<span class="sourceLineNo">1907</span><a name="line.1907"></a>
-<span class="sourceLineNo">1908</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1908"></a>
-<span class="sourceLineNo">1909</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1909"></a>
-<span class="sourceLineNo">1910</span>      .stream()<a name="line.1910"></a>
-<span class="sourceLineNo">1911</span>      .map(TableDescriptor::getTableName)<a name="line.1911"></a>
-<span class="sourceLineNo">1912</span>      .collect(Collectors.toSet());<a name="line.1912"></a>
-<span class="sourceLineNo">1913</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1913"></a>
-<span class="sourceLineNo">1914</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1914"></a>
-<span class="sourceLineNo">1915</span>    final List&lt;TableName&gt; targetTables =<a name="line.1915"></a>
-<span class="sourceLineNo">1916</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1916"></a>
-<span class="sourceLineNo">1917</span>    Collections.shuffle(targetTables);<a name="line.1917"></a>
-<span class="sourceLineNo">1918</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1918"></a>
-<span class="sourceLineNo">1919</span>  }<a name="line.1919"></a>
-<span class="sourceLineNo">1920</span><a name="line.1920"></a>
-<span class="sourceLineNo">1921</span>  /**<a name="line.1921"></a>
-<span class="sourceLineNo">1922</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1922"></a>
-<span class="sourceLineNo">1923</span>   */<a name="line.1923"></a>
-<span class="sourceLineNo">1924</span>  @Override<a name="line.1924"></a>
-<span class="sourceLineNo">1925</span>  public String getClientIdAuditPrefix() {<a name="line.1925"></a>
-<span class="sourceLineNo">1926</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1926"></a>
-<span class="sourceLineNo">1927</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<a name="line.1927"></a>
-<span class="sourceLineNo">1928</span>  }<a name="line.1928"></a>
-<span class="sourceLineNo">1929</span><a name="line.1929"></a>
-<span class="sourceLineNo">1930</span>  /**<a name="line.1930"></a>
-<span class="sourceLineNo">1931</span>   * Switch for the background CatalogJanitor thread.<a name="line.1931"></a>
-<span class="sourceLineNo">1932</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1932"></a>
-<span class="sourceLineNo">1933</span>   * if disabled.<a name="line.1933"></a>
-<span class="sourceLineNo">1934</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.1934"></a>
-<span class="sourceLineNo">1935</span>   */<a name="line.1935"></a>
-<span class="sourceLineNo">1936</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.1936"></a>
-<span class="sourceLineNo">1937</span>    this.catalogJanitorChore.setEnabled(b);<a name="line.1937"></a>
-<span class="sourceLineNo">1938</span>  }<a name="line.1938"></a>
-<span class="sourceLineNo">1939</span><a name="line.1939"></a>
-<span class="sourceLineNo">1940</span>  @Override<a name="line.1940"></a>
-<span class="sourceLineNo">1941</span>  public long mergeRegions(<a name="line.1941"></a>
-<span class="sourceLineNo">1942</span>      final RegionInfo[] regionsToMerge,<a name="line.1942"></a>
-<span class="sourceLineNo">1943</span>      final boolean forcible,<a name="line.1943"></a>
-<span class="sourceLineNo">1944</span>      final long ng,<a name="line.1944"></a>
-<span class="sourceLineNo">1945</span>      final long nonce) throws IOException {<a name="line.1945"></a>
-<span class="sourceLineNo">1946</span>    checkInitialized();<a name="line.1946"></a>
-<span class="sourceLineNo">1947</span><a name="line.1947"></a>
-<span class="sourceLineNo">1948</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.1948"></a>
-<span class="sourceLineNo">1949</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.1949"></a>
-<span class="sourceLineNo">1950</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.1950"></a>
-<span class="sourceLineNo">1951</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.1951"></a>
-<span class="sourceLineNo">1952</span>          " failed because merge switch is off");<a name="line.1952"></a>
-<span class="sourceLineNo">1953</span>    }<a name="line.1953"></a>
-<span class="sourceLineNo">1954</span><a name="line.1954"></a>
-<span class="sourceLineNo">1955</span>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.1955"></a>
-<span class="sourceLineNo">1956</span>      .collect(Collectors.joining(", "));<a name="line.1956"></a>
-<span class="sourceLineNo">1957</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.1957"></a>
-<span class="sourceLineNo">1958</span>      @Override<a name="line.1958"></a>
-<span class="sourceLineNo">1959</span>      protected void run() throws IOException {<a name="line.1959"></a>
-<span class="sourceLineNo">1960</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.1960"></a>
-<span class="sourceLineNo">1961</span>        String aid = getClientIdAuditPrefix();<a name="line.1961"></a>
-<span class="sourceLineNo">1962</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.1962"></a>
-<span class="sourceLineNo">1963</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.1963"></a>
-<span class="sourceLineNo">1964</span>            regionsToMerge, forcible));<a name="line.1964"></a>
-<span class="sourceLineNo">1965</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<a name="line.1965"></a>
-<span class="sourceLineNo">1966</span>      }<a name="line.1966"></a>
-<span class="sourceLineNo">1967</span><a name="line.1967"></a>
-<span class="sourceLineNo">1968</span>      @Override<a name="line.1968"></a>
-<span class="sourceLineNo">1969</span>      protected String getDescription() {<a name="line.1969"></a>
-<span class="sourceLineNo">1970</span>        return "MergeTableProcedure";<a name="line.1970"></a>
-<span class="sourceLineNo">1971</span>      }<a name="line.1971"></a>
-<span class="sourceLineNo">1972</span>    });<a name="line.1972"></a>
-<span class="sourceLineNo">1973</span>  }<a name="line.1973"></a>
-<span class="sourceLineNo">1974</span><a name="line.1974"></a>
-<span class="sourceLineNo">1975</span>  @Override<a name="line.1975"></a>
-<span class="sourceLineNo">1976</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.1976"></a>
-<span class="sourceLineNo">1977</span>      final long nonceGroup, final long nonce)<a name="line.1977"></a>
-<span class="sourceLineNo">1978</span>  throws IOException {<a name="line.1978"></a>
-<span class="sourceLineNo">1979</span>    checkInitialized();<a name="line.1979"></a>
-<span class="sourceLineNo">1980</span><a name="line.1980"></a>
-<span class="sourceLineNo">1981</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.1981"></a>
-<span class="sourceLineNo">1982</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.1982"></a>
-<span class="sourceLineNo">1983</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.1983"></a>
-<span class="sourceLineNo">1984</span>          " failed due to split switch off");<a name="line.1984"></a>
-<span class="sourceLineNo">1985</span>    }<a name="line.1985"></a>
-<span class="sourceLineNo">1986</span><a name="line.1986"></a>
-<span class="sourceLineNo">1987</span>    return MasterProcedureUtil.submitProcedure(<a name="line.1987"></a>
-<span class="sourceLineNo">1988</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.1988"></a>
-<span class="sourceLineNo">1989</span>      @Override<a name="line.1989"></a>
-<span class="sourceLineNo">1990</span>      protected void run() throws IOException {<a name="line.1990"></a>
-<span class="sourceLineNo">1991</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.1991"></a>
-<span class="sourceLineNo">1992</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.1992"></a>
-<span class="sourceLineNo">1993</span><a name="line.1993"></a>
-<span class="sourceLineNo">1994</span>        // Execute the operation asynchronously<a name="line.1994"></a>
-<span class="sourceLineNo">1995</span>        submitProcedure(getAssignmentManager().createSplitProcedure(regionInfo, splitRow));<a name="line.1995"></a>
-<span class="sourceLineNo">1996</span>      }<a name="line.1996"></a>
+<span class="sourceLineNo">1756</span>    if (isInMaintenanceMode()) {<a name="line.1756"></a>
+<span class="sourceLineNo">1757</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1757"></a>
+<span class="sourceLineNo">1758</span>      return true;<a name="line.1758"></a>
+<span class="sourceLineNo">1759</span>    }<a name="line.1759"></a>
+<span class="sourceLineNo">1760</span>    return false;<a name="line.1760"></a>
+<span class="sourceLineNo">1761</span>  }<a name="line.1761"></a>
+<span class="sourceLineNo">1762</span><a name="line.1762"></a>
+<span class="sourceLineNo">1763</span>  public boolean balance(boolean force) throws IOException {<a name="line.1763"></a>
+<span class="sourceLineNo">1764</span>    if (loadBalancerTracker == null || !loadBalancerTracker.isBalancerOn()) {<a name="line.1764"></a>
+<span class="sourceLineNo">1765</span>      return false;<a name="line.1765"></a>
+<span class="sourceLineNo">1766</span>    }<a name="line.1766"></a>
+<span class="sourceLineNo">1767</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1767"></a>
+<span class="sourceLineNo">1768</span>      return false;<a name="line.1768"></a>
+<span class="sourceLineNo">1769</span>    }<a name="line.1769"></a>
+<span class="sourceLineNo">1770</span><a name="line.1770"></a>
+<span class="sourceLineNo">1771</span>    synchronized (this.balancer) {<a name="line.1771"></a>
+<span class="sourceLineNo">1772</span>        // Only allow one balance run at at time.<a name="line.1772"></a>
+<span class="sourceLineNo">1773</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1773"></a>
+<span class="sourceLineNo">1774</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1774"></a>
+<span class="sourceLineNo">1775</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1775"></a>
+<span class="sourceLineNo">1776</span>        // ignore the force flag in that case<a name="line.1776"></a>
+<span class="sourceLineNo">1777</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1777"></a>
+<span class="sourceLineNo">1778</span>        String prefix = force &amp;&amp; !metaInTransition ? "R" : "Not r";<a name="line.1778"></a>
+<span class="sourceLineNo">1779</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1779"></a>
+<span class="sourceLineNo">1780</span>        int max = 5;<a name="line.1780"></a>
+<span class="sourceLineNo">1781</span>        boolean truncated = false;<a name="line.1781"></a>
+<span class="sourceLineNo">1782</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1782"></a>
+<span class="sourceLineNo">1783</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1783"></a>
+<span class="sourceLineNo">1784</span>          truncated = true;<a name="line.1784"></a>
+<span class="sourceLineNo">1785</span>        }<a name="line.1785"></a>
+<span class="sourceLineNo">1786</span>        LOG.info(prefix + " not running balancer because " + regionsInTransition.size() +<a name="line.1786"></a>
+<span class="sourceLineNo">1787</span>          " region(s) in transition: " + toPrint + (truncated? "(truncated list)": ""));<a name="line.1787"></a>
+<span class="sourceLineNo">1788</span>        if (!force || metaInTransition) return false;<a name="line.1788"></a>
+<span class="sourceLineNo">1789</span>      }<a name="line.1789"></a>
+<span class="sourceLineNo">1790</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1790"></a>
+<span class="sourceLineNo">1791</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1791"></a>
+<span class="sourceLineNo">1792</span>          this.serverManager.getDeadServers());<a name="line.1792"></a>
+<span class="sourceLineNo">1793</span>        return false;<a name="line.1793"></a>
+<span class="sourceLineNo">1794</span>      }<a name="line.1794"></a>
+<span class="sourceLineNo">1795</span><a name="line.1795"></a>
+<span class="sourceLineNo">1796</span>      if (this.cpHost != null) {<a name="line.1796"></a>
+<span class="sourceLineNo">1797</span>        try {<a name="line.1797"></a>
+<span class="sourceLineNo">1798</span>          if (this.cpHost.preBalance()) {<a name="line.1798"></a>
+<span class="sourceLineNo">1799</span>            LOG.debug("Coprocessor bypassing balancer request");<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>        } catch (IOException ioe) {<a name="line.1802"></a>
+<span class="sourceLineNo">1803</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<a name="line.1803"></a>
+<span class="sourceLineNo">1804</span>          return false;<a name="line.1804"></a>
+<span class="sourceLineNo">1805</span>        }<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>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1808"></a>
+<span class="sourceLineNo">1809</span>        this.assignmentManager.getRegionStates()<a name="line.1809"></a>
+<span class="sourceLineNo">1810</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1810"></a>
+<span class="sourceLineNo">1811</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1811"></a>
+<span class="sourceLineNo">1812</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<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>      //Give the balancer the current cluster state.<a name="line.1815"></a>
+<span class="sourceLineNo">1816</span>      this.balancer.setClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1816"></a>
+<span class="sourceLineNo">1817</span><a name="line.1817"></a>
+<span class="sourceLineNo">1818</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<a name="line.1818"></a>
+<span class="sourceLineNo">1819</span><a name="line.1819"></a>
+<span class="sourceLineNo">1820</span>      if (skipRegionManagementAction("balancer")) {<a name="line.1820"></a>
+<span class="sourceLineNo">1821</span>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1821"></a>
+<span class="sourceLineNo">1822</span>        return false;<a name="line.1822"></a>
+<span class="sourceLineNo">1823</span>      }<a name="line.1823"></a>
+<span class="sourceLineNo">1824</span><a name="line.1824"></a>
+<span class="sourceLineNo">1825</span>      List&lt;RegionPlan&gt; sucRPs = executeRegionPlansWithThrottling(plans);<a name="line.1825"></a>
+<span class="sourceLineNo">1826</span><a name="line.1826"></a>
+<span class="sourceLineNo">1827</span>      if (this.cpHost != null) {<a name="line.1827"></a>
+<span class="sourceLineNo">1828</span>        try {<a name="line.1828"></a>
+<span class="sourceLineNo">1829</span>          this.cpHost.postBalance(sucRPs);<a name="line.1829"></a>
+<span class="sourceLineNo">1830</span>        } catch (IOException ioe) {<a name="line.1830"></a>
+<span class="sourceLineNo">1831</span>          // balancing already succeeded so don't change the result<a name="line.1831"></a>
+<span class="sourceLineNo">1832</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<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>    }<a name="line.1835"></a>
+<span class="sourceLineNo">1836</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1836"></a>
+<span class="sourceLineNo">1837</span>    // Return true indicating a success.<a name="line.1837"></a>
+<span class="sourceLineNo">1838</span>    return true;<a name="line.1838"></a>
+<span class="sourceLineNo">1839</span>  }<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>   * Execute region plans with throttling<a name="line.1842"></a>
+<span class="sourceLineNo">1843</span>   * @param plans to execute<a name="line.1843"></a>
+<span class="sourceLineNo">1844</span>   * @return succeeded plans<a name="line.1844"></a>
+<span class="sourceLineNo">1845</span>   */<a name="line.1845"></a>
+<span class="sourceLineNo">1846</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1846"></a>
+<span class="sourceLineNo">1847</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1847"></a>
+<span class="sourceLineNo">1848</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1848"></a>
+<span class="sourceLineNo">1849</span>    long balanceStartTime = System.currentTimeMillis();<a name="line.1849"></a>
+<span class="sourceLineNo">1850</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1850"></a>
+<span class="sourceLineNo">1851</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1851"></a>
+<span class="sourceLineNo">1852</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1852"></a>
+<span class="sourceLineNo">1853</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1853"></a>
+<span class="sourceLineNo">1854</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1854"></a>
+<span class="sourceLineNo">1855</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1855"></a>
+<span class="sourceLineNo">1856</span>          + maxRegionsInTransition);<a name="line.1856"></a>
+<span class="sourceLineNo">1857</span><a name="line.1857"></a>
+<span class="sourceLineNo">1858</span>      for (RegionPlan plan: plans) {<a name="line.1858"></a>
+<span class="sourceLineNo">1859</span>        LOG.info("balance " + plan);<a name="line.1859"></a>
+<span class="sourceLineNo">1860</span>        //TODO: bulk assign<a name="line.1860"></a>
+<span class="sourceLineNo">1861</span>        try {<a name="line.1861"></a>
+<span class="sourceLineNo">1862</span>          this.assignmentManager.moveAsync(plan);<a name="line.1862"></a>
+<span class="sourceLineNo">1863</span>        } catch (HBaseIOException hioe) {<a name="line.1863"></a>
+<span class="sourceLineNo">1864</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1864"></a>
+<span class="sourceLineNo">1865</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1865"></a>
+<span class="sourceLineNo">1866</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1866"></a>
+<span class="sourceLineNo">1867</span>        }<a name="line.1867"></a>
+<span class="sourceLineNo">1868</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1868"></a>
+<span class="sourceLineNo">1869</span>        rpCount++;<a name="line.1869"></a>
+<span class="sourceLineNo">1870</span>        successRegionPlans.add(plan);<a name="line.1870"></a>
+<span class="sourceLineNo">1871</span><a name="line.1871"></a>
+<span class="sourceLineNo">1872</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1872"></a>
+<span class="sourceLineNo">1873</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1873"></a>
+<span class="sourceLineNo">1874</span>            cutoffTime);<a name="line.1874"></a>
+<span class="sourceLineNo">1875</span>        }<a name="line.1875"></a>
+<span class="sourceLineNo">1876</span><a name="line.1876"></a>
+<span class="sourceLineNo">1877</span>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1877"></a>
+<span class="sourceLineNo">1878</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1878"></a>
+<span class="sourceLineNo">1879</span>          &amp;&amp; System.currentTimeMillis() &gt; cutoffTime) {<a name="line.1879"></a>
+<span class="sourceLineNo">1880</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1880"></a>
+<span class="sourceLineNo">1881</span>          // a security net for now)<a name="line.1881"></a>
+<span class="sourceLineNo">1882</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1882"></a>
+<span class="sourceLineNo">1883</span>              + this.maxBalancingTime);<a name="line.1883"></a>
+<span class="sourceLineNo">1884</span>          break;<a name="line.1884"></a>
+<span class="sourceLineNo">1885</span>        }<a name="line.1885"></a>
+<span class="sourceLineNo">1886</span>      }<a name="line.1886"></a>
+<span class="sourceLineNo">1887</span>    }<a name="line.1887"></a>
+<span class="sourceLineNo">1888</span>    return successRegionPlans;<a name="line.1888"></a>
+<span class="sourceLineNo">1889</span>  }<a name="line.1889"></a>
+<span class="sourceLineNo">1890</span><a name="line.1890"></a>
+<span class="sourceLineNo">1891</span>  @Override<a name="line.1891"></a>
+<span class="sourceLineNo">1892</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1892"></a>
+<span class="sourceLineNo">1893</span>    return regionNormalizerManager;<a name="line.1893"></a>
+<span class="sourceLineNo">1894</span>  }<a name="line.1894"></a>
+<span class="sourceLineNo">1895</span><a name="line.1895"></a>
+<span class="sourceLineNo">1896</span>  @Override<a name="line.1896"></a>
+<span class="sourceLineNo">1897</span>  public boolean normalizeRegions(<a name="line.1897"></a>
+<span class="sourceLineNo">1898</span>    final NormalizeTableFilterParams ntfp,<a name="line.1898"></a>
+<span class="sourceLineNo">1899</span>    final boolean isHighPriority<a name="line.1899"></a>
+<span class="sourceLineNo">1900</span>  ) throws IOException {<a name="line.1900"></a>
+<span class="sourceLineNo">1901</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1901"></a>
+<span class="sourceLineNo">1902</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1902"></a>
+<span class="sourceLineNo">1903</span>      return false;<a name="line.1903"></a>
+<span class="sourceLineNo">1904</span>    }<a name="line.1904"></a>
+<span class="sourceLineNo">1905</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1905"></a>
+<span class="sourceLineNo">1906</span>      return false;<a name="line.1906"></a>
+<span class="sourceLineNo">1907</span>    }<a name="line.1907"></a>
+<span class="sourceLineNo">1908</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1908"></a>
+<span class="sourceLineNo">1909</span>      return false;<a name="line.1909"></a>
+<span class="sourceLineNo">1910</span>    }<a name="line.1910"></a>
+<span class="sourceLineNo">1911</span><a name="line.1911"></a>
+<span class="sourceLineNo">1912</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1912"></a>
+<span class="sourceLineNo">1913</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1913"></a>
+<span class="sourceLineNo">1914</span>      .stream()<a name="line.1914"></a>
+<span class="sourceLineNo">1915</span>      .map(TableDescriptor::getTableName)<a name="line.1915"></a>
+<span class="sourceLineNo">1916</span>      .collect(Collectors.toSet());<a name="line.1916"></a>
+<span class="sourceLineNo">1917</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1917"></a>
+<span class="sourceLineNo">1918</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1918"></a>
+<span class="sourceLineNo">1919</span>    final List&lt;TableName&gt; targetTables =<a name="line.1919"></a>
+<span class="sourceLineNo">1920</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1920"></a>
+<span class="sourceLineNo">1921</span>    Collections.shuffle(targetTables);<a name="line.1921"></a>
+<span class="sourceLineNo">1922</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1922"></a>
+<span class="sourceLineNo">1923</span>  }<a name="line.1923"></a>
+<span class="sourceLineNo">1924</span><a name="line.1924"></a>
+<span class="sourceLineNo">1925</span>  /**<a name="line.1925"></a>
+<span class="sourceLineNo">1926</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1926"></a>
+<span class="sourceLineNo">1927</span>   */<a name="line.1927"></a>
+<span class="sourceLineNo">1928</span>  @Override<a name="line.1928"></a>
+<span class="sourceLineNo">1929</span>  public String getClientIdAuditPrefix() {<a name="line.1929"></a>
+<span class="sourceLineNo">1930</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1930"></a>
+<span class="sourceLineNo">1931</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<a name="line.1931"></a>
+<span class="sourceLineNo">1932</span>  }<a name="line.1932"></a>
+<span class="sourceLineNo">1933</span><a name="line.1933"></a>
+<span class="sourceLineNo">1934</span>  /**<a name="line.1934"></a>
+<span class="sourceLineNo">1935</span>   * Switch for the background CatalogJanitor thread.<a name="line.1935"></a>
+<span class="sourceLineNo">1936</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1936"></a>
+<span class="sourceLineNo">1937</span>   * if disabled.<a name="line.1937"></a>
+<span class="sourceLineNo">1938</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.1938"></a>
+<span class="sourceLineNo">1939</span>   */<a name="line.1939"></a>
+<span class="sourceLineNo">1940</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.1940"></a>
+<span class="sourceLineNo">1941</span>    this.catalogJanitorChore.setEnabled(b);<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>  @Override<a name="line.1944"></a>
+<span class="sourceLineNo">1945</span>  public long mergeRegions(<a name="line.1945"></a>
+<span class="sourceLineNo">1946</span>      final RegionInfo[] regionsToMerge,<a name="line.1946"></a>
+<span class="sourceLineNo">1947</span>      final boolean forcible,<a name="line.1947"></a>
+<span class="sourceLineNo">1948</span>      final long ng,<a name="line.1948"></a>
+<span class="sourceLineNo">1949</span>      final long nonce) throws IOException {<a name="line.1949"></a>
+<span class="sourceLineNo">1950</span>    checkInitialized();<a name="line.1950"></a>
+<span class="sourceLineNo">1951</span><a name="line.1951"></a>
+<span class="sourceLineNo">1952</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.1952"></a>
+<span class="sourceLineNo">1953</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.1953"></a>
+<span class="sourceLineNo">1954</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.1954"></a>
+<span class="sourceLineNo">1955</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.1955"></a>
+<span class="sourceLineNo">1956</span>          " failed because merge switch is off");<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>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.1959"></a>
+<span class="sourceLineNo">1960</span>      .collect(Collectors.joining(", "));<a name="line.1960"></a>
+<span class="sourceLineNo">1961</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.1961"></a>
+<span class="sourceLineNo">1962</span>      @Override<a name="line.1962"></a>
+<span class="sourceLineNo">1963</span>      protected void run() throws IOException {<a name="line.1963"></a>
+<span class="sourceLineNo">1964</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.1964"></a>
+<span class="sourceLineNo">1965</span>        String aid = getClientIdAuditPrefix();<a name="line.1965"></a>
+<span class="sourceLineNo">1966</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.1966"></a>
+<span class="sourceLineNo">1967</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.1967"></a>
+<span class="sourceLineNo">1968</span>            regionsToMerge, forcible));<a name="line.1968"></a>
+<span class="sourceLineNo">1969</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<a name="line.1969"></a>
+<span class="sourceLineNo">1970</span>      }<a name="line.1970"></a>
+<span class="sourceLineNo">1971</span><a name="line.1971"></a>
+<span class="sourceLineNo">1972</span>      @Override<a name="line.1972"></a>
+<span class="sourceLineNo">1973</span>      protected String getDescription() {<a name="line.1973"></a>
+<span class="sourceLineNo">1974</span>        return "MergeTableProcedure";<a name="line.1974"></a>
+<span class="sourceLineNo">1975</span>      }<a name="line.1975"></a>
+<span class="sourceLineNo">1976</span>    });<a name="line.1976"></a>
+<span class="sourceLineNo">1977</span>  }<a name="line.1977"></a>
+<span class="sourceLineNo">1978</span><a name="line.1978"></a>
+<span class="sourceLineNo">1979</span>  @Override<a name="line.1979"></a>
+<span class="sourceLineNo">1980</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.1980"></a>
+<span class="sourceLineNo">1981</span>      final long nonceGroup, final long nonce)<a name="line.1981"></a>
+<span class="sourceLineNo">1982</span>  throws IOException {<a name="line.1982"></a>
+<span class="sourceLineNo">1983</span>    checkInitialized();<a name="line.1983"></a>
+<span class="sourceLineNo">1984</span><a name="line.1984"></a>
+<span class="sourceLineNo">1985</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.1985"></a>
+<span class="sourceLineNo">1986</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.1986"></a>
+<span class="sourceLineNo">1987</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.1987"></a>
+<span class="sourceLineNo">1988</span>          " failed due to split switch off");<a name="line.1988"></a>
+<span class="sourceLineNo">1989</span>    }<a name="line.1989"></a>
+<span class="sourceLineNo">1990</span><a name="line.1990"></a>
+<span class="sourceLineNo">1991</span>    return MasterProcedureUtil.submitProcedure(<a name="line.1991"></a>
+<span class="sourceLineNo">1992</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.1992"></a>
+<span class="sourceLineNo">1993</span>      @Override<a name="line.1993"></a>
+<span class="sourceLineNo">1994</span>      protected void run() throws IOException {<a name="line.1994"></a>
+<span class="sourceLineNo">1995</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.1995"></a>
+<span class="sourceLineNo">1996</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.1996"></a>
 <span class="sourceLineNo">1997</span><a name="line.1997"></a>
-<span class="sourceLineNo">1998</span>      @Override<a name="line.1998"></a>
-<span class="sourceLineNo">1999</span>      protected String getDescription() {<a name="line.1999"></a>
-<span class="sourceLineNo">2000</span>        return "SplitTableProcedure";<a name="line.2000"></a>
-<span class="sourceLineNo">2001</span>      }<a name="line.2001"></a>
-<span class="sourceLineNo">2002</span>    });<a name="line.2002"></a>
-<span class="sourceLineNo">2003</span>  }<a name="line.2003"></a>
-<span class="sourceLineNo">2004</span><a name="line.2004"></a>
-<span class="sourceLineNo">2005</span>  private void warmUpRegion(ServerName server, RegionInfo region) {<a name="line.2005"></a>
-<span class="sourceLineNo">2006</span>    FutureUtils.addListener(asyncClusterConnection.getRegionServerAdmin(server)<a name="line.2006"></a>
-<span class="sourceLineNo">2007</span>      .warmupRegion(RequestConverter.buildWarmupRegionRequest(region)), (r, e) -&gt; {<a name="line.2007"></a>
-<span class="sourceLineNo">2008</span>        if (e != null) {<a name="line.2008"></a>
-<span class="sourceLineNo">2009</span>          LOG.warn("Failed to warm up region {} on server {}", region, server, e);<a name="line.2009"></a>
-<span class="sourceLineNo">2010</span>        }<a name="line.2010"></a>
-<span class="sourceLineNo">2011</span>      });<a name="line.2011"></a>
-<span class="sourceLineNo">2012</span>  }<a name="line.2012"></a>
-<span class="sourceLineNo">2013</span><a name="line.2013"></a>
-<span class="sourceLineNo">2014</span>  // Public so can be accessed by tests. Blocks until move is done.<a name="line.2014"></a>
-<span class="sourceLineNo">2015</span>  // Replace with an async implementation from which you can get<a name="line.2015"></a>
-<span class="sourceLineNo">2016</span>  // a success/failure result.<a name="line.2016"></a>
-<span class="sourceLineNo">2017</span>  @VisibleForTesting<a name="line.2017"></a>
-<span class="sourceLineNo">2018</span>  public void move(final byte[] encodedRegionName, byte[] destServerName) throws IOException {<a name="line.2018"></a>
-<span class="sourceLineNo">2019</span>    RegionState regionState = assignmentManager.getRegionStates().<a name="line.2019"></a>
-<span class="sourceLineNo">2020</span>      getRegionState(Bytes.toString(encodedRegionName));<a name="line.2020"></a>
-<span class="sourceLineNo">2021</span><a name="line.2021"></a>
-<span class="sourceLineNo">2022</span>    RegionInfo hri;<a name="line.2022"></a>
-<span class="sourceLineNo">2023</span>    if (regionState != null) {<a name="line.2023"></a>
-<span class="sourceLineNo">2024</span>      hri = regionState.getRegion();<a name="line.2024"></a>
-<span class="sourceLineNo">2025</span>    } else {<a name="line.2025"></a>
-<span class="sourceLineNo">2026</span>      throw new UnknownRegionException(Bytes.toStringBinary(encodedRegionName));<a name="line.2026"></a>
-<span class="sourceLineNo">2027</span>    }<a name="line.2027"></a>
-<span class="sourceLineNo">2028</span><a name="line.2028"></a>
-<span class="sourceLineNo">2029</span>    ServerName dest;<a name="line.2029"></a>
-<span class="sourceLineNo">2030</span>    List&lt;ServerName&gt; exclude = hri.getTable().isSystemTable() ? assignmentManager.getExcludedServersForSystemTable()<a name="line.2030"></a>
-<span class="sourceLineNo">2031</span>        : new ArrayList&lt;&gt;(1);<a name="line.2031"></a>
-<span class="sourceLineNo">2032</span>    if (destServerName != null &amp;&amp; exclude.contains(ServerName.valueOf(Bytes.toString(destServerName)))) {<a name="line.2032"></a>
-<span class="sourceLineNo">2033</span>      LOG.info(<a name="line.2033"></a>
-<span class="sourceLineNo">2034</span>          Bytes.toString(encodedRegionName) + " can not move to " + Bytes.toString(destServerName)<a name="line.2034"></a>
-<span class="sourceLineNo">2035</span>              + " because the server is in exclude list");<a name="line.2035"></a>
-<span class="sourceLineNo">2036</span>      destServerName = null;<a name="line.2036"></a>
-<span class="sourceLineNo">2037</span>    }<a name="line.2037"></a>
-<span class="sourceLineNo">2038</span>    if (destServerName == null || destServerName.length == 0) {<a name="line.2038"></a>
-<span class="sourceLineNo">2039</span>      LOG.info("Passed destination servername is null/empty so " +<a name="line.2039"></a>
-<span class="sourceLineNo">2040</span>        "choosing a server at random");<a name="line.2040"></a>
-<span class="sourceLineNo">2041</span>      exclude.add(regionState.getServerName());<a name="line.2041"></a>
-<span class="sourceLineNo">2042</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList(exclude);<a name="line.2042"></a>
-<span class="sourceLineNo">2043</span>      dest = balancer.randomAssignment(hri, destServers);<a name="line.2043"></a>
-<span class="sourceLineNo">2044</span>      if (dest == null) {<a name="line.2044"></a>
-<span class="sourceLineNo">2045</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2045"></a>
-<span class="sourceLineNo">2046</span>        return;<a name="line.2046"></a>
-<span class="sourceLineNo">2047</span>      }<a name="line.2047"></a>
-<span class="sourceLineNo">2048</span>    } else {<a name="line.2048"></a>
-<span class="sourceLineNo">2049</span>      ServerName candidate = ServerName.valueOf(Bytes.toString(destServerName));<a name="line.2049"></a>
-<span class="sourceLineNo">2050</span>      dest = balancer.randomAssignment(hri, Lists.newArrayList(candidate));<a name="line.2050"></a>
-<span class="sourceLineNo">2051</span>      if (dest == null) {<a name="line.2051"></a>
-<span class="sourceLineNo">2052</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2052"></a>
-<span class="sourceLineNo">2053</span>        return;<a name="line.2053"></a>
-<span class="sourceLineNo">2054</span>      }<a name="line.2054"></a>
-<span class="sourceLineNo">2055</span>      // TODO: deal with table on master for rs group.<a name="line.2055"></a>
-<span class="sourceLineNo">2056</span>      if (dest.equals(serverName)) {<a name="line.2056"></a>
-<span class="sourceLineNo">2057</span>        // To avoid unnecessary region moving later by balancer. Don't put user<a name="line.2057"></a>
-<span class="sourceLineNo">2058</span>        // regions on master.<a name="line.2058"></a>
-<span class="sourceLineNo">2059</span>        LOG.debug("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.2059"></a>
-<span class="sourceLineNo">2060</span>          " to avoid unnecessary region moving later by load balancer," +<a name="line.2060"></a>
-<span class="sourceLineNo">2061</span>          " because it should not be on master");<a name="line.2061"></a>
-<span class="sourceLineNo">2062</span>        return;<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>    if (dest.equals(regionState.getServerName())) {<a name="line.2066"></a>
-<span class="sourceLineNo">2067</span>      LOG.debug("Skipping move of region " + hri.getRegionNameAsString()<a name="line.2067"></a>
-<span class="sourceLineNo">2068</span>        + " because region already assigned to the same server " + dest + ".");<a name="line.2068"></a>
-<span class="sourceLineNo">2069</span>      return;<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>    // Now we can do the move<a name="line.2072"></a>
-<span class="sourceLineNo">2073</span>    RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), dest);<a name="line.2073"></a>
-<span class="sourceLineNo">2074</span>    assert rp.getDestination() != null: rp.toString() + " " + dest;<a name="line.2074"></a>
+<span class="sourceLineNo">1998</span>        // Execute the operation asynchronously<a name="line.1998"></a>
+<span class="sourceLineNo">1999</span>        submitProcedure(getAssignmentManager().createSplitProcedure(regionInfo, splitRow));<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>      protected String getDescription() {<a name="line.2003"></a>
+<span class="sourceLineNo">2004</span>        return "SplitTableProcedure";<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>  }<a name="line.2007"></a>
+<span class="sourceLineNo">2008</span><a name="line.2008"></a>
+<span class="sourceLineNo">2009</span>  private void warmUpRegion(ServerName server, RegionInfo region) {<a name="line.2009"></a>
+<span class="sourceLineNo">2010</span>    FutureUtils.addListener(asyncClusterConnection.getRegionServerAdmin(server)<a name="line.2010"></a>
+<span class="sourceLineNo">2011</span>      .warmupRegion(RequestConverter.buildWarmupRegionRequest(region)), (r, e) -&gt; {<a name="line.2011"></a>
+<span class="sourceLineNo">2012</span>        if (e != null) {<a name="line.2012"></a>
+<span class="sourceLineNo">2013</span>          LOG.warn("Failed to warm up region {} on server {}", region, server, e);<a name="line.2013"></a>
+<span class="sourceLineNo">2014</span>        }<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><a name="line.2017"></a>
+<span class="sourceLineNo">2018</span>  // Public so can be accessed by tests. Blocks until move is done.<a name="line.2018"></a>
+<span class="sourceLineNo">2019</span>  // Replace with an async implementation from which you can get<a name="line.2019"></a>
+<span class="sourceLineNo">2020</span>  // a success/failure result.<a name="line.2020"></a>
+<span class="sourceLineNo">2021</span>  @VisibleForTesting<a name="line.2021"></a>
+<span class="sourceLineNo">2022</span>  public void move(final byte[] encodedRegionName, byte[] destServerName) throws IOException {<a name="line.2022"></a>
+<span class="sourceLineNo">2023</span>    RegionState regionState = assignmentManager.getRegionStates().<a name="line.2023"></a>
+<span class="sourceLineNo">2024</span>      getRegionState(Bytes.toString(encodedRegionName));<a name="line.2024"></a>
+<span class="sourceLineNo">2025</span><a name="line.2025"></a>
+<span class="sourceLineNo">2026</span>    RegionInfo hri;<a name="line.2026"></a>
+<span class="sourceLineNo">2027</span>    if (regionState != null) {<a name="line.2027"></a>
+<span class="sourceLineNo">2028</span>      hri = regionState.getRegion();<a name="line.2028"></a>
+<span class="sourceLineNo">2029</span>    } else {<a name="line.2029"></a>
+<span class="sourceLineNo">2030</span>      throw new UnknownRegionException(Bytes.toStringBinary(encodedRegionName));<a name="line.2030"></a>
+<span class="sourceLineNo">2031</span>    }<a name="line.2031"></a>
+<span class="sourceLineNo">2032</span><a name="line.2032"></a>
+<span class="sourceLineNo">2033</span>    ServerName dest;<a name="line.2033"></a>
+<span class="sourceLineNo">2034</span>    List&lt;ServerName&gt; exclude = hri.getTable().isSystemTable() ? assignmentManager.getExcludedServersForSystemTable()<a name="line.2034"></a>
+<span class="sourceLineNo">2035</span>        : new ArrayList&lt;&gt;(1);<a name="line.2035"></a>
+<span class="sourceLineNo">2036</span>    if (destServerName != null &amp;&amp; exclude.contains(ServerName.valueOf(Bytes.toString(destServerName)))) {<a name="line.2036"></a>
+<span class="sourceLineNo">2037</span>      LOG.info(<a name="line.2037"></a>
+<span class="sourceLineNo">2038</span>          Bytes.toString(encodedRegionName) + " can not move to " + Bytes.toString(destServerName)<a name="line.2038"></a>
+<span class="sourceLineNo">2039</span>              + " because the server is in exclude list");<a name="line.2039"></a>
+<span class="sourceLineNo">2040</span>      destServerName = null;<a name="line.2040"></a>
+<span class="sourceLineNo">2041</span>    }<a name="line.2041"></a>
+<span class="sourceLineNo">2042</span>    if (destServerName == null || destServerName.length == 0) {<a name="line.2042"></a>
+<span class="sourceLineNo">2043</span>      LOG.info("Passed destination servername is null/empty so " +<a name="line.2043"></a>
+<span class="sourceLineNo">2044</span>        "choosing a server at random");<a name="line.2044"></a>
+<span class="sourceLineNo">2045</span>      exclude.add(regionState.getServerName());<a name="line.2045"></a>
+<span class="sourceLineNo">2046</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList(exclude);<a name="line.2046"></a>
+<span class="sourceLineNo">2047</span>      dest = balancer.randomAssignment(hri, destServers);<a name="line.2047"></a>
+<span class="sourceLineNo">2048</span>      if (dest == null) {<a name="line.2048"></a>
+<span class="sourceLineNo">2049</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2049"></a>
+<span class="sourceLineNo">2050</span>        return;<a name="line.2050"></a>
+<span class="sourceLineNo">2051</span>      }<a name="line.2051"></a>
+<span class="sourceLineNo">2052</span>    } else {<a name="line.2052"></a>
+<span class="sourceLineNo">2053</span>      ServerName candidate = ServerName.valueOf(Bytes.toString(destServerName));<a name="line.2053"></a>
+<span class="sourceLineNo">2054</span>      dest = balancer.randomAssignment(hri, Lists.newArrayList(candidate));<a name="line.2054"></a>
+<span class="sourceLineNo">2055</span>      if (dest == null) {<a name="line.2055"></a>
+<span class="sourceLineNo">2056</span>        LOG.debug("Unable to determine a plan to assign " + hri);<a name="line.2056"></a>
+<span class="sourceLineNo">2057</span>        return;<a name="line.2057"></a>
+<span class="sourceLineNo">2058</span>      }<a name="line.2058"></a>
+<span class="sourceLineNo">2059</span>      // TODO: deal with table on master for rs group.<a name="line.2059"></a>
+<span class="sourceLineNo">2060</span>      if (dest.equals(serverName)) {<a name="line.2060"></a>
+<span class="sourceLineNo">2061</span>        // To avoid unnecessary region moving later by balancer. Don't put user<a name="line.2061"></a>
+<span class="sourceLineNo">2062</span>        // regions on master.<a name="line.2062"></a>
+<span class="sourceLineNo">2063</span>        LOG.debug("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.2063"></a>
+<span class="sourceLineNo">2064</span>          " to avoid unnecessary region moving later by load balancer," +<a name="line.2064"></a>
+<span class="sourceLineNo">2065</span>          " because it should not be on master");<a name="line.2065"></a>
+<span class="sourceLineNo">2066</span>        return;<a name="line.2066"></a>
+<span class="sourceLineNo">2067</span>      }<a name="line.2067"></a>
+<span class="sourceLineNo">2068</span>    }<a name="line.2068"></a>
+<span class="sourceLineNo">2069</span><a name="line.2069"></a>
+<span class="sourceLineNo">2070</span>    if (dest.equals(regionState.getServerName())) {<a name="line.2070"></a>
+<span class="sourceLineNo">2071</span>      LOG.debug("Skipping move of region " + hri.getRegionNameAsString()<a name="line.2071"></a>
+<span class="sourceLineNo">2072</span>        + " because region already assigned to the same server " + dest + ".");<a name="line.2072"></a>
+<span class="sourceLineNo">2073</span>      return;<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>    try {<a name="line.2076"></a>
-<span class="sourceLineNo">2077</span>      checkInitialized();<a name="line.2077"></a>
-<span class="sourceLineNo">2078</span>      if (this.cpHost != null) {<a name="line.2078"></a>
-<span class="sourceLineNo">2079</span>        this.cpHost.preMove(hri, rp.getSource(), rp.getDestination());<a name="line.2079"></a>
-<span class="sourceLineNo">2080</span>      }<a name="line.2080"></a>
-<span class="sourceLineNo">2081</span><a name="line.2081"></a>
-<span class="sourceLineNo">2082</span>      TransitRegionStateProcedure proc =<a name="line.2082"></a>
-<span class="sourceLineNo">2083</span>        this.assignmentManager.createMoveRegionProcedure(rp.getRegionInfo(), rp.getDestination());<a name="line.2083"></a>
-<span class="sourceLineNo">2084</span>      // Warmup the region on the destination before initiating the move.<a name="line.2084"></a>
-<span class="sourceLineNo">2085</span>      // A region server could reject the close request because it either does not<a name="line.2085"></a>
-<span class="sourceLineNo">2086</span>      // have the specified region or the region is being split.<a name="line.2086"></a>
-<span class="sourceLineNo">2087</span>      warmUpRegion(rp.getDestination(), hri);<a name="line.2087"></a>
-<span class="sourceLineNo">2088</span><a name="line.2088"></a>
-<span class="sourceLineNo">2089</span>      LOG.info(getClientIdAuditPrefix() + " move " + rp + ", running balancer");<a name="line.2089"></a>
-<span class="sourceLineNo">2090</span>      Future&lt;byte[]&gt; future = ProcedureSyncWait.submitProcedure(this.procedureExecutor, proc);<a name="line.2090"></a>
-<span class="sourceLineNo">2091</span>      try {<a name="line.2091"></a>
-<span class="sourceLineNo">2092</span>        // Is this going to work? Will we throw exception on error?<a name="line.2092"></a>
-<span class="sourceLineNo">2093</span>        // TODO: CompletableFuture rather than this stunted Future.<a name="line.2093"></a>
-<span class="sourceLineNo">2094</span>        future.get();<a name="line.2094"></a>
-<span class="sourceLineNo">2095</span>      } catch (InterruptedException | ExecutionException e) {<a name="line.2095"></a>
-<span class="sourceLineNo">2096</span>        throw new HBaseIOException(e);<a name="line.2096"></a>
-<span class="sourceLineNo">2097</span>      }<a name="line.2097"></a>
-<span class="sourceLineNo">2098</span>      if (this.cpHost != null) {<a name="line.2098"></a>
-<span class="sourceLineNo">2099</span>        this.cpHost.postMove(hri, rp.getSource(), rp.getDestination());<a name="line.2099"></a>
-<span class="sourceLineNo">2100</span>      }<a name="line.2100"></a>
-<span class="sourceLineNo">2101</span>    } catch (IOException ioe) {<a name="line.2101"></a>
-<span class="sourceLineNo">2102</span>      if (ioe instanceof HBaseIOException) {<a name="line.2102"></a>
-<span class="sourceLineNo">2103</span>        throw (HBaseIOException)ioe;<a name="line.2103"></a>
+<span class="sourceLineNo">2076</span>    // Now we can do the move<a name="line.2076"></a>
+<span class="sourceLineNo">2077</span>    RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), dest);<a name="line.2077"></a>
+<span class="sourceLineNo">2078</span>    assert rp.getDestination() != null: rp.toString() + " " + dest;<a name="line.2078"></a>
+<span class="sourceLineNo">2079</span><a name="line.2079"></a>
+<span class="sourceLineNo">2080</span>    try {<a name="line.2080"></a>
+<span class="sourceLineNo">2081</span>      checkInitialized();<a name="line.2081"></a>
+<span class="sourceLineNo">2082</span>      if (this.cpHost != null) {<a name="line.2082"></a>
+<span class="sourceLineNo">2083</span>        this.cpHost.preMove(hri, rp.getSource(), rp.getDestination());<a name="line.2083"></a>
+<span class="sourceLineNo">2084</span>      }<a name="line.2084"></a>
+<span class="sourceLineNo">2085</span><a name="line.2085"></a>
+<span class="sourceLineNo">2086</span>      TransitRegionStateProcedure proc =<a name="line.2086"></a>
+<span class="sourceLineNo">2087</span>        this.assignmentManager.createMoveRegionProcedure(rp.getRegionInfo(), rp.getDestination());<a name="line.2087"></a>
+<span class="sourceLineNo">2088</span>      // Warmup the region on the destination before initiating the move.<a name="line.2088"></a>
+<span class="sourceLineNo">2089</span>      // A region server could reject the close request because it either does not<a name="line.2089"></a>
+<span class="sourceLineNo">2090</span>      // have the specified region or the region is being split.<a name="line.2090"></a>
+<span class="sourceLineNo">2091</span>      warmUpRegion(rp.getDestination(), hri);<a name="line.2091"></a>
+<span class="sourceLineNo">2092</span><a name="line.2092"></a>
+<span class="sourceLineNo">2093</span>      LOG.info(getClientIdAuditPrefix() + " move " + rp + ", running balancer");<a name="line.2093"></a>
+<span class="sourceLineNo">2094</span>      Future&lt;byte[]&gt; future = ProcedureSyncWait.submitProcedure(this.procedureExecutor, proc);<a name="line.2094"></a>
+<span class="sourceLineNo">2095</span>      try {<a name="line.2095"></a>
+<span class="sourceLineNo">2096</span>        // Is this going to work? Will we throw exception on error?<a name="line.2096"></a>
+<span class="sourceLineNo">2097</span>        // TODO: CompletableFuture rather than this stunted Future.<a name="line.2097"></a>
+<span class="sourceLineNo">2098</span>        future.get();<a name="line.2098"></a>
+<span class="sourceLineNo">2099</span>      } catch (InterruptedException | ExecutionException e) {<a name="line.2099"></a>
+<span class="sourceLineNo">2100</span>        throw new HBaseIOException(e);<a name="line.2100"></a>
+<span class="sourceLineNo">2101</span>      }<a name="line.2101"></a>
+<span class="sourceLineNo">2102</span>      if (this.cpHost != null) {<a name="line.2102"></a>
+<span class="sourceLineNo">2103</span>        this.cpHost.postMove(hri, rp.getSource(), rp.getDestination());<a name="line.2103"></a>
 <span class="sourceLineNo">2104</span>      }<a name="line.2104"></a>
-<span class="sourceLineNo">2105</span>      throw new HBaseIOException(ioe);<a name="line.2105"></a>
-<span class="sourceLineNo">2106</span>    }<a name="line.2106"></a>
-<span class="sourceLineNo">2107</span>  }<a name="line.2107"></a>
-<span class="sourceLineNo">2108</span><a name="line.2108"></a>
-<span class="sourceLineNo">2109</span>  @Override<a name="line.2109"></a>
-<span class="sourceLineNo">2110</span>  public long createTable(final TableDescriptor tableDescriptor, final byte[][] splitKeys,<a name="line.2110"></a>
-<span class="sourceLineNo">2111</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2111"></a>
-<span class="sourceLineNo">2112</span>    checkInitialized();<a name="line.2112"></a>
-<span class="sourceLineNo">2113</span>    TableDescriptor desc = getMasterCoprocessorHost().preCreateTableRegionsInfos(tableDescriptor);<a name="line.2113"></a>
-<span class="sourceLineNo">2114</span>    if (desc == null) {<a name="line.2114"></a>
-<span class="sourceLineNo">2115</span>      throw new IOException("Creation for " + tableDescriptor + " is canceled by CP");<a name="line.2115"></a>
-<span class="sourceLineNo">2116</span>    }<a name="line.2116"></a>
-<span class="sourceLineNo">2117</span>    String namespace = desc.getTableName().getNamespaceAsString();<a name="line.2117"></a>
-<span class="sourceLineNo">2118</span>    this.clusterSchemaService.getNamespace(namespace);<a name="line.2118"></a>
-<span class="sourceLineNo">2119</span><a name="line.2119"></a>
-<span class="sourceLineNo">2120</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(desc, splitKeys);<a name="line.2120"></a>
-<span class="sourceLineNo">2121</span>    TableDescriptorChecker.sanityCheck(conf, desc);<a name="line.2121"></a>
-<span class="sourceLineNo">2122</span><a name="line.2122"></a>
-<span class="sourceLineNo">2123</span>    return MasterProcedureUtil<a name="line.2123"></a>
-<span class="sourceLineNo">2124</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2124"></a>
-<span class="sourceLineNo">2125</span>        @Override<a name="line.2125"></a>
-<span class="sourceLineNo">2126</span>        protected void run() throws IOException {<a name="line.2126"></a>
-<span class="sourceLineNo">2127</span>          getMaster().getMasterCoprocessorHost().preCreateTable(desc, newRegions);<a name="line.2127"></a>
-<span class="sourceLineNo">2128</span><a name="line.2128"></a>
-<span class="sourceLineNo">2129</span>          LOG.info(getClientIdAuditPrefix() + " create " + desc);<a name="line.2129"></a>
-<span class="sourceLineNo">2130</span><a name="line.2130"></a>
-<span class="sourceLineNo">2131</span>          // TODO: We can handle/merge duplicate requests, and differentiate the case of<a name="line.2131"></a>
-<span class="sourceLineNo">2132</span>          // TableExistsException by saying if the schema is the same or not.<a name="line.2132"></a>
-<span class="sourceLineNo">2133</span>          //<a name="line.2133"></a>
-<span class="sourceLineNo">2134</span>          // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2134"></a>
-<span class="sourceLineNo">2135</span>          // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2135"></a>
-<span class="sourceLineNo">2136</span>          ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2136"></a>
-<span class="sourceLineNo">2137</span>          submitProcedure(<a name="line.2137"></a>
-<span class="sourceLineNo">2138</span>            new CreateTableProcedure(procedureExecutor.getEnvironment(), desc, newRegions, latch));<a name="line.2138"></a>
-<span class="sourceLineNo">2139</span>          latch.await();<a name="line.2139"></a>
-<span class="sourceLineNo">2140</span><a name="line.2140"></a>
-<span class="sourceLineNo">2141</span>          getMaster().getMasterCoprocessorHost().postCreateTable(desc, newRegions);<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>        @Override<a name="line.2144"></a>
-<span class="sourceLineNo">2145</span>        protected String getDescription() {<a name="line.2145"></a>
-<span class="sourceLineNo">2146</span>          return "CreateTableProcedure";<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>  }<a name="line.2149"></a>
-<span class="sourceLineNo">2150</span><a name="line.2150"></a>
-<span class="sourceLineNo">2151</span>  @Override<a name="line.2151"></a>
-<span class="sourceLineNo">2152</span>  public long createSystemTable(final TableDescriptor tableDescriptor) throws IOException {<a name="line.2152"></a>
-<span class="sourceLineNo">2153</span>    if (isStopped()) {<a name="line.2153"></a>
-<span class="sourceLineNo">2154</span>      throw new MasterNotRunningException();<a name="line.2154"></a>
-<span class="sourceLineNo">2155</span>    }<a name="line.2155"></a>
-<span class="sourceLineNo">2156</span><a name="line.2156"></a>
-<span class="sourceLineNo">2157</span>    TableName tableName = tableDescriptor.getTableName();<a name="line.2157"></a>
-<span class="sourceLineNo">2158</span>    if (!(tableName.isSystemTable())) {<a name="line.2158"></a>
-<span class="sourceLineNo">2159</span>      throw new IllegalArgumentException(<a name="line.2159"></a>
-<span class="sourceLineNo">2160</span>        "Only system table creation can use this createSystemTable API");<a name="line.2160"></a>
-<span class="sourceLineNo">2161</span>    }<a name="line.2161"></a>
-<span class="sourceLineNo">2162</span><a name="line.2162"></a>
-<span class="sourceLineNo">2163</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(tableDescriptor, null);<a name="line.2163"></a>
-<span class="sourceLineNo">2164</span><a name="line.2164"></a>
-<span class="sourceLineNo">2165</span>    LOG.info(getClientIdAuditPrefix() + " create " + tableDescriptor);<a name="line.2165"></a>
+<span class="sourceLineNo">2105</span>    } catch (IOException ioe) {<a name="line.2105"></a>
+<span class="sourceLineNo">2106</span>      if (ioe instanceof HBaseIOException) {<a name="line.2106"></a>
+<span class="sourceLineNo">2107</span>        throw (HBaseIOException)ioe;<a name="line.2107"></a>
+<span class="sourceLineNo">2108</span>      }<a name="line.2108"></a>
+<span class="sourceLineNo">2109</span>      throw new HBaseIOException(ioe);<a name="line.2109"></a>
+<span class="sourceLineNo">2110</span>    }<a name="line.2110"></a>
+<span class="sourceLineNo">2111</span>  }<a name="line.2111"></a>
+<span class="sourceLineNo">2112</span><a name="line.2112"></a>
+<span class="sourceLineNo">2113</span>  @Override<a name="line.2113"></a>
+<span class="sourceLineNo">2114</span>  public long createTable(final TableDescriptor tableDescriptor, final byte[][] splitKeys,<a name="line.2114"></a>
+<span class="sourceLineNo">2115</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2115"></a>
+<span class="sourceLineNo">2116</span>    checkInitialized();<a name="line.2116"></a>
+<span class="sourceLineNo">2117</span>    TableDescriptor desc = getMasterCoprocessorHost().preCreateTableRegionsInfos(tableDescriptor);<a name="line.2117"></a>
+<span class="sourceLineNo">2118</span>    if (desc == null) {<a name="line.2118"></a>
+<span class="sourceLineNo">2119</span>      throw new IOException("Creation for " + tableDescriptor + " is canceled by CP");<a name="line.2119"></a>
+<span class="sourceLineNo">2120</span>    }<a name="line.2120"></a>
+<span class="sourceLineNo">2121</span>    String namespace = desc.getTableName().getNamespaceAsString();<a name="line.2121"></a>
+<span class="sourceLineNo">2122</span>    this.clusterSchemaService.getNamespace(namespace);<a name="line.2122"></a>
+<span class="sourceLineNo">2123</span><a name="line.2123"></a>
+<span class="sourceLineNo">2124</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(desc, splitKeys);<a name="line.2124"></a>
+<span class="sourceLineNo">2125</span>    TableDescriptorChecker.sanityCheck(conf, desc);<a name="line.2125"></a>
+<span class="sourceLineNo">2126</span><a name="line.2126"></a>
+<span class="sourceLineNo">2127</span>    return MasterProcedureUtil<a name="line.2127"></a>
+<span class="sourceLineNo">2128</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2128"></a>
+<span class="sourceLineNo">2129</span>        @Override<a name="line.2129"></a>
+<span class="sourceLineNo">2130</span>        protected void run() throws IOException {<a name="line.2130"></a>
+<span class="sourceLineNo">2131</span>          getMaster().getMasterCoprocessorHost().preCreateTable(desc, newRegions);<a name="line.2131"></a>
+<span class="sourceLineNo">2132</span><a name="line.2132"></a>
+<span class="sourceLineNo">2133</span>          LOG.info(getClientIdAuditPrefix() + " create " + desc);<a name="line.2133"></a>
+<span class="sourceLineNo">2134</span><a name="line.2134"></a>
+<span class="sourceLineNo">2135</span>          // TODO: We can handle/merge duplicate requests, and differentiate the case of<a name="line.2135"></a>
+<span class="sourceLineNo">2136</span>          // TableExistsException by saying if the schema is the same or not.<a name="line.2136"></a>
+<span class="sourceLineNo">2137</span>          //<a name="line.2137"></a>
+<span class="sourceLineNo">2138</span>          // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2138"></a>
+<span class="sourceLineNo">2139</span>          // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2139"></a>
+<span class="sourceLineNo">2140</span>          ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2140"></a>
+<span class="sourceLineNo">2141</span>          submitProcedure(<a name="line.2141"></a>
+<span class="sourceLineNo">2142</span>            new CreateTableProcedure(procedureExecutor.getEnvironment(), desc, newRegions, latch));<a name="line.2142"></a>
+<span class="sourceLineNo">2143</span>          latch.await();<a name="line.2143"></a>
+<span class="sourceLineNo">2144</span><a name="line.2144"></a>
+<span class="sourceLineNo">2145</span>          getMaster().getMasterCoprocessorHost().postCreateTable(desc, newRegions);<a name="line.2145"></a>
+<span class="sourceLineNo">2146</span>        }<a name="line.2146"></a>
+<span class="sourceLineNo">2147</span><a name="line.2147"></a>
+<span class="sourceLineNo">2148</span>        @Override<a name="line.2148"></a>
+<span class="sourceLineNo">2149</span>        protected String getDescription() {<a name="line.2149"></a>
+<span class="sourceLineNo">2150</span>          return "CreateTableProcedure";<a name="line.2150"></a>
+<span class="sourceLineNo">2151</span>        }<a name="line.2151"></a>
+<span class="sourceLineNo">2152</span>      });<a name="line.2152"></a>
+<span class="sourceLineNo">2153</span>  }<a name="line.2153"></a>
+<span class="sourceLineNo">2154</span><a name="line.2154"></a>
+<span class="sourceLineNo">2155</span>  @Override<a name="line.2155"></a>
+<span class="sourceLineNo">2156</span>  public long createSystemTable(final TableDescriptor tableDescriptor) throws IOException {<a name="line.2156"></a>
+<span class="sourceLineNo">2157</span>    if (isStopped()) {<a name="line.2157"></a>
+<span class="sourceLineNo">2158</span>      throw new MasterNotRunningException();<a name="line.2158"></a>
+<span class="sourceLineNo">2159</span>    }<a name="line.2159"></a>
+<span class="sourceLineNo">2160</span><a name="line.2160"></a>
+<span class="sourceLineNo">2161</span>    TableName tableName = tableDescriptor.getTableName();<a name="line.2161"></a>
+<span class="sourceLineNo">2162</span>    if (!(tableName.isSystemTable())) {<a name="line.2162"></a>
+<span class="sourceLineNo">2163</span>      throw new IllegalArgumentException(<a name="line.2163"></a>
+<span class="sourceLineNo">2164</span>        "Only system table creation can use this createSystemTable API");<a name="line.2164"></a>
+<span class="sourceLineNo">2165</span>    }<a name="line.2165"></a>
 <span class="sourceLineNo">2166</span><a name="line.2166"></a>
-<span class="sourceLineNo">2167</span>    // This special create table is called locally to master.  Therefore, no RPC means no need<a name="line.2167"></a>
-<span class="sourceLineNo">2168</span>    // to use nonce to detect duplicated RPC call.<a name="line.2168"></a>
-<span class="sourceLineNo">2169</span>    long procId = this.procedureExecutor.submitProcedure(<a name="line.2169"></a>
-<span class="sourceLineNo">2170</span>      new CreateTableProcedure(procedureExecutor.getEnvironment(), tableDescriptor, newRegions));<a name="line.2170"></a>
-<span class="sourceLineNo">2171</span><a name="line.2171"></a>
-<span class="sourceLineNo">2172</span>    return procId;<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>  private void startActiveMasterManager(int infoPort) throws KeeperException {<a name="line.2175"></a>
-<span class="sourceLineNo">2176</span>    String backupZNode = ZNodePaths.joinZNode(<a name="line.2176"></a>
-<span class="sourceLineNo">2177</span>      zooKeeper.getZNodePaths().backupMasterAddressesZNode, serverName.toString());<a name="line.2177"></a>
-<span class="sourceLineNo">2178</span>    /*<a name="line.2178"></a>
-<span class="sourceLineNo">2179</span>    * Add a ZNode for ourselves in the backup master directory since we<a name="line.2179"></a>
-<span class="sourceLineNo">2180</span>    * may not become the active master. If so, we want the actual active<a name="line.2180"></a>
-<span class="sourceLineNo">2181</span>    * master to know we are backup masters, so that it won't assign<a name="line.2181"></a>
-<span class="sourceLineNo">2182</span>    * regions to us if so configured.<a name="line.2182"></a>
-<span class="sourceLineNo">2183</span>    *<a name="line.2183"></a>
-<span class="sourceLineNo">2184</span>    * If we become the active master later, ActiveMasterManager will delete<a name="line.2184"></a>
-<span class="sourceLineNo">2185</span>    * this node explicitly.  If we crash before then, ZooKeeper will delete<a name="line.2185"></a>
-<span class="sourceLineNo">2186</span>    * this node for us since it is ephemeral.<a name="line.2186"></a>
-<span class="sourceLineNo">2187</span>    */<a name="line.2187"></a>
-<span class="sourceLineNo">2188</span>    LOG.info("Adding backup master ZNode " + backupZNode);<a name="line.2188"></a>
-<span class="sourceLineNo">2189</span>    if (!MasterAddressTracker.setMasterAddress(zooKeeper, backupZNode, serverName, infoPort)) {<a name="line.2189"></a>
-<span class="sourceLineNo">2190</span>      LOG.warn("Failed create of " + backupZNode + " by " + serverName);<a name="line.2190"></a>
-<span class="sourceLineNo">2191</span>    }<a name="line.2191"></a>
-<span class="sourceLineNo">2192</span>    this.activeMasterManager.setInfoPort(infoPort);<a name="line.2192"></a>
-<span class="sourceLineNo">2193</span>    int timeout = conf.getInt(HConstants.ZK_SESSION_TIMEOUT, HConstants.DEFAULT_ZK_SESSION_TIMEOUT);<a name="line.2193"></a>
-<span class="sourceLineNo">2194</span>    // If we're a backup master, stall until a primary to write this address<a name="line.2194"></a>
-<span class="sourceLineNo">2195</span>    if (conf.getBoolean(HConstants.MASTER_TYPE_BACKUP, HConstants.DEFAULT_MASTER_TYPE_BACKUP)) {<a name="line.2195"></a>
-<span class="sourceLineNo">2196</span>      LOG.debug("HMaster started in backup mode. Stalling until master znode is written.");<a name="line.2196"></a>
-<span class="sourceLineNo">2197</span>      // This will only be a minute or so while the cluster starts up,<a name="line.2197"></a>
-<span class="sourceLineNo">2198</span>      // so don't worry about setting watches on the parent znode<a name="line.2198"></a>
-<span class="sourceLineNo">2199</span>      while (!activeMasterManager.hasActiveMaster()) {<a name="line.2199"></a>
-<span class="sourceLineNo">2200</span>        LOG.debug("Waiting for master address and cluster state znode to be written.");<a name="line.2200"></a>
-<span class="sourceLineNo">2201</span>        Threads.sleep(timeout);<a name="line.2201"></a>
-<span class="sourceLineNo">2202</span>      }<a name="line.2202"></a>
-<span class="sourceLineNo">2203</span>    }<a name="line.2203"></a>
-<span class="sourceLineNo">2204</span>    MonitoredTask status = TaskMonitor.get().createStatus("Master startup");<a name="line.2204"></a>
-<span class="sourceLineNo">2205</span>    status.setDescription("Master startup");<a name="line.2205"></a>
-<span class="sourceLineNo">2206</span>    try {<a name="line.2206"></a>
-<span class="sourceLineNo">2207</span>      if (activeMasterManager.blockUntilBecomingActiveMaster(timeout, status)) {<a name="line.2207"></a>
-<span class="sourceLineNo">2208</span>        finishActiveMasterInitialization(status);<a name="line.2208"></a>
-<span class="sourceLineNo">2209</span>      }<a name="line.2209"></a>
-<span class="sourceLineNo">2210</span>    } catch (Throwable t) {<a name="line.2210"></a>
-<span class="sourceLineNo">2211</span>      status.setStatus("Failed to become active: " + t.getMessage());<a name="line.2211"></a>
-<span class="sourceLineNo">2212</span>      LOG.error(HBaseMarkers.FATAL, "Failed to become active master", t);<a name="line.2212"></a>
-<span class="sourceLineNo">2213</span>      // HBASE-5680: Likely hadoop23 vs hadoop 20.x/1.x incompatibility<a name="line.2213"></a>
-<span class="sourceLineNo">2214</span>      if (t instanceof NoClassDefFoundError &amp;&amp; t.getMessage().<a name="line.2214"></a>
-<span class="sourceLineNo">2215</span>          contains("org/apache/hadoop/hdfs/protocol/HdfsConstants$SafeModeAction")) {<a name="line.2215"></a>
-<span class="sourceLineNo">2216</span>        // improved error message for this special case<a name="line.2216"></a>
-<span class="sourceLineNo">2217</span>        abort("HBase is having a problem with its Hadoop jars.  You may need to recompile " +<a name="line.2217"></a>
-<span class="sourceLineNo">2218</span>          "HBase against Hadoop version " + org.apache.hadoop.util.VersionInfo.getVersion() +<a name="line.2218"></a>
-<span class="sourceLineNo">2219</span>          " or change your hadoop jars to start properly", t);<a name="line.2219"></a>
-<span class="sourceLineNo">2220</span>      } else {<a name="line.2220"></a>
-<span class="sourceLineNo">2221</span>        abort("Unhandled exception. Starting shutdown.", t);<a name="line.2221"></a>
-<span class="sourceLineNo">2222</span>      }<a name="line.2222"></a>
-<span class="sourceLineNo">2223</span>    } finally {<a name="line.2223"></a>
-<span class="sourceLineNo">2224</span>      status.cleanup();<a name="line.2224"></a>
-<span class="sourceLineNo">2225</span>    }<a name="line.2225"></a>
-<span class="sourceLineNo">2226</span>  }<a name="line.2226"></a>
-<span class="sourceLineNo">2227</span><a name="line.2227"></a>
-<span class="sourceLineNo">2228</span>  private static boolean isCatalogTable(final TableName tableName) {<a name="line.2228"></a>
-<span class="sourceLineNo">2229</span>    return tableName.equals(TableName.META_TABLE_NAME);<a name="line.2229"></a>
+<span class="sourceLineNo">2167</span>    RegionInfo[] newRegions = ModifyRegionUtils.createRegionInfos(tableDescriptor, null);<a name="line.2167"></a>
+<span class="sourceLineNo">2168</span><a name="line.2168"></a>
+<span class="sourceLineNo">2169</span>    LOG.info(getClientIdAuditPrefix() + " create " + tableDescriptor);<a name="line.2169"></a>
+<span class="sourceLineNo">2170</span><a name="line.2170"></a>
+<span class="sourceLineNo">2171</span>    // This special create table is called locally to master.  Therefore, no RPC means no need<a name="line.2171"></a>
+<span class="sourceLineNo">2172</span>    // to use nonce to detect duplicated RPC call.<a name="line.2172"></a>
+<span class="sourceLineNo">2173</span>    long procId = this.procedureExecutor.submitProcedure(<a name="line.2173"></a>
+<span class="sourceLineNo">2174</span>      new CreateTableProcedure(procedureExecutor.getEnvironment(), tableDescriptor, newRegions));<a name="line.2174"></a>
+<span class="sourceLineNo">2175</span><a name="line.2175"></a>
+<span class="sourceLineNo">2176</span>    return procId;<a name="line.2176"></a>
+<span class="sourceLineNo">2177</span>  }<a name="line.2177"></a>
+<span class="sourceLineNo">2178</span><a name="line.2178"></a>
+<span class="sourceLineNo">2179</span>  private void startActiveMasterManager(int infoPort) throws KeeperException {<a name="line.2179"></a>
+<span class="sourceLineNo">2180</span>    String backupZNode = ZNodePaths.joinZNode(<a name="line.2180"></a>
+<span class="sourceLineNo">2181</span>      zooKeeper.getZNodePaths().backupMasterAddressesZNode, serverName.toString());<a name="line.2181"></a>
+<span class="sourceLineNo">2182</span>    /*<a name="line.2182"></a>
+<span class="sourceLineNo">2183</span>    * Add a ZNode for ourselves in the backup master directory since we<a name="line.2183"></a>
+<span class="sourceLineNo">2184</span>    * may not become the active master. If so, we want the actual active<a name="line.2184"></a>
+<span class="sourceLineNo">2185</span>    * master to know we are backup masters, so that it won't assign<a name="line.2185"></a>
+<span class="sourceLineNo">2186</span>    * regions to us if so configured.<a name="line.2186"></a>
+<span class="sourceLineNo">2187</span>    *<a name="line.2187"></a>
+<span class="sourceLineNo">2188</span>    * If we become the active master later, ActiveMasterManager will delete<a name="line.2188"></a>
+<span class="sourceLineNo">2189</span>    * this node explicitly.  If we crash before then, ZooKeeper will delete<a name="line.2189"></a>
+<span class="sourceLineNo">2190</span>    * this node for us since it is ephemeral.<a name="line.2190"></a>
+<span class="sourceLineNo">2191</span>    */<a name="line.2191"></a>
+<span class="sourceLineNo">2192</span>    LOG.info("Adding backup master ZNode " + backupZNode);<a name="line.2192"></a>
+<span class="sourceLineNo">2193</span>    if (!MasterAddressTracker.setMasterAddress(zooKeeper, backupZNode, serverName, infoPort)) {<a name="line.2193"></a>
+<span class="sourceLineNo">2194</span>      LOG.warn("Failed create of " + backupZNode + " by " + serverName);<a name="line.2194"></a>
+<span class="sourceLineNo">2195</span>    }<a name="line.2195"></a>
+<span class="sourceLineNo">2196</span>    this.activeMasterManager.setInfoPort(infoPort);<a name="line.2196"></a>
+<span class="sourceLineNo">2197</span>    int timeout = conf.getInt(HConstants.ZK_SESSION_TIMEOUT, HConstants.DEFAULT_ZK_SESSION_TIMEOUT);<a name="line.2197"></a>
+<span class="sourceLineNo">2198</span>    // If we're a backup master, stall until a primary to write this address<a name="line.2198"></a>
+<span class="sourceLineNo">2199</span>    if (conf.getBoolean(HConstants.MASTER_TYPE_BACKUP, HConstants.DEFAULT_MASTER_TYPE_BACKUP)) {<a name="line.2199"></a>
+<span class="sourceLineNo">2200</span>      LOG.debug("HMaster started in backup mode. Stalling until master znode is written.");<a name="line.2200"></a>
+<span class="sourceLineNo">2201</span>      // This will only be a minute or so while the cluster starts up,<a name="line.2201"></a>
+<span class="sourceLineNo">2202</span>      // so don't worry about setting watches on the parent znode<a name="line.2202"></a>
+<span class="sourceLineNo">2203</span>      while (!activeMasterManager.hasActiveMaster()) {<a name="line.2203"></a>
+<span class="sourceLineNo">2204</span>        LOG.debug("Waiting for master address and cluster state znode to be written.");<a name="line.2204"></a>
+<span class="sourceLineNo">2205</span>        Threads.sleep(timeout);<a name="line.2205"></a>
+<span class="sourceLineNo">2206</span>      }<a name="line.2206"></a>
+<span class="sourceLineNo">2207</span>    }<a name="line.2207"></a>
+<span class="sourceLineNo">2208</span>    MonitoredTask status = TaskMonitor.get().createStatus("Master startup");<a name="line.2208"></a>
+<span class="sourceLineNo">2209</span>    status.setDescription("Master startup");<a name="line.2209"></a>
+<span class="sourceLineNo">2210</span>    try {<a name="line.2210"></a>
+<span class="sourceLineNo">2211</span>      if (activeMasterManager.blockUntilBecomingActiveMaster(timeout, status)) {<a name="line.2211"></a>
+<span class="sourceLineNo">2212</span>        finishActiveMasterInitialization(status);<a name="line.2212"></a>
+<span class="sourceLineNo">2213</span>      }<a name="line.2213"></a>
+<span class="sourceLineNo">2214</span>    } catch (Throwable t) {<a name="line.2214"></a>
+<span class="sourceLineNo">2215</span>      status.setStatus("Failed to become active: " + t.getMessage());<a name="line.2215"></a>
+<span class="sourceLineNo">2216</span>      LOG.error(HBaseMarkers.FATAL, "Failed to become active master", t);<a name="line.2216"></a>
+<span class="sourceLineNo">2217</span>      // HBASE-5680: Likely hadoop23 vs hadoop 20.x/1.x incompatibility<a name="line.2217"></a>
+<span class="sourceLineNo">2218</span>      if (t instanceof NoClassDefFoundError &amp;&amp; t.getMessage().<a name="line.2218"></a>
+<span class="sourceLineNo">2219</span>          contains("org/apache/hadoop/hdfs/protocol/HdfsConstants$SafeModeAction")) {<a name="line.2219"></a>
+<span class="sourceLineNo">2220</span>        // improved error message for this special case<a name="line.2220"></a>
+<span class="sourceLineNo">2221</span>        abort("HBase is having a problem with its Hadoop jars.  You may need to recompile " +<a name="line.2221"></a>
+<span class="sourceLineNo">2222</span>          "HBase against Hadoop version " + org.apache.hadoop.util.VersionInfo.getVersion() +<a name="line.2222"></a>
+<span class="sourceLineNo">2223</span>          " or change your hadoop jars to start properly", t);<a name="line.2223"></a>
+<span class="sourceLineNo">2224</span>      } else {<a name="line.2224"></a>
+<span class="sourceLineNo">2225</span>        abort("Unhandled exception. Starting shutdown.", t);<a name="line.2225"></a>
+<span class="sourceLineNo">2226</span>      }<a name="line.2226"></a>
+<span class="sourceLineNo">2227</span>    } finally {<a name="line.2227"></a>
+<span class="sourceLineNo">2228</span>      status.cleanup();<a name="line.2228"></a>
+<span class="sourceLineNo">2229</span>    }<a name="line.2229"></a>
 <span class="sourceLineNo">2230</span>  }<a name="line.2230"></a>
 <span class="sourceLineNo">2231</span><a name="line.2231"></a>
-<span class="sourceLineNo">2232</span>  @Override<a name="line.2232"></a>
-<span class="sourceLineNo">2233</span>  public long deleteTable(<a name="line.2233"></a>
-<span class="sourceLineNo">2234</span>      final TableName tableName,<a name="line.2234"></a>
-<span class="sourceLineNo">2235</span>      final long nonceGroup,<a name="line.2235"></a>
-<span class="sourceLineNo">2236</span>      final long nonce) throws IOException {<a name="line.2236"></a>
-<span class="sourceLineNo">2237</span>    checkInitialized();<a name="line.2237"></a>
-<span class="sourceLineNo">2238</span><a name="line.2238"></a>
-<span class="sourceLineNo">2239</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2239"></a>
-<span class="sourceLineNo">2240</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2240"></a>
-<span class="sourceLineNo">2241</span>      @Override<a name="line.2241"></a>
-<span class="sourceLineNo">2242</span>      protected void run() throws IOException {<a name="line.2242"></a>
-<span class="sourceLineNo">2243</span>        getMaster().getMasterCoprocessorHost().preDeleteTable(tableName);<a name="line.2243"></a>
-<span class="sourceLineNo">2244</span><a name="line.2244"></a>
-<span class="sourceLineNo">2245</span>        LOG.info(getClientIdAuditPrefix() + " delete " + tableName);<a name="line.2245"></a>
-<span class="sourceLineNo">2246</span><a name="line.2246"></a>
-<span class="sourceLineNo">2247</span>        // TODO: We can handle/merge duplicate request<a name="line.2247"></a>
-<span class="sourceLineNo">2248</span>        //<a name="line.2248"></a>
-<span class="sourceLineNo">2249</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2249"></a>
-<span class="sourceLineNo">2250</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2250"></a>
-<span class="sourceLineNo">2251</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2251"></a>
-<span class="sourceLineNo">2252</span>        submitProcedure(new DeleteTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2252"></a>
-<span class="sourceLineNo">2253</span>            tableName, latch));<a name="line.2253"></a>
-<span class="sourceLineNo">2254</span>        latch.await();<a name="line.2254"></a>
-<span class="sourceLineNo">2255</span><a name="line.2255"></a>
-<span class="sourceLineNo">2256</span>        getMaster().getMasterCoprocessorHost().postDeleteTable(tableName);<a name="line.2256"></a>
-<span class="sourceLineNo">2257</span>      }<a name="line.2257"></a>
-<span class="sourceLineNo">2258</span><a name="line.2258"></a>
-<span class="sourceLineNo">2259</span>      @Override<a name="line.2259"></a>
-<span class="sourceLineNo">2260</span>      protected String getDescription() {<a name="line.2260"></a>
-<span class="sourceLineNo">2261</span>        return "DeleteTableProcedure";<a name="line.2261"></a>
-<span class="sourceLineNo">2262</span>      }<a name="line.2262"></a>
-<span class="sourceLineNo">2263</span>    });<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>  @Override<a name="line.2266"></a>
-<span class="sourceLineNo">2267</span>  public long truncateTable(<a name="line.2267"></a>
-<span class="sourceLineNo">2268</span>      final TableName tableName,<a name="line.2268"></a>
-<span class="sourceLineNo">2269</span>      final boolean preserveSplits,<a name="line.2269"></a>
-<span class="sourceLineNo">2270</span>      final long nonceGroup,<a name="line.2270"></a>
-<span class="sourceLineNo">2271</span>      final long nonce) throws IOException {<a name="line.2271"></a>
-<span class="sourceLineNo">2272</span>    checkInitialized();<a name="line.2272"></a>
-<span class="sourceLineNo">2273</span><a name="line.2273"></a>
-<span class="sourceLineNo">2274</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2274"></a>
-<span class="sourceLineNo">2275</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2275"></a>
-<span class="sourceLineNo">2276</span>      @Override<a name="line.2276"></a>
-<span class="sourceLineNo">2277</span>      protected void run() throws IOException {<a name="line.2277"></a>
-<span class="sourceLineNo">2278</span>        getMaster().getMasterCoprocessorHost().preTruncateTable(tableName);<a name="line.2278"></a>
-<span class="sourceLineNo">2279</span><a name="line.2279"></a>
-<span class="sourceLineNo">2280</span>        LOG.info(getClientIdAuditPrefix() + " truncate " + tableName);<a name="line.2280"></a>
-<span class="sourceLineNo">2281</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createLatch(2, 0);<a name="line.2281"></a>
-<span class="sourceLineNo">2282</span>        submitProcedure(new TruncateTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2282"></a>
-<span class="sourceLineNo">2283</span>            tableName, preserveSplits, latch));<a name="line.2283"></a>
-<span class="sourceLineNo">2284</span>        latch.await();<a name="line.2284"></a>
-<span class="sourceLineNo">2285</span><a name="line.2285"></a>
-<span class="sourceLineNo">2286</span>        getMaster().getMasterCoprocessorHost().postTruncateTable(tableName);<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>      @Override<a name="line.2289"></a>
-<span class="sourceLineNo">2290</span>      protected String getDescription() {<a name="line.2290"></a>
-<span class="sourceLineNo">2291</span>        return "TruncateTableProcedure";<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><a name="line.2295"></a>
-<span class="sourceLineNo">2296</span>  @Override<a name="line.2296"></a>
-<span class="sourceLineNo">2297</span>  public long addColumn(final TableName tableName, final ColumnFamilyDescriptor column,<a name="line.2297"></a>
-<span class="sourceLineNo">2298</span>      final long nonceGroup, 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>    checkTableExists(tableName);<a name="line.2300"></a>
-<span class="sourceLineNo">2301</span><a name="line.2301"></a>
-<span class="sourceLineNo">2302</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2302"></a>
-<span class="sourceLineNo">2303</span><a name="line.2303"></a>
-<span class="sourceLineNo">2304</span>      @Override<a name="line.2304"></a>
-<span class="sourceLineNo">2305</span>      public TableDescriptor get() throws IOException {<a name="line.2305"></a>
-<span class="sourceLineNo">2306</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2306"></a>
-<span class="sourceLineNo">2307</span>        if (old.hasColumnFamily(column.getName())) {<a name="line.2307"></a>
-<span class="sourceLineNo">2308</span>          throw new InvalidFamilyOperationException("Column family '" + column.getNameAsString()<a name="line.2308"></a>
-<span class="sourceLineNo">2309</span>              + "' in table '" + tableName + "' already exists so cannot be added");<a name="line.2309"></a>
-<span class="sourceLineNo">2310</span>        }<a name="line.2310"></a>
-<span class="sourceLineNo">2311</span><a name="line.2311"></a>
-<span class="sourceLineNo">2312</span>        return TableDescriptorBuilder.newBuilder(old).setColumnFamily(column).build();<a name="line.2312"></a>
-<span class="sourceLineNo">2313</span>      }<a name="line.2313"></a>
-<span class="sourceLineNo">2314</span>    }, nonceGroup, nonce, true);<a name="line.2314"></a>
-<span class="sourceLineNo">2315</span>  }<a name="line.2315"></a>
-<span class="sourceLineNo">2316</span><a name="line.2316"></a>
-<span class="sourceLineNo">2317</span>  /**<a name="line.2317"></a>
-<span class="sourceLineNo">2318</span>   * Implement to return TableDescriptor after pre-checks<a name="line.2318"></a>
-<span class="sourceLineNo">2319</span>   */<a name="line.2319"></a>
-<span class="sourceLineNo">2320</span>  protected interface TableDescriptorGetter {<a name="line.2320"></a>
-<span class="sourceLineNo">2321</span>    TableDescriptor get() throws IOException;<a name="line.2321"></a>
-<span class="sourceLineNo">2322</span>  }<a name="line.2322"></a>
-<span class="sourceLineNo">2323</span><a name="line.2323"></a>
-<span class="sourceLineNo">2324</span>  @Override<a name="line.2324"></a>
-<span class="sourceLineNo">2325</span>  public long modifyColumn(final TableName tableName, final ColumnFamilyDescriptor descriptor,<a name="line.2325"></a>
-<span class="sourceLineNo">2326</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2326"></a>
-<span class="sourceLineNo">2327</span>    checkInitialized();<a name="line.2327"></a>
-<span class="sourceLineNo">2328</span>    checkTableExists(tableName);<a name="line.2328"></a>
-<span class="sourceLineNo">2329</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2329"></a>
-<span class="sourceLineNo">2330</span><a name="line.2330"></a>
-<span class="sourceLineNo">2331</span>      @Override<a name="line.2331"></a>
-<span class="sourceLineNo">2332</span>      public TableDescriptor get() throws IOException {<a name="line.2332"></a>
-<span class="sourceLineNo">2333</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2333"></a>
-<span class="sourceLineNo">2334</span>        if (!old.hasColumnFamily(descriptor.getName())) {<a name="line.2334"></a>
-<span class="sourceLineNo">2335</span>          throw new InvalidFamilyOperationException("Family '" + descriptor.getNameAsString()<a name="line.2335"></a>
-<span class="sourceLineNo">2336</span>              + "' does not exist, so it cannot be modified");<a name="line.2336"></a>
-<span class="sourceLineNo">2337</span>        }<a name="line.2337"></a>
-<span class="sourceLineNo">2338</span><a name="line.2338"></a>
-<span class="sourceLineNo">2339</span>        return TableDescriptorBuilder.newBuilder(old).modifyColumnFamily(descriptor).build();<a name="line.2339"></a>
-<span class="sourceLineNo">2340</span>      }<a name="line.2340"></a>
-<span class="sourceLineNo">2341</span>    }, nonceGroup, nonce, true);<a name="line.2341"></a>
-<span class="sourceLineNo">2342</span>  }<a name="line.2342"></a>
-<span class="sourceLineNo">2343</span><a name="line.2343"></a>
-<span class="sourceLineNo">2344</span>  @Override<a name="line.2344"></a>
-<span class="sourceLineNo">2345</span>  public long deleteColumn(final TableName tableName, final byte[] columnName,<a name="line.2345"></a>
-<span class="sourceLineNo">2346</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2346"></a>
-<span class="sourceLineNo">2347</span>    checkInitialized();<a name="line.2347"></a>
-<span class="sourceLineNo">2348</span>    checkTableExists(tableName);<a name="line.2348"></a>
-<span class="sourceLineNo">2349</span><a name="line.2349"></a>
-<span class="sourceLineNo">2350</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2350"></a>
-<span class="sourceLineNo">2351</span><a name="line.2351"></a>
-<span class="sourceLineNo">2352</span>      @Override<a name="line.2352"></a>
-<span class="sourceLineNo">2353</span>      public TableDescriptor get() throws IOException {<a name="line.2353"></a>
-<span class="sourceLineNo">2354</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2354"></a>
+<span class="sourceLineNo">2232</span>  private static boolean isCatalogTable(final TableName tableName) {<a name="line.2232"></a>
+<span class="sourceLineNo">2233</span>    return tableName.equals(TableName.META_TABLE_NAME);<a name="line.2233"></a>
+<span class="sourceLineNo">2234</span>  }<a name="line.2234"></a>
+<span class="sourceLineNo">2235</span><a name="line.2235"></a>
+<span class="sourceLineNo">2236</span>  @Override<a name="line.2236"></a>
+<span class="sourceLineNo">2237</span>  public long deleteTable(<a name="line.2237"></a>
+<span class="sourceLineNo">2238</span>      final TableName tableName,<a name="line.2238"></a>
+<span class="sourceLineNo">2239</span>      final long nonceGroup,<a name="line.2239"></a>
+<span class="sourceLineNo">2240</span>      final long nonce) throws IOException {<a name="line.2240"></a>
+<span class="sourceLineNo">2241</span>    checkInitialized();<a name="line.2241"></a>
+<span class="sourceLineNo">2242</span><a name="line.2242"></a>
+<span class="sourceLineNo">2243</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2243"></a>
+<span class="sourceLineNo">2244</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2244"></a>
+<span class="sourceLineNo">2245</span>      @Override<a name="line.2245"></a>
+<span class="sourceLineNo">2246</span>      protected void run() throws IOException {<a name="line.2246"></a>
+<span class="sourceLineNo">2247</span>        getMaster().getMasterCoprocessorHost().preDeleteTable(tableName);<a name="line.2247"></a>
+<span class="sourceLineNo">2248</span><a name="line.2248"></a>
+<span class="sourceLineNo">2249</span>        LOG.info(getClientIdAuditPrefix() + " delete " + tableName);<a name="line.2249"></a>
+<span class="sourceLineNo">2250</span><a name="line.2250"></a>
+<span class="sourceLineNo">2251</span>        // TODO: We can handle/merge duplicate request<a name="line.2251"></a>
+<span class="sourceLineNo">2252</span>        //<a name="line.2252"></a>
+<span class="sourceLineNo">2253</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2253"></a>
+<span class="sourceLineNo">2254</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2254"></a>
+<span class="sourceLineNo">2255</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2255"></a>
+<span class="sourceLineNo">2256</span>        submitProcedure(new DeleteTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2256"></a>
+<span class="sourceLineNo">2257</span>            tableName, latch));<a name="line.2257"></a>
+<span class="sourceLineNo">2258</span>        latch.await();<a name="line.2258"></a>
+<span class="sourceLineNo">2259</span><a name="line.2259"></a>
+<span class="sourceLineNo">2260</span>        getMaster().getMasterCoprocessorHost().postDeleteTable(tableName);<a name="line.2260"></a>
+<span class="sourceLineNo">2261</span>      }<a name="line.2261"></a>
+<span class="sourceLineNo">2262</span><a name="line.2262"></a>
+<span class="sourceLineNo">2263</span>      @Override<a name="line.2263"></a>
+<span class="sourceLineNo">2264</span>      protected String getDescription() {<a name="line.2264"></a>
+<span class="sourceLineNo">2265</span>        return "DeleteTableProcedure";<a name="line.2265"></a>
+<span class="sourceLineNo">2266</span>      }<a name="line.2266"></a>
+<span class="sourceLineNo">2267</span>    });<a name="line.2267"></a>
+<span class="sourceLineNo">2268</span>  }<a name="line.2268"></a>
+<span class="sourceLineNo">2269</span><a name="line.2269"></a>
+<span class="sourceLineNo">2270</span>  @Override<a name="line.2270"></a>
+<span class="sourceLineNo">2271</span>  public long truncateTable(<a name="line.2271"></a>
+<span class="sourceLineNo">2272</span>      final TableName tableName,<a name="line.2272"></a>
+<span class="sourceLineNo">2273</span>      final boolean preserveSplits,<a name="line.2273"></a>
+<span class="sourceLineNo">2274</span>      final long nonceGroup,<a name="line.2274"></a>
+<span class="sourceLineNo">2275</span>      final long nonce) throws IOException {<a name="line.2275"></a>
+<span class="sourceLineNo">2276</span>    checkInitialized();<a name="line.2276"></a>
+<span class="sourceLineNo">2277</span><a name="line.2277"></a>
+<span class="sourceLineNo">2278</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2278"></a>
+<span class="sourceLineNo">2279</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2279"></a>
+<span class="sourceLineNo">2280</span>      @Override<a name="line.2280"></a>
+<span class="sourceLineNo">2281</span>      protected void run() throws IOException {<a name="line.2281"></a>
+<span class="sourceLineNo">2282</span>        getMaster().getMasterCoprocessorHost().preTruncateTable(tableName);<a name="line.2282"></a>
+<span class="sourceLineNo">2283</span><a name="line.2283"></a>
+<span class="sourceLineNo">2284</span>        LOG.info(getClientIdAuditPrefix() + " truncate " + tableName);<a name="line.2284"></a>
+<span class="sourceLineNo">2285</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createLatch(2, 0);<a name="line.2285"></a>
+<span class="sourceLineNo">2286</span>        submitProcedure(new TruncateTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2286"></a>
+<span class="sourceLineNo">2287</span>            tableName, preserveSplits, latch));<a name="line.2287"></a>
+<span class="sourceLineNo">2288</span>        latch.await();<a name="line.2288"></a>
+<span class="sourceLineNo">2289</span><a name="line.2289"></a>
+<span class="sourceLineNo">2290</span>        getMaster().getMasterCoprocessorHost().postTruncateTable(tableName);<a name="line.2290"></a>
+<span class="sourceLineNo">2291</span>      }<a name="line.2291"></a>
+<span class="sourceLineNo">2292</span><a name="line.2292"></a>
+<span class="sourceLineNo">2293</span>      @Override<a name="line.2293"></a>
+<span class="sourceLineNo">2294</span>      protected String getDescription() {<a name="line.2294"></a>
+<span class="sourceLineNo">2295</span>        return "TruncateTableProcedure";<a name="line.2295"></a>
+<span class="sourceLineNo">2296</span>      }<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><a name="line.2299"></a>
+<span class="sourceLineNo">2300</span>  @Override<a name="line.2300"></a>
+<span class="sourceLineNo">2301</span>  public long addColumn(final TableName tableName, final ColumnFamilyDescriptor column,<a name="line.2301"></a>
+<span class="sourceLineNo">2302</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2302"></a>
+<span class="sourceLineNo">2303</span>    checkInitialized();<a name="line.2303"></a>
+<span class="sourceLineNo">2304</span>    checkTableExists(tableName);<a name="line.2304"></a>
+<span class="sourceLineNo">2305</span><a name="line.2305"></a>
+<span class="sourceLineNo">2306</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2306"></a>
+<span class="sourceLineNo">2307</span><a name="line.2307"></a>
+<span class="sourceLineNo">2308</span>      @Override<a name="line.2308"></a>
+<span class="sourceLineNo">2309</span>      public TableDescriptor get() throws IOException {<a name="line.2309"></a>
+<span class="sourceLineNo">2310</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2310"></a>
+<span class="sourceLineNo">2311</span>        if (old.hasColumnFamily(column.getName())) {<a name="line.2311"></a>
+<span class="sourceLineNo">2312</span>          throw new InvalidFamilyOperationException("Column family '" + column.getNameAsString()<a name="line.2312"></a>
+<span class="sourceLineNo">2313</span>              + "' in table '" + tableName + "' already exists so cannot be added");<a name="line.2313"></a>
+<span class="sourceLineNo">2314</span>        }<a name="line.2314"></a>
+<span class="sourceLineNo">2315</span><a name="line.2315"></a>
+<span class="sourceLineNo">2316</span>        return TableDescriptorBuilder.newBuilder(old).setColumnFamily(column).build();<a name="line.2316"></a>
+<span class="sourceLineNo">2317</span>      }<a name="line.2317"></a>
+<span class="sourceLineNo">2318</span>    }, nonceGroup, nonce, true);<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>  /**<a name="line.2321"></a>
+<span class="sourceLineNo">2322</span>   * Implement to return TableDescriptor after pre-checks<a name="line.2322"></a>
+<span class="sourceLineNo">2323</span>   */<a name="line.2323"></a>
+<span class="sourceLineNo">2324</span>  protected interface TableDescriptorGetter {<a name="line.2324"></a>
+<span class="sourceLineNo">2325</span>    TableDescriptor get() throws IOException;<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 modifyColumn(final TableName tableName, final ColumnFamilyDescriptor descriptor,<a name="line.2329"></a>
+<span class="sourceLineNo">2330</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2330"></a>
+<span class="sourceLineNo">2331</span>    checkInitialized();<a name="line.2331"></a>
+<span class="sourceLineNo">2332</span>    checkTableExists(tableName);<a name="line.2332"></a>
+<span class="sourceLineNo">2333</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2333"></a>
+<span class="sourceLineNo">2334</span><a name="line.2334"></a>
+<span class="sourceLineNo">2335</span>      @Override<a name="line.2335"></a>
+<span class="sourceLineNo">2336</span>      public TableDescriptor get() throws IOException {<a name="line.2336"></a>
+<span class="sourceLineNo">2337</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2337"></a>
+<span class="sourceLineNo">2338</span>        if (!old.hasColumnFamily(descriptor.getName())) {<a name="line.2338"></a>
+<span class="sourceLineNo">2339</span>          throw new InvalidFamilyOperationException("Family '" + descriptor.getNameAsString()<a name="line.2339"></a>
+<span class="sourceLineNo">2340</span>              + "' does not exist, so it cannot be modified");<a name="line.2340"></a>
+<span class="sourceLineNo">2341</span>        }<a name="line.2341"></a>
+<span class="sourceLineNo">2342</span><a name="line.2342"></a>
+<span class="sourceLineNo">2343</span>        return TableDescriptorBuilder.newBuilder(old).modifyColumnFamily(descriptor).build();<a name="line.2343"></a>
+<span class="sourceLineNo">2344</span>      }<a name="line.2344"></a>
+<span class="sourceLineNo">2345</span>    }, nonceGroup, nonce, true);<a name="line.2345"></a>
+<span class="sourceLineNo">2346</span>  }<a name="line.2346"></a>
+<span class="sourceLineNo">2347</span><a name="line.2347"></a>
+<span class="sourceLineNo">2348</span>  @Override<a name="line.2348"></a>
+<span class="sourceLineNo">2349</span>  public long deleteColumn(final TableName tableName, final byte[] columnName,<a name="line.2349"></a>
+<span class="sourceLineNo">2350</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2350"></a>
+<span class="sourceLineNo">2351</span>    checkInitialized();<a name="line.2351"></a>
+<span class="sourceLineNo">2352</span>    checkTableExists(tableName);<a name="line.2352"></a>
+<span class="sourceLineNo">2353</span><a name="line.2353"></a>
+<span class="sourceLineNo">2354</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2354"></a>
 <span class="sourceLineNo">2355</span><a name="line.2355"></a>
-<span class="sourceLineNo">2356</span>        if (!old.hasColumnFamily(columnName)) {<a name="line.2356"></a>
-<span class="sourceLineNo">2357</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2357"></a>
-<span class="sourceLineNo">2358</span>              + "' does not exist, so it cannot be deleted");<a name="line.2358"></a>
-<span class="sourceLineNo">2359</span>        }<a name="line.2359"></a>
-<span class="sourceLineNo">2360</span>        if (old.getColumnFamilyCount() == 1) {<a name="line.2360"></a>
+<span class="sourceLineNo">2356</span>      @Override<a name="line.2356"></a>
+<span class="sourceLineNo">2357</span>      public TableDescriptor get() throws IOException {<a name="line.2357"></a>
+<span class="sourceLineNo">2358</span>        TableDescriptor old = getTableDescriptors().get(tableName);<a name="line.2358"></a>
+<span class="sourceLineNo">2359</span><a name="line.2359"></a>
+<span class="sourceLineNo">2360</span>        if (!old.hasColumnFamily(columnName)) {<a name="line.2360"></a>
 <span class="sourceLineNo">2361</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2361"></a>
-<span class="sourceLineNo">2362</span>              + "' is the only column family in the table, so it cannot be deleted");<a name="line.2362"></a>
+<span class="sourceLineNo">2362</span>              + "' does not exist, so it cannot be deleted");<a name="line.2362"></a>
 <span class="sourceLineNo">2363</span>        }<a name="line.2363"></a>
-<span class="sourceLineNo">2364</span>        return TableDescriptorBuilder.newBuilder(old).removeColumnFamily(columnName).build();<a name="line.2364"></a>
-<span class="sourceLineNo">2365</span>      }<a name="line.2365"></a>
-<span class="sourceLineNo">2366</span>    }, nonceGroup, nonce, true);<a name="line.2366"></a>
-<span class="sourceLineNo">2367</span>  }<a name="line.2367"></a>
-<span class="sourceLineNo">2368</span><a name="line.2368"></a>
-<span class="sourceLineNo">2369</span>  @Override<a name="line.2369"></a>
-<span class="sourceLineNo">2370</span>  public long enableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2370"></a>
-<span class="sourceLineNo">2371</span>      throws IOException {<a name="line.2371"></a>
-<span class="sourceLineNo">2372</span>    checkInitialized();<a name="line.2372"></a>
-<span class="sourceLineNo">2373</span><a name="line.2373"></a>
-<span class="sourceLineNo">2374</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2374"></a>
-<span class="sourceLineNo">2375</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2375"></a>
-<span class="sourceLineNo">2376</span>      @Override<a name="line.2376"></a>
-<span class="sourceLineNo">2377</span>      protected void run() throws IOException {<a name="line.2377"></a>
-<span class="sourceLineNo">2378</span>        getMaster().getMasterCoprocessorHost().preEnableTable(tableName);<a name="line.2378"></a>
-<span class="sourceLineNo">2379</span><a name="line.2379"></a>
-<span class="sourceLineNo">2380</span>        // Normally, it would make sense for this authorization check to exist inside<a name="line.2380"></a>
-<span class="sourceLineNo">2381</span>        // AccessController, but because the authorization check is done based on internal state<a name="line.2381"></a>
-<span class="sourceLineNo">2382</span>        // (rather than explicit permissions) we'll do the check here instead of in the<a name="line.2382"></a>
-<span class="sourceLineNo">2383</span>        // coprocessor.<a name="line.2383"></a>
-<span class="sourceLineNo">2384</span>        MasterQuotaManager quotaManager = getMasterQuotaManager();<a name="line.2384"></a>
-<span class="sourceLineNo">2385</span>        if (quotaManager != null) {<a name="line.2385"></a>
-<span class="sourceLineNo">2386</span>          if (quotaManager.isQuotaInitialized()) {<a name="line.2386"></a>
-<span class="sourceLineNo">2387</span>              SpaceQuotaSnapshot currSnapshotOfTable =<a name="line.2387"></a>
-<span class="sourceLineNo">2388</span>                  QuotaTableUtil.getCurrentSnapshotFromQuotaTable(getConnection(), tableName);<a name="line.2388"></a>
-<span class="sourceLineNo">2389</span>              if (currSnapshotOfTable != null) {<a name="line.2389"></a>
-<span class="sourceLineNo">2390</span>                SpaceQuotaStatus quotaStatus = currSnapshotOfTable.getQuotaStatus();<a name="line.2390"></a>
-<span class="sourceLineNo">2391</span>                if (quotaStatus.isInViolation()<a name="line.2391"></a>
-<span class="sourceLineNo">2392</span>                    &amp;&amp; SpaceViolationPolicy.DISABLE == quotaStatus.getPolicy().orElse(null)) {<a name="line.2392"></a>
-<span class="sourceLineNo">2393</span>                throw new AccessDeniedException("Enabling the table '" + tableName<a name="line.2393"></a>
-<span class="sourceLineNo">2394</span>                    + "' is disallowed due to a violated space quota.");<a name="line.2394"></a>
-<span class="sourceLineNo">2395</span>              }<a name="line.2395"></a>
-<span class="sourceLineNo">2396</span>            }<a name="line.2396"></a>
-<span class="sourceLineNo">2397</span>          } else if (LOG.isTraceEnabled()) {<a name="line.2397"></a>
-<span class="sourceLineNo">2398</span>            LOG.trace("Unable to check for space quotas as the MasterQuotaManager is not enabled");<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><a name="line.2401"></a>
-<span class="sourceLineNo">2402</span>        LOG.info(getClientIdAuditPrefix() + " enable " + tableName);<a name="line.2402"></a>
-<span class="sourceLineNo">2403</span><a name="line.2403"></a>
-<span class="sourceLineNo">2404</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2404"></a>
-<span class="sourceLineNo">2405</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2405"></a>
-<span class="sourceLineNo">2406</span>        // we want to make sure that the table is prepared to be<a name="line.2406"></a>
-<span class="sourceLineNo">2407</span>        // enabled (the table is locked and the table state is set).<a name="line.2407"></a>
-<span class="sourceLineNo">2408</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2408"></a>
-<span class="sourceLineNo">2409</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createLatch();<a name="line.2409"></a>
-<span class="sourceLineNo">2410</span>        submitProcedure(new EnableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2410"></a>
-<span class="sourceLineNo">2411</span>            tableName, prepareLatch));<a name="line.2411"></a>
-<span class="sourceLineNo">2412</span>        prepareLatch.await();<a name="line.2412"></a>
-<span class="sourceLineNo">2413</span><a name="line.2413"></a>
-<span class="sourceLineNo">2414</span>        getMaster().getMasterCoprocessorHost().postEnableTable(tableName);<a name="line.2414"></a>
-<span class="sourceLineNo">2415</span>      }<a name="line.2415"></a>
-<span class="sourceLineNo">2416</span><a name="line.2416"></a>
-<span class="sourceLineNo">2417</span>      @Override<a name="line.2417"></a>
-<span class="sourceLineNo">2418</span>      protected String getDescription() {<a name="line.2418"></a>
-<span class="sourceLineNo">2419</span>        return "EnableTableProcedure";<a name="line.2419"></a>
-<span class="sourceLineNo">2420</span>      }<a name="line.2420"></a>
-<span class="sourceLineNo">2421</span>    });<a name="line.2421"></a>
-<span class="sourceLineNo">2422</span>  }<a name="line.2422"></a>
-<span class="sourceLineNo">2423</span><a name="line.2423"></a>
-<span class="sourceLineNo">2424</span>  @Override<a name="line.2424"></a>
-<span class="sourceLineNo">2425</span>  public long disableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2425"></a>
-<span class="sourceLineNo">2426</span>      throws IOException {<a name="line.2426"></a>
-<span class="sourceLineNo">2427</span>    checkInitialized();<a name="line.2427"></a>
-<span class="sourceLineNo">2428</span><a name="line.2428"></a>
-<span class="sourceLineNo">2429</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2429"></a>
-<span class="sourceLineNo">2430</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2430"></a>
-<span class="sourceLineNo">2431</span>      @Override<a name="line.2431"></a>
-<span class="sourceLineNo">2432</span>      protected void run() throws IOException {<a name="line.2432"></a>
-<span class="sourceLineNo">2433</span>        getMaster().getMasterCoprocessorHost().preDisableTable(tableName);<a name="line.2433"></a>
-<span class="sourceLineNo">2434</span><a name="line.2434"></a>
-<span class="sourceLineNo">2435</span>        LOG.info(getClientIdAuditPrefix() + " disable " + tableName);<a name="line.2435"></a>
-<span class="sourceLineNo">2436</span><a name="line.2436"></a>
-<span class="sourceLineNo">2437</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2437"></a>
-<span class="sourceLineNo">2438</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2438"></a>
-<span class="sourceLineNo">2439</span>        // we want to make sure that the table is prepared to be<a name="line.2439"></a>
-<span class="sourceLineNo">2440</span>        // enabled (the table is locked and the table state is set).<a name="line.2440"></a>
-<span class="sourceLineNo">2441</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2441"></a>
-<span class="sourceLineNo">2442</span>        //<a name="line.2442"></a>
-<span class="sourceLineNo">2443</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2443"></a>
-<span class="sourceLineNo">2444</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2444"></a>
-<span class="sourceLineNo">2445</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2445"></a>
-<span class="sourceLineNo">2446</span>        submitProcedure(new DisableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2446"></a>
-<span class="sourceLineNo">2447</span>            tableName, false, prepareLatch));<a name="line.2447"></a>
-<span class="sourceLineNo">2448</span>        prepareLatch.await();<a name="line.2448"></a>
-<span class="sourceLineNo">2449</span><a name="line.2449"></a>
-<span class="sourceLineNo">2450</span>        getMaster().getMasterCoprocessorHost().postDisableTable(tableName);<a name="line.2450"></a>
-<span class="sourceLineNo">2451</span>      }<a name="line.2451"></a>
-<span class="sourceLineNo">2452</span><a name="line.2452"></a>
-<span class="sourceLineNo">2453</span>      @Override<a name="line.2453"></a>
-<span class="sourceLineNo">2454</span>      protected String getDescription() {<a name="line.2454"></a>
-<span class="sourceLineNo">2455</span>        return "DisableTableProcedure";<a name="line.2455"></a>
-<span class="sourceLineNo">2456</span>      }<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><a name="line.2459"></a>
-<span class="sourceLineNo">2460</span>  private long modifyTable(final TableName tableName,<a name="line.2460"></a>
-<span class="sourceLineNo">2461</span>      final TableDescriptorGetter newDescriptorGetter, final long nonceGroup, final long nonce,<a name="line.2461"></a>
-<span class="sourceLineNo">2462</span>      final boolean shouldCheckDescriptor) throws IOException {<a name="line.2462"></a>
-<span class="sourceLineNo">2463</span>    return MasterProcedureUtil<a name="line.2463"></a>
-<span class="sourceLineNo">2464</span>        .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2464"></a>
-<span class="sourceLineNo">2465</span>          @Override<a name="line.2465"></a>
-<span class="sourceLineNo">2466</span>          protected void run() throws IOException {<a name="line.2466"></a>
-<span class="sourceLineNo">2467</span>            TableDescriptor oldDescriptor = getMaster().getTableDescriptors().get(tableName);<a name="line.2467"></a>
-<span class="sourceLineNo">2468</span>            TableDescriptor newDescriptor = getMaster().getMasterCoprocessorHost()<a name="line.2468"></a>
-<span class="sourceLineNo">2469</span>                .preModifyTable(tableName, oldDescriptor, newDescriptorGetter.get());<a name="line.2469"></a>
-<span class="sourceLineNo">2470</span>            TableDescriptorChecker.sanityCheck(conf, newDescriptor);<a name="line.2470"></a>
-<span class="sourceLineNo">2471</span>            LOG.info("{} modify table {} from {} to {}", getClientIdAuditPrefix(), tableName,<a name="line.2471"></a>
-<span class="sourceLineNo">2472</span>                oldDescriptor, newDescriptor);<a name="line.2472"></a>
-<span class="sourceLineNo">2473</span><a name="line.2473"></a>
-<span class="sourceLineNo">2474</span>            // Execute the operation synchronously - wait for the operation completes before<a name="line.2474"></a>
-<span class="sourceLineNo">2475</span>            // continuing.<a name="line.2475"></a>
-<span class="sourceLineNo">2476</span>            //<a name="line.2476"></a>
-<span class="sourceLineNo">2477</span>            // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2477"></a>
-<span class="sourceLineNo">2478</span>            // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2478"></a>
-<span class="sourceLineNo">2479</span>            ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2479"></a>
-<span class="sourceLineNo">2480</span>            submitProcedure(new ModifyTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2480"></a>
-<span class="sourceLineNo">2481</span>                newDescriptor, latch, oldDescriptor, shouldCheckDescriptor));<a name="line.2481"></a>
-<span class="sourceLineNo">2482</span>            latch.await();<a name="line.2482"></a>
-<span class="sourceLineNo">2483</span><a name="line.2483"></a>
-<span class="sourceLineNo">2484</span>            getMaster().getMasterCoprocessorHost().postModifyTable(tableName, oldDescriptor,<a name="line.2484"></a>
-<span class="sourceLineNo">2485</span>              newDescriptor);<a name="line.2485"></a>
-<span class="sourceLineNo">2486</span>          }<a name="line.2486"></a>
+<span class="sourceLineNo">2364</span>        if (old.getColumnFamilyCount() == 1) {<a name="line.2364"></a>
+<span class="sourceLineNo">2365</span>          throw new InvalidFamilyOperationException("Family '" + Bytes.toString(columnName)<a name="line.2365"></a>
+<span class="sourceLineNo">2366</span>              + "' is the only column family in the table, so it cannot be deleted");<a name="line.2366"></a>
+<span class="sourceLineNo">2367</span>        }<a name="line.2367"></a>
+<span class="sourceLineNo">2368</span>        return TableDescriptorBuilder.newBuilder(old).removeColumnFamily(columnName).build();<a name="line.2368"></a>
+<span class="sourceLineNo">2369</span>      }<a name="line.2369"></a>
+<span class="sourceLineNo">2370</span>    }, nonceGroup, nonce, true);<a name="line.2370"></a>
+<span class="sourceLineNo">2371</span>  }<a name="line.2371"></a>
+<span class="sourceLineNo">2372</span><a name="line.2372"></a>
+<span class="sourceLineNo">2373</span>  @Override<a name="line.2373"></a>
+<span class="sourceLineNo">2374</span>  public long enableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2374"></a>
+<span class="sourceLineNo">2375</span>      throws IOException {<a name="line.2375"></a>
+<span class="sourceLineNo">2376</span>    checkInitialized();<a name="line.2376"></a>
+<span class="sourceLineNo">2377</span><a name="line.2377"></a>
+<span class="sourceLineNo">2378</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2378"></a>
+<span class="sourceLineNo">2379</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2379"></a>
+<span class="sourceLineNo">2380</span>      @Override<a name="line.2380"></a>
+<span class="sourceLineNo">2381</span>      protected void run() throws IOException {<a name="line.2381"></a>
+<span class="sourceLineNo">2382</span>        getMaster().getMasterCoprocessorHost().preEnableTable(tableName);<a name="line.2382"></a>
+<span class="sourceLineNo">2383</span><a name="line.2383"></a>
+<span class="sourceLineNo">2384</span>        // Normally, it would make sense for this authorization check to exist inside<a name="line.2384"></a>
+<span class="sourceLineNo">2385</span>        // AccessController, but because the authorization check is done based on internal state<a name="line.2385"></a>
+<span class="sourceLineNo">2386</span>        // (rather than explicit permissions) we'll do the check here instead of in the<a name="line.2386"></a>
+<span class="sourceLineNo">2387</span>        // coprocessor.<a name="line.2387"></a>
+<span class="sourceLineNo">2388</span>        MasterQuotaManager quotaManager = getMasterQuotaManager();<a name="line.2388"></a>
+<span class="sourceLineNo">2389</span>        if (quotaManager != null) {<a name="line.2389"></a>
+<span class="sourceLineNo">2390</span>          if (quotaManager.isQuotaInitialized()) {<a name="line.2390"></a>
+<span class="sourceLineNo">2391</span>              SpaceQuotaSnapshot currSnapshotOfTable =<a name="line.2391"></a>
+<span class="sourceLineNo">2392</span>                  QuotaTableUtil.getCurrentSnapshotFromQuotaTable(getConnection(), tableName);<a name="line.2392"></a>
+<span class="sourceLineNo">2393</span>              if (currSnapshotOfTable != null) {<a name="line.2393"></a>
+<span class="sourceLineNo">2394</span>                SpaceQuotaStatus quotaStatus = currSnapshotOfTable.getQuotaStatus();<a name="line.2394"></a>
+<span class="sourceLineNo">2395</span>                if (quotaStatus.isInViolation()<a name="line.2395"></a>
+<span class="sourceLineNo">2396</span>                    &amp;&amp; SpaceViolationPolicy.DISABLE == quotaStatus.getPolicy().orElse(null)) {<a name="line.2396"></a>
+<span class="sourceLineNo">2397</span>                throw new AccessDeniedException("Enabling the table '" + tableName<a name="line.2397"></a>
+<span class="sourceLineNo">2398</span>                    + "' is disallowed due to a violated space quota.");<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>          } else if (LOG.isTraceEnabled()) {<a name="line.2401"></a>
+<span class="sourceLineNo">2402</span>            LOG.trace("Unable to check for space quotas as the MasterQuotaManager is not enabled");<a name="line.2402"></a>
+<span class="sourceLineNo">2403</span>          }<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>        LOG.info(getClientIdAuditPrefix() + " enable " + tableName);<a name="line.2406"></a>
+<span class="sourceLineNo">2407</span><a name="line.2407"></a>
+<span class="sourceLineNo">2408</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2408"></a>
+<span class="sourceLineNo">2409</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2409"></a>
+<span class="sourceLineNo">2410</span>        // we want to make sure that the table is prepared to be<a name="line.2410"></a>
+<span class="sourceLineNo">2411</span>        // enabled (the table is locked and the table state is set).<a name="line.2411"></a>
+<span class="sourceLineNo">2412</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2412"></a>
+<span class="sourceLineNo">2413</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createLatch();<a name="line.2413"></a>
+<span class="sourceLineNo">2414</span>        submitProcedure(new EnableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2414"></a>
+<span class="sourceLineNo">2415</span>            tableName, prepareLatch));<a name="line.2415"></a>
+<span class="sourceLineNo">2416</span>        prepareLatch.await();<a name="line.2416"></a>
+<span class="sourceLineNo">2417</span><a name="line.2417"></a>
+<span class="sourceLineNo">2418</span>        getMaster().getMasterCoprocessorHost().postEnableTable(tableName);<a name="line.2418"></a>
+<span class="sourceLineNo">2419</span>      }<a name="line.2419"></a>
+<span class="sourceLineNo">2420</span><a name="line.2420"></a>
+<span class="sourceLineNo">2421</span>      @Override<a name="line.2421"></a>
+<span class="sourceLineNo">2422</span>      protected String getDescription() {<a name="line.2422"></a>
+<span class="sourceLineNo">2423</span>        return "EnableTableProcedure";<a name="line.2423"></a>
+<span class="sourceLineNo">2424</span>      }<a name="line.2424"></a>
+<span class="sourceLineNo">2425</span>    });<a name="line.2425"></a>
+<span class="sourceLineNo">2426</span>  }<a name="line.2426"></a>
+<span class="sourceLineNo">2427</span><a name="line.2427"></a>
+<span class="sourceLineNo">2428</span>  @Override<a name="line.2428"></a>
+<span class="sourceLineNo">2429</span>  public long disableTable(final TableName tableName, final long nonceGroup, final long nonce)<a name="line.2429"></a>
+<span class="sourceLineNo">2430</span>      throws IOException {<a name="line.2430"></a>
+<span class="sourceLineNo">2431</span>    checkInitialized();<a name="line.2431"></a>
+<span class="sourceLineNo">2432</span><a name="line.2432"></a>
+<span class="sourceLineNo">2433</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2433"></a>
+<span class="sourceLineNo">2434</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2434"></a>
+<span class="sourceLineNo">2435</span>      @Override<a name="line.2435"></a>
+<span class="sourceLineNo">2436</span>      protected void run() throws IOException {<a name="line.2436"></a>
+<span class="sourceLineNo">2437</span>        getMaster().getMasterCoprocessorHost().preDisableTable(tableName);<a name="line.2437"></a>
+<span class="sourceLineNo">2438</span><a name="line.2438"></a>
+<span class="sourceLineNo">2439</span>        LOG.info(getClientIdAuditPrefix() + " disable " + tableName);<a name="line.2439"></a>
+<span class="sourceLineNo">2440</span><a name="line.2440"></a>
+<span class="sourceLineNo">2441</span>        // Execute the operation asynchronously - client will check the progress of the operation<a name="line.2441"></a>
+<span class="sourceLineNo">2442</span>        // In case the request is from a &lt;1.1 client before returning,<a name="line.2442"></a>
+<span class="sourceLineNo">2443</span>        // we want to make sure that the table is prepared to be<a name="line.2443"></a>
+<span class="sourceLineNo">2444</span>        // enabled (the table is locked and the table state is set).<a name="line.2444"></a>
+<span class="sourceLineNo">2445</span>        // Note: if the procedure throws exception, we will catch it and rethrow.<a name="line.2445"></a>
+<span class="sourceLineNo">2446</span>        //<a name="line.2446"></a>
+<span class="sourceLineNo">2447</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2447"></a>
+<span class="sourceLineNo">2448</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2448"></a>
+<span class="sourceLineNo">2449</span>        final ProcedurePrepareLatch prepareLatch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2449"></a>
+<span class="sourceLineNo">2450</span>        submitProcedure(new DisableTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2450"></a>
+<span class="sourceLineNo">2451</span>            tableName, false, prepareLatch));<a name="line.2451"></a>
+<span class="sourceLineNo">2452</span>        prepareLatch.await();<a name="line.2452"></a>
+<span class="sourceLineNo">2453</span><a name="line.2453"></a>
+<span class="sourceLineNo">2454</span>        getMaster().getMasterCoprocessorHost().postDisableTable(tableName);<a name="line.2454"></a>
+<span class="sourceLineNo">2455</span>      }<a name="line.2455"></a>
+<span class="sourceLineNo">2456</span><a name="line.2456"></a>
+<span class="sourceLineNo">2457</span>      @Override<a name="line.2457"></a>
+<span class="sourceLineNo">2458</span>      protected String getDescription() {<a name="line.2458"></a>
+<span class="sourceLineNo">2459</span>        return "DisableTableProcedure";<a name="line.2459"></a>
+<span class="sourceLineNo">2460</span>      }<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>  private long modifyTable(final TableName tableName,<a name="line.2464"></a>
+<span class="sourceLineNo">2465</span>      final TableDescriptorGetter newDescriptorGetter, final long nonceGroup, final long nonce,<a name="line.2465"></a>
+<span class="sourceLineNo">2466</span>      final boolean shouldCheckDescriptor) throws IOException {<a name="line.2466"></a>
+<span class="sourceLineNo">2467</span>    return MasterProcedureUtil<a name="line.2467"></a>
+<span class="sourceLineNo">2468</span>        .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2468"></a>
+<span class="sourceLineNo">2469</span>          @Override<a name="line.2469"></a>
+<span class="sourceLineNo">2470</span>          protected void run() throws IOException {<a name="line.2470"></a>
+<span class="sourceLineNo">2471</span>            TableDescriptor oldDescriptor = getMaster().getTableDescriptors().get(tableName);<a name="line.2471"></a>
+<span class="sourceLineNo">2472</span>            TableDescriptor newDescriptor = getMaster().getMasterCoprocessorHost()<a name="line.2472"></a>
+<span class="sourceLineNo">2473</span>                .preModifyTable(tableName, oldDescriptor, newDescriptorGetter.get());<a name="line.2473"></a>
+<span class="sourceLineNo">2474</span>            TableDescriptorChecker.sanityCheck(conf, newDescriptor);<a name="line.2474"></a>
+<span class="sourceLineNo">2475</span>            LOG.info("{} modify table {} from {} to {}", getClientIdAuditPrefix(), tableName,<a name="line.2475"></a>
+<span class="sourceLineNo">2476</span>                oldDescriptor, newDescriptor);<a name="line.2476"></a>
+<span class="sourceLineNo">2477</span><a name="line.2477"></a>
+<span class="sourceLineNo">2478</span>            // Execute the operation synchronously - wait for the operation completes before<a name="line.2478"></a>
+<span class="sourceLineNo">2479</span>            // continuing.<a name="line.2479"></a>
+<span class="sourceLineNo">2480</span>            //<a name="line.2480"></a>
+<span class="sourceLineNo">2481</span>            // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.2481"></a>
+<span class="sourceLineNo">2482</span>            // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.2482"></a>
+<span class="sourceLineNo">2483</span>            ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.2483"></a>
+<span class="sourceLineNo">2484</span>            submitProcedure(new ModifyTableProcedure(procedureExecutor.getEnvironment(),<a name="line.2484"></a>
+<span class="sourceLineNo">2485</span>                newDescriptor, latch, oldDescriptor, shouldCheckDescriptor));<a name="line.2485"></a>
+<span class="sourceLineNo">2486</span>            latch.await();<a name="line.2486"></a>
 <span class="sourceLineNo">2487</span><a name="line.2487"></a>
-<span class="sourceLineNo">2488</span>          @Override<a name="line.2488"></a>
-<span class="sourceLineNo">2489</span>          protected String getDescription() {<a name="line.2489"></a>
-<span class="sourceLineNo">2490</span>            return "ModifyTableProcedure";<a name="line.2490"></a>
-<span class="sourceLineNo">2491</span>          }<a name="line.2491"></a>
-<span class="sourceLineNo">2492</span>        });<a name="line.2492"></a>
-<span class="sourceLineNo">2493</span><a name="line.2493"></a>
-<span class="sourceLineNo">2494</span>  }<a name="line.2494"></a>
-<span class="sourceLineNo">2495</span><a name="line.2495"></a>
-<span class="sourceLineNo">2496</span>  @Override<a name="line.2496"></a>
-<span class="sourceLineNo">2497</span>  public long modifyTable(final TableName tableName, final TableDescriptor newDescriptor,<a name="line.2497"></a>
-<span class="sourceLineNo">2498</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2498"></a>
-<span class="sourceLineNo">2499</span>    checkInitialized();<a name="line.2499"></a>
-<span class="sourceLineNo">2500</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2500"></a>
-<span class="sourceLineNo">2501</span>      @Override<a name="line.2501"></a>
-<span class="sourceLineNo">2502</span>      public TableDescriptor get() throws IOException {<a name="line.2502"></a>
-<span class="sourceLineNo">2503</span>        return newDescriptor;<a name="line.2503"></a>
-<span class="sourceLineNo">2504</span>      }<a name="line.2504"></a>
-<span class="sourceLineNo">2505</span>    }, nonceGroup, nonce, false);<a name="line.2505"></a>
-<span class="sourceLineNo">2506</span><a name="line.2506"></a>
-<span class="sourceLineNo">2507</span>  }<a name="line.2507"></a>
-<span class="sourceLineNo">2508</span><a name="line.2508"></a>
-<span class="sourceLineNo">2509</span>  public long restoreSnapshot(final SnapshotDescription snapshotDesc,<a name="line.2509"></a>
-<span class="sourceLineNo">2510</span>      final long nonceGroup, final long nonce, final boolean restoreAcl) throws IOException {<a name="line.2510"></a>
-<span class="sourceLineNo">2511</span>    checkInitialized();<a name="line.2511"></a>
-<span class="sourceLineNo">2512</span>    getSnapshotManager().checkSnapshotSupport();<a name="line.2512"></a>
-<span class="sourceLineNo">2513</span><a name="line.2513"></a>
-<span class="sourceLineNo">2514</span>    // Ensure namespace exists. Will throw exception if non-known NS.<a name="line.2514"></a>
-<span class="sourceLineNo">2515</span>    final TableName dstTable = TableName.valueOf(snapshotDesc.getTable());<a name="line.2515"></a>
-<span class="sourceLineNo">2516</span>    getClusterSchema().getNamespace(dstTable.getNamespaceAsString());<a name="line.2516"></a>
+<span class="sourceLineNo">2488</span>            getMaster().getMasterCoprocessorHost().postModifyTable(tableName, oldDescriptor,<a name="line.2488"></a>
+<span class="sourceLineNo">2489</span>              newDescriptor);<a name="line.2489"></a>
+<span class="sourceLineNo">2490</span>          }<a name="line.2490"></a>
+<span class="sourceLineNo">2491</span><a name="line.2491"></a>
+<span class="sourceLineNo">2492</span>          @Override<a name="line.2492"></a>
+<span class="sourceLineNo">2493</span>          protected String getDescription() {<a name="line.2493"></a>
+<span class="sourceLineNo">2494</span>            return "ModifyTableProcedure";<a name="line.2494"></a>
+<span class="sourceLineNo">2495</span>          }<a name="line.2495"></a>
+<span class="sourceLineNo">2496</span>        });<a name="line.2496"></a>
+<span class="sourceLineNo">2497</span><a name="line.2497"></a>
+<span class="sourceLineNo">2498</span>  }<a name="line.2498"></a>
+<span class="sourceLineNo">2499</span><a name="line.2499"></a>
+<span class="sourceLineNo">2500</span>  @Override<a name="line.2500"></a>
+<span class="sourceLineNo">2501</span>  public long modifyTable(final TableName tableName, final TableDescriptor newDescriptor,<a name="line.2501"></a>
+<span class="sourceLineNo">2502</span>      final long nonceGroup, final long nonce) throws IOException {<a name="line.2502"></a>
+<span class="sourceLineNo">2503</span>    checkInitialized();<a name="line.2503"></a>
+<span class="sourceLineNo">2504</span>    return modifyTable(tableName, new TableDescriptorGetter() {<a name="line.2504"></a>
+<span class="sourceLineNo">2505</span>      @Override<a name="line.2505"></a>
+<span class="sourceLineNo">2506</span>      public TableDescriptor get() throws IOException {<a name="line.2506"></a>
+<span class="sourceLineNo">2507</span>        return newDescriptor;<a name="line.2507"></a>
+<span class="sourceLineNo">2508</span>      }<a name="line.2508"></a>
+<span class="sourceLineNo">2509</span>    }, nonceGroup, nonce, false);<a name="line.2509"></a>
+<span class="sourceLineNo">2510</span><a name="line.2510"></a>
+<span class="sourceLineNo">2511</span>  }<a name="line.2511"></a>
+<span class="sourceLineNo">2512</span><a name="line.2512"></a>
+<span class="sourceLineNo">2513</span>  public long restoreSnapshot(final SnapshotDescription snapshotDesc,<a name="line.2513"></a>
+<span class="sourceLineNo">2514</span>      final long nonceGroup, final long nonce, final boolean restoreAcl) throws IOException {<a name="line.2514"></a>
+<span class="sourceLineNo">2515</span>    checkInitialized();<a name="line.2515"></a>
+<span class="sourceLineNo">2516</span>    getSnapshotManager().checkSnapshotSupport();<a name="line.2516"></a>
 <span class="sourceLineNo">2517</span><a name="line.2517"></a>
-<span class="sourceLineNo">2518</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2518"></a>
-<span class="sourceLineNo">2519</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2519"></a>
-<span class="sourceLineNo">2520</span>      @Override<a name="line.2520"></a>
-<span class="sourceLineNo">2521</span>      protected void run() throws IOException {<a name="line.2521"></a>
-<span class="sourceLineNo">2522</span>          setProcId(<a name="line.2522"></a>
-<span class="sourceLineNo">2523</span>            getSnapshotManager().restoreOrCloneSnapshot(snapshotDesc, getNonceKey(), restoreAcl));<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>      @Override<a name="line.2526"></a>
-<span class="sourceLineNo">2527</span>      protected String getDescription() {<a name="line.2527"></a>
-<span class="sourceLineNo">2528</span>        return "RestoreSnapshotProcedure";<a name="line.2528"></a>
-<span class="sourceLineNo">2529</span>      }<a name="line.2529"></a>
-<span class="sourceLineNo">2530</span>    });<a name="line.2530"></a>
-<span class="sourceLineNo">2531</span>  }<a name="line.2531"></a>
-<span class="sourceLineNo">2532</span><a name="line.2532"></a>
-<span class="sourceLineNo">2533</span>  private void checkTableExists(final TableName tableName)<a name="line.2533"></a>
-<span class="sourceLineNo">2534</span>    throws IOException, TableNotFoundException {<a name="line.2534"></a>
-<span class="sourceLineNo">2535</span>    if (!tableDescriptors.exists(tableName)) {<a name="line.2535"></a>
-<span class="sourceLineNo">2536</span>      throw new TableNotFoundException(tableName);<a name="line.2536"></a>
-<span class="sourceLineNo">2537</span>    }<a name="line.2537"></a>
-<span class="sourceLineNo">2538</span>  }<a name="line.2538"></a>
-<span class="sourceLineNo">2539</span><a name="line.2539"></a>
-<span class="sourceLineNo">2540</span>  @Override<a name="line.2540"></a>
-<span class="sourceLineNo">2541</span>  public void checkTableModifiable(final TableName tableName)<a name="line.2541"></a>
-<span class="sourceLineNo">2542</span>      throws IOException, TableNotFoundException, TableNotDisabledException {<a name="line.2542"></a>
-<span class="sourceLineNo">2543</span>    if (isCatalogTable(tableName)) {<a name="line.2543"></a>
-<span class="sourceLineNo">2544</span>      throw new IOException("Can't modify catalog tables");<a name="line.2544"></a>
-<span class="sourceLineNo">2545</span>    }<a name="line.2545"></a>
-<span class="sourceLineNo">2546</span>    checkTableExists(tableName);<a name="line.2546"></a>
-<span class="sourceLineNo">2547</span>    TableState ts = getTableStateManager().getTableState(tableName);<a name="line.2547"></a>
-<span class="sourceLineNo">2548</span>    if (!ts.isDisabled()) {<a name="line.2548"></a>
-<span class="sourceLineNo">2549</span>      throw new TableNotDisabledException("Not DISABLED; " + ts);<a name="line.2549"></a>
-<span class="sourceLineNo">2550</span>    }<a name="line.2550"></a>
-<span class="sourceLineNo">2551</span>  }<a name="line.2551"></a>
-<span class="sourceLineNo">2552</span><a name="line.2552"></a>
-<span class="sourceLineNo">2553</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor() throws InterruptedIOException {<a name="line.2553"></a>
-<span class="sourceLineNo">2554</span>    return getClusterMetricsWithoutCoprocessor(EnumSet.allOf(Option.class));<a name="line.2554"></a>
+<span class="sourceLineNo">2518</span>    // Ensure namespace exists. Will throw exception if non-known NS.<a name="line.2518"></a>
+<span class="sourceLineNo">2519</span>    final TableName dstTable = TableName.valueOf(snapshotDesc.getTable());<a name="line.2519"></a>
+<span class="sourceLineNo">2520</span>    getClusterSchema().getNamespace(dstTable.getNamespaceAsString());<a name="line.2520"></a>
+<span class="sourceLineNo">2521</span><a name="line.2521"></a>
+<span class="sourceLineNo">2522</span>    return MasterProcedureUtil.submitProcedure(<a name="line.2522"></a>
+<span class="sourceLineNo">2523</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.2523"></a>
+<span class="sourceLineNo">2524</span>      @Override<a name="line.2524"></a>
+<span class="sourceLineNo">2525</span>      protected void run() throws IOException {<a name="line.2525"></a>
+<span class="sourceLineNo">2526</span>          setProcId(<a name="line.2526"></a>
+<span class="sourceLineNo">2527</span>            getSnapshotManager().restoreOrCloneSnapshot(snapshotDesc, getNonceKey(), restoreAcl));<a name="line.2527"></a>
+<span class="sourceLineNo">2528</span>      }<a name="line.2528"></a>
+<span class="sourceLineNo">2529</span><a name="line.2529"></a>
+<span class="sourceLineNo">2530</span>      @Override<a name="line.2530"></a>
+<span class="sourceLineNo">2531</span>      protected String getDescription() {<a name="line.2531"></a>
+<span class="sourceLineNo">2532</span>        return "RestoreSnapshotProcedure";<a name="line.2532"></a>
+<span class="sourceLineNo">2533</span>      }<a name="line.2533"></a>
+<span class="sourceLineNo">2534</span>    });<a name="line.2534"></a>
+<span class="sourceLineNo">2535</span>  }<a name="line.2535"></a>
+<span class="sourceLineNo">2536</span><a name="line.2536"></a>
+<span class="sourceLineNo">2537</span>  private void checkTableExists(final TableName tableName)<a name="line.2537"></a>
+<span class="sourceLineNo">2538</span>    throws IOException, TableNotFoundException {<a name="line.2538"></a>
+<span class="sourceLineNo">2539</span>    if (!tableDescriptors.exists(tableName)) {<a name="line.2539"></a>
+<span class="sourceLineNo">2540</span>      throw new TableNotFoundException(tableName);<a name="line.2540"></a>
+<span class="sourceLineNo">2541</span>    }<a name="line.2541"></a>
+<span class="sourceLineNo">2542</span>  }<a name="line.2542"></a>
+<span class="sourceLineNo">2543</span><a name="line.2543"></a>
+<span class="sourceLineNo">2544</span>  @Override<a name="line.2544"></a>
+<span class="sourceLineNo">2545</span>  public void checkTableModifiable(final TableName tableName)<a name="line.2545"></a>
+<span class="sourceLineNo">2546</span>      throws IOException, TableNotFoundException, TableNotDisabledException {<a name="line.2546"></a>
+<span class="sourceLineNo">2547</span>    if (isCatalogTable(tableName)) {<a name="line.2547"></a>
+<span class="sourceLineNo">2548</span>      throw new IOException("Can't modify catalog tables");<a name="line.2548"></a>
+<span class="sourceLineNo">2549</span>    }<a name="line.2549"></a>
+<span class="sourceLineNo">2550</span>    checkTableExists(tableName);<a name="line.2550"></a>
+<span class="sourceLineNo">2551</span>    TableState ts = getTableStateManager().getTableState(tableName);<a name="line.2551"></a>
+<span class="sourceLineNo">2552</span>    if (!ts.isDisabled()) {<a name="line.2552"></a>
+<span class="sourceLineNo">2553</span>      throw new TableNotDisabledException("Not DISABLED; " + ts);<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>  public ClusterMetrics getClusterMetricsWithoutCoprocessor(EnumSet&lt;Option&gt; options)<a name="line.2557"></a>
-<span class="sourceLineNo">2558</span>      throws InterruptedIOException {<a name="line.2558"></a>
-<span class="sourceLineNo">2559</span>    ClusterMetricsBuilder builder = ClusterMetricsBuilder.newBuilder();<a name="line.2559"></a>
-<span class="sourceLineNo">2560</span>    // given that hbase1 can't submit the request with Option,<a name="line.2560"></a>
-<span class="sourceLineNo">2561</span>    // we return all information to client if the list of Option is empty.<a name="line.2561"></a>
-<span class="sourceLineNo">2562</span>    if (options.isEmpty()) {<a name="line.2562"></a>
-<span class="sourceLineNo">2563</span>      options = EnumSet.allOf(Option.class);<a name="line.2563"></a>
-<span class="sourceLineNo">2564</span>    }<a name="line.2564"></a>
-<span class="sourceLineNo">2565</span><a name="line.2565"></a>
-<span class="sourceLineNo">2566</span>    for (Option opt : options) {<a name="line.2566"></a>
-<span class="sourceLineNo">2567</span>      switch (opt) {<a name="line.2567"></a>
-<span class="sourceLineNo">2568</span>        case HBASE_VERSION: builder.setHBaseVersion(VersionInfo.getVersion()); break;<a name="line.2568"></a>
-<span class="sourceLineNo">2569</span>        case CLUSTER_ID: builder.setClusterId(getClusterId()); break;<a name="line.2569"></a>
-<span class="sourceLineNo">2570</span>        case MASTER: builder.setMasterName(getServerName()); break;<a name="line.2570"></a>
-<span class="sourceLineNo">2571</span>        case BACKUP_MASTERS: builder.setBackerMasterNames(getBackupMasters()); break;<a name="line.2571"></a>
-<span class="sourceLineNo">2572</span>        case LIVE_SERVERS: {<a name="line.2572"></a>
-<span class="sourceLineNo">2573</span>          if (serverManager != null) {<a name="line.2573"></a>
-<span class="sourceLineNo">2574</span>            builder.setLiveServerMetrics(serverManager.getOnlineServers().entrySet().stream()<a name="line.2574"></a>
-<span class="sourceLineNo">2575</span>              .collect(Collectors.toMap(e -&gt; e.getKey(), e -&gt; e.getValue())));<a name="line.2575"></a>
-<span class="sourceLineNo">2576</span>          }<a name="line.2576"></a>
-<span class="sourceLineNo">2577</span>          break;<a name="line.2577"></a>
-<span class="sourceLineNo">2578</span>        }<a name="line.2578"></a>
-<span class="sourceLineNo">2579</span>        case DEAD_SERVERS: {<a name="line.2579"></a>
-<span class="sourceLineNo">2580</span>          if (serverManager != null) {<a name="line.2580"></a>
-<span class="sourceLineNo">2581</span>            builder.setDeadServerNames(new ArrayList&lt;&gt;(<a name="line.2581"></a>
-<span class="sourceLineNo">2582</span>              serverManager.getDeadServers().copyServerNames()));<a name="line.2582"></a>
-<span class="sourceLineNo">2583</span>          }<a name="line.2583"></a>
-<span class="sourceLineNo">2584</span>          break;<a name="line.2584"></a>
-<span class="sourceLineNo">2585</span>        }<a name="line.2585"></a>
-<span class="sourceLineNo">2586</span>        case MASTER_COPROCESSORS: {<a name="line.2586"></a>
-<span class="sourceLineNo">2587</span>          if (cpHost != null) {<a name="line.2587"></a>
-<span class="sourceLineNo">2588</span>            builder.setMasterCoprocessorNames(Arrays.asList(getMasterCoprocessors()));<a name="line.2588"></a>
-<span class="sourceLineNo">2589</span>          }<a name="line.2589"></a>
-<span class="sourceLineNo">2590</span>          break;<a name="line.2590"></a>
-<span class="sourceLineNo">2591</span>        }<a name="line.2591"></a>
-<span class="sourceLineNo">2592</span>        case REGIONS_IN_TRANSITION: {<a name="line.2592"></a>
-<span class="sourceLineNo">2593</span>          if (assignmentManager != null) {<a name="line.2593"></a>
-<span class="sourceLineNo">2594</span>            builder.setRegionsInTransition(assignmentManager.getRegionStates()<a name="line.2594"></a>
-<span class="sourceLineNo">2595</span>                .getRegionsStateInTransition());<a name="line.2595"></a>
-<span class="sourceLineNo">2596</span>          }<a name="line.2596"></a>
-<span class="sourceLineNo">2597</span>          break;<a name="line.2597"></a>
-<span class="sourceLineNo">2598</span>        }<a name="line.2598"></a>
-<span class="sourceLineNo">2599</span>        case BALANCER_ON: {<a name="line.2599"></a>
-<span class="sourceLineNo">2600</span>          if (loadBalancerTracker != null) {<a name="line.2600"></a>
-<span class="sourceLineNo">2601</span>            builder.setBalancerOn(loadBalancerTracker.isBalancerOn());<a name="line.2601"></a>
-<span class="sourceLineNo">2602</span>          }<a name="line.2602"></a>
-<span class="sourceLineNo">2603</span>          break;<a name="line.2603"></a>
-<span class="sourceLineNo">2604</span>        }<a name="line.2604"></a>
-<span class="sourceLineNo">2605</span>        case MASTER_INFO_PORT: {<a name="line.2605"></a>
-<span class="sourceLineNo">2606</span>          if (infoServer != null) {<a name="line.2606"></a>
-<span class="sourceLineNo">2607</span>            builder.setMasterInfoPort(infoServer.getPort());<a name="line.2607"></a>
-<span class="sourceLineNo">2608</span>          }<a name="line.2608"></a>
-<span class="sourceLineNo">2609</span>          break;<a name="line.2609"></a>
-<span class="sourceLineNo">2610</span>        }<a name="line.2610"></a>
-<span class="sourceLineNo">2611</span>        case SERVERS_NAME: {<a name="line.2611"></a>
-<span class="sourceLineNo">2612</span>          if (serverManager != null) {<a name="line.2612"></a>
-<span class="sourceLineNo">2613</span>            builder.setServerNames(serverManager.getOnlineServersList());<a name="line.2613"></a>
-<span class="sourceLineNo">2614</span>          }<a name="line.2614"></a>
-<span class="sourceLineNo">2615</span>          break;<a name="line.2615"></a>
-<span class="sourceLineNo">2616</span>        }<a name="line.2616"></a>
-<span class="sourceLineNo">2617</span>        case TABLE_TO_REGIONS_COUNT: {<a name="line.2617"></a>
-<span class="sourceLineNo">2618</span>          if (isActiveMaster() &amp;&amp; isInitialized() &amp;&amp; assignmentManager != null) {<a name="line.2618"></a>
-<span class="sourceLineNo">2619</span>            try {<a name="line.2619"></a>
-<span class="sourceLineNo">2620</span>              Map&lt;TableName, RegionStatesCount&gt; tableRegionStatesCountMap = new HashMap&lt;&gt;();<a name="line.2620"></a>
-<span class="sourceLineNo">2621</span>              Map&lt;String, TableDescriptor&gt; tableDescriptorMap = getTableDescriptors().getAll();<a name="line.2621"></a>
-<span class="sourceLineNo">2622</span>              for (TableDescriptor tableDescriptor : tableDescriptorMap.values()) {<a name="line.2622"></a>
-<span class="sourceLineNo">2623</span>                TableName tableName = tableDescriptor.getTableName();<a name="line.2623"></a>
-<span class="sourceLineNo">2624</span>                RegionStatesCount regionStatesCount = assignmentManager<a name="line.2624"></a>
-<span class="sourceLineNo">2625</span>                  .getRegionStatesCount(tableName);<a name="line.2625"></a>
-<span class="sourceLineNo">2626</span>                tableRegionStatesCountMap.put(tableName, regionStatesCount);<a name="line.2626"></a>
-<span class="sourceLineNo">2627</span>              }<a name="line.2627"></a>
-<span class="sourceLineNo">2628</span>              builder.setTableRegionStatesCount(tableRegionStatesCountMap);<a name="line.2628"></a>
-<span class="sourceLineNo">2629</span>            } catch (IOException e) {<a name="line.2629"></a>
-<span class="sourceLineNo">2630</span>              LOG.error("Error while populating TABLE_TO_REGIONS_COUNT for Cluster Metrics..", e);<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>          break;<a name="line.2633"></a>
-<span class="sourceLineNo">2634</span>        }<a name="line.2634"></a>
-<span class="sourceLineNo">2635</span>      }<a name="line.2635"></a>
-<span class="sourceLineNo">2636</span>    }<a name="line.2636"></a>
-<span class="sourceLineNo">2637</span>    return builder.build();<a name="line.2637"></a>
-<span class="sourceLineNo">2638</span>  }<a name="line.2638"></a>
-<span class="sourceLineNo">2639</span><a name="line.2639"></a>
-<span class="sourceLineNo">2640</span>  /**<a name="line.2640"></a>
-<span class="sourceLineNo">2641</span>   * @return cluster status<a name="line.2641"></a>
-<span class="sourceLineNo">2642</span>   */<a name="line.2642"></a>
-<span class="sourceLineNo">2643</span>  public ClusterMetrics getClusterMetrics() throws IOException {<a name="line.2643"></a>
-<span class="sourceLineNo">2644</span>    return getClusterMetrics(EnumSet.allOf(Option.class));<a name="line.2644"></a>
-<span class="sourceLineNo">2645</span>  }<a name="line.2645"></a>
-<span class="sourceLineNo">2646</span><a name="line.2646"></a>
-<span class="sourceLineNo">2647</span>  public ClusterMetrics getClusterMetrics(EnumSet&lt;Option&gt; options) throws IOException {<a name="line.2647"></a>
-<span class="sourceLineNo">2648</span>    if (cpHost != null) {<a name="line.2648"></a>
-<span class="sourceLineNo">2649</span>      cpHost.preGetClusterMetrics();<a name="line.2649"></a>
-<span class="sourceLineNo">2650</span>    }<a name="line.2650"></a>
-<span class="sourceLineNo">2651</span>    ClusterMetrics status = getClusterMetricsWithoutCoprocessor(options);<a name="line.2651"></a>
+<span class="sourceLineNo">2557</span>  public ClusterMetrics getClusterMetricsWithoutCoprocessor() throws InterruptedIOException {<a name="line.2557"></a>
+<span class="sourceLineNo">2558</span>    return getClusterMetricsWithoutCoprocessor(EnumSet.allOf(Option.class));<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>  public ClusterMetrics getClusterMetricsWithoutCoprocessor(EnumSet&lt;Option&gt; options)<a name="line.2561"></a>
+<span class="sourceLineNo">2562</span>      throws InterruptedIOException {<a name="line.2562"></a>
+<span class="sourceLineNo">2563</span>    ClusterMetricsBuilder builder = ClusterMetricsBuilder.newBuilder();<a name="line.2563"></a>
+<span class="sourceLineNo">2564</span>    // given that hbase1 can't submit the request with Option,<a name="line.2564"></a>
+<span class="sourceLineNo">2565</span>    // we return all information to client if the list of Option is empty.<a name="line.2565"></a>
+<span class="sourceLineNo">2566</span>    if (options.isEmpty()) {<a name="line.2566"></a>
+<span class="sourceLineNo">2567</span>      options = EnumSet.allOf(Option.class);<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>    for (Option opt : options) {<a name="line.2570"></a>
+<span class="sourceLineNo">2571</span>      switch (opt) {<a name="line.2571"></a>
+<span class="sourceLineNo">2572</span>        case HBASE_VERSION: builder.setHBaseVersion(VersionInfo.getVersion()); break;<a name="line.2572"></a>
+<span class="sourceLineNo">2573</span>        case CLUSTER_ID: builder.setClusterId(getClusterId()); break;<a name="line.2573"></a>
+<span class="sourceLineNo">2574</span>        case MASTER: builder.setMasterName(getServerName()); break;<a name="line.2574"></a>
+<span class="sourceLineNo">2575</span>        case BACKUP_MASTERS: builder.setBackerMasterNames(getBackupMasters()); break;<a name="line.2575"></a>
+<span class="sourceLineNo">2576</span>        case LIVE_SERVERS: {<a name="line.2576"></a>
+<span class="sourceLineNo">2577</span>          if (serverManager != null) {<a name="line.2577"></a>
+<span class="sourceLineNo">2578</span>            builder.setLiveServerMetrics(serverManager.getOnlineServers().entrySet().stream()<a name="line.2578"></a>
+<span class="sourceLineNo">2579</span>              .collect(Collectors.toMap(e -&gt; e.getKey(), e -&gt; e.getValue())));<a name="line.2579"></a>
+<span class="sourceLineNo">2580</span>          }<a name="line.2580"></a>
+<span class="sourceLineNo">2581</span>          break;<a name="line.2581"></a>
+<span class="sourceLineNo">2582</span>        }<a name="line.2582"></a>
+<span class="sourceLineNo">2583</span>        case DEAD_SERVERS: {<a name="line.2583"></a>
+<span class="sourceLineNo">2584</span>          if (serverManager != null) {<a name="line.2584"></a>
+<span class="sourceLineNo">2585</span>            builder.setDeadServerNames(new ArrayList&lt;&gt;(<a name="line.2585"></a>
+<span class="sourceLineNo">2586</span>              serverManager.getDeadServers().copyServerNames()));<a name="line.2586"></a>
+<span class="sourceLineNo">2587</span>          }<a name="line.2587"></a>
+<span class="sourceLineNo">2588</span>          break;<a name="line.2588"></a>
+<span class="sourceLineNo">2589</span>        }<a name="line.2589"></a>
+<span class="sourceLineNo">2590</span>        case MASTER_COPROCESSORS: {<a name="line.2590"></a>
+<span class="sourceLineNo">2591</span>          if (cpHost != null) {<a name="line.2591"></a>
+<span class="sourceLineNo">2592</span>            builder.setMasterCoprocessorNames(Arrays.asList(getMasterCoprocessors()));<a name="line.2592"></a>
+<span class="sourceLineNo">2593</span>          }<a name="line.2593"></a>
+<span class="sourceLineNo">2594</span>          break;<a name="line.2594"></a>
+<span class="sourceLineNo">2595</span>        }<a name="line.2595"></a>
+<span class="sourceLineNo">2596</span>        case REGIONS_IN_TRANSITION: {<a name="line.2596"></a>
+<span class="sourceLineNo">2597</span>          if (assignmentManager != null) {<a name="line.2597"></a>
+<span class="sourceLineNo">2598</span>            builder.setRegionsInTransition(assignmentManager.getRegionStates()<a name="line.2598"></a>
+<span class="sourceLineNo">2599</span>                .getRegionsStateInTransition());<a name="line.2599"></a>
+<span class="sourceLineNo">2600</span>          }<a name="line.2600"></a>
+<span class="sourceLineNo">2601</span>          break;<a name="line.2601"></a>
+<span class="sourceLineNo">2602</span>        }<a name="line.2602"></a>
+<span class="sourceLineNo">2603</span>        case BALANCER_ON: {<a name="line.2603"></a>
+<span class="sourceLineNo">2604</span>          if (loadBalancerTracker != null) {<a name="line.2604"></a>
+<span class="sourceLineNo">2605</span>            builder.setBalancerOn(loadBalancerTracker.isBalancerOn());<a name="line.2605"></a>
+<span class="sourceLineNo">2606</span>          }<a name="line.2606"></a>
+<span class="sourceLineNo">2607</span>          break;<a name="line.2607"></a>
+<span class="sourceLineNo">2608</span>        }<a name="line.2608"></a>
+<span class="sourceLineNo">2609</span>        case MASTER_INFO_PORT: {<a name="line.2609"></a>
+<span class="sourceLineNo">2610</span>          if (infoServer != null) {<a name="line.2610"></a>
+<span class="sourceLineNo">2611</span>            builder.setMasterInfoPort(infoServer.getPort());<a name="line.2611"></a>
+<span class="sourceLineNo">2612</span>          }<a name="line.2612"></a>
+<span class="sourceLineNo">2613</span>          break;<a name="line.2613"></a>
+<span class="sourceLineNo">2614</span>        }<a name="line.2614"></a>
+<span class="sourceLineNo">2615</span>        case SERVERS_NAME: {<a name="line.2615"></a>
+<span class="sourceLineNo">2616</span>          if (serverManager != null) {<a name="line.2616"></a>
+<span class="sourceLineNo">2617</span>            builder.setServerNames(serverManager.getOnlineServersList());<a name="line.2617"></a>
+<span class="sourceLineNo">2618</span>          }<a name="line.2618"></a>
+<span class="sourceLineNo">2619</span>          break;<a name="line.2619"></a>
+<span class="sourceLineNo">2620</span>        }<a name="line.2620"></a>
+<span class="sourceLineNo">2621</span>        case TABLE_TO_REGIONS_COUNT: {<a name="line.2621"></a>
+<span class="sourceLineNo">2622</span>          if (isActiveMaster() &amp;&amp; isInitialized() &amp;&amp; assignmentManager != null) {<a name="line.2622"></a>
+<span class="sourceLineNo">2623</span>            try {<a name="line.2623"></a>
+<span class="sourceLineNo">2624</span>              Map&lt;TableName, RegionStatesCount&gt; tableRegionStatesCountMap = new HashMap&lt;&gt;();<a name="line.2624"></a>
+<span class="sourceLineNo">2625</span>              Map&lt;String, TableDescriptor&gt; tableDescriptorMap = getTableDescriptors().getAll();<a name="line.2625"></a>
+<span class="sourceLineNo">2626</span>              for (TableDescriptor tableDescriptor : tableDescriptorMap.values()) {<a name="line.2626"></a>
+<span class="sourceLineNo">2627</span>                TableName tableName = tableDescriptor.getTableName();<a name="line.2627"></a>
+<span class="sourceLineNo">2628</span>                RegionStatesCount regionStatesCount = assignmentManager<a name="line.2628"></a>
+<span class="sourceLineNo">2629</span>                  .getRegionStatesCount(tableName);<a name="line.2629"></a>
+<span class="sourceLineNo">2630</span>                tableRegionStatesCountMap.put(tableName, regionStatesCount);<a name="line.2630"></a>
+<span class="sourceLineNo">2631</span>              }<a name="line.2631"></a>
+<span class="sourceLineNo">2632</span>              builder.setTableRegionStatesCount(tableRegionStatesCountMap);<a name="line.2632"></a>
+<span class="sourceLineNo">2633</span>            } catch (IOException e) {<a name="line.2633"></a>
+<span class="sourceLineNo">2634</span>              LOG.error("Error while populating TABLE_TO_REGIONS_COUNT for Cluster Metrics..", e);<a name="line.2634"></a>
+<span class="sourceLineNo">2635</span>            }<a name="line.2635"></a>
+<span class="sourceLineNo">2636</span>          }<a name="line.2636"></a>
+<span class="sourceLineNo">2637</span>          break;<a name="line.2637"></a>
+<span class="sourceLineNo">2638</span>        }<a name="line.2638"></a>
+<span class="sourceLineNo">2639</span>      }<a name="line.2639"></a>
+<span class="sourceLineNo">2640</span>    }<a name="line.2640"></a>
+<span class="sourceLineNo">2641</span>    return builder.build();<a name="line.2641"></a>
+<span class="sourceLineNo">2642</span>  }<a name="line.2642"></a>
+<span class="sourceLineNo">2643</span><a name="line.2643"></a>
+<span class="sourceLineNo">2644</span>  /**<a name="line.2644"></a>
+<span class="sourceLineNo">2645</span>   * @return cluster status<a name="line.2645"></a>
+<span class="sourceLineNo">2646</span>   */<a name="line.2646"></a>
+<span class="sourceLineNo">2647</span>  public ClusterMetrics getClusterMetrics() throws IOException {<a name="line.2647"></a>
+<span class="sourceLineNo">2648</span>    return getClusterMetrics(EnumSet.allOf(Option.class));<a name="line.2648"></a>
+<span class="sourceLineNo">2649</span>  }<a name="line.2649"></a>
+<span class="sourceLineNo">2650</span><a name="line.2650"></a>
+<span class="sourceLineNo">2651</span>  public ClusterMetrics getClusterMetrics(EnumSet&lt;Option&gt; options) throws IOException {<a name="line.2651"></a>
 <span class="sourceLineNo">2652</span>    if (cpHost != null) {<a name="line.2652"></a>
-<span class="sourceLineNo">2653</span>      cpHost.postGetClusterMetrics(status);<a name="line.2653"></a>
+<span class="sourceLineNo">2653</span>      cpHost.preGetClusterMetrics();<a name="line.2653"></a>
 <span class="sourceLineNo">2654</span>    }<a name="line.2654"></a>
-<span class="sourceLineNo">2655</span>    return status;<a name="line.2655"></a>
-<span class="sourceLineNo">2656</span>  }<a name="line.2656"></a>
-<span class="sourceLineNo">2657</span><a name="line.2657"></a>
-<span class="sourceLineNo">2658</span>  List&lt;ServerName&gt; getBackupMasters() {<a name="line.2658"></a>
-<span class="sourceLineNo">2659</span>    return activeMasterManager.getBackupMasters();<a name="line.2659"></a>
+<span class="sourceLineNo">2655</span>    ClusterMetrics status = getClusterMetricsWithoutCoprocessor(options);<a name="line.2655"></a>
+<span class="sourceLineNo">2656</span>    if (cpHost != null) {<a name="line.2656"></a>
+<span class="sourceLineNo">2657</span>      cpHost.postGetClusterMetrics(status);<a name="line.2657"></a>
+<span class="sourceLineNo">2658</span>    }<a name="line.2658"></a>
+<span class="sourceLineNo">2659</span>    return status;<a name="line.2659"></a>
 <span class="sourceLineNo">2660</span>  }<a name="line.2660"></a>
 <span class="sourceLineNo">2661</span><a name="line.2661"></a>
-<span class="sourceLineNo">2662</span>  /**<a name="line.2662"></a>
-<span class="sourceLineNo">2663</span>   * The set of loaded coprocessors is stored in a static set. Since it's<a name="line.2663"></a>
-<span class="sourceLineNo">2664</span>   * statically allocated, it does not require that HMaster's cpHost be<a name="line.2664"></a>
-<span class="sourceLineNo">2665</span>   * initialized prior to accessing it.<a name="line.2665"></a>
-<span class="sourceLineNo">2666</span>   * @return a String representation of the set of names of the loaded coprocessors.<a name="line.2666"></a>
-<span class="sourceLineNo">2667</span>   */<a name="line.2667"></a>
-<span class="sourceLineNo">2668</span>  public static String getLoadedCoprocessors() {<a name="line.2668"></a>
-<span class="sourceLineNo">2669</span>    return CoprocessorHost.getLoadedCoprocessors().toString();<a name="line.2669"></a>
-<span class="sourceLineNo">2670</span>  }<a name="line.2670"></a>
-<span class="sourceLineNo">2671</span><a name="line.2671"></a>
-<span class="sourceLineNo">2672</span>  /**<a name="line.2672"></a>
-<span class="sourceLineNo">2673</span>   * @return timestamp in millis when HMaster was started.<a name="line.2673"></a>
-<span class="sourceLineNo">2674</span>   */<a name="line.2674"></a>
-<span class="sourceLineNo">2675</span>  public long getMasterStartTime() {<a name="line.2675"></a>
-<span class="sourceLineNo">2676</span>    return startcode;<a name="line.2676"></a>
-<span class="sourceLineNo">2677</span>  }<a name="line.2677"></a>
-<span class="sourceLineNo">2678</span><a name="line.2678"></a>
-<span class="sourceLineNo">2679</span>  /**<a name="line.2679"></a>
-<span class="sourceLineNo">2680</span>   * @return timestamp in millis when HMaster became the active master.<a name="line.2680"></a>
-<span class="sourceLineNo">2681</span>   */<a name="line.2681"></a>
-<span class="sourceLineNo">2682</span>  public long getMasterActiveTime() {<a name="line.2682"></a>
-<span class="sourceLineNo">2683</span>    return masterActiveTime;<a name="line.2683"></a>
-<span class="sourceLineNo">2684</span>  }<a name="line.2684"></a>
-<span class="sourceLineNo">2685</span><a name="line.2685"></a>
-<span class="sourceLineNo">2686</span>  /**<a name="line.2686"></a>
-<span class="sourceLineNo">2687</span>   * @return timestamp in millis when HMaster finished becoming the active master<a name="line.2687"></a>
-<span class="sourceLineNo">2688</span>   */<a name="line.2688"></a>
-<span class="sourceLineNo">2689</span>  public long getMasterFinishedInitializationTime() {<a name="line.2689"></a>
-<span class="sourceLineNo">2690</span>    return masterFinishedInitializationTime;<a name="line.2690"></a>
-<span class="sourceLineNo">2691</span>  }<a name="line.2691"></a>
-<span class="sourceLineNo">2692</span><a name="line.2692"></a>
-<span class="sourceLineNo">2693</span>  public int getNumWALFiles() {<a name="line.2693"></a>
-<span class="sourceLineNo">2694</span>    return 0;<a name="line.2694"></a>
+<span class="sourceLineNo">2662</span>  List&lt;ServerName&gt; getBackupMasters() {<a name="line.2662"></a>
+<span class="sourceLineNo">2663</span>    return activeMasterManager.getBackupMasters();<a name="line.2663"></a>
+<span class="sourceLineNo">2664</span>  }<a name="line.2664"></a>
+<span class="sourceLineNo">2665</span><a name="line.2665"></a>
+<span class="sourceLineNo">2666</span>  /**<a name="line.2666"></a>
+<span class="sourceLineNo">2667</span>   * The set of loaded coprocessors is stored in a static set. Since it's<a name="line.2667"></a>
+<span class="sourceLineNo">2668</span>   * statically allocated, it does not require that HMaster's cpHost be<a name="line.2668"></a>
+<span class="sourceLineNo">2669</span>   * initialized prior to accessing it.<a name="line.2669"></a>
+<span class="sourceLineNo">2670</span>   * @return a String representation of the set of names of the loaded coprocessors.<a name="line.2670"></a>
+<span class="sourceLineNo">2671</span>   */<a name="line.2671"></a>
+<span class="sourceLineNo">2672</span>  public static String getLoadedCoprocessors() {<a name="line.2672"></a>
+<span class="sourceLineNo">2673</span>    return CoprocessorHost.getLoadedCoprocessors().toString();<a name="line.2673"></a>
+<span class="sourceLineNo">2674</span>  }<a name="line.2674"></a>
+<span class="sourceLineNo">2675</span><a name="line.2675"></a>
+<span class="sourceLineNo">2676</span>  /**<a name="line.2676"></a>
+<span class="sourceLineNo">2677</span>   * @return timestamp in millis when HMaster was started.<a name="line.2677"></a>
+<span class="sourceLineNo">2678</span>   */<a name="line.2678"></a>
+<span class="sourceLineNo">2679</span>  public long getMasterStartTime() {<a name="line.2679"></a>
+<span class="sourceLineNo">2680</span>    return startcode;<a name="line.2680"></a>
+<span class="sourceLineNo">2681</span>  }<a name="line.2681"></a>
+<span class="sourceLineNo">2682</span><a name="line.2682"></a>
+<span class="sourceLineNo">2683</span>  /**<a name="line.2683"></a>
+<span class="sourceLineNo">2684</span>   * @return timestamp in millis when HMaster became the active master.<a name="line.2684"></a>
+<span class="sourceLineNo">2685</span>   */<a name="line.2685"></a>
+<span class="sourceLineNo">2686</span>  public long getMasterActiveTime() {<a name="line.2686"></a>
+<span class="sourceLineNo">2687</span>    return masterActiveTime;<a name="line.2687"></a>
+<span class="sourceLineNo">2688</span>  }<a name="line.2688"></a>
+<span class="sourceLineNo">2689</span><a name="line.2689"></a>
+<span class="sourceLineNo">2690</span>  /**<a name="line.2690"></a>
+<span class="sourceLineNo">2691</span>   * @return timestamp in millis when HMaster finished becoming the active master<a name="line.2691"></a>
+<span class="sourceLineNo">2692</span>   */<a name="line.2692"></a>
+<span class="sourceLineNo">2693</span>  public long getMasterFinishedInitializationTime() {<a name="line.2693"></a>
+<span class="sourceLineNo">2694</span>    return masterFinishedInitializationTime;<a name="line.2694"></a>
 <span class="sourceLineNo">2695</span>  }<a name="line.2695"></a>
 <span class="sourceLineNo">2696</span><a name="line.2696"></a>
-<span class="sourceLineNo">2697</span>  public ProcedureStore getProcedureStore() {<a name="line.2697"></a>
-<span class="sourceLineNo">2698</span>    return procedureStore;<a name="line.2698"></a>
+<span class="sourceLineNo">2697</span>  public int getNumWALFiles() {<a name="line.2697"></a>
+<span class="sourceLineNo">2698</span>    return 0;<a name="line.2698"></a>
 <span class="sourceLineNo">2699</span>  }<a name="line.2699"></a>
 <span class="sourceLineNo">2700</span><a name="line.2700"></a>
-<span class="sourceLineNo">2701</span>  public int getRegionServerInfoPort(final ServerName sn) {<a name="line.2701"></a>
-<span class="sourceLineNo">2702</span>    int port = this.serverManager.getInfoPort(sn);<a name="line.2702"></a>
-<span class="sourceLineNo">2703</span>    return port == 0 ? conf.getInt(HConstants.REGIONSERVER_INFO_PORT,<a name="line.2703"></a>
-<span class="sourceLineNo">2704</span>      HConstants.DEFAULT_REGIONSERVER_INFOPORT) : port;<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>  @Override<a name="line.2707"></a>
-<span class="sourceLineNo">2708</span>  public String getRegionServerVersion(ServerName sn) {<a name="line.2708"></a>
-<span class="sourceLineNo">2709</span>    // Will return "0.0.0" if the server is not online to prevent move system region to unknown<a name="line.2709"></a>
-<span class="sourceLineNo">2710</span>    // version RS.<a name="line.2710"></a>
-<span class="sourceLineNo">2711</span>    return this.serverManager.getVersion(sn);<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>  @Override<a name="line.2714"></a>
-<span class="sourceLineNo">2715</span>  public void checkIfShouldMoveSystemRegionAsync() {<a name="line.2715"></a>
-<span class="sourceLineNo">2716</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.2716"></a>
-<span class="sourceLineNo">2717</span>  }<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>   * @return array of coprocessor SimpleNames.<a name="line.2720"></a>
-<span class="sourceLineNo">2721</span>   */<a name="line.2721"></a>
-<span class="sourceLineNo">2722</span>  public String[] getMasterCoprocessors() {<a name="line.2722"></a>
-<span class="sourceLineNo">2723</span>    Set&lt;String&gt; masterCoprocessors = getMasterCoprocessorHost().getCoprocessors();<a name="line.2723"></a>
-<span class="sourceLineNo">2724</span>    return masterCoprocessors.toArray(new String[masterCoprocessors.size()]);<a name="line.2724"></a>
-<span class="sourceLineNo">2725</span>  }<a name="line.2725"></a>
-<span class="sourceLineNo">2726</span><a name="line.2726"></a>
-<span class="sourceLineNo">2727</span>  @Override<a name="line.2727"></a>
-<span class="sourceLineNo">2728</span>  public void abort(String reason, Throwable cause) {<a name="line.2728"></a>
-<span class="sourceLineNo">2729</span>    if (!setAbortRequested() || isStopped()) {<a name="line.2729"></a>
-<span class="sourceLineNo">2730</span>      LOG.debug("Abort called but aborted={}, stopped={}", isAborted(), isStopped());<a name="line.2730"></a>
-<span class="sourceLineNo">2731</span>      return;<a name="line.2731"></a>
-<span class="sourceLineNo">2732</span>    }<a name="line.2732"></a>
-<span class="sourceLineNo">2733</span>    if (cpHost != null) {<a name="line.2733"></a>
-<span class="sourceLineNo">2734</span>      // HBASE-4014: dump a list of loaded coprocessors.<a name="line.2734"></a>
-<span class="sourceLineNo">2735</span>      LOG.error(HBaseMarkers.FATAL, "Master server abort: loaded coprocessors are: " +<a name="line.2735"></a>
-<span class="sourceLineNo">2736</span>          getLoadedCoprocessors());<a name="line.2736"></a>
-<span class="sourceLineNo">2737</span>    }<a name="line.2737"></a>
-<span class="sourceLineNo">2738</span>    String msg = "***** ABORTING master " + this + ": " + reason + " *****";<a name="line.2738"></a>
-<span class="sourceLineNo">2739</span>    if (cause != null) {<a name="line.2739"></a>
-<span class="sourceLineNo">2740</span>      LOG.error(HBaseMarkers.FATAL, msg, cause);<a name="line.2740"></a>
-<span class="sourceLineNo">2741</span>    } else {<a name="line.2741"></a>
-<span class="sourceLineNo">2742</span>      LOG.error(HBaseMarkers.FATAL, msg);<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>    try {<a name="line.2745"></a>
-<span class="sourceLineNo">2746</span>      stopMaster();<a name="line.2746"></a>
-<span class="sourceLineNo">2747</span>    } catch (IOException e) {<a name="line.2747"></a>
-<span class="sourceLineNo">2748</span>      LOG.error("Exception occurred while stopping master", e);<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><a name="line.2751"></a>
-<span class="sourceLineNo">2752</span>  @Override<a name="line.2752"></a>
-<span class="sourceLineNo">2753</span>  public ZKWatcher getZooKeeper() {<a name="line.2753"></a>
-<span class="sourceLineNo">2754</span>    return zooKeeper;<a name="line.2754"></a>
-<span class="sourceLineNo">2755</span>  }<a name="line.2755"></a>
-<span class="sourceLineNo">2756</span><a name="line.2756"></a>
-<span class="sourceLineNo">2757</span>  @Override<a name="line.2757"></a>
-<span class="sourceLineNo">2758</span>  public MasterCoprocessorHost getMasterCoprocessorHost() {<a name="line.2758"></a>
-<span class="sourceLineNo">2759</span>    return cpHost;<a name="line.2759"></a>
-<span class="sourceLineNo">2760</span>  }<a name="line.2760"></a>
-<span class="sourceLineNo">2761</span><a name="line.2761"></a>
-<span class="sourceLineNo">2762</span>  @Override<a name="line.2762"></a>
-<span class="sourceLineNo">2763</span>  public MasterQuotaManager getMasterQuotaManager() {<a name="line.2763"></a>
-<span class="sourceLineNo">2764</span>    return quotaManager;<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>  @Override<a name="line.2767"></a>
-<span class="sourceLineNo">2768</span>  public ProcedureExecutor&lt;MasterProcedureEnv&gt; getMasterProcedureExecutor() {<a name="line.2768"></a>
-<span class="sourceLineNo">2769</span>    return procedureExecutor;<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>  @Override<a name="line.2772"></a>
-<span class="sourceLineNo">2773</span>  public ServerName getServerName() {<a name="line.2773"></a>
-<span class="sourceLineNo">2774</span>    return this.serverName;<a name="line.2774"></a>
-<span class="sourceLineNo">2775</span>  }<a name="line.2775"></a>
-<span class="sourceLineNo">2776</span><a name="line.2776"></a>
-<span class="sourceLineNo">2777</span>  @Override<a name="line.2777"></a>
-<span class="sourceLineNo">2778</span>  public AssignmentManager getAssignmentManager() {<a name="line.2778"></a>
-<span class="sourceLineNo">2779</span>    return this.assignmentManager;<a name="line.2779"></a>
-<span class="sourceLineNo">2780</span>  }<a name="line.2780"></a>
-<span class="sourceLineNo">2781</span><a name="line.2781"></a>
-<span class="sourceLineNo">2782</span>  @Override<a name="line.2782"></a>
-<span class="sourceLineNo">2783</span>  public CatalogJanitor getCatalogJanitor() {<a name="line.2783"></a>
-<span class="sourceLineNo">2784</span>    return this.catalogJanitorChore;<a name="line.2784"></a>
-<span class="sourceLineNo">2785</span>  }<a name="line.2785"></a>
-<span class="sourceLineNo">2786</span><a name="line.2786"></a>
-<span class="sourceLineNo">2787</span>  public MemoryBoundedLogMessageBuffer getRegionServerFatalLogBuffer() {<a name="line.2787"></a>
-<span class="sourceLineNo">2788</span>    return rsFatals;<a name="line.2788"></a>
+<span class="sourceLineNo">2701</span>  public ProcedureStore getProcedureStore() {<a name="line.2701"></a>
+<span class="sourceLineNo">2702</span>    return procedureStore;<a name="line.2702"></a>
+<span class="sourceLineNo">2703</span>  }<a name="line.2703"></a>
+<span class="sourceLineNo">2704</span><a name="line.2704"></a>
+<span class="sourceLineNo">2705</span>  public int getRegionServerInfoPort(final ServerName sn) {<a name="line.2705"></a>
+<span class="sourceLineNo">2706</span>    int port = this.serverManager.getInfoPort(sn);<a name="line.2706"></a>
+<span class="sourceLineNo">2707</span>    return port == 0 ? conf.getInt(HConstants.REGIONSERVER_INFO_PORT,<a name="line.2707"></a>
+<span class="sourceLineNo">2708</span>      HConstants.DEFAULT_REGIONSERVER_INFOPORT) : port;<a name="line.2708"></a>
+<span class="sourceLineNo">2709</span>  }<a name="line.2709"></a>
+<span class="sourceLineNo">2710</span><a name="line.2710"></a>
+<span class="sourceLineNo">2711</span>  @Override<a name="line.2711"></a>
+<span class="sourceLineNo">2712</span>  public String getRegionServerVersion(ServerName sn) {<a name="line.2712"></a>
+<span class="sourceLineNo">2713</span>    // Will return "0.0.0" if the server is not online to prevent move system region to unknown<a name="line.2713"></a>
+<span class="sourceLineNo">2714</span>    // version RS.<a name="line.2714"></a>
+<span class="sourceLineNo">2715</span>    return this.serverManager.getVersion(sn);<a name="line.2715"></a>
+<span class="sourceLineNo">2716</span>  }<a name="line.2716"></a>
+<span class="sourceLineNo">2717</span><a name="line.2717"></a>
+<span class="sourceLineNo">2718</span>  @Override<a name="line.2718"></a>
+<span class="sourceLineNo">2719</span>  public void checkIfShouldMoveSystemRegionAsync() {<a name="line.2719"></a>
+<span class="sourceLineNo">2720</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.2720"></a>
+<span class="sourceLineNo">2721</span>  }<a name="line.2721"></a>
+<span class="sourceLineNo">2722</span><a name="line.2722"></a>
+<span class="sourceLineNo">2723</span>  /**<a name="line.2723"></a>
+<span class="sourceLineNo">2724</span>   * @return array of coprocessor SimpleNames.<a name="line.2724"></a>
+<span class="sourceLineNo">2725</span>   */<a name="line.2725"></a>
+<span class="sourceLineNo">2726</span>  public String[] getMasterCoprocessors() {<a name="line.2726"></a>
+<span class="sourceLineNo">2727</span>    Set&lt;String&gt; masterCoprocessors = getMasterCoprocessorHost().getCoprocessors();<a name="line.2727"></a>
+<span class="sourceLineNo">2728</span>    return masterCoprocessors.toArray(new String[masterCoprocessors.size()]);<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>  @Override<a name="line.2731"></a>
+<span class="sourceLineNo">2732</span>  public void abort(String reason, Throwable cause) {<a name="line.2732"></a>
+<span class="sourceLineNo">2733</span>    if (!setAbortRequested() || isStopped()) {<a name="line.2733"></a>
+<span class="sourceLineNo">2734</span>      LOG.debug("Abort called but aborted={}, stopped={}", isAborted(), isStopped());<a name="line.2734"></a>
+<span class="sourceLineNo">2735</span>      return;<a name="line.2735"></a>
+<span class="sourceLineNo">2736</span>    }<a name="line.2736"></a>
+<span class="sourceLineNo">2737</span>    if (cpHost != null) {<a name="line.2737"></a>
+<span class="sourceLineNo">2738</span>      // HBASE-4014: dump a list of loaded coprocessors.<a name="line.2738"></a>
+<span class="sourceLineNo">2739</span>      LOG.error(HBaseMarkers.FATAL, "Master server abort: loaded coprocessors are: " +<a name="line.2739"></a>
+<span class="sourceLineNo">2740</span>          getLoadedCoprocessors());<a name="line.2740"></a>
+<span class="sourceLineNo">2741</span>    }<a name="line.2741"></a>
+<span class="sourceLineNo">2742</span>    String msg = "***** ABORTING master " + this + ": " + reason + " *****";<a name="line.2742"></a>
+<span class="sourceLineNo">2743</span>    if (cause != null) {<a name="line.2743"></a>
+<span class="sourceLineNo">2744</span>      LOG.error(HBaseMarkers.FATAL, msg, cause);<a name="line.2744"></a>
+<span class="sourceLineNo">2745</span>    } else {<a name="line.2745"></a>
+<span class="sourceLineNo">2746</span>      LOG.error(HBaseMarkers.FATAL, msg);<a name="line.2746"></a>
+<span class="sourceLineNo">2747</span>    }<a name="line.2747"></a>
+<span class="sourceLineNo">2748</span><a name="line.2748"></a>
+<span class="sourceLineNo">2749</span>    try {<a name="line.2749"></a>
+<span class="sourceLineNo">2750</span>      stopMaster();<a name="line.2750"></a>
+<span class="sourceLineNo">2751</span>    } catch (IOException e) {<a name="line.2751"></a>
+<span class="sourceLineNo">2752</span>      LOG.error("Exception occurred while stopping master", e);<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>  @Override<a name="line.2756"></a>
+<span class="sourceLineNo">2757</span>  public ZKWatcher getZooKeeper() {<a name="line.2757"></a>
+<span class="sourceLineNo">2758</span>    return zooKeeper;<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>  @Override<a name="line.2761"></a>
+<span class="sourceLineNo">2762</span>  public MasterCoprocessorHost getMasterCoprocessorHost() {<a name="line.2762"></a>
+<span class="sourceLineNo">2763</span>    return cpHost;<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>  @Override<a name="line.2766"></a>
+<span class="sourceLineNo">2767</span>  public MasterQuotaManager getMasterQuotaManager() {<a name="line.2767"></a>
+<span class="sourceLineNo">2768</span>    return quotaManager;<a name="line.2768"></a>
+<span class="sourceLineNo">2769</span>  }<a name="line.2769"></a>
+<span class="sourceLineNo">2770</span><a name="line.2770"></a>
+<span class="sourceLineNo">2771</span>  @Override<a name="line.2771"></a>
+<span class="sourceLineNo">2772</span>  public ProcedureExecutor&lt;MasterProcedureEnv&gt; getMasterProcedureExecutor() {<a name="line.2772"></a>
+<span class="sourceLineNo">2773</span>    return procedureExecutor;<a name="line.2773"></a>
+<span class="sourceLineNo">2774</span>  }<a name="line.2774"></a>
+<span class="sourceLineNo">2775</span><a name="line.2775"></a>
+<span class="sourceLineNo">2776</span>  @Override<a name="line.2776"></a>
+<span class="sourceLineNo">2777</span>  public ServerName getServerName() {<a name="line.2777"></a>
+<span class="sourceLineNo">2778</span>    return this.serverName;<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>  @Override<a name="line.2781"></a>
+<span class="sourceLineNo">2782</span>  public AssignmentManager getAssignmentManager() {<a name="line.2782"></a>
+<span class="sourceLineNo">2783</span>    return this.assignmentManager;<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>  @Override<a name="line.2786"></a>
+<span class="sourceLineNo">2787</span>  public CatalogJanitor getCatalogJanitor() {<a name="line.2787"></a>
+<span class="sourceLineNo">2788</span>    return this.catalogJanitorChore;<a name="line.2788"></a>
 <span class="sourceLineNo">2789</span>  }<a name="line.2789"></a>
 <span class="sourceLineNo">2790</span><a name="line.2790"></a>
-<span class="sourceLineNo">2791</span>  /**<a name="line.2791"></a>
-<span class="sourceLineNo">2792</span>   * Shutdown the cluster.<a name="line.2792"></a>
-<span class="sourceLineNo">2793</span>   * Master runs a coordinated stop of all RegionServers and then itself.<a name="line.2793"></a>
-<span class="sourceLineNo">2794</span>   */<a name="line.2794"></a>
-<span class="sourceLineNo">2795</span>  public void shutdown() throws IOException {<a name="line.2795"></a>
-<span class="sourceLineNo">2796</span>    if (cpHost != null) {<a name="line.2796"></a>
-<span class="sourceLineNo">2797</span>      cpHost.preShutdown();<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>    // Tell the servermanager cluster shutdown has been called. This makes it so when Master is<a name="line.2800"></a>
-<span class="sourceLineNo">2801</span>    // last running server, it'll stop itself. Next, we broadcast the cluster shutdown by setting<a name="line.2801"></a>
-<span class="sourceLineNo">2802</span>    // the cluster status as down. RegionServers will notice this change in state and will start<a name="line.2802"></a>
-<span class="sourceLineNo">2803</span>    // shutting themselves down. When last has exited, Master can go down.<a name="line.2803"></a>
-<span class="sourceLineNo">2804</span>    if (this.serverManager != null) {<a name="line.2804"></a>
-<span class="sourceLineNo">2805</span>      this.serverManager.shutdownCluster();<a name="line.2805"></a>
-<span class="sourceLineNo">2806</span>    }<a name="line.2806"></a>
-<span class="sourceLineNo">2807</span>    if (this.clusterStatusTracker != null) {<a name="line.2807"></a>
-<span class="sourceLineNo">2808</span>      try {<a name="line.2808"></a>
-<span class="sourceLineNo">2809</span>        this.clusterStatusTracker.setClusterDown();<a name="line.2809"></a>
-<span class="sourceLineNo">2810</span>      } catch (KeeperException e) {<a name="line.2810"></a>
-<span class="sourceLineNo">2811</span>        LOG.error("ZooKeeper exception trying to set cluster as down in ZK", e);<a name="line.2811"></a>
-<span class="sourceLineNo">2812</span>      }<a name="line.2812"></a>
-<span class="sourceLineNo">2813</span>    }<a name="line.2813"></a>
-<span class="sourceLineNo">2814</span>    // Stop the procedure executor. Will stop any ongoing assign, unassign, server crash etc.,<a name="line.2814"></a>
-<span class="sourceLineNo">2815</span>    // processing so we can go down.<a name="line.2815"></a>
-<span class="sourceLineNo">2816</span>    if (this.procedureExecutor != null) {<a name="line.2816"></a>
-<span class="sourceLineNo">2817</span>      this.procedureExecutor.stop();<a name="line.2817"></a>
-<span class="sourceLineNo">2818</span>    }<a name="line.2818"></a>
-<span class="sourceLineNo">2819</span>    // Shutdown our cluster connection. This will kill any hosted RPCs that might be going on;<a name="line.2819"></a>
-<span class="sourceLineNo">2820</span>    // this is what we want especially if the Master is in startup phase doing call outs to<a name="line.2820"></a>
-<span class="sourceLineNo">2821</span>    // hbase:meta, etc. when cluster is down. Without ths connection close, we'd have to wait on<a name="line.2821"></a>
-<span class="sourceLineNo">2822</span>    // the rpc to timeout.<a name="line.2822"></a>
-<span class="sourceLineNo">2823</span>    if (this.asyncClusterConnection != null) {<a name="line.2823"></a>
-<span class="sourceLineNo">2824</span>      this.asyncClusterConnection.close();<a name="line.2824"></a>
-<span class="sourceLineNo">2825</span>    }<a name="line.2825"></a>
-<span class="sourceLineNo">2826</span>  }<a name="line.2826"></a>
-<span class="sourceLineNo">2827</span><a name="line.2827"></a>
-<span class="sourceLineNo">2828</span>  public void stopMaster() throws IOException {<a name="line.2828"></a>
-<span class="sourceLineNo">2829</span>    if (cpHost != null) {<a name="line.2829"></a>
-<span class="sourceLineNo">2830</span>      cpHost.preStopMaster();<a name="line.2830"></a>
-<span class="sourceLineNo">2831</span>    }<a name="line.2831"></a>
-<span class="sourceLineNo">2832</span>    stop("Stopped by " + Thread.currentThread().getName());<a name="line.2832"></a>
-<span class="sourceLineNo">2833</span>  }<a name="line.2833"></a>
-<span class="sourceLineNo">2834</span><a name="line.2834"></a>
-<span class="sourceLineNo">2835</span>  @Override<a name="line.2835"></a>
-<span class="sourceLineNo">2836</span>  public void stop(String msg) {<a name="line.2836"></a>
-<span class="sourceLineNo">2837</span>    if (!isStopped()) {<a name="line.2837"></a>
-<span class="sourceLineNo">2838</span>      super.stop(msg);<a name="line.2838"></a>
-<span class="sourceLineNo">2839</span>      if (this.activeMasterManager != null) {<a name="line.2839"></a>
-<span class="sourceLineNo">2840</span>        this.activeMasterManager.stop();<a name="line.2840"></a>
-<span class="sourceLineNo">2841</span>      }<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>  @VisibleForTesting<a name="line.2845"></a>
-<span class="sourceLineNo">2846</span>  protected void checkServiceStarted() throws ServerNotRunningYetException {<a name="line.2846"></a>
-<span class="sourceLineNo">2847</span>    if (!serviceStarted) {<a name="line.2847"></a>
-<span class="sourceLineNo">2848</span>      throw new ServerNotRunningYetException("Server is not running yet");<a name="line.2848"></a>
-<span class="sourceLineNo">2849</span>    }<a name="line.2849"></a>
-<span class="sourceLineNo">2850</span>  }<a name="line.2850"></a>
-<span class="sourceLineNo">2851</span><a name="line.2851"></a>
-<span class="sourceLineNo">2852</span>  public static class MasterStoppedException extends DoNotRetryIOException {<a name="line.2852"></a>
-<span class="sourceLineNo">2853</span>    MasterStoppedException() {<a name="line.2853"></a>
-<span class="sourceLineNo">2854</span>      super();<a name="line.2854"></a>
-<span class="sourceLineNo">2855</span>    }<a name="line.2855"></a>
-<span class="sourceLineNo">2856</span>  }<a name="line.2856"></a>
-<span class="sourceLineNo">2857</span><a name="line.2857"></a>
-<span class="sourceLineNo">2858</span>  void checkInitialized() throws PleaseHoldException, ServerNotRunningYetException,<a name="line.2858"></a>
-<span class="sourceLineNo">2859</span>      MasterNotRunningException, MasterStoppedException {<a name="line.2859"></a>
-<span class="sourceLineNo">2860</span>    checkServiceStarted();<a name="line.2860"></a>
-<span class="sourceLineNo">2861</span>    if (!isInitialized()) {<a name="line.2861"></a>
-<span class="sourceLineNo">2862</span>      throw new PleaseHoldException("Master is initializing");<a name="line.2862"></a>
-<span class="sourceLineNo">2863</span>    }<a name="line.2863"></a>
-<span class="sourceLineNo">2864</span>    if (isStopped()) {<a name="line.2864"></a>
-<span class="sourceLineNo">2865</span>      throw new MasterStoppedException();<a name="line.2865"></a>
-<span class="sourceLineNo">2866</span>    }<a name="line.2866"></a>
-<span class="sourceLineNo">2867</span>  }<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>   * Report whether this master is currently the active master or not.<a name="line.2870"></a>
-<span class="sourceLineNo">2871</span>   * If not active master, we are parked on ZK waiting to become active.<a name="line.2871"></a>
-<span class="sourceLineNo">2872</span>   *<a name="line.2872"></a>
-<span class="sourceLineNo">2873</span>   * This method is used for testing.<a name="line.2873"></a>
-<span class="sourceLineNo">2874</span>   *<a name="line.2874"></a>
-<span class="sourceLineNo">2875</span>   * @return true if active master, false if not.<a name="line.2875"></a>
-<span class="sourceLineNo">2876</span>   */<a name="line.2876"></a>
-<span class="sourceLineNo">2877</span>  @Override<a name="line.2877"></a>
-<span class="sourceLineNo">2878</span>  public boolean isActiveMaster() {<a name="line.2878"></a>
-<span class="sourceLineNo">2879</span>    return activeMaster;<a name="line.2879"></a>
-<span class="sourceLineNo">2880</span>  }<a name="line.2880"></a>
-<span class="sourceLineNo">2881</span><a name="line.2881"></a>
-<span class="sourceLineNo">2882</span>  /**<a name="line.2882"></a>
-<span class="sourceLineNo">2883</span>   * Report whether this master has completed with its initialization and is<a name="line.2883"></a>
-<span class="sourceLineNo">2884</span>   * ready.  If ready, the master is also the active master.  A standby master<a name="line.2884"></a>
-<span class="sourceLineNo">2885</span>   * is never ready.<a name="line.2885"></a>
-<span class="sourceLineNo">2886</span>   *<a name="line.2886"></a>
-<span class="sourceLineNo">2887</span>   * This method is used for testing.<a name="line.2887"></a>
-<span class="sourceLineNo">2888</span>   *<a name="line.2888"></a>
-<span class="sourceLineNo">2889</span>   * @return true if master is ready to go, false if not.<a name="line.2889"></a>
-<span class="sourceLineNo">2890</span>   */<a name="line.2890"></a>
-<span class="sourceLineNo">2891</span>  @Override<a name="line.2891"></a>
-<span class="sourceLineNo">2892</span>  public boolean isInitialized() {<a name="line.2892"></a>
-<span class="sourceLineNo">2893</span>    return initialized.isReady();<a name="line.2893"></a>
-<span class="sourceLineNo">2894</span>  }<a name="line.2894"></a>
-<span class="sourceLineNo">2895</span><a name="line.2895"></a>
-<span class="sourceLineNo">2896</span>  /**<a name="line.2896"></a>
-<span class="sourceLineNo">2897</span>   * Report whether this master is in maintenance mode.<a name="line.2897"></a>
-<span class="sourceLineNo">2898</span>   *<a name="line.2898"></a>
-<span class="sourceLineNo">2899</span>   * @return true if master is in maintenanceMode<a name="line.2899"></a>
-<span class="sourceLineNo">2900</span>   */<a name="line.2900"></a>
-<span class="sourceLineNo">2901</span>  @Override<a name="line.2901"></a>
-<span class="sourceLineNo">2902</span>  public boolean isInMaintenanceMode() {<a name="line.2902"></a>
-<span class="sourceLineNo">2903</span>    return maintenanceMode;<a name="line.2903"></a>
-<span class="sourceLineNo">2904</span>  }<a name="line.2904"></a>
-<span class="sourceLineNo">2905</span><a name="line.2905"></a>
-<span class="sourceLineNo">2906</span>  @VisibleForTesting<a name="line.2906"></a>
-<span class="sourceLineNo">2907</span>  public void setInitialized(boolean isInitialized) {<a name="line.2907"></a>
-<span class="sourceLineNo">2908</span>    procedureExecutor.getEnvironment().setEventReady(initialized, isInitialized);<a name="line.2908"></a>
-<span class="sourceLineNo">2909</span>  }<a name="line.2909"></a>
-<span class="sourceLineNo">2910</span><a name="line.2910"></a>
-<span class="sourceLineNo">2911</span>  @Override<a name="line.2911"></a>
-<span class="sourceLineNo">2912</span>  public ProcedureEvent&lt;?&gt; getInitializedEvent() {<a name="line.2912"></a>
-<span class="sourceLineNo">2913</span>    return initialized;<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>  /**<a name="line.2916"></a>
-<span class="sourceLineNo">2917</span>   * Compute the average load across all region servers.<a name="line.2917"></a>
-<span class="sourceLineNo">2918</span>   * Currently, this uses a very naive computation - just uses the number of<a name="line.2918"></a>
-<span class="sourceLineNo">2919</span>   * regions being served, ignoring stats about number of requests.<a name="line.2919"></a>
-<span class="sourceLineNo">2920</span>   * @return the average load<a name="line.2920"></a>
-<span class="sourceLineNo">2921</span>   */<a name="line.2921"></a>
-<span class="sourceLineNo">2922</span>  public double getAverageLoad() {<a name="line.2922"></a>
-<span class="sourceLineNo">2923</span>    if (this.assignmentManager == null) {<a name="line.2923"></a>
-<span class="sourceLineNo">2924</span>      return 0;<a name="line.2924"></a>
-<span class="sourceLineNo">2925</span>    }<a name="line.2925"></a>
-<span class="sourceLineNo">2926</span><a name="line.2926"></a>
-<span class="sourceLineNo">2927</span>    RegionStates regionStates = this.assignmentManager.getRegionStates();<a name="line.2927"></a>
-<span class="sourceLineNo">2928</span>    if (regionStates == null) {<a name="line.2928"></a>
-<span class="sourceLineNo">2929</span>      return 0;<a name="line.2929"></a>
-<span class="sourceLineNo">2930</span>    }<a name="line.2930"></a>
-<span class="sourceLineNo">2931</span>    return regionStates.getAverageLoad();<a name="line.2931"></a>
-<span class="sourceLineNo">2932</span>  }<a name="line.2932"></a>
-<span class="sourceLineNo">2933</span><a name="line.2933"></a>
-<span class="sourceLineNo">2934</span>  @Override<a name="line.2934"></a>
-<span class="sourceLineNo">2935</span>  public boolean registerService(Service instance) {<a name="line.2935"></a>
-<span class="sourceLineNo">2936</span>    /*<a name="line.2936"></a>
-<span class="sourceLineNo">2937</span>     * No stacking of instances is allowed for a single service name<a name="line.2937"></a>
-<span class="sourceLineNo">2938</span>     */<a name="line.2938"></a>
-<span class="sourceLineNo">2939</span>    Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();<a name="line.2939"></a>
-<span class="sourceLineNo">2940</span>    String serviceName = CoprocessorRpcUtils.getServiceName(serviceDesc);<a name="line.2940"></a>
-<span class="sourceLineNo">2941</span>    if (coprocessorServiceHandlers.containsKey(serviceName)) {<a name="line.2941"></a>
-<span class="sourceLineNo">2942</span>      LOG.error("Coprocessor service "+serviceName+<a name="line.2942"></a>
-<span class="sourceLineNo">2943</span>          " already registered, rejecting request from "+instance<a name="line.2943"></a>
-<span class="sourceLineNo">2944</span>      );<a name="line.2944"></a>
-<span class="sourceLineNo">2945</span>      return false;<a name="line.2945"></a>
-<span class="sourceLineNo">2946</span>    }<a name="line.2946"></a>
-<span class="sourceLineNo">2947</span><a name="line.2947"></a>
-<span class="sourceLineNo">2948</span>    coprocessorServiceHandlers.put(serviceName, instance);<a name="line.2948"></a>
-<span class="sourceLineNo">2949</span>    if (LOG.isDebugEnabled()) {<a name="line.2949"></a>
-<span class="sourceLineNo">2950</span>      LOG.debug("Registered master coprocessor service: service="+serviceName);<a name="line.2950"></a>
-<span class="sourceLineNo">2951</span>    }<a name="line.2951"></a>
-<span class="sourceLineNo">2952</span>    return true;<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>   * Utility for constructing an instance of the passed HMaster class.<a name="line.2956"></a>
-<span class="sourceLineNo">2957</span>   * @param masterClass<a name="line.2957"></a>
-<span class="sourceLineNo">2958</span>   * @return HMaster instance.<a name="line.2958"></a>
-<span class="sourceLineNo">2959</span>   */<a name="line.2959"></a>
-<span class="sourceLineNo">2960</span>  public static HMaster constructMaster(Class&lt;? extends HMaster&gt; masterClass,<a name="line.2960"></a>
-<span class="sourceLineNo">2961</span>      final Configuration conf)  {<a name="line.2961"></a>
-<span class="sourceLineNo">2962</span>    try {<a name="line.2962"></a>
-<span class="sourceLineNo">2963</span>      Constructor&lt;? extends HMaster&gt; c = masterClass.getConstructor(Configuration.class);<a name="line.2963"></a>
-<span class="sourceLineNo">2964</span>      return c.newInstance(conf);<a name="line.2964"></a>
-<span class="sourceLineNo">2965</span>    } catch(Exception e) {<a name="line.2965"></a>
-<span class="sourceLineNo">2966</span>      Throwable error = e;<a name="line.2966"></a>
-<span class="sourceLineNo">2967</span>      if (e instanceof InvocationTargetException &amp;&amp;<a name="line.2967"></a>
-<span class="sourceLineNo">2968</span>          ((InvocationTargetException)e).getTargetException() != null) {<a name="line.2968"></a>
-<span class="sourceLineNo">2969</span>        error = ((InvocationTargetException)e).getTargetException();<a name="line.2969"></a>
-<span class="sourceLineNo">2970</span>      }<a name="line.2970"></a>
-<span class="sourceLineNo">2971</span>      throw new RuntimeException("Failed construction of Master: " + masterClass.toString() + ". "<a name="line.2971"></a>
-<span class="sourceLineNo">2972</span>        , error);<a name="line.2972"></a>
-<span class="sourceLineNo">2973</span>    }<a name="line.2973"></a>
-<span class="sourceLineNo">2974</span>  }<a name="line.2974"></a>
-<span class="sourceLineNo">2975</span><a name="line.2975"></a>
-<span class="sourceLineNo">2976</span>  /**<a name="line.2976"></a>
-<span class="sourceLineNo">2977</span>   * @see org.apache.hadoop.hbase.master.HMasterCommandLine<a name="line.2977"></a>
-<span class="sourceLineNo">2978</span>   */<a name="line.2978"></a>
-<span class="sourceLineNo">2979</span>  public static void main(String [] args) {<a name="line.2979"></a>
-<span class="sourceLineNo">2980</span>    LOG.info("STARTING service " + HMaster.class.getSimpleName());<a name="line.2980"></a>
-<span class="sourceLineNo">2981</span>    VersionInfo.logVersion();<a name="line.2981"></a>
-<span class="sourceLineNo">2982</span>    new HMasterCommandLine(HMaster.class).doMain(args);<a name="line.2982"></a>
-<span class="sourceLineNo">2983</span>  }<a name="line.2983"></a>
-<span class="sourceLineNo">2984</span><a name="line.2984"></a>
-<span class="sourceLineNo">2985</span>  public HFileCleaner getHFileCleaner() {<a name="line.2985"></a>
-<span class="sourceLineNo">2986</span>    return this.hfileCleaner;<a name="line.2986"></a>
+<span class="sourceLineNo">2791</span>  public MemoryBoundedLogMessageBuffer getRegionServerFatalLogBuffer() {<a name="line.2791"></a>
+<span class="sourceLineNo">2792</span>    return rsFatals;<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>  /**<a name="line.2795"></a>
+<span class="sourceLineNo">2796</span>   * Shutdown the cluster.<a name="line.2796"></a>
+<span class="sourceLineNo">2797</span>   * Master runs a coordinated stop of all RegionServers and then itself.<a name="line.2797"></a>
+<span class="sourceLineNo">2798</span>   */<a name="line.2798"></a>
+<span class="sourceLineNo">2799</span>  public void shutdown() throws IOException {<a name="line.2799"></a>
+<span class="sourceLineNo">2800</span>    if (cpHost != null) {<a name="line.2800"></a>
+<span class="sourceLineNo">2801</span>      cpHost.preShutdown();<a name="line.2801"></a>
+<span class="sourceLineNo">2802</span>    }<a name="line.2802"></a>
+<span class="sourceLineNo">2803</span><a name="line.2803"></a>
+<span class="sourceLineNo">2804</span>    // Tell the servermanager cluster shutdown has been called. This makes it so when Master is<a name="line.2804"></a>
+<span class="sourceLineNo">2805</span>    // last running server, it'll stop itself. Next, we broadcast the cluster shutdown by setting<a name="line.2805"></a>
+<span class="sourceLineNo">2806</span>    // the cluster status as down. RegionServers will notice this change in state and will start<a name="line.2806"></a>
+<span class="sourceLineNo">2807</span>    // shutting themselves down. When last has exited, Master can go down.<a name="line.2807"></a>
+<span class="sourceLineNo">2808</span>    if (this.serverManager != null) {<a name="line.2808"></a>
+<span class="sourceLineNo">2809</span>      this.serverManager.shutdownCluster();<a name="line.2809"></a>
+<span class="sourceLineNo">2810</span>    }<a name="line.2810"></a>
+<span class="sourceLineNo">2811</span>    if (this.clusterStatusTracker != null) {<a name="line.2811"></a>
+<span class="sourceLineNo">2812</span>      try {<a name="line.2812"></a>
+<span class="sourceLineNo">2813</span>        this.clusterStatusTracker.setClusterDown();<a name="line.2813"></a>
+<span class="sourceLineNo">2814</span>      } catch (KeeperException e) {<a name="line.2814"></a>
+<span class="sourceLineNo">2815</span>        LOG.error("ZooKeeper exception trying to set cluster as down in ZK", e);<a name="line.2815"></a>
+<span class="sourceLineNo">2816</span>      }<a name="line.2816"></a>
+<span class="sourceLineNo">2817</span>    }<a name="line.2817"></a>
+<span class="sourceLineNo">2818</span>    // Stop the procedure executor. Will stop any ongoing assign, unassign, server crash etc.,<a name="line.2818"></a>
+<span class="sourceLineNo">2819</span>    // processing so we can go down.<a name="line.2819"></a>
+<span class="sourceLineNo">2820</span>    if (this.procedureExecutor != null) {<a name="line.2820"></a>
+<span class="sourceLineNo">2821</span>      this.procedureExecutor.stop();<a name="line.2821"></a>
+<span class="sourceLineNo">2822</span>    }<a name="line.2822"></a>
+<span class="sourceLineNo">2823</span>    // Shutdown our cluster connection. This will kill any hosted RPCs that might be going on;<a name="line.2823"></a>
+<span class="sourceLineNo">2824</span>    // this is what we want especially if the Master is in startup phase doing call outs to<a name="line.2824"></a>
+<span class="sourceLineNo">2825</span>    // hbase:meta, etc. when cluster is down. Without ths connection close, we'd have to wait on<a name="line.2825"></a>
+<span class="sourceLineNo">2826</span>    // the rpc to timeout.<a name="line.2826"></a>
+<span class="sourceLineNo">2827</span>    if (this.asyncClusterConnection != null) {<a name="line.2827"></a>
+<span class="sourceLineNo">2828</span>      this.asyncClusterConnection.close();<a name="line.2828"></a>
+<span class="sourceLineNo">2829</span>    }<a name="line.2829"></a>
+<span class="sourceLineNo">2830</span>  }<a name="line.2830"></a>
+<span class="sourceLineNo">2831</span><a name="line.2831"></a>
+<span class="sourceLineNo">2832</span>  public void stopMaster() throws IOException {<a name="line.2832"></a>
+<span class="sourceLineNo">2833</span>    if (cpHost != null) {<a name="line.2833"></a>
+<span class="sourceLineNo">2834</span>      cpHost.preStopMaster();<a name="line.2834"></a>
+<span class="sourceLineNo">2835</span>    }<a name="line.2835"></a>
+<span class="sourceLineNo">2836</span>    stop("Stopped by " + Thread.currentThread().getName());<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>  @Override<a name="line.2839"></a>
+<span class="sourceLineNo">2840</span>  public void stop(String msg) {<a name="line.2840"></a>
+<span class="sourceLineNo">2841</span>    if (!isStopped()) {<a name="line.2841"></a>
+<span class="sourceLineNo">2842</span>      super.stop(msg);<a name="line.2842"></a>
+<span class="sourceLineNo">2843</span>      if (this.activeMasterManager != null) {<a name="line.2843"></a>
+<span class="sourceLineNo">2844</span>        this.activeMasterManager.stop();<a name="line.2844"></a>
+<span class="sourceLineNo">2845</span>      }<a name="line.2845"></a>
+<span class="sourceLineNo">2846</span>    }<a name="line.2846"></a>
+<span class="sourceLineNo">2847</span>  }<a name="line.2847"></a>
+<span class="sourceLineNo">2848</span><a name="line.2848"></a>
+<span class="sourceLineNo">2849</span>  @VisibleForTesting<a name="line.2849"></a>
+<span class="sourceLineNo">2850</span>  protected void checkServiceStarted() throws ServerNotRunningYetException {<a name="line.2850"></a>
+<span class="sourceLineNo">2851</span>    if (!serviceStarted) {<a name="line.2851"></a>
+<span class="sourceLineNo">2852</span>      throw new ServerNotRunningYetException("Server is not running yet");<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><a name="line.2855"></a>
+<span class="sourceLineNo">2856</span>  public static class MasterStoppedException extends DoNotRetryIOException {<a name="line.2856"></a>
+<span class="sourceLineNo">2857</span>    MasterStoppedException() {<a name="line.2857"></a>
+<span class="sourceLineNo">2858</span>      super();<a name="line.2858"></a>
+<span class="sourceLineNo">2859</span>    }<a name="line.2859"></a>
+<span class="sourceLineNo">2860</span>  }<a name="line.2860"></a>
+<span class="sourceLineNo">2861</span><a name="line.2861"></a>
+<span class="sourceLineNo">2862</span>  void checkInitialized() throws PleaseHoldException, ServerNotRunningYetException,<a name="line.2862"></a>
+<span class="sourceLineNo">2863</span>      MasterNotRunningException, MasterStoppedException {<a name="line.2863"></a>
+<span class="sourceLineNo">2864</span>    checkServiceStarted();<a name="line.2864"></a>
+<span class="sourceLineNo">2865</span>    if (!isInitialized()) {<a name="line.2865"></a>
+<span class="sourceLineNo">2866</span>      throw new PleaseHoldException("Master is initializing");<a name="line.2866"></a>
+<span class="sourceLineNo">2867</span>    }<a name="line.2867"></a>
+<span class="sourceLineNo">2868</span>    if (isStopped()) {<a name="line.2868"></a>
+<span class="sourceLineNo">2869</span>      throw new MasterStoppedException();<a name="line.2869"></a>
+<span class="sourceLineNo">2870</span>    }<a name="line.2870"></a>
+<span class="sourceLineNo">2871</span>  }<a name="line.2871"></a>
+<span class="sourceLineNo">2872</span><a name="line.2872"></a>
+<span class="sourceLineNo">2873</span>  /**<a name="line.2873"></a>
+<span class="sourceLineNo">2874</span>   * Report whether this master is currently the active master or not.<a name="line.2874"></a>
+<span class="sourceLineNo">2875</span>   * If not active master, we are parked on ZK waiting to become active.<a name="line.2875"></a>
+<span class="sourceLineNo">2876</span>   *<a name="line.2876"></a>
+<span class="sourceLineNo">2877</span>   * This method is used for testing.<a name="line.2877"></a>
+<span class="sourceLineNo">2878</span>   *<a name="line.2878"></a>
+<span class="sourceLineNo">2879</span>   * @return true if active master, false if not.<a name="line.2879"></a>
+<span class="sourceLineNo">2880</span>   */<a name="line.2880"></a>
+<span class="sourceLineNo">2881</span>  @Override<a name="line.2881"></a>
+<span class="sourceLineNo">2882</span>  public boolean isActiveMaster() {<a name="line.2882"></a>
+<span class="sourceLineNo">2883</span>    return activeMaster;<a name="line.2883"></a>
+<span class="sourceLineNo">2884</span>  }<a name="line.2884"></a>
+<span class="sourceLineNo">2885</span><a name="line.2885"></a>
+<span class="sourceLineNo">2886</span>  /**<a name="line.2886"></a>
+<span class="sourceLineNo">2887</span>   * Report whether this master has completed with its initialization and is<a name="line.2887"></a>
+<span class="sourceLineNo">2888</span>   * ready.  If ready, the master is also the active master.  A standby master<a name="line.2888"></a>
+<span class="sourceLineNo">2889</span>   * is never ready.<a name="line.2889"></a>
+<span class="sourceLineNo">2890</span>   *<a name="line.2890"></a>
+<span class="sourceLineNo">2891</span>   * This method is used for testing.<a name="line.2891"></a>
+<span class="sourceLineNo">2892</span>   *<a name="line.2892"></a>
+<span class="sourceLineNo">2893</span>   * @return true if master is ready to go, false if not.<a name="line.2893"></a>
+<span class="sourceLineNo">2894</span>   */<a name="line.2894"></a>
+<span class="sourceLineNo">2895</span>  @Override<a name="line.2895"></a>
+<span class="sourceLineNo">2896</span>  public boolean isInitialized() {<a name="line.2896"></a>
+<span class="sourceLineNo">2897</span>    return initialized.isReady();<a name="line.2897"></a>
+<span class="sourceLineNo">2898</span>  }<a name="line.2898"></a>
+<span class="sourceLineNo">2899</span><a name="line.2899"></a>
+<span class="sourceLineNo">2900</span>  /**<a name="line.2900"></a>
+<span class="sourceLineNo">2901</span>   * Report whether this master is in maintenance mode.<a name="line.2901"></a>
+<span class="sourceLineNo">2902</span>   *<a name="line.2902"></a>
+<span class="sourceLineNo">2903</span>   * @return true if master is in maintenanceMode<a name="line.2903"></a>
+<span class="sourceLineNo">2904</span>   */<a name="line.2904"></a>
+<span class="sourceLineNo">2905</span>  @Override<a name="line.2905"></a>
+<span class="sourceLineNo">2906</span>  public boolean isInMaintenanceMode() {<a name="line.2906"></a>
+<span class="sourceLineNo">2907</span>    return maintenanceMode;<a name="line.2907"></a>
+<span class="sourceLineNo">2908</span>  }<a name="line.2908"></a>
+<span class="sourceLineNo">2909</span><a name="line.2909"></a>
+<span class="sourceLineNo">2910</span>  @VisibleForTesting<a name="line.2910"></a>
+<span class="sourceLineNo">2911</span>  public void setInitialized(boolean isInitialized) {<a name="line.2911"></a>
+<span class="sourceLineNo">2912</span>    procedureExecutor.getEnvironment().setEventReady(initialized, isInitialized);<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>  @Override<a name="line.2915"></a>
+<span class="sourceLineNo">2916</span>  public ProcedureEvent&lt;?&gt; getInitializedEvent() {<a name="line.2916"></a>
+<span class="sourceLineNo">2917</span>    return initialized;<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>   * Compute the average load across all region servers.<a name="line.2921"></a>
+<span class="sourceLineNo">2922</span>   * Currently, this uses a very naive computation - just uses the number of<a name="line.2922"></a>
+<span class="sourceLineNo">2923</span>   * regions being served, ignoring stats about number of requests.<a name="line.2923"></a>
+<span class="sourceLineNo">2924</span>   * @return the average load<a name="line.2924"></a>
+<span class="sourceLineNo">2925</span>   */<a name="line.2925"></a>
+<span class="sourceLineNo">2926</span>  public double getAverageLoad() {<a name="line.2926"></a>
+<span class="sourceLineNo">2927</span>    if (this.assignmentManager == null) {<a name="line.2927"></a>
+<span class="sourceLineNo">2928</span>      return 0;<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>    RegionStates regionStates = this.assignmentManager.getRegionStates();<a name="line.2931"></a>
+<span class="sourceLineNo">2932</span>    if (regionStates == null) {<a name="line.2932"></a>
+<span class="sourceLineNo">2933</span>      return 0;<a name="line.2933"></a>
+<span class="sourceLineNo">2934</span>    }<a name="line.2934"></a>
+<span class="sourceLineNo">2935</span>    return regionStates.getAverageLoad();<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>  @Override<a name="line.2938"></a>
+<span class="sourceLineNo">2939</span>  public boolean registerService(Service instance) {<a name="line.2939"></a>
+<span class="sourceLineNo">2940</span>    /*<a name="line.2940"></a>
+<span class="sourceLineNo">2941</span>     * No stacking of instances is allowed for a single service name<a name="line.2941"></a>
+<span class="sourceLineNo">2942</span>     */<a name="line.2942"></a>
+<span class="sourceLineNo">2943</span>    Descriptors.ServiceDescriptor serviceDesc = instance.getDescriptorForType();<a name="line.2943"></a>
+<span class="sourceLineNo">2944</span>    String serviceName = CoprocessorRpcUtils.getServiceName(serviceDesc);<a name="line.2944"></a>
+<span class="sourceLineNo">2945</span>    if (coprocessorServiceHandlers.containsKey(serviceName)) {<a name="line.2945"></a>
+<span class="sourceLineNo">2946</span>      LOG.error("Coprocessor service "+serviceName+<a name="line.2946"></a>
+<span class="sourceLineNo">2947</span>          " already registered, rejecting request from "+instance<a name="line.2947"></a>
+<span class="sourceLineNo">2948</span>      );<a name="line.2948"></a>
+<span class="sourceLineNo">2949</span>      return false;<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>    coprocessorServiceHandlers.put(serviceName, instance);<a name="line.2952"></a>
+<span class="sourceLineNo">2953</span>    if (LOG.isDebugEnabled()) {<a name="line.2953"></a>
+<span class="sourceLineNo">2954</span>      LOG.debug("Registered master coprocessor service: service="+serviceName);<a name="line.2954"></a>
+<span class="sourceLineNo">2955</span>    }<a name="line.2955"></a>
+<span class="sourceLineNo">2956</span>    return true;<a name="line.2956"></a>
+<span class="sourceLineNo">2957</span>  }<a name="line.2957"></a>
+<span class="sourceLineNo">2958</span><a name="line.2958"></a>
+<span class="sourceLineNo">2959</span>  /**<a name="line.2959"></a>
+<span class="sourceLineNo">2960</span>   * Utility for constructing an instance of the passed HMaster class.<a name="line.2960"></a>
+<span class="sourceLineNo">2961</span>   * @param masterClass<a name="line.2961"></a>
+<span class="sourceLineNo">2962</span>   * @return HMaster instance.<a name="line.2962"></a>
+<span class="sourceLineNo">2963</span>   */<a name="line.2963"></a>
+<span class="sourceLineNo">2964</span>  public static HMaster constructMaster(Class&lt;? extends HMaster&gt; masterClass,<a name="line.2964"></a>
+<span class="sourceLineNo">2965</span>      final Configuration conf)  {<a name="line.2965"></a>
+<span class="sourceLineNo">2966</span>    try {<a name="line.2966"></a>
+<span class="sourceLineNo">2967</span>      Constructor&lt;? extends HMaster&gt; c = masterClass.getConstructor(Configuration.class);<a name="line.2967"></a>
+<span class="sourceLineNo">2968</span>      return c.newInstance(conf);<a name="line.2968"></a>
+<span class="sourceLineNo">2969</span>    } catch(Exception e) {<a name="line.2969"></a>
+<span class="sourceLineNo">2970</span>      Throwable error = e;<a name="line.2970"></a>
+<span class="sourceLineNo">2971</span>      if (e instanceof InvocationTargetException &amp;&amp;<a name="line.2971"></a>
+<span class="sourceLineNo">2972</span>          ((InvocationTargetException)e).getTargetException() != null) {<a name="line.2972"></a>
+<span class="sourceLineNo">2973</span>        error = ((InvocationTargetException)e).getTargetException();<a name="line.2973"></a>
+<span class="sourceLineNo">2974</span>      }<a name="line.2974"></a>
+<span class="sourceLineNo">2975</span>      throw new RuntimeException("Failed construction of Master: " + masterClass.toString() + ". "<a name="line.2975"></a>
+<span class="sourceLineNo">2976</span>        , error);<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><a name="line.2979"></a>
+<span class="sourceLineNo">2980</span>  /**<a name="line.2980"></a>
+<span class="sourceLineNo">2981</span>   * @see org.apache.hadoop.hbase.master.HMasterCommandLine<a name="line.2981"></a>
+<span class="sourceLineNo">2982</span>   */<a name="line.2982"></a>
+<span class="sourceLineNo">2983</span>  public static void main(String [] args) {<a name="line.2983"></a>
+<span class="sourceLineNo">2984</span>    LOG.info("STARTING service " + HMaster.class.getSimpleName());<a name="line.2984"></a>
+<span class="sourceLineNo">2985</span>    VersionInfo.logVersion();<a name="line.2985"></a>
+<span class="sourceLineNo">2986</span>    new HMasterCommandLine(HMaster.class).doMain(args);<a name="line.2986"></a>
 <span class="sourceLineNo">2987</span>  }<a name="line.2987"></a>
 <span class="sourceLineNo">2988</span><a name="line.2988"></a>
-<span class="sourceLineNo">2989</span>  public LogCleaner getLogCleaner() {<a name="line.2989"></a>
-<span class="sourceLineNo">2990</span>    return this.logCleaner;<a name="line.2990"></a>
+<span class="sourceLineNo">2989</span>  public HFileCleaner getHFileCleaner() {<a name="line.2989"></a>
+<span class="sourceLineNo">2990</span>    return this.hfileCleaner;<a name="line.2990"></a>
 <span class="sourceLineNo">2991</span>  }<a name="line.2991"></a>
 <span class="sourceLineNo">2992</span><a name="line.2992"></a>
-<span class="sourceLineNo">2993</span>  /**<a name="line.2993"></a>
-<span class="sourceLineNo">2994</span>   * @return the underlying snapshot manager<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 SnapshotManager getSnapshotManager() {<a name="line.2997"></a>
-<span class="sourceLineNo">2998</span>    return this.snapshotManager;<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>  /**<a name="line.3001"></a>
-<span class="sourceLineNo">3002</span>   * @return the underlying MasterProcedureManagerHost<a name="line.3002"></a>
-<span class="sourceLineNo">3003</span>   */<a name="line.3003"></a>
-<span class="sourceLineNo">3004</span>  @Override<a name="line.3004"></a>
-<span class="sourceLineNo">3005</span>  public MasterProcedureManagerHost getMasterProcedureManagerHost() {<a name="line.3005"></a>
-<span class="sourceLineNo">3006</span>    return mpmHost;<a name="line.3006"></a>
-<span class="sourceLineNo">3007</span>  }<a name="line.3007"></a>
-<span class="sourceLineNo">3008</span><a name="line.3008"></a>
-<span class="sourceLineNo">3009</span>  @Override<a name="line.3009"></a>
-<span class="sourceLineNo">3010</span>  public ClusterSchema getClusterSchema() {<a name="line.3010"></a>
-<span class="sourceLineNo">3011</span>    return this.clusterSchemaService;<a name="line.3011"></a>
-<span class="sourceLineNo">3012</span>  }<a name="line.3012"></a>
-<span class="sourceLineNo">3013</span><a name="line.3013"></a>
-<span class="sourceLineNo">3014</span>  /**<a name="line.3014"></a>
-<span class="sourceLineNo">3015</span>   * Create a new Namespace.<a name="line.3015"></a>
-<span class="sourceLineNo">3016</span>   * @param namespaceDescriptor descriptor for new Namespace<a name="line.3016"></a>
-<span class="sourceLineNo">3017</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3017"></a>
-<span class="sourceLineNo">3018</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3018"></a>
-<span class="sourceLineNo">3019</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3019"></a>
-<span class="sourceLineNo">3020</span>   * @return procedure id<a name="line.3020"></a>
-<span class="sourceLineNo">3021</span>   */<a name="line.3021"></a>
-<span class="sourceLineNo">3022</span>  long createNamespace(final NamespaceDescriptor namespaceDescriptor, final long nonceGroup,<a name="line.3022"></a>
-<span class="sourceLineNo">3023</span>      final long nonce) throws IOException {<a name="line.3023"></a>
-<span class="sourceLineNo">3024</span>    checkInitialized();<a name="line.3024"></a>
-<span class="sourceLineNo">3025</span><a name="line.3025"></a>
-<span class="sourceLineNo">3026</span>    TableName.isLegalNamespaceName(Bytes.toBytes(namespaceDescriptor.getName()));<a name="line.3026"></a>
-<span class="sourceLineNo">3027</span><a name="line.3027"></a>
-<span class="sourceLineNo">3028</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3028"></a>
-<span class="sourceLineNo">3029</span>          nonceGroup, nonce) {<a name="line.3029"></a>
-<span class="sourceLineNo">3030</span>      @Override<a name="line.3030"></a>
-<span class="sourceLineNo">3031</span>      protected void run() throws IOException {<a name="line.3031"></a>
-<span class="sourceLineNo">3032</span>        getMaster().getMasterCoprocessorHost().preCreateNamespace(namespaceDescriptor);<a name="line.3032"></a>
-<span class="sourceLineNo">3033</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3033"></a>
-<span class="sourceLineNo">3034</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3034"></a>
-<span class="sourceLineNo">3035</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3035"></a>
-<span class="sourceLineNo">3036</span>        LOG.info(getClientIdAuditPrefix() + " creating " + namespaceDescriptor);<a name="line.3036"></a>
-<span class="sourceLineNo">3037</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3037"></a>
-<span class="sourceLineNo">3038</span>        // continuing.<a name="line.3038"></a>
-<span class="sourceLineNo">3039</span>        setProcId(getClusterSchema().createNamespace(namespaceDescriptor, getNonceKey(), latch));<a name="line.3039"></a>
-<span class="sourceLineNo">3040</span>        latch.await();<a name="line.3040"></a>
-<span class="sourceLineNo">3041</span>        getMaster().getMasterCoprocessorHost().postCreateNamespace(namespaceDescriptor);<a name="line.3041"></a>
-<span class="sourceLineNo">3042</span>      }<a name="line.3042"></a>
-<span class="sourceLineNo">3043</span><a name="line.3043"></a>
-<span class="sourceLineNo">3044</span>      @Override<a name="line.3044"></a>
-<span class="sourceLineNo">3045</span>      protected String getDescription() {<a name="line.3045"></a>
-<span class="sourceLineNo">3046</span>        return "CreateNamespaceProcedure";<a name="line.3046"></a>
-<span class="sourceLineNo">3047</span>      }<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>  /**<a name="line.3051"></a>
-<span class="sourceLineNo">3052</span>   * Modify an existing Namespace.<a name="line.3052"></a>
-<span class="sourceLineNo">3053</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3053"></a>
-<span class="sourceLineNo">3054</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3054"></a>
-<span class="sourceLineNo">3055</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3055"></a>
-<span class="sourceLineNo">3056</span>   * @return procedure id<a name="line.3056"></a>
-<span class="sourceLineNo">3057</span>   */<a name="line.3057"></a>
-<span class="sourceLineNo">3058</span>  long modifyNamespace(final NamespaceDescriptor newNsDescriptor, final long nonceGroup,<a name="line.3058"></a>
-<span class="sourceLineNo">3059</span>      final long nonce) throws IOException {<a name="line.3059"></a>
-<span class="sourceLineNo">3060</span>    checkInitialized();<a name="line.3060"></a>
-<span class="sourceLineNo">3061</span><a name="line.3061"></a>
-<span class="sourceLineNo">3062</span>    TableName.isLegalNamespaceName(Bytes.toBytes(newNsDescriptor.getName()));<a name="line.3062"></a>
-<span class="sourceLineNo">3063</span><a name="line.3063"></a>
-<span class="sourceLineNo">3064</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3064"></a>
-<span class="sourceLineNo">3065</span>          nonceGroup, nonce) {<a name="line.3065"></a>
-<span class="sourceLineNo">3066</span>      @Override<a name="line.3066"></a>
-<span class="sourceLineNo">3067</span>      protected void run() throws IOException {<a name="line.3067"></a>
-<span class="sourceLineNo">3068</span>        NamespaceDescriptor oldNsDescriptor = getNamespace(newNsDescriptor.getName());<a name="line.3068"></a>
-<span class="sourceLineNo">3069</span>        getMaster().getMasterCoprocessorHost().preModifyNamespace(oldNsDescriptor, newNsDescriptor);<a name="line.3069"></a>
-<span class="sourceLineNo">3070</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3070"></a>
-<span class="sourceLineNo">3071</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3071"></a>
-<span class="sourceLineNo">3072</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3072"></a>
-<span class="sourceLineNo">3073</span>        LOG.info(getClientIdAuditPrefix() + " modify " + newNsDescriptor);<a name="line.3073"></a>
-<span class="sourceLineNo">3074</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3074"></a>
-<span class="sourceLineNo">3075</span>        // continuing.<a name="line.3075"></a>
-<span class="sourceLineNo">3076</span>        setProcId(getClusterSchema().modifyNamespace(newNsDescriptor, getNonceKey(), latch));<a name="line.3076"></a>
-<span class="sourceLineNo">3077</span>        latch.await();<a name="line.3077"></a>
-<span class="sourceLineNo">3078</span>        getMaster().getMasterCoprocessorHost().postModifyNamespace(oldNsDescriptor,<a name="line.3078"></a>
-<span class="sourceLineNo">3079</span>          newNsDescriptor);<a name="line.3079"></a>
-<span class="sourceLineNo">3080</span>      }<a name="line.3080"></a>
-<span class="sourceLineNo">3081</span><a name="line.3081"></a>
-<span class="sourceLineNo">3082</span>      @Override<a name="line.3082"></a>
-<span class="sourceLineNo">3083</span>      protected String getDescription() {<a name="line.3083"></a>
-<span class="sourceLineNo">3084</span>        return "ModifyNamespaceProcedure";<a name="line.3084"></a>
-<span class="sourceLineNo">3085</span>      }<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>  /**<a name="line.3089"></a>
-<span class="sourceLineNo">3090</span>   * Delete an existing Namespace. Only empty Namespaces (no tables) can be removed.<a name="line.3090"></a>
-<span class="sourceLineNo">3091</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3091"></a>
-<span class="sourceLineNo">3092</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3092"></a>
-<span class="sourceLineNo">3093</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3093"></a>
-<span class="sourceLineNo">3094</span>   * @return procedure id<a name="line.3094"></a>
-<span class="sourceLineNo">3095</span>   */<a name="line.3095"></a>
-<span class="sourceLineNo">3096</span>  long deleteNamespace(final String name, final long nonceGroup, final long nonce)<a name="line.3096"></a>
-<span class="sourceLineNo">3097</span>      throws IOException {<a name="line.3097"></a>
-<span class="sourceLineNo">3098</span>    checkInitialized();<a name="line.3098"></a>
-<span class="sourceLineNo">3099</span><a name="line.3099"></a>
-<span class="sourceLineNo">3100</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3100"></a>
-<span class="sourceLineNo">3101</span>          nonceGroup, nonce) {<a name="line.3101"></a>
-<span class="sourceLineNo">3102</span>      @Override<a name="line.3102"></a>
-<span class="sourceLineNo">3103</span>      protected void run() throws IOException {<a name="line.3103"></a>
-<span class="sourceLineNo">3104</span>        getMaster().getMasterCoprocessorHost().preDeleteNamespace(name);<a name="line.3104"></a>
-<span class="sourceLineNo">3105</span>        LOG.info(getClientIdAuditPrefix() + " delete " + name);<a name="line.3105"></a>
-<span class="sourceLineNo">3106</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3106"></a>
-<span class="sourceLineNo">3107</span>        // continuing.<a name="line.3107"></a>
-<span class="sourceLineNo">3108</span>        //<a name="line.3108"></a>
-<span class="sourceLineNo">3109</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3109"></a>
-<span class="sourceLineNo">3110</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3110"></a>
-<span class="sourceLineNo">3111</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3111"></a>
-<span class="sourceLineNo">3112</span>        setProcId(submitProcedure(<a name="line.3112"></a>
-<span class="sourceLineNo">3113</span>              new DeleteNamespaceProcedure(procedureExecutor.getEnvironment(), name, latch)));<a name="line.3113"></a>
-<span class="sourceLineNo">3114</span>        latch.await();<a name="line.3114"></a>
-<span class="sourceLineNo">3115</span>        // Will not be invoked in the face of Exception thrown by the Procedure's execution<a name="line.3115"></a>
-<span class="sourceLineNo">3116</span>        getMaster().getMasterCoprocessorHost().postDeleteNamespace(name);<a name="line.3116"></a>
-<span class="sourceLineNo">3117</span>      }<a name="line.3117"></a>
-<span class="sourceLineNo">3118</span><a name="line.3118"></a>
-<span class="sourceLineNo">3119</span>      @Override<a name="line.3119"></a>
-<span class="sourceLineNo">3120</span>      protected String getDescription() {<a name="line.3120"></a>
-<span class="sourceLineNo">3121</span>        return "DeleteNamespaceProcedure";<a name="line.3121"></a>
-<span class="sourceLineNo">3122</span>      }<a name="line.3122"></a>
-<span class="sourceLineNo">3123</span>    });<a name="line.3123"></a>
-<span class="sourceLineNo">3124</span>  }<a name="line.3124"></a>
-<span class="sourceLineNo">3125</span><a name="line.3125"></a>
-<span class="sourceLineNo">3126</span>  /**<a name="line.3126"></a>
-<span class="sourceLineNo">3127</span>   * Get a Namespace<a name="line.3127"></a>
-<span class="sourceLineNo">3128</span>   * @param name Name of the Namespace<a name="line.3128"></a>
-<span class="sourceLineNo">3129</span>   * @return Namespace descriptor for &lt;code&gt;name&lt;/code&gt;<a name="line.3129"></a>
-<span class="sourceLineNo">3130</span>   */<a name="line.3130"></a>
-<span class="sourceLineNo">3131</span>  NamespaceDescriptor getNamespace(String name) throws IOException {<a name="line.3131"></a>
-<span class="sourceLineNo">3132</span>    checkInitialized();<a name="line.3132"></a>
-<span class="sourceLineNo">3133</span>    if (this.cpHost != null) this.cpHost.preGetNamespaceDescriptor(name);<a name="line.3133"></a>
-<span class="sourceLineNo">3134</span>    NamespaceDescriptor nsd = this.clusterSchemaService.getNamespace(name);<a name="line.3134"></a>
-<span class="sourceLineNo">3135</span>    if (this.cpHost != null) this.cpHost.postGetNamespaceDescriptor(nsd);<a name="line.3135"></a>
-<span class="sourceLineNo">3136</span>    return nsd;<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>  /**<a name="line.3139"></a>
-<span class="sourceLineNo">3140</span>   * Get all Namespaces<a name="line.3140"></a>
-<span class="sourceLineNo">3141</span>   * @return All Namespace descriptors<a name="line.3141"></a>
-<span class="sourceLineNo">3142</span>   */<a name="line.3142"></a>
-<span class="sourceLineNo">3143</span>  List&lt;NamespaceDescriptor&gt; getNamespaces() throws IOException {<a name="line.3143"></a>
-<span class="sourceLineNo">3144</span>    checkInitialized();<a name="line.3144"></a>
-<span class="sourceLineNo">3145</span>    final List&lt;NamespaceDescriptor&gt; nsds = new ArrayList&lt;&gt;();<a name="line.3145"></a>
-<span class="sourceLineNo">3146</span>    if (cpHost != null) {<a name="line.3146"></a>
-<span class="sourceLineNo">3147</span>      cpHost.preListNamespaceDescriptors(nsds);<a name="line.3147"></a>
-<span class="sourceLineNo">3148</span>    }<a name="line.3148"></a>
-<span class="sourceLineNo">3149</span>    nsds.addAll(this.clusterSchemaService.getNamespaces());<a name="line.3149"></a>
-<span class="sourceLineNo">3150</span>    if (this.cpHost != null) {<a name="line.3150"></a>
-<span class="sourceLineNo">3151</span>      this.cpHost.postListNamespaceDescriptors(nsds);<a name="line.3151"></a>
+<span class="sourceLineNo">2993</span>  public LogCleaner getLogCleaner() {<a name="line.2993"></a>
+<span class="sourceLineNo">2994</span>    return this.logCleaner;<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>  /**<a name="line.2997"></a>
+<span class="sourceLineNo">2998</span>   * @return the underlying snapshot manager<a name="line.2998"></a>
+<span class="sourceLineNo">2999</span>   */<a name="line.2999"></a>
+<span class="sourceLineNo">3000</span>  @Override<a name="line.3000"></a>
+<span class="sourceLineNo">3001</span>  public SnapshotManager getSnapshotManager() {<a name="line.3001"></a>
+<span class="sourceLineNo">3002</span>    return this.snapshotManager;<a name="line.3002"></a>
+<span class="sourceLineNo">3003</span>  }<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>   * @return the underlying MasterProcedureManagerHost<a name="line.3006"></a>
+<span class="sourceLineNo">3007</span>   */<a name="line.3007"></a>
+<span class="sourceLineNo">3008</span>  @Override<a name="line.3008"></a>
+<span class="sourceLineNo">3009</span>  public MasterProcedureManagerHost getMasterProcedureManagerHost() {<a name="line.3009"></a>
+<span class="sourceLineNo">3010</span>    return mpmHost;<a name="line.3010"></a>
+<span class="sourceLineNo">3011</span>  }<a name="line.3011"></a>
+<span class="sourceLineNo">3012</span><a name="line.3012"></a>
+<span class="sourceLineNo">3013</span>  @Override<a name="line.3013"></a>
+<span class="sourceLineNo">3014</span>  public ClusterSchema getClusterSchema() {<a name="line.3014"></a>
+<span class="sourceLineNo">3015</span>    return this.clusterSchemaService;<a name="line.3015"></a>
+<span class="sourceLineNo">3016</span>  }<a name="line.3016"></a>
+<span class="sourceLineNo">3017</span><a name="line.3017"></a>
+<span class="sourceLineNo">3018</span>  /**<a name="line.3018"></a>
+<span class="sourceLineNo">3019</span>   * Create a new Namespace.<a name="line.3019"></a>
+<span class="sourceLineNo">3020</span>   * @param namespaceDescriptor descriptor for new Namespace<a name="line.3020"></a>
+<span class="sourceLineNo">3021</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3021"></a>
+<span class="sourceLineNo">3022</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3022"></a>
+<span class="sourceLineNo">3023</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3023"></a>
+<span class="sourceLineNo">3024</span>   * @return procedure id<a name="line.3024"></a>
+<span class="sourceLineNo">3025</span>   */<a name="line.3025"></a>
+<span class="sourceLineNo">3026</span>  long createNamespace(final NamespaceDescriptor namespaceDescriptor, final long nonceGroup,<a name="line.3026"></a>
+<span class="sourceLineNo">3027</span>      final long nonce) throws IOException {<a name="line.3027"></a>
+<span class="sourceLineNo">3028</span>    checkInitialized();<a name="line.3028"></a>
+<span class="sourceLineNo">3029</span><a name="line.3029"></a>
+<span class="sourceLineNo">3030</span>    TableName.isLegalNamespaceName(Bytes.toBytes(namespaceDescriptor.getName()));<a name="line.3030"></a>
+<span class="sourceLineNo">3031</span><a name="line.3031"></a>
+<span class="sourceLineNo">3032</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3032"></a>
+<span class="sourceLineNo">3033</span>          nonceGroup, nonce) {<a name="line.3033"></a>
+<span class="sourceLineNo">3034</span>      @Override<a name="line.3034"></a>
+<span class="sourceLineNo">3035</span>      protected void run() throws IOException {<a name="line.3035"></a>
+<span class="sourceLineNo">3036</span>        getMaster().getMasterCoprocessorHost().preCreateNamespace(namespaceDescriptor);<a name="line.3036"></a>
+<span class="sourceLineNo">3037</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3037"></a>
+<span class="sourceLineNo">3038</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3038"></a>
+<span class="sourceLineNo">3039</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3039"></a>
+<span class="sourceLineNo">3040</span>        LOG.info(getClientIdAuditPrefix() + " creating " + namespaceDescriptor);<a name="line.3040"></a>
+<span class="sourceLineNo">3041</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3041"></a>
+<span class="sourceLineNo">3042</span>        // continuing.<a name="line.3042"></a>
+<span class="sourceLineNo">3043</span>        setProcId(getClusterSchema().createNamespace(namespaceDescriptor, getNonceKey(), latch));<a name="line.3043"></a>
+<span class="sourceLineNo">3044</span>        latch.await();<a name="line.3044"></a>
+<span class="sourceLineNo">3045</span>        getMaster().getMasterCoprocessorHost().postCreateNamespace(namespaceDescriptor);<a name="line.3045"></a>
+<span class="sourceLineNo">3046</span>      }<a name="line.3046"></a>
+<span class="sourceLineNo">3047</span><a name="line.3047"></a>
+<span class="sourceLineNo">3048</span>      @Override<a name="line.3048"></a>
+<span class="sourceLineNo">3049</span>      protected String getDescription() {<a name="line.3049"></a>
+<span class="sourceLineNo">3050</span>        return "CreateNamespaceProcedure";<a name="line.3050"></a>
+<span class="sourceLineNo">3051</span>      }<a name="line.3051"></a>
+<span class="sourceLineNo">3052</span>    });<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>   * Modify an existing Namespace.<a name="line.3056"></a>
+<span class="sourceLineNo">3057</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3057"></a>
+<span class="sourceLineNo">3058</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3058"></a>
+<span class="sourceLineNo">3059</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3059"></a>
+<span class="sourceLineNo">3060</span>   * @return procedure id<a name="line.3060"></a>
+<span class="sourceLineNo">3061</span>   */<a name="line.3061"></a>
+<span class="sourceLineNo">3062</span>  long modifyNamespace(final NamespaceDescriptor newNsDescriptor, final long nonceGroup,<a name="line.3062"></a>
+<span class="sourceLineNo">3063</span>      final long nonce) throws IOException {<a name="line.3063"></a>
+<span class="sourceLineNo">3064</span>    checkInitialized();<a name="line.3064"></a>
+<span class="sourceLineNo">3065</span><a name="line.3065"></a>
+<span class="sourceLineNo">3066</span>    TableName.isLegalNamespaceName(Bytes.toBytes(newNsDescriptor.getName()));<a name="line.3066"></a>
+<span class="sourceLineNo">3067</span><a name="line.3067"></a>
+<span class="sourceLineNo">3068</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3068"></a>
+<span class="sourceLineNo">3069</span>          nonceGroup, nonce) {<a name="line.3069"></a>
+<span class="sourceLineNo">3070</span>      @Override<a name="line.3070"></a>
+<span class="sourceLineNo">3071</span>      protected void run() throws IOException {<a name="line.3071"></a>
+<span class="sourceLineNo">3072</span>        NamespaceDescriptor oldNsDescriptor = getNamespace(newNsDescriptor.getName());<a name="line.3072"></a>
+<span class="sourceLineNo">3073</span>        getMaster().getMasterCoprocessorHost().preModifyNamespace(oldNsDescriptor, newNsDescriptor);<a name="line.3073"></a>
+<span class="sourceLineNo">3074</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3074"></a>
+<span class="sourceLineNo">3075</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3075"></a>
+<span class="sourceLineNo">3076</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3076"></a>
+<span class="sourceLineNo">3077</span>        LOG.info(getClientIdAuditPrefix() + " modify " + newNsDescriptor);<a name="line.3077"></a>
+<span class="sourceLineNo">3078</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3078"></a>
+<span class="sourceLineNo">3079</span>        // continuing.<a name="line.3079"></a>
+<span class="sourceLineNo">3080</span>        setProcId(getClusterSchema().modifyNamespace(newNsDescriptor, getNonceKey(), latch));<a name="line.3080"></a>
+<span class="sourceLineNo">3081</span>        latch.await();<a name="line.3081"></a>
+<span class="sourceLineNo">3082</span>        getMaster().getMasterCoprocessorHost().postModifyNamespace(oldNsDescriptor,<a name="line.3082"></a>
+<span class="sourceLineNo">3083</span>          newNsDescriptor);<a name="line.3083"></a>
+<span class="sourceLineNo">3084</span>      }<a name="line.3084"></a>
+<span class="sourceLineNo">3085</span><a name="line.3085"></a>
+<span class="sourceLineNo">3086</span>      @Override<a name="line.3086"></a>
+<span class="sourceLineNo">3087</span>      protected String getDescription() {<a name="line.3087"></a>
+<span class="sourceLineNo">3088</span>        return "ModifyNamespaceProcedure";<a name="line.3088"></a>
+<span class="sourceLineNo">3089</span>      }<a name="line.3089"></a>
+<span class="sourceLineNo">3090</span>    });<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>   * Delete an existing Namespace. Only empty Namespaces (no tables) can be removed.<a name="line.3094"></a>
+<span class="sourceLineNo">3095</span>   * @param nonceGroup Identifier for the source of the request, a client or process.<a name="line.3095"></a>
+<span class="sourceLineNo">3096</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3096"></a>
+<span class="sourceLineNo">3097</span>   * &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3097"></a>
+<span class="sourceLineNo">3098</span>   * @return procedure id<a name="line.3098"></a>
+<span class="sourceLineNo">3099</span>   */<a name="line.3099"></a>
+<span class="sourceLineNo">3100</span>  long deleteNamespace(final String name, final long nonceGroup, final long nonce)<a name="line.3100"></a>
+<span class="sourceLineNo">3101</span>      throws IOException {<a name="line.3101"></a>
+<span class="sourceLineNo">3102</span>    checkInitialized();<a name="line.3102"></a>
+<span class="sourceLineNo">3103</span><a name="line.3103"></a>
+<span class="sourceLineNo">3104</span>    return MasterProcedureUtil.submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this,<a name="line.3104"></a>
+<span class="sourceLineNo">3105</span>          nonceGroup, nonce) {<a name="line.3105"></a>
+<span class="sourceLineNo">3106</span>      @Override<a name="line.3106"></a>
+<span class="sourceLineNo">3107</span>      protected void run() throws IOException {<a name="line.3107"></a>
+<span class="sourceLineNo">3108</span>        getMaster().getMasterCoprocessorHost().preDeleteNamespace(name);<a name="line.3108"></a>
+<span class="sourceLineNo">3109</span>        LOG.info(getClientIdAuditPrefix() + " delete " + name);<a name="line.3109"></a>
+<span class="sourceLineNo">3110</span>        // Execute the operation synchronously - wait for the operation to complete before<a name="line.3110"></a>
+<span class="sourceLineNo">3111</span>        // continuing.<a name="line.3111"></a>
+<span class="sourceLineNo">3112</span>        //<a name="line.3112"></a>
+<span class="sourceLineNo">3113</span>        // We need to wait for the procedure to potentially fail due to "prepare" sanity<a name="line.3113"></a>
+<span class="sourceLineNo">3114</span>        // checks. This will block only the beginning of the procedure. See HBASE-19953.<a name="line.3114"></a>
+<span class="sourceLineNo">3115</span>        ProcedurePrepareLatch latch = ProcedurePrepareLatch.createBlockingLatch();<a name="line.3115"></a>
+<span class="sourceLineNo">3116</span>        setProcId(submitProcedure(<a name="line.3116"></a>
+<span class="sourceLineNo">3117</span>              new DeleteNamespaceProcedure(procedureExecutor.getEnvironment(), name, latch)));<a name="line.3117"></a>
+<span class="sourceLineNo">3118</span>        latch.await();<a name="line.3118"></a>
+<span class="sourceLineNo">3119</span>        // Will not be invoked in the face of Exception thrown by the Procedure's execution<a name="line.3119"></a>
+<span class="sourceLineNo">3120</span>        getMaster().getMasterCoprocessorHost().postDeleteNamespace(name);<a name="line.3120"></a>
+<span class="sourceLineNo">3121</span>      }<a name="line.3121"></a>
+<span class="sourceLineNo">3122</span><a name="line.3122"></a>
+<span class="sourceLineNo">3123</span>      @Override<a name="line.3123"></a>
+<span class="sourceLineNo">3124</span>      protected String getDescription() {<a name="line.3124"></a>
+<span class="sourceLineNo">3125</span>        return "DeleteNamespaceProcedure";<a name="line.3125"></a>
+<span class="sourceLineNo">3126</span>      }<a name="line.3126"></a>
+<span class="sourceLineNo">3127</span>    });<a name="line.3127"></a>
+<span class="sourceLineNo">3128</span>  }<a name="line.3128"></a>
+<span class="sourceLineNo">3129</span><a name="line.3129"></a>
+<span class="sourceLineNo">3130</span>  /**<a name="line.3130"></a>
+<span class="sourceLineNo">3131</span>   * Get a Namespace<a name="line.3131"></a>
+<span class="sourceLineNo">3132</span>   * @param name Name of the Namespace<a name="line.3132"></a>
+<span class="sourceLineNo">3133</span>   * @return Namespace descriptor for &lt;code&gt;name&lt;/code&gt;<a name="line.3133"></a>
+<span class="sourceLineNo">3134</span>   */<a name="line.3134"></a>
+<span class="sourceLineNo">3135</span>  NamespaceDescriptor getNamespace(String name) throws IOException {<a name="line.3135"></a>
+<span class="sourceLineNo">3136</span>    checkInitialized();<a name="line.3136"></a>
+<span class="sourceLineNo">3137</span>    if (this.cpHost != null) this.cpHost.preGetNamespaceDescriptor(name);<a name="line.3137"></a>
+<span class="sourceLineNo">3138</span>    NamespaceDescriptor nsd = this.clusterSchemaService.getNamespace(name);<a name="line.3138"></a>
+<span class="sourceLineNo">3139</span>    if (this.cpHost != null) this.cpHost.postGetNamespaceDescriptor(nsd);<a name="line.3139"></a>
+<span class="sourceLineNo">3140</span>    return nsd;<a name="line.3140"></a>
+<span class="sourceLineNo">3141</span>  }<a name="line.3141"></a>
+<span class="sourceLineNo">3142</span><a name="line.3142"></a>
+<span class="sourceLineNo">3143</span>  /**<a name="line.3143"></a>
+<span class="sourceLineNo">3144</span>   * Get all Namespaces<a name="line.3144"></a>
+<span class="sourceLineNo">3145</span>   * @return All Namespace descriptors<a name="line.3145"></a>
+<span class="sourceLineNo">3146</span>   */<a name="line.3146"></a>
+<span class="sourceLineNo">3147</span>  List&lt;NamespaceDescriptor&gt; getNamespaces() throws IOException {<a name="line.3147"></a>
+<span class="sourceLineNo">3148</span>    checkInitialized();<a name="line.3148"></a>
+<span class="sourceLineNo">3149</span>    final List&lt;NamespaceDescriptor&gt; nsds = new ArrayList&lt;&gt;();<a name="line.3149"></a>
+<span class="sourceLineNo">3150</span>    if (cpHost != null) {<a name="line.3150"></a>
+<span class="sourceLineNo">3151</span>      cpHost.preListNamespaceDescriptors(nsds);<a name="line.3151"></a>
 <span class="sourceLineNo">3152</span>    }<a name="line.3152"></a>
-<span class="sourceLineNo">3153</span>    return nsds;<a name="line.3153"></a>
-<span class="sourceLineNo">3154</span>  }<a name="line.3154"></a>
-<span class="sourceLineNo">3155</span><a name="line.3155"></a>
-<span class="sourceLineNo">3156</span>  /**<a name="line.3156"></a>
-<span class="sourceLineNo">3157</span>   * List namespace names<a name="line.3157"></a>
-<span class="sourceLineNo">3158</span>   * @return All namespace names<a name="line.3158"></a>
-<span class="sourceLineNo">3159</span>   */<a name="line.3159"></a>
-<span class="sourceLineNo">3160</span>  public List&lt;String&gt; listNamespaces() throws IOException {<a name="line.3160"></a>
-<span class="sourceLineNo">3161</span>    checkInitialized();<a name="line.3161"></a>
-<span class="sourceLineNo">3162</span>    List&lt;String&gt; namespaces = new ArrayList&lt;&gt;();<a name="line.3162"></a>
-<span class="sourceLineNo">3163</span>    if (cpHost != null) {<a name="line.3163"></a>
-<span class="sourceLineNo">3164</span>      cpHost.preListNamespaces(namespaces);<a name="line.3164"></a>
-<span class="sourceLineNo">3165</span>    }<a name="line.3165"></a>
-<span class="sourceLineNo">3166</span>    for (NamespaceDescriptor namespace : clusterSchemaService.getNamespaces()) {<a name="line.3166"></a>
-<span class="sourceLineNo">3167</span>      namespaces.add(namespace.getName());<a name="line.3167"></a>
-<span class="sourceLineNo">3168</span>    }<a name="line.3168"></a>
-<span class="sourceLineNo">3169</span>    if (cpHost != null) {<a name="line.3169"></a>
-<span class="sourceLineNo">3170</span>      cpHost.postListNamespaces(namespaces);<a name="line.3170"></a>
-<span class="sourceLineNo">3171</span>    }<a name="line.3171"></a>
-<span class="sourceLineNo">3172</span>    return namespaces;<a name="line.3172"></a>
-<span class="sourceLineNo">3173</span>  }<a name="line.3173"></a>
-<span class="sourceLineNo">3174</span><a name="line.3174"></a>
-<span class="sourceLineNo">3175</span>  @Override<a name="line.3175"></a>
-<span class="sourceLineNo">3176</span>  public List&lt;TableName&gt; listTableNamesByNamespace(String name) throws IOException {<a name="line.3176"></a>
-<span class="sourceLineNo">3177</span>    checkInitialized();<a name="line.3177"></a>
-<span class="sourceLineNo">3178</span>    return listTableNames(name, null, true);<a name="line.3178"></a>
-<span class="sourceLineNo">3179</span>  }<a name="line.3179"></a>
-<span class="sourceLineNo">3180</span><a name="line.3180"></a>
-<span class="sourceLineNo">3181</span>  @Override<a name="line.3181"></a>
-<span class="sourceLineNo">3182</span>  public List&lt;TableDescriptor&gt; listTableDescriptorsByNamespace(String name) throws IOException {<a name="line.3182"></a>
-<span class="sourceLineNo">3183</span>    checkInitialized();<a name="line.3183"></a>
-<span class="sourceLineNo">3184</span>    return listTableDescriptors(name, null, null, true);<a name="line.3184"></a>
-<span class="sourceLineNo">3185</span>  }<a name="line.3185"></a>
-<span class="sourceLineNo">3186</span><a name="line.3186"></a>
-<span class="sourceLineNo">3187</span>  @Override<a name="line.3187"></a>
-<span class="sourceLineNo">3188</span>  public boolean abortProcedure(final long procId, final boolean mayInterruptIfRunning)<a name="line.3188"></a>
-<span class="sourceLineNo">3189</span>      throws IOException {<a name="line.3189"></a>
-<span class="sourceLineNo">3190</span>    if (cpHost != null) {<a name="line.3190"></a>
-<span class="sourceLineNo">3191</span>      cpHost.preAbortProcedure(this.procedureExecutor, procId);<a name="line.3191"></a>
-<span class="sourceLineNo">3192</span>    }<a name="line.3192"></a>
-<span class="sourceLineNo">3193</span><a name="line.3193"></a>
-<span class="sourceLineNo">3194</span>    final boolean result = this.procedureExecutor.abort(procId, mayInterruptIfRunning);<a name="line.3194"></a>
-<span class="sourceLineNo">3195</span><a name="line.3195"></a>
-<span class="sourceLineNo">3196</span>    if (cpHost != null) {<a name="line.3196"></a>
-<span class="sourceLineNo">3197</span>      cpHost.postAbortProcedure();<a name="line.3197"></a>
-<span class="sourceLineNo">3198</span>    }<a name="line.3198"></a>
+<span class="sourceLineNo">3153</span>    nsds.addAll(this.clusterSchemaService.getNamespaces());<a name="line.3153"></a>
+<span class="sourceLineNo">3154</span>    if (this.cpHost != null) {<a name="line.3154"></a>
+<span class="sourceLineNo">3155</span>      this.cpHost.postListNamespaceDescriptors(nsds);<a name="line.3155"></a>
+<span class="sourceLineNo">3156</span>    }<a name="line.3156"></a>
+<span class="sourceLineNo">3157</span>    return nsds;<a name="line.3157"></a>
+<span class="sourceLineNo">3158</span>  }<a name="line.3158"></a>
+<span class="sourceLineNo">3159</span><a name="line.3159"></a>
+<span class="sourceLineNo">3160</span>  /**<a name="line.3160"></a>
+<span class="sourceLineNo">3161</span>   * List namespace names<a name="line.3161"></a>
+<span class="sourceLineNo">3162</span>   * @return All namespace names<a name="line.3162"></a>
+<span class="sourceLineNo">3163</span>   */<a name="line.3163"></a>
+<span class="sourceLineNo">3164</span>  public List&lt;String&gt; listNamespaces() throws IOException {<a name="line.3164"></a>
+<span class="sourceLineNo">3165</span>    checkInitialized();<a name="line.3165"></a>
+<span class="sourceLineNo">3166</span>    List&lt;String&gt; namespaces = new ArrayList&lt;&gt;();<a name="line.3166"></a>
+<span class="sourceLineNo">3167</span>    if (cpHost != null) {<a name="line.3167"></a>
+<span class="sourceLineNo">3168</span>      cpHost.preListNamespaces(namespaces);<a name="line.3168"></a>
+<span class="sourceLineNo">3169</span>    }<a name="line.3169"></a>
+<span class="sourceLineNo">3170</span>    for (NamespaceDescriptor namespace : clusterSchemaService.getNamespaces()) {<a name="line.3170"></a>
+<span class="sourceLineNo">3171</span>      namespaces.add(namespace.getName());<a name="line.3171"></a>
+<span class="sourceLineNo">3172</span>    }<a name="line.3172"></a>
+<span class="sourceLineNo">3173</span>    if (cpHost != null) {<a name="line.3173"></a>
+<span class="sourceLineNo">3174</span>      cpHost.postListNamespaces(namespaces);<a name="line.3174"></a>
+<span class="sourceLineNo">3175</span>    }<a name="line.3175"></a>
+<span class="sourceLineNo">3176</span>    return namespaces;<a name="line.3176"></a>
+<span class="sourceLineNo">3177</span>  }<a name="line.3177"></a>
+<span class="sourceLineNo">3178</span><a name="line.3178"></a>
+<span class="sourceLineNo">3179</span>  @Override<a name="line.3179"></a>
+<span class="sourceLineNo">3180</span>  public List&lt;TableName&gt; listTableNamesByNamespace(String name) throws IOException {<a name="line.3180"></a>
+<span class="sourceLineNo">3181</span>    checkInitialized();<a name="line.3181"></a>
+<span class="sourceLineNo">3182</span>    return listTableNames(name, null, true);<a name="line.3182"></a>
+<span class="sourceLineNo">3183</span>  }<a name="line.3183"></a>
+<span class="sourceLineNo">3184</span><a name="line.3184"></a>
+<span class="sourceLineNo">3185</span>  @Override<a name="line.3185"></a>
+<span class="sourceLineNo">3186</span>  public List&lt;TableDescriptor&gt; listTableDescriptorsByNamespace(String name) throws IOException {<a name="line.3186"></a>
+<span class="sourceLineNo">3187</span>    checkInitialized();<a name="line.3187"></a>
+<span class="sourceLineNo">3188</span>    return listTableDescriptors(name, null, null, true);<a name="line.3188"></a>
+<span class="sourceLineNo">3189</span>  }<a name="line.3189"></a>
+<span class="sourceLineNo">3190</span><a name="line.3190"></a>
+<span class="sourceLineNo">3191</span>  @Override<a name="line.3191"></a>
+<span class="sourceLineNo">3192</span>  public boolean abortProcedure(final long procId, final boolean mayInterruptIfRunning)<a name="line.3192"></a>
+<span class="sourceLineNo">3193</span>      throws IOException {<a name="line.3193"></a>
+<span class="sourceLineNo">3194</span>    if (cpHost != null) {<a name="line.3194"></a>
+<span class="sourceLineNo">3195</span>      cpHost.preAbortProcedure(this.procedureExecutor, procId);<a name="line.3195"></a>
+<span class="sourceLineNo">3196</span>    }<a name="line.3196"></a>
+<span class="sourceLineNo">3197</span><a name="line.3197"></a>
+<span class="sourceLineNo">3198</span>    final boolean result = this.procedureExecutor.abort(procId, mayInterruptIfRunning);<a name="line.3198"></a>
 <span class="sourceLineNo">3199</span><a name="line.3199"></a>
-<span class="sourceLineNo">3200</span>    return result;<a name="line.3200"></a>
-<span class="sourceLineNo">3201</span>  }<a name="line.3201"></a>
-<span class="sourceLineNo">3202</span><a name="line.3202"></a>
-<span class="sourceLineNo">3203</span>  @Override<a name="line.3203"></a>
-<span class="sourceLineNo">3204</span>  public List&lt;Procedure&lt;?&gt;&gt; getProcedures() throws IOException {<a name="line.3204"></a>
-<span class="sourceLineNo">3205</span>    if (cpHost != null) {<a name="line.3205"></a>
-<span class="sourceLineNo">3206</span>      cpHost.preGetProcedures();<a name="line.3206"></a>
-<span class="sourceLineNo">3207</span>    }<a name="line.3207"></a>
-<span class="sourceLineNo">3208</span><a name="line.3208"></a>
-<span class="sourceLineNo">3209</span>    @SuppressWarnings({ "unchecked", "rawtypes" })<a name="line.3209"></a>
-<span class="sourceLineNo">3210</span>    List&lt;Procedure&lt;?&gt;&gt; procList = (List) this.procedureExecutor.getProcedures();<a name="line.3210"></a>
-<span class="sourceLineNo">3211</span><a name="line.3211"></a>
-<span class="sourceLineNo">3212</span>    if (cpHost != null) {<a name="line.3212"></a>
-<span class="sourceLineNo">3213</span>      cpHost.postGetProcedures(procList);<a name="line.3213"></a>
-<span class="sourceLineNo">3214</span>    }<a name="line.3214"></a>
+<span class="sourceLineNo">3200</span>    if (cpHost != null) {<a name="line.3200"></a>
+<span class="sourceLineNo">3201</span>      cpHost.postAbortProcedure();<a name="line.3201"></a>
+<span class="sourceLineNo">3202</span>    }<a name="line.3202"></a>
+<span class="sourceLineNo">3203</span><a name="line.3203"></a>
+<span class="sourceLineNo">3204</span>    return result;<a name="line.3204"></a>
+<span class="sourceLineNo">3205</span>  }<a name="line.3205"></a>
+<span class="sourceLineNo">3206</span><a name="line.3206"></a>
+<span class="sourceLineNo">3207</span>  @Override<a name="line.3207"></a>
+<span class="sourceLineNo">3208</span>  public List&lt;Procedure&lt;?&gt;&gt; getProcedures() throws IOException {<a name="line.3208"></a>
+<span class="sourceLineNo">3209</span>    if (cpHost != null) {<a name="line.3209"></a>
+<span class="sourceLineNo">3210</span>      cpHost.preGetProcedures();<a name="line.3210"></a>
+<span class="sourceLineNo">3211</span>    }<a name="line.3211"></a>
+<span class="sourceLineNo">3212</span><a name="line.3212"></a>
+<span class="sourceLineNo">3213</span>    @SuppressWarnings({ "unchecked", "rawtypes" })<a name="line.3213"></a>
+<span class="sourceLineNo">3214</span>    List&lt;Procedure&lt;?&gt;&gt; procList = (List) this.procedureExecutor.getProcedures();<a name="line.3214"></a>
 <span class="sourceLineNo">3215</span><a name="line.3215"></a>
-<span class="sourceLineNo">3216</span>    return procList;<a name="line.3216"></a>
-<span class="sourceLineNo">3217</span>  }<a name="line.3217"></a>
-<span class="sourceLineNo">3218</span><a name="line.3218"></a>
-<span class="sourceLineNo">3219</span>  @Override<a name="line.3219"></a>
-<span class="sourceLineNo">3220</span>  public List&lt;LockedResource&gt; getLocks() throws IOException {<a name="line.3220"></a>
-<span class="sourceLineNo">3221</span>    if (cpHost != null) {<a name="line.3221"></a>
-<span class="sourceLineNo">3222</span>      cpHost.preGetLocks();<a name="line.3222"></a>
-<span class="sourceLineNo">3223</span>    }<a name="line.3223"></a>
-<span class="sourceLineNo">3224</span><a name="line.3224"></a>
-<span class="sourceLineNo">3225</span>    MasterProcedureScheduler procedureScheduler =<a name="line.3225"></a>
-<span class="sourceLineNo">3226</span>      procedureExecutor.getEnvironment().getProcedureScheduler();<a name="line.3226"></a>
-<span class="sourceLineNo">3227</span><a name="line.3227"></a>
-<span class="sourceLineNo">3228</span>    final List&lt;LockedResource&gt; lockedResources = procedureScheduler.getLocks();<a name="line.3228"></a>
-<span class="sourceLineNo">3229</span><a name="line.3229"></a>
-<span class="sourceLineNo">3230</span>    if (cpHost != null) {<a name="line.3230"></a>
-<span class="sourceLineNo">3231</span>      cpHost.postGetLocks(lockedResources);<a name="line.3231"></a>
-<span class="sourceLineNo">3232</span>    }<a name="line.3232"></a>
+<span class="sourceLineNo">3216</span>    if (cpHost != null) {<a name="line.3216"></a>
+<span class="sourceLineNo">3217</span>      cpHost.postGetProcedures(procList);<a name="line.3217"></a>
+<span class="sourceLineNo">3218</span>    }<a name="line.3218"></a>
+<span class="sourceLineNo">3219</span><a name="line.3219"></a>
+<span class="sourceLineNo">3220</span>    return procList;<a name="line.3220"></a>
+<span class="sourceLineNo">3221</span>  }<a name="line.3221"></a>
+<span class="sourceLineNo">3222</span><a name="line.3222"></a>
+<span class="sourceLineNo">3223</span>  @Override<a name="line.3223"></a>
+<span class="sourceLineNo">3224</span>  public List&lt;LockedResource&gt; getLocks() throws IOException {<a name="line.3224"></a>
+<span class="sourceLineNo">3225</span>    if (cpHost != null) {<a name="line.3225"></a>
+<span class="sourceLineNo">3226</span>      cpHost.preGetLocks();<a name="line.3226"></a>
+<span class="sourceLineNo">3227</span>    }<a name="line.3227"></a>
+<span class="sourceLineNo">3228</span><a name="line.3228"></a>
+<span class="sourceLineNo">3229</span>    MasterProcedureScheduler procedureScheduler =<a name="line.3229"></a>
+<span class="sourceLineNo">3230</span>      procedureExecutor.getEnvironment().getProcedureScheduler();<a name="line.3230"></a>
+<span class="sourceLineNo">3231</span><a name="line.3231"></a>
+<span class="sourceLineNo">3232</span>    final List&lt;LockedResource&gt; lockedResources = procedureScheduler.getLocks();<a name="line.3232"></a>
 <span class="sourceLineNo">3233</span><a name="line.3233"></a>
-<span class="sourceLineNo">3234</span>    return lockedResources;<a name="line.3234"></a>
-<span class="sourceLineNo">3235</span>  }<a name="line.3235"></a>
-<span class="sourceLineNo">3236</span><a name="line.3236"></a>
-<span class="sourceLineNo">3237</span>  /**<a name="line.3237"></a>
-<span class="sourceLineNo">3238</span>   * Returns the list of table descriptors that match the specified request<a name="line.3238"></a>
-<span class="sourceLineNo">3239</span>   * @param namespace the namespace to query, or null if querying for all<a name="line.3239"></a>
-<span class="sourceLineNo">3240</span>   * @param regex The regular expression to match against, or null if querying for all<a name="line.3240"></a>
-<span class="sourceLineNo">3241</span>   * @param tableNameList the list of table names, or null if querying for all<a name="line.3241"></a>
-<span class="sourceLineNo">3242</span>   * @param includeSysTables False to match only against userspace tables<a name="line.3242"></a>
-<span class="sourceLineNo">3243</span>   * @return the list of table descriptors<a name="line.3243"></a>
-<span class="sourceLineNo">3244</span>   */<a name="line.3244"></a>
-<span class="sourceLineNo">3245</span>  public List&lt;TableDescriptor&gt; listTableDescriptors(final String namespace, final String regex,<a name="line.3245"></a>
-<span class="sourceLineNo">3246</span>      final List&lt;TableName&gt; tableNameList, final boolean includeSysTables)<a name="line.3246"></a>
-<span class="sourceLineNo">3247</span>  throws IOException {<a name="line.3247"></a>
-<span class="sourceLineNo">3248</span>    List&lt;TableDescriptor&gt; htds = new ArrayList&lt;&gt;();<a name="line.3248"></a>
-<span class="sourceLineNo">3249</span>    if (cpHost != null) {<a name="line.3249"></a>
-<span class="sourceLineNo">3250</span>      cpHost.preGetTableDescriptors(tableNameList, htds, regex);<a name="line.3250"></a>
-<span class="sourceLineNo">3251</span>    }<a name="line.3251"></a>
-<span class="sourceLineNo">3252</span>    htds = getTableDescriptors(htds, namespace, regex, tableNameList, includeSysTables);<a name="line.3252"></a>
+<span class="sourceLineNo">3234</span>    if (cpHost != null) {<a name="line.3234"></a>
+<span class="sourceLineNo">3235</span>      cpHost.postGetLocks(lockedResources);<a name="line.3235"></a>
+<span class="sourceLineNo">3236</span>    }<a name="line.3236"></a>
+<span class="sourceLineNo">3237</span><a name="line.3237"></a>
+<span class="sourceLineNo">3238</span>    return lockedResources;<a name="line.3238"></a>
+<span class="sourceLineNo">3239</span>  }<a name="line.3239"></a>
+<span class="sourceLineNo">3240</span><a name="line.3240"></a>
+<span class="sourceLineNo">3241</span>  /**<a name="line.3241"></a>
+<span class="sourceLineNo">3242</span>   * Returns the list of table descriptors that match the specified request<a name="line.3242"></a>
+<span class="sourceLineNo">3243</span>   * @param namespace the namespace to query, or null if querying for all<a name="line.3243"></a>
+<span class="sourceLineNo">3244</span>   * @param regex The regular expression to match against, or null if querying for all<a name="line.3244"></a>
+<span class="sourceLineNo">3245</span>   * @param tableNameList the list of table names, or null if querying for all<a name="line.3245"></a>
+<span class="sourceLineNo">3246</span>   * @param includeSysTables False to match only against userspace tables<a name="line.3246"></a>
+<span class="sourceLineNo">3247</span>   * @return the list of table descriptors<a name="line.3247"></a>
+<span class="sourceLineNo">3248</span>   */<a name="line.3248"></a>
+<span class="sourceLineNo">3249</span>  public List&lt;TableDescriptor&gt; listTableDescriptors(final String namespace, final String regex,<a name="line.3249"></a>
+<span class="sourceLineNo">3250</span>      final List&lt;TableName&gt; tableNameList, final boolean includeSysTables)<a name="line.3250"></a>
+<span class="sourceLineNo">3251</span>  throws IOException {<a name="line.3251"></a>
+<span class="sourceLineNo">3252</span>    List&lt;TableDescriptor&gt; htds = new ArrayList&lt;&gt;();<a name="line.3252"></a>
 <span class="sourceLineNo">3253</span>    if (cpHost != null) {<a name="line.3253"></a>
-<span class="sourceLineNo">3254</span>      cpHost.postGetTableDescriptors(tableNameList, htds, regex);<a name="line.3254"></a>
+<span class="sourceLineNo">3254</span>      cpHost.preGetTableDescriptors(tableNameList, htds, regex);<a name="line.3254"></a>
 <span class="sourceLineNo">3255</span>    }<a name="line.3255"></a>
-<span class="sourceLineNo">3256</span>    return htds;<a name="line.3256"></a>
-<span class="sourceLineNo">3257</span>  }<a name="line.3257"></a>
-<span class="sourceLineNo">3258</span><a name="line.3258"></a>
-<span class="sourceLineNo">3259</span>  /**<a name="line.3259"></a>
-<span class="sourceLineNo">3260</span>   * Returns the list of table names that match the specified request<a name="line.3260"></a>
-<span class="sourceLineNo">3261</span>   * @param regex The regular expression to match against, or null if querying for all<a name="line.3261"></a>
-<span class="sourceLineNo">3262</span>   * @param namespace the namespace to query, or null if querying for all<a name="line.3262"></a>
-<span class="sourceLineNo">3263</span>   * @param includeSysTables False to match only against userspace tables<a name="line.3263"></a>
-<span class="sourceLineNo">3264</span>   * @return the list of table names<a name="line.3264"></a>
-<span class="sourceLineNo">3265</span>   */<a name="line.3265"></a>
-<span class="sourceLineNo">3266</span>  public List&lt;TableName&gt; listTableNames(final String namespace, final String regex,<a name="line.3266"></a>
-<span class="sourceLineNo">3267</span>      final boolean includeSysTables) throws IOException {<a name="line.3267"></a>
-<span class="sourceLineNo">3268</span>    List&lt;TableDescriptor&gt; htds = new ArrayList&lt;&gt;();<a name="line.3268"></a>
-<span class="sourceLineNo">3269</span>    if (cpHost != null) {<a name="line.3269"></a>
-<span class="sourceLineNo">3270</span>      cpHost.preGetTableNames(htds, regex);<a name="line.3270"></a>
-<span class="sourceLineNo">3271</span>    }<a name="line.3271"></a>
-<span class="sourceLineNo">3272</span>    htds = getTableDescriptors(htds, namespace, regex, null, includeSysTables);<a name="line.3272"></a>
+<span class="sourceLineNo">3256</span>    htds = getTableDescriptors(htds, namespace, regex, tableNameList, includeSysTables);<a name="line.3256"></a>
+<span class="sourceLineNo">3257</span>    if (cpHost != null) {<a name="line.3257"></a>
+<span class="sourceLineNo">3258</span>      cpHost.postGetTableDescriptors(tableNameList, htds, regex);<a name="line.3258"></a>
+<span class="sourceLineNo">3259</span>    }<a name="line.3259"></a>
+<span class="sourceLineNo">3260</span>    return htds;<a name="line.3260"></a>
+<span class="sourceLineNo">3261</span>  }<a name="line.3261"></a>
+<span class="sourceLineNo">3262</span><a name="line.3262"></a>
+<span class="sourceLineNo">3263</span>  /**<a name="line.3263"></a>
+<span class="sourceLineNo">3264</span>   * Returns the list of table names that match the specified request<a name="line.3264"></a>
+<span class="sourceLineNo">3265</span>   * @param regex The regular expression to match against, or null if querying for all<a name="line.3265"></a>
+<span class="sourceLineNo">3266</span>   * @param namespace the namespace to query, or null if querying for all<a name="line.3266"></a>
+<span class="sourceLineNo">3267</span>   * @param includeSysTables False to match only against userspace tables<a name="line.3267"></a>
+<span class="sourceLineNo">3268</span>   * @return the list of table names<a name="line.3268"></a>
+<span class="sourceLineNo">3269</span>   */<a name="line.3269"></a>
+<span class="sourceLineNo">3270</span>  public List&lt;TableName&gt; listTableNames(final String namespace, final String regex,<a name="line.3270"></a>
+<span class="sourceLineNo">3271</span>      final boolean includeSysTables) throws IOException {<a name="line.3271"></a>
+<span class="sourceLineNo">3272</span>    List&lt;TableDescriptor&gt; htds = new ArrayList&lt;&gt;();<a name="line.3272"></a>
 <span class="sourceLineNo">3273</span>    if (cpHost != null) {<a name="line.3273"></a>
-<span class="sourceLineNo">3274</span>      cpHost.postGetTableNames(htds, regex);<a name="line.3274"></a>
+<span class="sourceLineNo">3274</span>      cpHost.preGetTableNames(htds, regex);<a name="line.3274"></a>
 <span class="sourceLineNo">3275</span>    }<a name="line.3275"></a>
-<span class="sourceLineNo">3276</span>    List&lt;TableName&gt; result = new ArrayList&lt;&gt;(htds.size());<a name="line.3276"></a>
-<span class="sourceLineNo">3277</span>    for (TableDescriptor htd: htds) result.add(htd.getTableName());<a name="line.3277"></a>
-<span class="sourceLineNo">3278</span>    return result;<a name="line.3278"></a>
-<span class="sourceLineNo">3279</span>  }<a name="line.3279"></a>
-<span class="sourceLineNo">3280</span><a name="line.3280"></a>
-<span class="sourceLineNo">3281</span>  /**<a name="line.3281"></a>
-<span class="sourceLineNo">3282</span>   * Return a list of table table descriptors after applying any provided filter parameters. Note<a name="line.3282"></a>
-<span class="sourceLineNo">3283</span>   * that the user-facing description of this filter logic is presented on the class-level javadoc<a name="line.3283"></a>
-<span class="sourceLineNo">3284</span>   * of {@link NormalizeTableFilterParams}.<a name="line.3284"></a>
-<span class="sourceLineNo">3285</span>   */<a name="line.3285"></a>
-<span class="sourceLineNo">3286</span>  private List&lt;TableDescriptor&gt; getTableDescriptors(final List&lt;TableDescriptor&gt; htds,<a name="line.3286"></a>
-<span class="sourceLineNo">3287</span>      final String namespace, final String regex, final List&lt;TableName&gt; tableNameList,<a name="line.3287"></a>
-<span class="sourceLineNo">3288</span>      final boolean includeSysTables)<a name="line.3288"></a>
-<span class="sourceLineNo">3289</span>  throws IOException {<a name="line.3289"></a>
-<span class="sourceLineNo">3290</span>    if (tableNameList == null || tableNameList.isEmpty()) {<a name="line.3290"></a>
-<span class="sourceLineNo">3291</span>      // request for all TableDescriptors<a name="line.3291"></a>
-<span class="sourceLineNo">3292</span>      Collection&lt;TableDescriptor&gt; allHtds;<a name="line.3292"></a>
-<span class="sourceLineNo">3293</span>      if (namespace != null &amp;&amp; namespace.length() &gt; 0) {<a name="line.3293"></a>
-<span class="sourceLineNo">3294</span>        // Do a check on the namespace existence. Will fail if does not exist.<a name="line.3294"></a>
-<span class="sourceLineNo">3295</span>        this.clusterSchemaService.getNamespace(namespace);<a name="line.3295"></a>
-<span class="sourceLineNo">3296</span>        allHtds = tableDescriptors.getByNamespace(namespace).values();<a name="line.3296"></a>
-<span class="sourceLineNo">3297</span>      } else {<a name="line.3297"></a>
-<span class="sourceLineNo">3298</span>        allHtds = tableDescriptors.getAll().values();<a name="line.3298"></a>
-<span class="sourceLineNo">3299</span>      }<a name="line.3299"></a>
-<span class="sourceLineNo">3300</span>      for (TableDescriptor desc: allHtds) {<a name="line.3300"></a>
-<span class="sourceLineNo">3301</span>        if (tableStateManager.isTablePresent(desc.getTableName())<a name="line.3301"></a>
-<span class="sourceLineNo">3302</span>            &amp;&amp; (includeSysTables || !desc.getTableName().isSystemTable())) {<a name="line.3302"></a>
-<span class="sourceLineNo">3303</span>          htds.add(desc);<a name="line.3303"></a>
-<span class="sourceLineNo">3304</span>        }<a name="line.3304"></a>
-<span class="sourceLineNo">3305</span>      }<a name="line.3305"></a>
-<span class="sourceLineNo">3306</span>    } else {<a name="line.3306"></a>
-<span class="sourceLineNo">3307</span>      for (TableName s: tableNameList) {<a name="line.3307"></a>
-<span class="sourceLineNo">3308</span>        if (tableStateManager.isTablePresent(s)) {<a name="line.3308"></a>
-<span class="sourceLineNo">3309</span>          TableDescriptor desc = tableDescriptors.get(s);<a name="line.3309"></a>
-<span class="sourceLineNo">3310</span>          if (desc != null) {<a name="line.3310"></a>
-<span class="sourceLineNo">3311</span>            htds.add(desc);<a name="line.3311"></a>
-<span class="sourceLineNo">3312</span>          }<a name="line.3312"></a>
-<span class="sourceLineNo">3313</span>        }<a name="line.3313"></a>
-<span class="sourceLineNo">3314</span>      }<a name="line.3314"></a>
-<span class="sourceLineNo">3315</span>    }<a name="line.3315"></a>
-<span class="sourceLineNo">3316</span><a name="line.3316"></a>
-<span class="sourceLineNo">3317</span>    // Retains only those matched by regular expression.<a name="line.3317"></a>
-<span class="sourceLineNo">3318</span>    if (regex != null) filterTablesByRegex(htds, Pattern.compile(regex));<a name="line.3318"></a>
-<span class="sourceLineNo">3319</span>    return htds;<a name="line.3319"></a>
-<span class="sourceLineNo">3320</span>  }<a name="line.3320"></a>
-<span class="sourceLineNo">3321</span><a name="line.3321"></a>
-<span class="sourceLineNo">3322</span>  /**<a name="line.3322"></a>
-<span class="sourceLineNo">3323</span>   * Removes the table descriptors that don't match the pattern.<a name="line.3323"></a>
-<span class="sourceLineNo">3324</span>   * @param descriptors list of table descriptors to filter<a name="line.3324"></a>
-<span class="sourceLineNo">3325</span>   * @param pattern the regex to use<a name="line.3325"></a>
-<span class="sourceLineNo">3326</span>   */<a name="line.3326"></a>
-<span class="sourceLineNo">3327</span>  private static void filterTablesByRegex(final Collection&lt;TableDescriptor&gt; descriptors,<a name="line.3327"></a>
-<span class="sourceLineNo">3328</span>      final Pattern pattern) {<a name="line.3328"></a>
-<span class="sourceLineNo">3329</span>    final String defaultNS = NamespaceDescriptor.DEFAULT_NAMESPACE_NAME_STR;<a name="line.3329"></a>
-<span class="sourceLineNo">3330</span>    Iterator&lt;TableDescriptor&gt; itr = descriptors.iterator();<a name="line.3330"></a>
-<span class="sourceLineNo">3331</span>    while (itr.hasNext()) {<a name="line.3331"></a>
-<span class="sourceLineNo">3332</span>      TableDescriptor htd = itr.next();<a name="line.3332"></a>
-<span class="sourceLineNo">3333</span>      String tableName = htd.getTableName().getNameAsString();<a name="line.3333"></a>
-<span class="sourceLineNo">3334</span>      boolean matched = pattern.matcher(tableName).matches();<a name="line.3334"></a>
-<span class="sourceLineNo">3335</span>      if (!matched &amp;&amp; htd.getTableName().getNamespaceAsString().equals(defaultNS)) {<a name="line.3335"></a>
-<span class="sourceLineNo">3336</span>        matched = pattern.matcher(defaultNS + TableName.NAMESPACE_DELIM + tableName).matches();<a name="line.3336"></a>
-<span class="sourceLineNo">3337</span>      }<a name="line.3337"></a>
-<span class="sourceLineNo">3338</span>      if (!matched) {<a name="line.3338"></a>
-<span class="sourceLineNo">3339</span>        itr.remove();<a name="line.3339"></a>
-<span class="sourceLineNo">3340</span>      }<a name="line.3340"></a>
-<span class="sourceLineNo">3341</span>    }<a name="line.3341"></a>
-<span class="sourceLineNo">3342</span>  }<a name="line.3342"></a>
-<span class="sourceLineNo">3343</span><a name="line.3343"></a>
-<span class="sourceLineNo">3344</span>  @Override<a name="line.3344"></a>
-<span class="sourceLineNo">3345</span>  public long getLastMajorCompactionTimestamp(TableName table) throws IOException {<a name="line.3345"></a>
-<span class="sourceLineNo">3346</span>    return getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.3346"></a>
-<span class="sourceLineNo">3347</span>        .getLastMajorCompactionTimestamp(table);<a name="line.3347"></a>
-<span class="sourceLineNo">3348</span>  }<a name="line.3348"></a>
-<span class="sourceLineNo">3349</span><a name="line.3349"></a>
-<span class="sourceLineNo">3350</span>  @Override<a name="line.3350"></a>
-<span class="sourceLineNo">3351</span>  public long getLastMajorCompactionTimestampForRegion(byte[] regionName) throws IOException {<a name="line.3351"></a>
-<span class="sourceLineNo">3352</span>    return getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.3352"></a>
-<span class="sourceLineNo">3353</span>        .getLastMajorCompactionTimestamp(regionName);<a name="line.3353"></a>
-<span class="sourceLineNo">3354</span>  }<a name="line.3354"></a>
-<span class="sourceLineNo">3355</span><a name="line.3355"></a>
-<span class="sourceLineNo">3356</span>  /**<a name="line.3356"></a>
-<span class="sourceLineNo">3357</span>   * Gets the mob file compaction state for a specific table.<a name="line.3357"></a>
-<span class="sourceLineNo">3358</span>   * Whether all the mob files are selected is known during the compaction execution, but<a name="line.3358"></a>
-<span class="sourceLineNo">3359</span>   * the statistic is done just before compaction starts, it is hard to know the compaction<a name="line.3359"></a>
-<span class="sourceLineNo">3360</span>   * type at that time, so the rough statistics are chosen for the mob file compaction. Only two<a name="line.3360"></a>
-<span class="sourceLineNo">3361</span>   * compaction states are available, CompactionState.MAJOR_AND_MINOR and CompactionState.NONE.<a name="line.3361"></a>
-<span class="sourceLineNo">3362</span>   * @param tableName The current table name.<a name="line.3362"></a>
-<span class="sourceLineNo">3363</span>   * @return If a given table is in mob file compaction now.<a name="line.3363"></a>
-<span class="sourceLineNo">3364</span>   */<a name="line.3364"></a>
-<span class="sourceLineNo">3365</span>  public GetRegionInfoResponse.CompactionState getMobCompactionState(TableName tableName) {<a name="line.3365"></a>
-<span class="sourceLineNo">3366</span>    AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3366"></a>
-<span class="sourceLineNo">3367</span>    if (compactionsCount != null &amp;&amp; compactionsCount.get() != 0) {<a name="line.3367"></a>
-<span class="sourceLineNo">3368</span>      return GetRegionInfoResponse.CompactionState.MAJOR_AND_MINOR;<a name="line.3368"></a>
-<span class="sourceLineNo">3369</span>    }<a name="line.3369"></a>
-<span class="sourceLineNo">3370</span>    return GetRegionInfoResponse.CompactionState.NONE;<a name="line.3370"></a>
-<span class="sourceLineNo">3371</span>  }<a name="line.3371"></a>
-<span class="sourceLineNo">3372</span><a name="line.3372"></a>
-<span class="sourceLineNo">3373</span>  public void reportMobCompactionStart(TableName tableName) throws IOException {<a name="line.3373"></a>
-<span class="sourceLineNo">3374</span>    IdLock.Entry lockEntry = null;<a name="line.3374"></a>
-<span class="sourceLineNo">3375</span>    try {<a name="line.3375"></a>
-<span class="sourceLineNo">3376</span>      lockEntry = mobCompactionLock.getLockEntry(tableName.hashCode());<a name="line.3376"></a>
-<span class="sourceLineNo">3377</span>      AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3377"></a>
-<span class="sourceLineNo">3378</span>      if (compactionsCount == null) {<a name="line.3378"></a>
-<span class="sourceLineNo">3379</span>        compactionsCount = new AtomicInteger(0);<a name="line.3379"></a>
-<span class="sourceLineNo">3380</span>        mobCompactionStates.put(tableName, compactionsCount);<a name="line.3380"></a>
-<span class="sourceLineNo">3381</span>      }<a name="line.3381"></a>
-<span class="sourceLineNo">3382</span>      compactionsCount.incrementAndGet();<a name="line.3382"></a>
-<span class="sourceLineNo">3383</span>    } finally {<a name="line.3383"></a>
-<span class="sourceLineNo">3384</span>      if (lockEntry != null) {<a name="line.3384"></a>
-<span class="sourceLineNo">3385</span>        mobCompactionLock.releaseLockEntry(lockEntry);<a name="line.3385"></a>
-<span class="sourceLineNo">3386</span>      }<a name="line.3386"></a>
-<span class="sourceLineNo">3387</span>    }<a name="line.3387"></a>
-<span class="sourceLineNo">3388</span>  }<a name="line.3388"></a>
-<span class="sourceLineNo">3389</span><a name="line.3389"></a>
-<span class="sourceLineNo">3390</span>  public void reportMobCompactionEnd(TableName tableName) throws IOException {<a name="line.3390"></a>
-<span class="sourceLineNo">3391</span>    IdLock.Entry lockEntry = null;<a name="line.3391"></a>
-<span class="sourceLineNo">3392</span>    try {<a name="line.3392"></a>
-<span class="sourceLineNo">3393</span>      lockEntry = mobCompactionLock.getLockEntry(tableName.hashCode());<a name="line.3393"></a>
-<span class="sourceLineNo">3394</span>      AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3394"></a>
-<span class="sourceLineNo">3395</span>      if (compactionsCount != null) {<a name="line.3395"></a>
-<span class="sourceLineNo">3396</span>        int count = compactionsCount.decrementAndGet();<a name="line.3396"></a>
-<span class="sourceLineNo">3397</span>        // remove the entry if the count is 0.<a name="line.3397"></a>
-<span class="sourceLineNo">3398</span>        if (count == 0) {<a name="line.3398"></a>
-<span class="sourceLineNo">3399</span>          mobCompactionStates.remove(tableName);<a name="line.3399"></a>
-<span class="sourceLineNo">3400</span>        }<a name="line.3400"></a>
-<span class="sourceLineNo">3401</span>      }<a name="line.3401"></a>
-<span class="sourceLineNo">3402</span>    } finally {<a name="line.3402"></a>
-<span class="sourceLineNo">3403</span>      if (lockEntry != null) {<a name="line.3403"></a>
-<span class="sourceLineNo">3404</span>        mobCompactionLock.releaseLockEntry(lockEntry);<a name="line.3404"></a>
+<span class="sourceLineNo">3276</span>    htds = getTableDescriptors(htds, namespace, regex, null, includeSysTables);<a name="line.3276"></a>
+<span class="sourceLineNo">3277</span>    if (cpHost != null) {<a name="line.3277"></a>
+<span class="sourceLineNo">3278</span>      cpHost.postGetTableNames(htds, regex);<a name="line.3278"></a>
+<span class="sourceLineNo">3279</span>    }<a name="line.3279"></a>
+<span class="sourceLineNo">3280</span>    List&lt;TableName&gt; result = new ArrayList&lt;&gt;(htds.size());<a name="line.3280"></a>
+<span class="sourceLineNo">3281</span>    for (TableDescriptor htd: htds) result.add(htd.getTableName());<a name="line.3281"></a>
+<span class="sourceLineNo">3282</span>    return result;<a name="line.3282"></a>
+<span class="sourceLineNo">3283</span>  }<a name="line.3283"></a>
+<span class="sourceLineNo">3284</span><a name="line.3284"></a>
+<span class="sourceLineNo">3285</span>  /**<a name="line.3285"></a>
+<span class="sourceLineNo">3286</span>   * Return a list of table table descriptors after applying any provided filter parameters. Note<a name="line.3286"></a>
+<span class="sourceLineNo">3287</span>   * that the user-facing description of this filter logic is presented on the class-level javadoc<a name="line.3287"></a>
+<span class="sourceLineNo">3288</span>   * of {@link NormalizeTableFilterParams}.<a name="line.3288"></a>
+<span class="sourceLineNo">3289</span>   */<a name="line.3289"></a>
+<span class="sourceLineNo">3290</span>  private List&lt;TableDescriptor&gt; getTableDescriptors(final List&lt;TableDescriptor&gt; htds,<a name="line.3290"></a>
+<span class="sourceLineNo">3291</span>      final String namespace, final String regex, final List&lt;TableName&gt; tableNameList,<a name="line.3291"></a>
+<span class="sourceLineNo">3292</span>      final boolean includeSysTables)<a name="line.3292"></a>
+<span class="sourceLineNo">3293</span>  throws IOException {<a name="line.3293"></a>
+<span class="sourceLineNo">3294</span>    if (tableNameList == null || tableNameList.isEmpty()) {<a name="line.3294"></a>
+<span class="sourceLineNo">3295</span>      // request for all TableDescriptors<a name="line.3295"></a>
+<span class="sourceLineNo">3296</span>      Collection&lt;TableDescriptor&gt; allHtds;<a name="line.3296"></a>
+<span class="sourceLineNo">3297</span>      if (namespace != null &amp;&amp; namespace.length() &gt; 0) {<a name="line.3297"></a>
+<span class="sourceLineNo">3298</span>        // Do a check on the namespace existence. Will fail if does not exist.<a name="line.3298"></a>
+<span class="sourceLineNo">3299</span>        this.clusterSchemaService.getNamespace(namespace);<a name="line.3299"></a>
+<span class="sourceLineNo">3300</span>        allHtds = tableDescriptors.getByNamespace(namespace).values();<a name="line.3300"></a>
+<span class="sourceLineNo">3301</span>      } else {<a name="line.3301"></a>
+<span class="sourceLineNo">3302</span>        allHtds = tableDescriptors.getAll().values();<a name="line.3302"></a>
+<span class="sourceLineNo">3303</span>      }<a name="line.3303"></a>
+<span class="sourceLineNo">3304</span>      for (TableDescriptor desc: allHtds) {<a name="line.3304"></a>
+<span class="sourceLineNo">3305</span>        if (tableStateManager.isTablePresent(desc.getTableName())<a name="line.3305"></a>
+<span class="sourceLineNo">3306</span>            &amp;&amp; (includeSysTables || !desc.getTableName().isSystemTable())) {<a name="line.3306"></a>
+<span class="sourceLineNo">3307</span>          htds.add(desc);<a name="line.3307"></a>
+<span class="sourceLineNo">3308</span>        }<a name="line.3308"></a>
+<span class="sourceLineNo">3309</span>      }<a name="line.3309"></a>
+<span class="sourceLineNo">3310</span>    } else {<a name="line.3310"></a>
+<span class="sourceLineNo">3311</span>      for (TableName s: tableNameList) {<a name="line.3311"></a>
+<span class="sourceLineNo">3312</span>        if (tableStateManager.isTablePresent(s)) {<a name="line.3312"></a>
+<span class="sourceLineNo">3313</span>          TableDescriptor desc = tableDescriptors.get(s);<a name="line.3313"></a>
+<span class="sourceLineNo">3314</span>          if (desc != null) {<a name="line.3314"></a>
+<span class="sourceLineNo">3315</span>            htds.add(desc);<a name="line.3315"></a>
+<span class="sourceLineNo">3316</span>          }<a name="line.3316"></a>
+<span class="sourceLineNo">3317</span>        }<a name="line.3317"></a>
+<span class="sourceLineNo">3318</span>      }<a name="line.3318"></a>
+<span class="sourceLineNo">3319</span>    }<a name="line.3319"></a>
+<span class="sourceLineNo">3320</span><a name="line.3320"></a>
+<span class="sourceLineNo">3321</span>    // Retains only those matched by regular expression.<a name="line.3321"></a>
+<span class="sourceLineNo">3322</span>    if (regex != null) filterTablesByRegex(htds, Pattern.compile(regex));<a name="line.3322"></a>
+<span class="sourceLineNo">3323</span>    return htds;<a name="line.3323"></a>
+<span class="sourceLineNo">3324</span>  }<a name="line.3324"></a>
+<span class="sourceLineNo">3325</span><a name="line.3325"></a>
+<span class="sourceLineNo">3326</span>  /**<a name="line.3326"></a>
+<span class="sourceLineNo">3327</span>   * Removes the table descriptors that don't match the pattern.<a name="line.3327"></a>
+<span class="sourceLineNo">3328</span>   * @param descriptors list of table descriptors to filter<a name="line.3328"></a>
+<span class="sourceLineNo">3329</span>   * @param pattern the regex to use<a name="line.3329"></a>
+<span class="sourceLineNo">3330</span>   */<a name="line.3330"></a>
+<span class="sourceLineNo">3331</span>  private static void filterTablesByRegex(final Collection&lt;TableDescriptor&gt; descriptors,<a name="line.3331"></a>
+<span class="sourceLineNo">3332</span>      final Pattern pattern) {<a name="line.3332"></a>
+<span class="sourceLineNo">3333</span>    final String defaultNS = NamespaceDescriptor.DEFAULT_NAMESPACE_NAME_STR;<a name="line.3333"></a>
+<span class="sourceLineNo">3334</span>    Iterator&lt;TableDescriptor&gt; itr = descriptors.iterator();<a name="line.3334"></a>
+<span class="sourceLineNo">3335</span>    while (itr.hasNext()) {<a name="line.3335"></a>
+<span class="sourceLineNo">3336</span>      TableDescriptor htd = itr.next();<a name="line.3336"></a>
+<span class="sourceLineNo">3337</span>      String tableName = htd.getTableName().getNameAsString();<a name="line.3337"></a>
+<span class="sourceLineNo">3338</span>      boolean matched = pattern.matcher(tableName).matches();<a name="line.3338"></a>
+<span class="sourceLineNo">3339</span>      if (!matched &amp;&amp; htd.getTableName().getNamespaceAsString().equals(defaultNS)) {<a name="line.3339"></a>
+<span class="sourceLineNo">3340</span>        matched = pattern.matcher(defaultNS + TableName.NAMESPACE_DELIM + tableName).matches();<a name="line.3340"></a>
+<span class="sourceLineNo">3341</span>      }<a name="line.3341"></a>
+<span class="sourceLineNo">3342</span>      if (!matched) {<a name="line.3342"></a>
+<span class="sourceLineNo">3343</span>        itr.remove();<a name="line.3343"></a>
+<span class="sourceLineNo">3344</span>      }<a name="line.3344"></a>
+<span class="sourceLineNo">3345</span>    }<a name="line.3345"></a>
+<span class="sourceLineNo">3346</span>  }<a name="line.3346"></a>
+<span class="sourceLineNo">3347</span><a name="line.3347"></a>
+<span class="sourceLineNo">3348</span>  @Override<a name="line.3348"></a>
+<span class="sourceLineNo">3349</span>  public long getLastMajorCompactionTimestamp(TableName table) throws IOException {<a name="line.3349"></a>
+<span class="sourceLineNo">3350</span>    return getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.3350"></a>
+<span class="sourceLineNo">3351</span>        .getLastMajorCompactionTimestamp(table);<a name="line.3351"></a>
+<span class="sourceLineNo">3352</span>  }<a name="line.3352"></a>
+<span class="sourceLineNo">3353</span><a name="line.3353"></a>
+<span class="sourceLineNo">3354</span>  @Override<a name="line.3354"></a>
+<span class="sourceLineNo">3355</span>  public long getLastMajorCompactionTimestampForRegion(byte[] regionName) throws IOException {<a name="line.3355"></a>
+<span class="sourceLineNo">3356</span>    return getClusterMetrics(EnumSet.of(Option.LIVE_SERVERS))<a name="line.3356"></a>
+<span class="sourceLineNo">3357</span>        .getLastMajorCompactionTimestamp(regionName);<a name="line.3357"></a>
+<span class="sourceLineNo">3358</span>  }<a name="line.3358"></a>
+<span class="sourceLineNo">3359</span><a name="line.3359"></a>
+<span class="sourceLineNo">3360</span>  /**<a name="line.3360"></a>
+<span class="sourceLineNo">3361</span>   * Gets the mob file compaction state for a specific table.<a name="line.3361"></a>
+<span class="sourceLineNo">3362</span>   * Whether all the mob files are selected is known during the compaction execution, but<a name="line.3362"></a>
+<span class="sourceLineNo">3363</span>   * the statistic is done just before compaction starts, it is hard to know the compaction<a name="line.3363"></a>
+<span class="sourceLineNo">3364</span>   * type at that time, so the rough statistics are chosen for the mob file compaction. Only two<a name="line.3364"></a>
+<span class="sourceLineNo">3365</span>   * compaction states are available, CompactionState.MAJOR_AND_MINOR and CompactionState.NONE.<a name="line.3365"></a>
+<span class="sourceLineNo">3366</span>   * @param tableName The current table name.<a name="line.3366"></a>
+<span class="sourceLineNo">3367</span>   * @return If a given table is in mob file compaction now.<a name="line.3367"></a>
+<span class="sourceLineNo">3368</span>   */<a name="line.3368"></a>
+<span class="sourceLineNo">3369</span>  public GetRegionInfoResponse.CompactionState getMobCompactionState(TableName tableName) {<a name="line.3369"></a>
+<span class="sourceLineNo">3370</span>    AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3370"></a>
+<span class="sourceLineNo">3371</span>    if (compactionsCount != null &amp;&amp; compactionsCount.get() != 0) {<a name="line.3371"></a>
+<span class="sourceLineNo">3372</span>      return GetRegionInfoResponse.CompactionState.MAJOR_AND_MINOR;<a name="line.3372"></a>
+<span class="sourceLineNo">3373</span>    }<a name="line.3373"></a>
+<span class="sourceLineNo">3374</span>    return GetRegionInfoResponse.CompactionState.NONE;<a name="line.3374"></a>
+<span class="sourceLineNo">3375</span>  }<a name="line.3375"></a>
+<span class="sourceLineNo">3376</span><a name="line.3376"></a>
+<span class="sourceLineNo">3377</span>  public void reportMobCompactionStart(TableName tableName) throws IOException {<a name="line.3377"></a>
+<span class="sourceLineNo">3378</span>    IdLock.Entry lockEntry = null;<a name="line.3378"></a>
+<span class="sourceLineNo">3379</span>    try {<a name="line.3379"></a>
+<span class="sourceLineNo">3380</span>      lockEntry = mobCompactionLock.getLockEntry(tableName.hashCode());<a name="line.3380"></a>
+<span class="sourceLineNo">3381</span>      AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3381"></a>
+<span class="sourceLineNo">3382</span>      if (compactionsCount == null) {<a name="line.3382"></a>
+<span class="sourceLineNo">3383</span>        compactionsCount = new AtomicInteger(0);<a name="line.3383"></a>
+<span class="sourceLineNo">3384</span>        mobCompactionStates.put(tableName, compactionsCount);<a name="line.3384"></a>
+<span class="sourceLineNo">3385</span>      }<a name="line.3385"></a>
+<span class="sourceLineNo">3386</span>      compactionsCount.incrementAndGet();<a name="line.3386"></a>
+<span class="sourceLineNo">3387</span>    } finally {<a name="line.3387"></a>
+<span class="sourceLineNo">3388</span>      if (lockEntry != null) {<a name="line.3388"></a>
+<span class="sourceLineNo">3389</span>        mobCompactionLock.releaseLockEntry(lockEntry);<a name="line.3389"></a>
+<span class="sourceLineNo">3390</span>      }<a name="line.3390"></a>
+<span class="sourceLineNo">3391</span>    }<a name="line.3391"></a>
+<span class="sourceLineNo">3392</span>  }<a name="line.3392"></a>
+<span class="sourceLineNo">3393</span><a name="line.3393"></a>
+<span class="sourceLineNo">3394</span>  public void reportMobCompactionEnd(TableName tableName) throws IOException {<a name="line.3394"></a>
+<span class="sourceLineNo">3395</span>    IdLock.Entry lockEntry = null;<a name="line.3395"></a>
+<span class="sourceLineNo">3396</span>    try {<a name="line.3396"></a>
+<span class="sourceLineNo">3397</span>      lockEntry = mobCompactionLock.getLockEntry(tableName.hashCode());<a name="line.3397"></a>
+<span class="sourceLineNo">3398</span>      AtomicInteger compactionsCount = mobCompactionStates.get(tableName);<a name="line.3398"></a>
+<span class="sourceLineNo">3399</span>      if (compactionsCount != null) {<a name="line.3399"></a>
+<span class="sourceLineNo">3400</span>        int count = compactionsCount.decrementAndGet();<a name="line.3400"></a>
+<span class="sourceLineNo">3401</span>        // remove the entry if the count is 0.<a name="line.3401"></a>
+<span class="sourceLineNo">3402</span>        if (count == 0) {<a name="line.3402"></a>
+<span class="sourceLineNo">3403</span>          mobCompactionStates.remove(tableName);<a name="line.3403"></a>
+<span class="sourceLineNo">3404</span>        }<a name="line.3404"></a>
 <span class="sourceLineNo">3405</span>      }<a name="line.3405"></a>
-<span class="sourceLineNo">3406</span>    }<a name="line.3406"></a>
-<span class="sourceLineNo">3407</span>  }<a name="line.3407"></a>
-<span class="sourceLineNo">3408</span><a name="line.3408"></a>
-<span class="sourceLineNo">3409</span><a name="line.3409"></a>
-<span class="sourceLineNo">3410</span>  /**<a name="line.3410"></a>
-<span class="sourceLineNo">3411</span>   * Queries the state of the {@link LoadBalancerTracker}. If the balancer is not initialized,<a name="line.3411"></a>
-<span class="sourceLineNo">3412</span>   * false is returned.<a name="line.3412"></a>
-<span class="sourceLineNo">3413</span>   *<a name="line.3413"></a>
-<span class="sourceLineNo">3414</span>   * @return The state of the load balancer, or false if the load balancer isn't defined.<a name="line.3414"></a>
-<span class="sourceLineNo">3415</span>   */<a name="line.3415"></a>
-<span class="sourceLineNo">3416</span>  public boolean isBalancerOn() {<a name="line.3416"></a>
-<span class="sourceLineNo">3417</span>    return !isInMaintenanceMode()<a name="line.3417"></a>
-<span class="sourceLineNo">3418</span>        &amp;&amp; loadBalancerTracker != null<a name="line.3418"></a>
-<span class="sourceLineNo">3419</span>        &amp;&amp; loadBalancerTracker.isBalancerOn();<a name="line.3419"></a>
-<span class="sourceLineNo">3420</span>  }<a name="line.3420"></a>
-<span class="sourceLineNo">3421</span><a name="line.3421"></a>
-<span class="sourceLineNo">3422</span>  /**<a name="line.3422"></a>
-<span class="sourceLineNo">3423</span>   * Queries the state of the {@link RegionNormalizerTracker}. If it's not initialized,<a name="line.3423"></a>
-<span class="sourceLineNo">3424</span>   * false is returned.<a name="line.3424"></a>
-<span class="sourceLineNo">3425</span>   */<a name="line.3425"></a>
-<span class="sourceLineNo">3426</span>  public boolean isNormalizerOn() {<a name="line.3426"></a>
-<span class="sourceLineNo">3427</span>    return !isInMaintenanceMode()<a name="line.3427"></a>
-<span class="sourceLineNo">3428</span>      &amp;&amp; getRegionNormalizerManager().isNormalizerOn();<a name="line.3428"></a>
-<span class="sourceLineNo">3429</span>  }<a name="line.3429"></a>
-<span class="sourceLineNo">3430</span><a name="line.3430"></a>
-<span class="sourceLineNo">3431</span>  /**<a name="line.3431"></a>
-<span class="sourceLineNo">3432</span>   * Queries the state of the {@link SplitOrMergeTracker}. If it is not initialized,<a name="line.3432"></a>
-<span class="sourceLineNo">3433</span>   * false is returned. If switchType is illegal, false will return.<a name="line.3433"></a>
-<span class="sourceLineNo">3434</span>   * @param switchType see {@link org.apache.hadoop.hbase.client.MasterSwitchType}<a name="line.3434"></a>
-<span class="sourceLineNo">3435</span>   * @return The state of the switch<a name="line.3435"></a>
-<span class="sourceLineNo">3436</span>   */<a name="line.3436"></a>
-<span class="sourceLineNo">3437</span>  @Override<a name="line.3437"></a>
-<span class="sourceLineNo">3438</span>  public boolean isSplitOrMergeEnabled(MasterSwitchType switchType) {<a name="line.3438"></a>
-<span class="sourceLineNo">3439</span>    return !isInMaintenanceMode()<a name="line.3439"></a>
-<span class="sourceLineNo">3440</span>        &amp;&amp; splitOrMergeTracker != null<a name="line.3440"></a>
-<span class="sourceLineNo">3441</span>        &amp;&amp; splitOrMergeTracker.isSplitOrMergeEnabled(switchType);<a name="line.3441"></a>
-<span class="sourceLineNo">3442</span>  }<a name="line.3442"></a>
-<span class="sourceLineNo">3443</span><a name="line.3443"></a>
-<span class="sourceLineNo">3444</span>  /**<a name="line.3444"></a>
-<span class="sourceLineNo">3445</span>   * Fetch the configured {@link LoadBalancer} class name. If none is set, a default is returned.<a name="line.3445"></a>
-<span class="sourceLineNo">3446</span>   * &lt;p/&gt;<a name="line.3446"></a>
-<span class="sourceLineNo">3447</span>   * Notice that, the base load balancer will always be {@link RSGroupBasedLoadBalancer} now, so<a name="line.3447"></a>
-<span class="sourceLineNo">3448</span>   * this method will return the balancer used inside each rs group.<a name="line.3448"></a>
-<span class="sourceLineNo">3449</span>   * @return The name of the {@link LoadBalancer} in use.<a name="line.3449"></a>
-<span class="sourceLineNo">3450</span>   */<a name="line.3450"></a>
-<span class="sourceLineNo">3451</span>  public String getLoadBalancerClassName() {<a name="line.3451"></a>
-<span class="sourceLineNo">3452</span>    return conf.get(HConstants.HBASE_MASTER_LOADBALANCER_CLASS,<a name="line.3452"></a>
-<span class="sourceLineNo">3453</span>      LoadBalancerFactory.getDefaultLoadBalancerClass().getName());<a name="line.3453"></a>
-<span class="sourceLineNo">3454</span>  }<a name="line.3454"></a>
-<span class="sourceLineNo">3455</span><a name="line.3455"></a>
-<span class="sourceLineNo">3456</span>  public SplitOrMergeTracker getSplitOrMergeTracker() {<a name="line.3456"></a>
-<span class="sourceLineNo">3457</span>    return splitOrMergeTracker;<a name="line.3457"></a>
+<span class="sourceLineNo">3406</span>    } finally {<a name="line.3406"></a>
+<span class="sourceLineNo">3407</span>      if (lockEntry != null) {<a name="line.3407"></a>
+<span class="sourceLineNo">3408</span>        mobCompactionLock.releaseLockEntry(lockEntry);<a name="line.3408"></a>
+<span class="sourceLineNo">3409</span>      }<a name="line.3409"></a>
+<span class="sourceLineNo">3410</span>    }<a name="line.3410"></a>
+<span class="sourceLineNo">3411</span>  }<a name="line.3411"></a>
+<span class="sourceLineNo">3412</span><a name="line.3412"></a>
+<span class="sourceLineNo">3413</span><a name="line.3413"></a>
+<span class="sourceLineNo">3414</span>  /**<a name="line.3414"></a>
+<span class="sourceLineNo">3415</span>   * Queries the state of the {@link LoadBalancerTracker}. If the balancer is not initialized,<a name="line.3415"></a>
+<span class="sourceLineNo">3416</span>   * false is returned.<a name="line.3416"></a>
+<span class="sourceLineNo">3417</span>   *<a name="line.3417"></a>
+<span class="sourceLineNo">3418</span>   * @return The state of the load balancer, or false if the load balancer isn't defined.<a name="line.3418"></a>
+<span class="sourceLineNo">3419</span>   */<a name="line.3419"></a>
+<span class="sourceLineNo">3420</span>  public boolean isBalancerOn() {<a name="line.3420"></a>
+<span class="sourceLineNo">3421</span>    return !isInMaintenanceMode()<a name="line.3421"></a>
+<span class="sourceLineNo">3422</span>        &amp;&amp; loadBalancerTracker != null<a name="line.3422"></a>
+<span class="sourceLineNo">3423</span>        &amp;&amp; loadBalancerTracker.isBalancerOn();<a name="line.3423"></a>
+<span class="sourceLineNo">3424</span>  }<a name="line.3424"></a>
+<span class="sourceLineNo">3425</span><a name="line.3425"></a>
+<span class="sourceLineNo">3426</span>  /**<a name="line.3426"></a>
+<span class="sourceLineNo">3427</span>   * Queries the state of the {@link RegionNormalizerTracker}. If it's not initialized,<a name="line.3427"></a>
+<span class="sourceLineNo">3428</span>   * false is returned.<a name="line.3428"></a>
+<span class="sourceLineNo">3429</span>   */<a name="line.3429"></a>
+<span class="sourceLineNo">3430</span>  public boolean isNormalizerOn() {<a name="line.3430"></a>
+<span class="sourceLineNo">3431</span>    return !isInMaintenanceMode()<a name="line.3431"></a>
+<span class="sourceLineNo">3432</span>      &amp;&amp; getRegionNormalizerManager().isNormalizerOn();<a name="line.3432"></a>
+<span class="sourceLineNo">3433</span>  }<a name="line.3433"></a>
+<span class="sourceLineNo">3434</span><a name="line.3434"></a>
+<span class="sourceLineNo">3435</span>  /**<a name="line.3435"></a>
+<span class="sourceLineNo">3436</span>   * Queries the state of the {@link SplitOrMergeTracker}. If it is not initialized,<a name="line.3436"></a>
+<span class="sourceLineNo">3437</span>   * false is returned. If switchType is illegal, false will return.<a name="line.3437"></a>
+<span class="sourceLineNo">3438</span>   * @param switchType see {@link org.apache.hadoop.hbase.client.MasterSwitchType}<a name="line.3438"></a>
+<span class="sourceLineNo">3439</span>   * @return The state of the switch<a name="line.3439"></a>
+<span class="sourceLineNo">3440</span>   */<a name="line.3440"></a>
+<span class="sourceLineNo">3441</span>  @Override<a name="line.3441"></a>
+<span class="sourceLineNo">3442</span>  public boolean isSplitOrMergeEnabled(MasterSwitchType switchType) {<a name="line.3442"></a>
+<span class="sourceLineNo">3443</span>    return !isInMaintenanceMode()<a name="line.3443"></a>
+<span class="sourceLineNo">3444</span>        &amp;&amp; splitOrMergeTracker != null<a name="line.3444"></a>
+<span class="sourceLineNo">3445</span>        &amp;&amp; splitOrMergeTracker.isSplitOrMergeEnabled(switchType);<a name="line.3445"></a>
+<span class="sourceLineNo">3446</span>  }<a name="line.3446"></a>
+<span class="sourceLineNo">3447</span><a name="line.3447"></a>
+<span class="sourceLineNo">3448</span>  /**<a name="line.3448"></a>
+<span class="sourceLineNo">3449</span>   * Fetch the configured {@link LoadBalancer} class name. If none is set, a default is returned.<a name="line.3449"></a>
+<span class="sourceLineNo">3450</span>   * &lt;p/&gt;<a name="line.3450"></a>
+<span class="sourceLineNo">3451</span>   * Notice that, the base load balancer will always be {@link RSGroupBasedLoadBalancer} now, so<a name="line.3451"></a>
+<span class="sourceLineNo">3452</span>   * this method will return the balancer used inside each rs group.<a name="line.3452"></a>
+<span class="sourceLineNo">3453</span>   * @return The name of the {@link LoadBalancer} in use.<a name="line.3453"></a>
+<span class="sourceLineNo">3454</span>   */<a name="line.3454"></a>
+<span class="sourceLineNo">3455</span>  public String getLoadBalancerClassName() {<a name="line.3455"></a>
+<span class="sourceLineNo">3456</span>    return conf.get(HConstants.HBASE_MASTER_LOADBALANCER_CLASS,<a name="line.3456"></a>
+<span class="sourceLineNo">3457</span>      LoadBalancerFactory.getDefaultLoadBalancerClass().getName());<a name="line.3457"></a>
 <span class="sourceLineNo">3458</span>  }<a name="line.3458"></a>
 <span class="sourceLineNo">3459</span><a name="line.3459"></a>
-<span class="sourceLineNo">3460</span>  @Override<a name="line.3460"></a>
-<span class="sourceLineNo">3461</span>  public RSGroupBasedLoadBalancer getLoadBalancer() {<a name="line.3461"></a>
-<span class="sourceLineNo">3462</span>    return balancer;<a name="line.3462"></a>
-<span class="sourceLineNo">3463</span>  }<a name="line.3463"></a>
-<span class="sourceLineNo">3464</span><a name="line.3464"></a>
-<span class="sourceLineNo">3465</span>  @Override<a name="line.3465"></a>
-<span class="sourceLineNo">3466</span>  public FavoredNodesManager getFavoredNodesManager() {<a name="line.3466"></a>
-<span class="sourceLineNo">3467</span>    return balancer.getFavoredNodesManager();<a name="line.3467"></a>
-<span class="sourceLineNo">3468</span>  }<a name="line.3468"></a>
-<span class="sourceLineNo">3469</span><a name="line.3469"></a>
-<span class="sourceLineNo">3470</span>  private long executePeerProcedure(AbstractPeerProcedure&lt;?&gt; procedure) throws IOException {<a name="line.3470"></a>
-<span class="sourceLineNo">3471</span>    long procId = procedureExecutor.submitProcedure(procedure);<a name="line.3471"></a>
-<span class="sourceLineNo">3472</span>    procedure.getLatch().await();<a name="line.3472"></a>
-<span class="sourceLineNo">3473</span>    return procId;<a name="line.3473"></a>
-<span class="sourceLineNo">3474</span>  }<a name="line.3474"></a>
-<span class="sourceLineNo">3475</span><a name="line.3475"></a>
-<span class="sourceLineNo">3476</span>  @Override<a name="line.3476"></a>
-<span class="sourceLineNo">3477</span>  public long addReplicationPeer(String peerId, ReplicationPeerConfig peerConfig, boolean enabled)<a name="line.3477"></a>
-<span class="sourceLineNo">3478</span>      throws ReplicationException, IOException {<a name="line.3478"></a>
-<span class="sourceLineNo">3479</span>    LOG.info(getClientIdAuditPrefix() + " creating replication peer, id=" + peerId + ", config=" +<a name="line.3479"></a>
-<span class="sourceLineNo">3480</span>      peerConfig + ", state=" + (enabled ? "ENABLED" : "DISABLED"));<a name="line.3480"></a>
-<span class="sourceLineNo">3481</span>    return executePeerProcedure(new AddPeerProcedure(peerId, peerConfig, enabled));<a name="line.3481"></a>
-<span class="sourceLineNo">3482</span>  }<a name="line.3482"></a>
-<span class="sourceLineNo">3483</span><a name="line.3483"></a>
-<span class="sourceLineNo">3484</span>  @Override<a name="line.3484"></a>
-<span class="sourceLineNo">3485</span>  public long removeReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3485"></a>
-<span class="sourceLineNo">3486</span>    LOG.info(getClientIdAuditPrefix() + " removing replication peer, id=" + peerId);<a name="line.3486"></a>
-<span class="sourceLineNo">3487</span>    return executePeerProcedure(new RemovePeerProcedure(peerId));<a name="line.3487"></a>
-<span class="sourceLineNo">3488</span>  }<a name="line.3488"></a>
-<span class="sourceLineNo">3489</span><a name="line.3489"></a>
-<span class="sourceLineNo">3490</span>  @Override<a name="line.3490"></a>
-<span class="sourceLineNo">3491</span>  public long enableReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3491"></a>
-<span class="sourceLineNo">3492</span>    LOG.info(getClientIdAuditPrefix() + " enable replication peer, id=" + peerId);<a name="line.3492"></a>
-<span class="sourceLineNo">3493</span>    return executePeerProcedure(new EnablePeerProcedure(peerId));<a name="line.3493"></a>
-<span class="sourceLineNo">3494</span>  }<a name="line.3494"></a>
-<span class="sourceLineNo">3495</span><a name="line.3495"></a>
-<span class="sourceLineNo">3496</span>  @Override<a name="line.3496"></a>
-<span class="sourceLineNo">3497</span>  public long disableReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3497"></a>
-<span class="sourceLineNo">3498</span>    LOG.info(getClientIdAuditPrefix() + " disable replication peer, id=" + peerId);<a name="line.3498"></a>
-<span class="sourceLineNo">3499</span>    return executePeerProcedure(new DisablePeerProcedure(peerId));<a name="line.3499"></a>
-<span class="sourceLineNo">3500</span>  }<a name="line.3500"></a>
-<span class="sourceLineNo">3501</span><a name="line.3501"></a>
-<span class="sourceLineNo">3502</span>  @Override<a name="line.3502"></a>
-<span class="sourceLineNo">3503</span>  public ReplicationPeerConfig getReplicationPeerConfig(String peerId)<a name="line.3503"></a>
-<span class="sourceLineNo">3504</span>      throws ReplicationException, IOException {<a name="line.3504"></a>
-<span class="sourceLineNo">3505</span>    if (cpHost != null) {<a name="line.3505"></a>
-<span class="sourceLineNo">3506</span>      cpHost.preGetReplicationPeerConfig(peerId);<a name="line.3506"></a>
-<span class="sourceLineNo">3507</span>    }<a name="line.3507"></a>
-<span class="sourceLineNo">3508</span>    LOG.info(getClientIdAuditPrefix() + " get replication peer config, id=" + peerId);<a name="line.3508"></a>
-<span class="sourceLineNo">3509</span>    ReplicationPeerConfig peerConfig = this.replicationPeerManager.getPeerConfig(peerId)<a name="line.3509"></a>
-<span class="sourceLineNo">3510</span>        .orElseThrow(() -&gt; new ReplicationPeerNotFoundException(peerId));<a name="line.3510"></a>
-<span class="sourceLineNo">3511</span>    if (cpHost != null) {<a name="line.3511"></a>
-<span class="sourceLineNo">3512</span>      cpHost.postGetReplicationPeerConfig(peerId);<a name="line.3512"></a>
-<span class="sourceLineNo">3513</span>    }<a name="line.3513"></a>
-<span class="sourceLineNo">3514</span>    return peerConfig;<a name="line.3514"></a>
-<span class="sourceLineNo">3515</span>  }<a name="line.3515"></a>
-<span class="sourceLineNo">3516</span><a name="line.3516"></a>
-<span class="sourceLineNo">3517</span>  @Override<a name="line.3517"></a>
-<span class="sourceLineNo">3518</span>  public long updateReplicationPeerConfig(String peerId, ReplicationPeerConfig peerConfig)<a name="line.3518"></a>
-<span class="sourceLineNo">3519</span>      throws ReplicationException, IOException {<a name="line.3519"></a>
-<span class="sourceLineNo">3520</span>    LOG.info(getClientIdAuditPrefix() + " update replication peer config, id=" + peerId +<a name="line.3520"></a>
-<span class="sourceLineNo">3521</span>      ", config=" + peerConfig);<a name="line.3521"></a>
-<span class="sourceLineNo">3522</span>    return executePeerProcedure(new UpdatePeerConfigProcedure(peerId, peerConfig));<a name="line.3522"></a>
-<span class="sourceLineNo">3523</span>  }<a name="line.3523"></a>
-<span class="sourceLineNo">3524</span><a name="line.3524"></a>
-<span class="sourceLineNo">3525</span>  @Override<a name="line.3525"></a>
-<span class="sourceLineNo">3526</span>  public List&lt;ReplicationPeerDescription&gt; listReplicationPeers(String regex)<a name="line.3526"></a>
-<span class="sourceLineNo">3527</span>      throws ReplicationException, IOException {<a name="line.3527"></a>
-<span class="sourceLineNo">3528</span>    if (cpHost != null) {<a name="line.3528"></a>
-<span class="sourceLineNo">3529</span>      cpHost.preListReplicationPeers(regex);<a name="line.3529"></a>
-<span class="sourceLineNo">3530</span>    }<a name="line.3530"></a>
-<span class="sourceLineNo">3531</span>    LOG.debug("{} list replication peers, regex={}", getClientIdAuditPrefix(), regex);<a name="line.3531"></a>
-<span class="sourceLineNo">3532</span>    Pattern pattern = regex == null ? null : Pattern.compile(regex);<a name="line.3532"></a>
-<span class="sourceLineNo">3533</span>    List&lt;ReplicationPeerDescription&gt; peers =<a name="line.3533"></a>
-<span class="sourceLineNo">3534</span>      this.replicationPeerManager.listPeers(pattern);<a name="line.3534"></a>
-<span class="sourceLineNo">3535</span>    if (cpHost != null) {<a name="line.3535"></a>
-<span class="sourceLineNo">3536</span>      cpHost.postListReplicationPeers(regex);<a name="line.3536"></a>
-<span class="sourceLineNo">3537</span>    }<a name="line.3537"></a>
-<span class="sourceLineNo">3538</span>    return peers;<a name="line.3538"></a>
-<span class="sourceLineNo">3539</span>  }<a name="line.3539"></a>
-<span class="sourceLineNo">3540</span><a name="line.3540"></a>
-<span class="sourceLineNo">3541</span>  @Override<a name="line.3541"></a>
-<span class="sourceLineNo">3542</span>  public long transitReplicationPeerSyncReplicationState(String peerId, SyncReplicationState state)<a name="line.3542"></a>
-<span class="sourceLineNo">3543</span>    throws ReplicationException, IOException {<a name="line.3543"></a>
-<span class="sourceLineNo">3544</span>    LOG.info(<a name="line.3544"></a>
-<span class="sourceLineNo">3545</span>      getClientIdAuditPrefix() +<a name="line.3545"></a>
-<span class="sourceLineNo">3546</span>        " transit current cluster state to {} in a synchronous replication peer id={}",<a name="line.3546"></a>
-<span class="sourceLineNo">3547</span>      state, peerId);<a name="line.3547"></a>
-<span class="sourceLineNo">3548</span>    return executePeerProcedure(new TransitPeerSyncReplicationStateProcedure(peerId, state));<a name="line.3548"></a>
-<span class="sourceLineNo">3549</span>  }<a name="line.3549"></a>
-<span class="sourceLineNo">3550</span><a name="line.3550"></a>
-<span class="sourceLineNo">3551</span>  /**<a name="line.3551"></a>
-<span class="sourceLineNo">3552</span>   * Mark region server(s) as decommissioned (previously called 'draining') to prevent additional<a name="line.3552"></a>
-<span class="sourceLineNo">3553</span>   * regions from getting assigned to them. Also unload the regions on the servers asynchronously.0<a name="line.3553"></a>
-<span class="sourceLineNo">3554</span>   * @param servers Region servers to decommission.<a name="line.3554"></a>
-<span class="sourceLineNo">3555</span>   */<a name="line.3555"></a>
-<span class="sourceLineNo">3556</span>  public void decommissionRegionServers(final List&lt;ServerName&gt; servers, final boolean offload)<a name="line.3556"></a>
-<span class="sourceLineNo">3557</span>      throws IOException {<a name="line.3557"></a>
-<span class="sourceLineNo">3558</span>    List&lt;ServerName&gt; serversAdded = new ArrayList&lt;&gt;(servers.size());<a name="line.3558"></a>
-<span class="sourceLineNo">3559</span>    // Place the decommission marker first.<a name="line.3559"></a>
-<span class="sourceLineNo">3560</span>    String parentZnode = getZooKeeper().getZNodePaths().drainingZNode;<a name="line.3560"></a>
-<span class="sourceLineNo">3561</span>    for (ServerName server : servers) {<a name="line.3561"></a>
-<span class="sourceLineNo">3562</span>      try {<a name="line.3562"></a>
-<span class="sourceLineNo">3563</span>        String node = ZNodePaths.joinZNode(parentZnode, server.getServerName());<a name="line.3563"></a>
-<span class="sourceLineNo">3564</span>        ZKUtil.createAndFailSilent(getZooKeeper(), node);<a name="line.3564"></a>
-<span class="sourceLineNo">3565</span>      } catch (KeeperException ke) {<a name="line.3565"></a>
-<span class="sourceLineNo">3566</span>        throw new HBaseIOException(<a name="line.3566"></a>
-<span class="sourceLineNo">3567</span>          this.zooKeeper.prefix("Unable to decommission '" + server.getServerName() + "'."), ke);<a name="line.3567"></a>
-<span class="sourceLineNo">3568</span>      }<a name="line.3568"></a>
-<span class="sourceLineNo">3569</span>      if (this.serverManager.addServerToDrainList(server)) {<a name="line.3569"></a>
-<span class="sourceLineNo">3570</span>        serversAdded.add(server);<a name="line.3570"></a>
-<span class="sourceLineNo">3571</span>      }<a name="line.3571"></a>
-<span class="sourceLineNo">3572</span>    }<a name="line.3572"></a>
-<span class="sourceLineNo">3573</span>    // Move the regions off the decommissioned servers.<a name="line.3573"></a>
-<span class="sourceLineNo">3574</span>    if (offload) {<a name="line.3574"></a>
-<span class="sourceLineNo">3575</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList();<a name="line.3575"></a>
-<span class="sourceLineNo">3576</span>      for (ServerName server : serversAdded) {<a name="line.3576"></a>
-<span class="sourceLineNo">3577</span>        final List&lt;RegionInfo&gt; regionsOnServer = this.assignmentManager.getRegionsOnServer(server);<a name="line.3577"></a>
-<span class="sourceLineNo">3578</span>        for (RegionInfo hri : regionsOnServer) {<a name="line.3578"></a>
-<span class="sourceLineNo">3579</span>          ServerName dest = balancer.randomAssignment(hri, destServers);<a name="line.3579"></a>
-<span class="sourceLineNo">3580</span>          if (dest == null) {<a name="line.3580"></a>
-<span class="sourceLineNo">3581</span>            throw new HBaseIOException("Unable to determine a plan to move " + hri);<a name="line.3581"></a>
-<span class="sourceLineNo">3582</span>          }<a name="line.3582"></a>
-<span class="sourceLineNo">3583</span>          RegionPlan rp = new RegionPlan(hri, server, dest);<a name="line.3583"></a>
-<span class="sourceLineNo">3584</span>          this.assignmentManager.moveAsync(rp);<a name="line.3584"></a>
-<span class="sourceLineNo">3585</span>        }<a name="line.3585"></a>
-<span class="sourceLineNo">3586</span>      }<a name="line.3586"></a>
-<span class="sourceLineNo">3587</span>    }<a name="line.3587"></a>
-<span class="sourceLineNo">3588</span>  }<a name="line.3588"></a>
-<span class="sourceLineNo">3589</span><a name="line.3589"></a>
-<span class="sourceLineNo">3590</span>  /**<a name="line.3590"></a>
-<span class="sourceLineNo">3591</span>   * List region servers marked as decommissioned (previously called 'draining') to not get regions<a name="line.3591"></a>
-<span class="sourceLineNo">3592</span>   * assigned to them.<a name="line.3592"></a>
-<span class="sourceLineNo">3593</span>   * @return List of decommissioned servers.<a name="line.3593"></a>
-<span class="sourceLineNo">3594</span>   */<a name="line.3594"></a>
-<span class="sourceLineNo">3595</span>  public List&lt;ServerName&gt; listDecommissionedRegionServers() {<a name="line.3595"></a>
-<span class="sourceLineNo">3596</span>    return this.serverManager.getDrainingServersList();<a name="line.3596"></a>
-<span class="sourceLineNo">3597</span>  }<a name="line.3597"></a>
-<span class="sourceLineNo">3598</span><a name="line.3598"></a>
-<span class="sourceLineNo">3599</span>  /**<a name="line.3599"></a>
-<span class="sourceLineNo">3600</span>   * Remove decommission marker (previously called 'draining') from a region server to allow regions<a name="line.3600"></a>
-<span class="sourceLineNo">3601</span>   * assignments. Load regions onto the server asynchronously if a list of regions is given<a name="line.3601"></a>
-<span class="sourceLineNo">3602</span>   * @param server Region server to remove decommission marker from.<a name="line.3602"></a>
-<span class="sourceLineNo">3603</span>   */<a name="line.3603"></a>
-<span class="sourceLineNo">3604</span>  public void recommissionRegionServer(final ServerName server,<a name="line.3604"></a>
-<span class="sourceLineNo">3605</span>      final List&lt;byte[]&gt; encodedRegionNames) throws IOException {<a name="line.3605"></a>
-<span class="sourceLineNo">3606</span>    // Remove the server from decommissioned (draining) server list.<a name="line.3606"></a>
-<span class="sourceLineNo">3607</span>    String parentZnode = getZooKeeper().getZNodePaths().drainingZNode;<a name="line.3607"></a>
-<span class="sourceLineNo">3608</span>    String node = ZNodePaths.joinZNode(parentZnode, server.getServerName());<a name="line.3608"></a>
-<span class="sourceLineNo">3609</span>    try {<a name="line.3609"></a>
-<span class="sourceLineNo">3610</span>      ZKUtil.deleteNodeFailSilent(getZooKeeper(), node);<a name="line.3610"></a>
-<span class="sourceLineNo">3611</span>    } catch (KeeperException ke) {<a name="line.3611"></a>
-<span class="sourceLineNo">3612</span>      throw new HBaseIOException(<a name="line.3612"></a>
-<span class="sourceLineNo">3613</span>        this.zooKeeper.prefix("Unable to recommission '" + server.getServerName() + "'."), ke);<a name="line.3613"></a>
-<span class="sourceLineNo">3614</span>    }<a name="line.3614"></a>
-<span class="sourceLineNo">3615</span>    this.serverManager.removeServerFromDrainList(server);<a name="line.3615"></a>
-<span class="sourceLineNo">3616</span><a name="line.3616"></a>
-<span class="sourceLineNo">3617</span>    // Load the regions onto the server if we are given a list of regions.<a name="line.3617"></a>
-<span class="sourceLineNo">3618</span>    if (encodedRegionNames == null || encodedRegionNames.isEmpty()) {<a name="line.3618"></a>
-<span class="sourceLineNo">3619</span>      return;<a name="line.3619"></a>
-<span class="sourceLineNo">3620</span>    }<a name="line.3620"></a>
-<span class="sourceLineNo">3621</span>    if (!this.serverManager.isServerOnline(server)) {<a name="line.3621"></a>
-<span class="sourceLineNo">3622</span>      return;<a name="line.3622"></a>
-<span class="sourceLineNo">3623</span>    }<a name="line.3623"></a>
-<span class="sourceLineNo">3624</span>    for (byte[] encodedRegionName : encodedRegionNames) {<a name="line.3624"></a>
-<span class="sourceLineNo">3625</span>      RegionState regionState =<a name="line.3625"></a>
-<span class="sourceLineNo">3626</span>        assignmentManager.getRegionStates().getRegionState(Bytes.toString(encodedRegionName));<a name="line.3626"></a>
-<span class="sourceLineNo">3627</span>      if (regionState == null) {<a name="line.3627"></a>
-<span class="sourceLineNo">3628</span>        LOG.warn("Unknown region " + Bytes.toStringBinary(encodedRegionName));<a name="line.3628"></a>
-<span class="sourceLineNo">3629</span>        continue;<a name="line.3629"></a>
-<span class="sourceLineNo">3630</span>      }<a name="line.3630"></a>
-<span class="sourceLineNo">3631</span>      RegionInfo hri = regionState.getRegion();<a name="line.3631"></a>
-<span class="sourceLineNo">3632</span>      if (server.equals(regionState.getServerName())) {<a name="line.3632"></a>
-<span class="sourceLineNo">3633</span>        LOG.info("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.3633"></a>
-<span class="sourceLineNo">3634</span>          " because region already assigned to the same server " + server + ".");<a name="line.3634"></a>
-<span class="sourceLineNo">3635</span>        continue;<a name="line.3635"></a>
-<span class="sourceLineNo">3636</span>      }<a name="line.3636"></a>
-<span class="sourceLineNo">3637</span>      RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), server);<a name="line.3637"></a>
-<span class="sourceLineNo">3638</span>      this.assignmentManager.moveAsync(rp);<a name="line.3638"></a>
-<span class="sourceLineNo">3639</span>    }<a name="line.3639"></a>
-<span class="sourceLineNo">3640</span>  }<a name="line.3640"></a>
-<span class="sourceLineNo">3641</span><a name="line.3641"></a>
-<span class="sourceLineNo">3642</span>  @Override<a name="line.3642"></a>
-<span class="sourceLineNo">3643</span>  public LockManager getLockManager() {<a name="line.3643"></a>
-<span class="sourceLineNo">3644</span>    return lockManager;<a name="line.3644"></a>
-<span class="sourceLineNo">3645</span>  }<a name="line.3645"></a>
-<span class="sourceLineNo">3646</span><a name="line.3646"></a>
-<span class="sourceLineNo">3647</span>  public QuotaObserverChore getQuotaObserverChore() {<a name="line.3647"></a>
-<span class="sourceLineNo">3648</span>    return this.quotaObserverChore;<a name="line.3648"></a>
+<span class="sourceLineNo">3460</span>  public SplitOrMergeTracker getSplitOrMergeTracker() {<a name="line.3460"></a>
+<span class="sourceLineNo">3461</span>    return splitOrMergeTracker;<a name="line.3461"></a>
+<span class="sourceLineNo">3462</span>  }<a name="line.3462"></a>
+<span class="sourceLineNo">3463</span><a name="line.3463"></a>
+<span class="sourceLineNo">3464</span>  @Override<a name="line.3464"></a>
+<span class="sourceLineNo">3465</span>  public RSGroupBasedLoadBalancer getLoadBalancer() {<a name="line.3465"></a>
+<span class="sourceLineNo">3466</span>    return balancer;<a name="line.3466"></a>
+<span class="sourceLineNo">3467</span>  }<a name="line.3467"></a>
+<span class="sourceLineNo">3468</span><a name="line.3468"></a>
+<span class="sourceLineNo">3469</span>  @Override<a name="line.3469"></a>
+<span class="sourceLineNo">3470</span>  public FavoredNodesManager getFavoredNodesManager() {<a name="line.3470"></a>
+<span class="sourceLineNo">3471</span>    return balancer.getFavoredNodesManager();<a name="line.3471"></a>
+<span class="sourceLineNo">3472</span>  }<a name="line.3472"></a>
+<span class="sourceLineNo">3473</span><a name="line.3473"></a>
+<span class="sourceLineNo">3474</span>  private long executePeerProcedure(AbstractPeerProcedure&lt;?&gt; procedure) throws IOException {<a name="line.3474"></a>
+<span class="sourceLineNo">3475</span>    long procId = procedureExecutor.submitProcedure(procedure);<a name="line.3475"></a>
+<span class="sourceLineNo">3476</span>    procedure.getLatch().await();<a name="line.3476"></a>
+<span class="sourceLineNo">3477</span>    return procId;<a name="line.3477"></a>
+<span class="sourceLineNo">3478</span>  }<a name="line.3478"></a>
+<span class="sourceLineNo">3479</span><a name="line.3479"></a>
+<span class="sourceLineNo">3480</span>  @Override<a name="line.3480"></a>
+<span class="sourceLineNo">3481</span>  public long addReplicationPeer(String peerId, ReplicationPeerConfig peerConfig, boolean enabled)<a name="line.3481"></a>
+<span class="sourceLineNo">3482</span>      throws ReplicationException, IOException {<a name="line.3482"></a>
+<span class="sourceLineNo">3483</span>    LOG.info(getClientIdAuditPrefix() + " creating replication peer, id=" + peerId + ", config=" +<a name="line.3483"></a>
+<span class="sourceLineNo">3484</span>      peerConfig + ", state=" + (enabled ? "ENABLED" : "DISABLED"));<a name="line.3484"></a>
+<span class="sourceLineNo">3485</span>    return executePeerProcedure(new AddPeerProcedure(peerId, peerConfig, enabled));<a name="line.3485"></a>
+<span class="sourceLineNo">3486</span>  }<a name="line.3486"></a>
+<span class="sourceLineNo">3487</span><a name="line.3487"></a>
+<span class="sourceLineNo">3488</span>  @Override<a name="line.3488"></a>
+<span class="sourceLineNo">3489</span>  public long removeReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3489"></a>
+<span class="sourceLineNo">3490</span>    LOG.info(getClientIdAuditPrefix() + " removing replication peer, id=" + peerId);<a name="line.3490"></a>
+<span class="sourceLineNo">3491</span>    return executePeerProcedure(new RemovePeerProcedure(peerId));<a name="line.3491"></a>
+<span class="sourceLineNo">3492</span>  }<a name="line.3492"></a>
+<span class="sourceLineNo">3493</span><a name="line.3493"></a>
+<span class="sourceLineNo">3494</span>  @Override<a name="line.3494"></a>
+<span class="sourceLineNo">3495</span>  public long enableReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3495"></a>
+<span class="sourceLineNo">3496</span>    LOG.info(getClientIdAuditPrefix() + " enable replication peer, id=" + peerId);<a name="line.3496"></a>
+<span class="sourceLineNo">3497</span>    return executePeerProcedure(new EnablePeerProcedure(peerId));<a name="line.3497"></a>
+<span class="sourceLineNo">3498</span>  }<a name="line.3498"></a>
+<span class="sourceLineNo">3499</span><a name="line.3499"></a>
+<span class="sourceLineNo">3500</span>  @Override<a name="line.3500"></a>
+<span class="sourceLineNo">3501</span>  public long disableReplicationPeer(String peerId) throws ReplicationException, IOException {<a name="line.3501"></a>
+<span class="sourceLineNo">3502</span>    LOG.info(getClientIdAuditPrefix() + " disable replication peer, id=" + peerId);<a name="line.3502"></a>
+<span class="sourceLineNo">3503</span>    return executePeerProcedure(new DisablePeerProcedure(peerId));<a name="line.3503"></a>
+<span class="sourceLineNo">3504</span>  }<a name="line.3504"></a>
+<span class="sourceLineNo">3505</span><a name="line.3505"></a>
+<span class="sourceLineNo">3506</span>  @Override<a name="line.3506"></a>
+<span class="sourceLineNo">3507</span>  public ReplicationPeerConfig getReplicationPeerConfig(String peerId)<a name="line.3507"></a>
+<span class="sourceLineNo">3508</span>      throws ReplicationException, IOException {<a name="line.3508"></a>
+<span class="sourceLineNo">3509</span>    if (cpHost != null) {<a name="line.3509"></a>
+<span class="sourceLineNo">3510</span>      cpHost.preGetReplicationPeerConfig(peerId);<a name="line.3510"></a>
+<span class="sourceLineNo">3511</span>    }<a name="line.3511"></a>
+<span class="sourceLineNo">3512</span>    LOG.info(getClientIdAuditPrefix() + " get replication peer config, id=" + peerId);<a name="line.3512"></a>
+<span class="sourceLineNo">3513</span>    ReplicationPeerConfig peerConfig = this.replicationPeerManager.getPeerConfig(peerId)<a name="line.3513"></a>
+<span class="sourceLineNo">3514</span>        .orElseThrow(() -&gt; new ReplicationPeerNotFoundException(peerId));<a name="line.3514"></a>
+<span class="sourceLineNo">3515</span>    if (cpHost != null) {<a name="line.3515"></a>
+<span class="sourceLineNo">3516</span>      cpHost.postGetReplicationPeerConfig(peerId);<a name="line.3516"></a>
+<span class="sourceLineNo">3517</span>    }<a name="line.3517"></a>
+<span class="sourceLineNo">3518</span>    return peerConfig;<a name="line.3518"></a>
+<span class="sourceLineNo">3519</span>  }<a name="line.3519"></a>
+<span class="sourceLineNo">3520</span><a name="line.3520"></a>
+<span class="sourceLineNo">3521</span>  @Override<a name="line.3521"></a>
+<span class="sourceLineNo">3522</span>  public long updateReplicationPeerConfig(String peerId, ReplicationPeerConfig peerConfig)<a name="line.3522"></a>
+<span class="sourceLineNo">3523</span>      throws ReplicationException, IOException {<a name="line.3523"></a>
+<span class="sourceLineNo">3524</span>    LOG.info(getClientIdAuditPrefix() + " update replication peer config, id=" + peerId +<a name="line.3524"></a>
+<span class="sourceLineNo">3525</span>      ", config=" + peerConfig);<a name="line.3525"></a>
+<span class="sourceLineNo">3526</span>    return executePeerProcedure(new UpdatePeerConfigProcedure(peerId, peerConfig));<a name="line.3526"></a>
+<span class="sourceLineNo">3527</span>  }<a name="line.3527"></a>
+<span class="sourceLineNo">3528</span><a name="line.3528"></a>
+<span class="sourceLineNo">3529</span>  @Override<a name="line.3529"></a>
+<span class="sourceLineNo">3530</span>  public List&lt;ReplicationPeerDescription&gt; listReplicationPeers(String regex)<a name="line.3530"></a>
+<span class="sourceLineNo">3531</span>      throws ReplicationException, IOException {<a name="line.3531"></a>
+<span class="sourceLineNo">3532</span>    if (cpHost != null) {<a name="line.3532"></a>
+<span class="sourceLineNo">3533</span>      cpHost.preListReplicationPeers(regex);<a name="line.3533"></a>
+<span class="sourceLineNo">3534</span>    }<a name="line.3534"></a>
+<span class="sourceLineNo">3535</span>    LOG.debug("{} list replication peers, regex={}", getClientIdAuditPrefix(), regex);<a name="line.3535"></a>
+<span class="sourceLineNo">3536</span>    Pattern pattern = regex == null ? null : Pattern.compile(regex);<a name="line.3536"></a>
+<span class="sourceLineNo">3537</span>    List&lt;ReplicationPeerDescription&gt; peers =<a name="line.3537"></a>
+<span class="sourceLineNo">3538</span>      this.replicationPeerManager.listPeers(pattern);<a name="line.3538"></a>
+<span class="sourceLineNo">3539</span>    if (cpHost != null) {<a name="line.3539"></a>
+<span class="sourceLineNo">3540</span>      cpHost.postListReplicationPeers(regex);<a name="line.3540"></a>
+<span class="sourceLineNo">3541</span>    }<a name="line.3541"></a>
+<span class="sourceLineNo">3542</span>    return peers;<a name="line.3542"></a>
+<span class="sourceLineNo">3543</span>  }<a name="line.3543"></a>
+<span class="sourceLineNo">3544</span><a name="line.3544"></a>
+<span class="sourceLineNo">3545</span>  @Override<a name="line.3545"></a>
+<span class="sourceLineNo">3546</span>  public long transitReplicationPeerSyncReplicationState(String peerId, SyncReplicationState state)<a name="line.3546"></a>
+<span class="sourceLineNo">3547</span>    throws ReplicationException, IOException {<a name="line.3547"></a>
+<span class="sourceLineNo">3548</span>    LOG.info(<a name="line.3548"></a>
+<span class="sourceLineNo">3549</span>      getClientIdAuditPrefix() +<a name="line.3549"></a>
+<span class="sourceLineNo">3550</span>        " transit current cluster state to {} in a synchronous replication peer id={}",<a name="line.3550"></a>
+<span class="sourceLineNo">3551</span>      state, peerId);<a name="line.3551"></a>
+<span class="sourceLineNo">3552</span>    return executePeerProcedure(new TransitPeerSyncReplicationStateProcedure(peerId, state));<a name="line.3552"></a>
+<span class="sourceLineNo">3553</span>  }<a name="line.3553"></a>
+<span class="sourceLineNo">3554</span><a name="line.3554"></a>
+<span class="sourceLineNo">3555</span>  /**<a name="line.3555"></a>
+<span class="sourceLineNo">3556</span>   * Mark region server(s) as decommissioned (previously called 'draining') to prevent additional<a name="line.3556"></a>
+<span class="sourceLineNo">3557</span>   * regions from getting assigned to them. Also unload the regions on the servers asynchronously.0<a name="line.3557"></a>
+<span class="sourceLineNo">3558</span>   * @param servers Region servers to decommission.<a name="line.3558"></a>
+<span class="sourceLineNo">3559</span>   */<a name="line.3559"></a>
+<span class="sourceLineNo">3560</span>  public void decommissionRegionServers(final List&lt;ServerName&gt; servers, final boolean offload)<a name="line.3560"></a>
+<span class="sourceLineNo">3561</span>      throws IOException {<a name="line.3561"></a>
+<span class="sourceLineNo">3562</span>    List&lt;ServerName&gt; serversAdded = new ArrayList&lt;&gt;(servers.size());<a name="line.3562"></a>
+<span class="sourceLineNo">3563</span>    // Place the decommission marker first.<a name="line.3563"></a>
+<span class="sourceLineNo">3564</span>    String parentZnode = getZooKeeper().getZNodePaths().drainingZNode;<a name="line.3564"></a>
+<span class="sourceLineNo">3565</span>    for (ServerName server : servers) {<a name="line.3565"></a>
+<span class="sourceLineNo">3566</span>      try {<a name="line.3566"></a>
+<span class="sourceLineNo">3567</span>        String node = ZNodePaths.joinZNode(parentZnode, server.getServerName());<a name="line.3567"></a>
+<span class="sourceLineNo">3568</span>        ZKUtil.createAndFailSilent(getZooKeeper(), node);<a name="line.3568"></a>
+<span class="sourceLineNo">3569</span>      } catch (KeeperException ke) {<a name="line.3569"></a>
+<span class="sourceLineNo">3570</span>        throw new HBaseIOException(<a name="line.3570"></a>
+<span class="sourceLineNo">3571</span>          this.zooKeeper.prefix("Unable to decommission '" + server.getServerName() + "'."), ke);<a name="line.3571"></a>
+<span class="sourceLineNo">3572</span>      }<a name="line.3572"></a>
+<span class="sourceLineNo">3573</span>      if (this.serverManager.addServerToDrainList(server)) {<a name="line.3573"></a>
+<span class="sourceLineNo">3574</span>        serversAdded.add(server);<a name="line.3574"></a>
+<span class="sourceLineNo">3575</span>      }<a name="line.3575"></a>
+<span class="sourceLineNo">3576</span>    }<a name="line.3576"></a>
+<span class="sourceLineNo">3577</span>    // Move the regions off the decommissioned servers.<a name="line.3577"></a>
+<span class="sourceLineNo">3578</span>    if (offload) {<a name="line.3578"></a>
+<span class="sourceLineNo">3579</span>      final List&lt;ServerName&gt; destServers = this.serverManager.createDestinationServersList();<a name="line.3579"></a>
+<span class="sourceLineNo">3580</span>      for (ServerName server : serversAdded) {<a name="line.3580"></a>
+<span class="sourceLineNo">3581</span>        final List&lt;RegionInfo&gt; regionsOnServer = this.assignmentManager.getRegionsOnServer(server);<a name="line.3581"></a>
+<span class="sourceLineNo">3582</span>        for (RegionInfo hri : regionsOnServer) {<a name="line.3582"></a>
+<span class="sourceLineNo">3583</span>          ServerName dest = balancer.randomAssignment(hri, destServers);<a name="line.3583"></a>
+<span class="sourceLineNo">3584</span>          if (dest == null) {<a name="line.3584"></a>
+<span class="sourceLineNo">3585</span>            throw new HBaseIOException("Unable to determine a plan to move " + hri);<a name="line.3585"></a>
+<span class="sourceLineNo">3586</span>          }<a name="line.3586"></a>
+<span class="sourceLineNo">3587</span>          RegionPlan rp = new RegionPlan(hri, server, dest);<a name="line.3587"></a>
+<span class="sourceLineNo">3588</span>          this.assignmentManager.moveAsync(rp);<a name="line.3588"></a>
+<span class="sourceLineNo">3589</span>        }<a name="line.3589"></a>
+<span class="sourceLineNo">3590</span>      }<a name="line.3590"></a>
+<span class="sourceLineNo">3591</span>    }<a name="line.3591"></a>
+<span class="sourceLineNo">3592</span>  }<a name="line.3592"></a>
+<span class="sourceLineNo">3593</span><a name="line.3593"></a>
+<span class="sourceLineNo">3594</span>  /**<a name="line.3594"></a>
+<span class="sourceLineNo">3595</span>   * List region servers marked as decommissioned (previously called 'draining') to not get regions<a name="line.3595"></a>
+<span class="sourceLineNo">3596</span>   * assigned to them.<a name="line.3596"></a>
+<span class="sourceLineNo">3597</span>   * @return List of decommissioned servers.<a name="line.3597"></a>
+<span class="sourceLineNo">3598</span>   */<a name="line.3598"></a>
+<span class="sourceLineNo">3599</span>  public List&lt;ServerName&gt; listDecommissionedRegionServers() {<a name="line.3599"></a>
+<span class="sourceLineNo">3600</span>    return this.serverManager.getDrainingServersList();<a name="line.3600"></a>
+<span class="sourceLineNo">3601</span>  }<a name="line.3601"></a>
+<span class="sourceLineNo">3602</span><a name="line.3602"></a>
+<span class="sourceLineNo">3603</span>  /**<a name="line.3603"></a>
+<span class="sourceLineNo">3604</span>   * Remove decommission marker (previously called 'draining') from a region server to allow regions<a name="line.3604"></a>
+<span class="sourceLineNo">3605</span>   * assignments. Load regions onto the server asynchronously if a list of regions is given<a name="line.3605"></a>
+<span class="sourceLineNo">3606</span>   * @param server Region server to remove decommission marker from.<a name="line.3606"></a>
+<span class="sourceLineNo">3607</span>   */<a name="line.3607"></a>
+<span class="sourceLineNo">3608</span>  public void recommissionRegionServer(final ServerName server,<a name="line.3608"></a>
+<span class="sourceLineNo">3609</span>      final List&lt;byte[]&gt; encodedRegionNames) throws IOException {<a name="line.3609"></a>
+<span class="sourceLineNo">3610</span>    // Remove the server from decommissioned (draining) server list.<a name="line.3610"></a>
+<span class="sourceLineNo">3611</span>    String parentZnode = getZooKeeper().getZNodePaths().drainingZNode;<a name="line.3611"></a>
+<span class="sourceLineNo">3612</span>    String node = ZNodePaths.joinZNode(parentZnode, server.getServerName());<a name="line.3612"></a>
+<span class="sourceLineNo">3613</span>    try {<a name="line.3613"></a>
+<span class="sourceLineNo">3614</span>      ZKUtil.deleteNodeFailSilent(getZooKeeper(), node);<a name="line.3614"></a>
+<span class="sourceLineNo">3615</span>    } catch (KeeperException ke) {<a name="line.3615"></a>
+<span class="sourceLineNo">3616</span>      throw new HBaseIOException(<a name="line.3616"></a>
+<span class="sourceLineNo">3617</span>        this.zooKeeper.prefix("Unable to recommission '" + server.getServerName() + "'."), ke);<a name="line.3617"></a>
+<span class="sourceLineNo">3618</span>    }<a name="line.3618"></a>
+<span class="sourceLineNo">3619</span>    this.serverManager.removeServerFromDrainList(server);<a name="line.3619"></a>
+<span class="sourceLineNo">3620</span><a name="line.3620"></a>
+<span class="sourceLineNo">3621</span>    // Load the regions onto the server if we are given a list of regions.<a name="line.3621"></a>
+<span class="sourceLineNo">3622</span>    if (encodedRegionNames == null || encodedRegionNames.isEmpty()) {<a name="line.3622"></a>
+<span class="sourceLineNo">3623</span>      return;<a name="line.3623"></a>
+<span class="sourceLineNo">3624</span>    }<a name="line.3624"></a>
+<span class="sourceLineNo">3625</span>    if (!this.serverManager.isServerOnline(server)) {<a name="line.3625"></a>
+<span class="sourceLineNo">3626</span>      return;<a name="line.3626"></a>
+<span class="sourceLineNo">3627</span>    }<a name="line.3627"></a>
+<span class="sourceLineNo">3628</span>    for (byte[] encodedRegionName : encodedRegionNames) {<a name="line.3628"></a>
+<span class="sourceLineNo">3629</span>      RegionState regionState =<a name="line.3629"></a>
+<span class="sourceLineNo">3630</span>        assignmentManager.getRegionStates().getRegionState(Bytes.toString(encodedRegionName));<a name="line.3630"></a>
+<span class="sourceLineNo">3631</span>      if (regionState == null) {<a name="line.3631"></a>
+<span class="sourceLineNo">3632</span>        LOG.warn("Unknown region " + Bytes.toStringBinary(encodedRegionName));<a name="line.3632"></a>
+<span class="sourceLineNo">3633</span>        continue;<a name="line.3633"></a>
+<span class="sourceLineNo">3634</span>      }<a name="line.3634"></a>
+<span class="sourceLineNo">3635</span>      RegionInfo hri = regionState.getRegion();<a name="line.3635"></a>
+<span class="sourceLineNo">3636</span>      if (server.equals(regionState.getServerName())) {<a name="line.3636"></a>
+<span class="sourceLineNo">3637</span>        LOG.info("Skipping move of region " + hri.getRegionNameAsString() +<a name="line.3637"></a>
+<span class="sourceLineNo">3638</span>          " because region already assigned to the same server " + server + ".");<a name="line.3638"></a>
+<span class="sourceLineNo">3639</span>        continue;<a name="line.3639"></a>
+<span class="sourceLineNo">3640</span>      }<a name="line.3640"></a>
+<span class="sourceLineNo">3641</span>      RegionPlan rp = new RegionPlan(hri, regionState.getServerName(), server);<a name="line.3641"></a>
+<span class="sourceLineNo">3642</span>      this.assignmentManager.moveAsync(rp);<a name="line.3642"></a>
+<span class="sourceLineNo">3643</span>    }<a name="line.3643"></a>
+<span class="sourceLineNo">3644</span>  }<a name="line.3644"></a>
+<span class="sourceLineNo">3645</span><a name="line.3645"></a>
+<span class="sourceLineNo">3646</span>  @Override<a name="line.3646"></a>
+<span class="sourceLineNo">3647</span>  public LockManager getLockManager() {<a name="line.3647"></a>
+<span class="sourceLineNo">3648</span>    return lockManager;<a name="line.3648"></a>
 <span class="sourceLineNo">3649</span>  }<a name="line.3649"></a>
 <span class="sourceLineNo">3650</span><a name="line.3650"></a>
-<span class="sourceLineNo">3651</span>  public SpaceQuotaSnapshotNotifier getSpaceQuotaSnapshotNotifier() {<a name="line.3651"></a>
-<span class="sourceLineNo">3652</span>    return this.spaceQuotaSnapshotNotifier;<a name="line.3652"></a>
+<span class="sourceLineNo">3651</span>  public QuotaObserverChore getQuotaObserverChore() {<a name="line.3651"></a>
+<span class="sourceLineNo">3652</span>    return this.quotaObserverChore;<a name="line.3652"></a>
 <span class="sourceLineNo">3653</span>  }<a name="line.3653"></a>
 <span class="sourceLineNo">3654</span><a name="line.3654"></a>
-<span class="sourceLineNo">3655</span>  @SuppressWarnings("unchecked")<a name="line.3655"></a>
-<span class="sourceLineNo">3656</span>  private RemoteProcedure&lt;MasterProcedureEnv, ?&gt; getRemoteProcedure(long procId) {<a name="line.3656"></a>
-<span class="sourceLineNo">3657</span>    Procedure&lt;?&gt; procedure = procedureExecutor.getProcedure(procId);<a name="line.3657"></a>
-<span class="sourceLineNo">3658</span>    if (procedure == null) {<a name="line.3658"></a>
-<span class="sourceLineNo">3659</span>      return null;<a name="line.3659"></a>
-<span class="sourceLineNo">3660</span>    }<a name="line.3660"></a>
-<span class="sourceLineNo">3661</span>    assert procedure instanceof RemoteProcedure;<a name="line.3661"></a>
-<span class="sourceLineNo">3662</span>    return (RemoteProcedure&lt;MasterProcedureEnv, ?&gt;) procedure;<a name="line.3662"></a>
-<span class="sourceLineNo">3663</span>  }<a name="line.3663"></a>
-<span class="sourceLineNo">3664</span><a name="line.3664"></a>
-<span class="sourceLineNo">3665</span>  public void remoteProcedureCompleted(long procId) {<a name="line.3665"></a>
-<span class="sourceLineNo">3666</span>    LOG.debug("Remote procedure done, pid={}", procId);<a name="line.3666"></a>
-<span class="sourceLineNo">3667</span>    RemoteProcedure&lt;MasterProcedureEnv, ?&gt; procedure = getRemoteProcedure(procId);<a name="line.3667"></a>
-<span class="sourceLineNo">3668</span>    if (procedure != null) {<a name="line.3668"></a>
-<span class="sourceLineNo">3669</span>      procedure.remoteOperationCompleted(procedureExecutor.getEnvironment());<a name="line.3669"></a>
-<span class="sourceLineNo">3670</span>    }<a name="line.3670"></a>
-<span class="sourceLineNo">3671</span>  }<a name="line.3671"></a>
-<span class="sourceLineNo">3672</span><a name="line.3672"></a>
-<span class="sourceLineNo">3673</span>  public void remoteProcedureFailed(long procId, RemoteProcedureException error) {<a name="line.3673"></a>
-<span class="sourceLineNo">3674</span>    LOG.debug("Remote procedure failed, pid={}", procId, error);<a name="line.3674"></a>
-<span class="sourceLineNo">3675</span>    RemoteProcedure&lt;MasterProcedureEnv, ?&gt; procedure = getRemoteProcedure(procId);<a name="line.3675"></a>
-<span class="sourceLineNo">3676</span>    if (procedure != null) {<a name="line.3676"></a>
-<span class="sourceLineNo">3677</span>      procedure.remoteOperationFailed(procedureExecutor.getEnvironment(), error);<a name="line.3677"></a>
-<span class="sourceLineNo">3678</span>    }<a name="line.3678"></a>
-<span class="sourceLineNo">3679</span>  }<a name="line.3679"></a>
-<span class="sourceLineNo">3680</span><a name="line.3680"></a>
-<span class="sourceLineNo">3681</span>  /**<a name="line.3681"></a>
-<span class="sourceLineNo">3682</span>   * Reopen regions provided in the argument<a name="line.3682"></a>
-<span class="sourceLineNo">3683</span>   *<a name="line.3683"></a>
-<span class="sourceLineNo">3684</span>   * @param tableName The current table name<a name="line.3684"></a>
-<span class="sourceLineNo">3685</span>   * @param regionNames The region names of the regions to reopen<a name="line.3685"></a>
-<span class="sourceLineNo">3686</span>   * @param nonceGroup Identifier for the source of the request, a client or process<a name="line.3686"></a>
-<span class="sourceLineNo">3687</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3687"></a>
-<span class="sourceLineNo">3688</span>   *   &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3688"></a>
-<span class="sourceLineNo">3689</span>   * @return procedure Id<a name="line.3689"></a>
-<span class="sourceLineNo">3690</span>   * @throws IOException if reopening region fails while running procedure<a name="line.3690"></a>
-<span class="sourceLineNo">3691</span>   */<a name="line.3691"></a>
-<span class="sourceLineNo">3692</span>  long reopenRegions(final TableName tableName, final List&lt;byte[]&gt; regionNames,<a name="line.3692"></a>
-<span class="sourceLineNo">3693</span>      final long nonceGroup, final long nonce)<a name="line.3693"></a>
-<span class="sourceLineNo">3694</span>      throws IOException {<a name="line.3694"></a>
-<span class="sourceLineNo">3695</span><a name="line.3695"></a>
-<span class="sourceLineNo">3696</span>    return MasterProcedureUtil<a name="line.3696"></a>
-<span class="sourceLineNo">3697</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.3697"></a>
-<span class="sourceLineNo">3698</span><a name="line.3698"></a>
-<span class="sourceLineNo">3699</span>        @Override<a name="line.3699"></a>
-<span class="sourceLineNo">3700</span>        protected void run() throws IOException {<a name="line.3700"></a>
-<span class="sourceLineNo">3701</span>          submitProcedure(new ReopenTableRegionsProcedure(tableName, regionNames));<a name="line.3701"></a>
-<span class="sourceLineNo">3702</span>        }<a name="line.3702"></a>
-<span class="sourceLineNo">3703</span><a name="line.3703"></a>
-<span class="sourceLineNo">3704</span>        @Override<a name="line.3704"></a>
-<span class="sourceLineNo">3705</span>        protected String getDescription() {<a name="line.3705"></a>
-<span class="sourceLineNo">3706</span>          return "ReopenTableRegionsProcedure";<a name="line.3706"></a>
-<span class="sourceLineNo">3707</span>        }<a name="line.3707"></a>
-<span class="sourceLineNo">3708</span><a name="line.3708"></a>
-<span class="sourceLineNo">3709</span>      });<a name="line.3709"></a>
-<span class="sourceLineNo">3710</span><a name="line.3710"></a>
-<span class="sourceLineNo">3711</span>  }<a name="line.3711"></a>
+<span class="sourceLineNo">3655</span>  public SpaceQuotaSnapshotNotifier getSpaceQuotaSnapshotNotifier() {<a name="line.3655"></a>
+<span class="sourceLineNo">3656</span>    return this.spaceQuotaSnapshotNotifier;<a name="line.3656"></a>
+<span class="sourceLineNo">3657</span>  }<a name="line.3657"></a>
+<span class="sourceLineNo">3658</span><a name="line.3658"></a>
+<span class="sourceLineNo">3659</span>  @SuppressWarnings("unchecked")<a name="line.3659"></a>
+<span class="sourceLineNo">3660</span>  private RemoteProcedure&lt;MasterProcedureEnv, ?&gt; getRemoteProcedure(long procId) {<a name="line.3660"></a>
+<span class="sourceLineNo">3661</span>    Procedure&lt;?&gt; procedure = procedureExecutor.getProcedure(procId);<a name="line.3661"></a>
+<span class="sourceLineNo">3662</span>    if (procedure == null) {<a name="line.3662"></a>
+<span class="sourceLineNo">3663</span>      return null;<a name="line.3663"></a>
+<span class="sourceLineNo">3664</span>    }<a name="line.3664"></a>
+<span class="sourceLineNo">3665</span>    assert procedure instanceof RemoteProcedure;<a name="line.3665"></a>
+<span class="sourceLineNo">3666</span>    return (RemoteProcedure&lt;MasterProcedureEnv, ?&gt;) procedure;<a name="line.3666"></a>
+<span class="sourceLineNo">3667</span>  }<a name="line.3667"></a>
+<span class="sourceLineNo">3668</span><a name="line.3668"></a>
+<span class="sourceLineNo">3669</span>  public void remoteProcedureCompleted(long procId) {<a name="line.3669"></a>
+<span class="sourceLineNo">3670</span>    LOG.debug("Remote procedure done, pid={}", procId);<a name="line.3670"></a>
+<span class="sourceLineNo">3671</span>    RemoteProcedure&lt;MasterProcedureEnv, ?&gt; procedure = getRemoteProcedure(procId);<a name="line.3671"></a>
+<span class="sourceLineNo">3672</span>    if (procedure != null) {<a name="line.3672"></a>
+<span class="sourceLineNo">3673</span>      procedure.remoteOperationCompleted(procedureExecutor.getEnvironment());<a name="line.3673"></a>
+<span class="sourceLineNo">3674</span>    }<a name="line.3674"></a>
+<span class="sourceLineNo">3675</span>  }<a name="line.3675"></a>
+<span class="sourceLineNo">3676</span><a name="line.3676"></a>
+<span class="sourceLineNo">3677</span>  public void remoteProcedureFailed(long procId, RemoteProcedureException error) {<a name="line.3677"></a>
+<span class="sourceLineNo">3678</span>    LOG.debug("Remote procedure failed, pid={}", procId, error);<a name="line.3678"></a>
+<span class="sourceLineNo">3679</span>    RemoteProcedure&lt;MasterProcedureEnv, ?&gt; procedure = getRemoteProcedure(procId);<a name="line.3679"></a>
+<span class="sourceLineNo">3680</span>    if (procedure != null) {<a name="line.3680"></a>
+<span class="sourceLineNo">3681</span>      procedure.remoteOperationFailed(procedureExecutor.getEnvironment(), error);<a name="line.3681"></a>
+<span class="sourceLineNo">3682</span>    }<a name="line.3682"></a>
+<span class="sourceLineNo">3683</span>  }<a name="line.3683"></a>
+<span class="sourceLineNo">3684</span><a name="line.3684"></a>
+<span class="sourceLineNo">3685</span>  /**<a name="line.3685"></a>
+<span class="sourceLineNo">3686</span>   * Reopen regions provided in the argument<a name="line.3686"></a>
+<span class="sourceLineNo">3687</span>   *<a name="line.3687"></a>
+<span class="sourceLineNo">3688</span>   * @param tableName The current table name<a name="line.3688"></a>
+<span class="sourceLineNo">3689</span>   * @param regionNames The region names of the regions to reopen<a name="line.3689"></a>
+<span class="sourceLineNo">3690</span>   * @param nonceGroup Identifier for the source of the request, a client or process<a name="line.3690"></a>
+<span class="sourceLineNo">3691</span>   * @param nonce A unique identifier for this operation from the client or process identified by<a name="line.3691"></a>
+<span class="sourceLineNo">3692</span>   *   &lt;code&gt;nonceGroup&lt;/code&gt; (the source must ensure each operation gets a unique id).<a name="line.3692"></a>
+<span class="sourceLineNo">3693</span>   * @return procedure Id<a name="line.3693"></a>
+<span class="sourceLineNo">3694</span>   * @throws IOException if reopening region fails while running procedure<a name="line.3694"></a>
+<span class="sourceLineNo">3695</span>   */<a name="line.3695"></a>
+<span class="sourceLineNo">3696</span>  long reopenRegions(final TableName tableName, final List&lt;byte[]&gt; regionNames,<a name="line.3696"></a>
+<span class="sourceLineNo">3697</span>      final long nonceGroup, final long nonce)<a name="line.3697"></a>
+<span class="sourceLineNo">3698</span>      throws IOException {<a name="line.3698"></a>
+<span class="sourceLineNo">3699</span><a name="line.3699"></a>
+<span class="sourceLineNo">3700</span>    return MasterProcedureUtil<a name="line.3700"></a>
+<span class="sourceLineNo">3701</span>      .submitProcedure(new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.3701"></a>
+<span class="sourceLineNo">3702</span><a name="line.3702"></a>
+<span class="sourceLineNo">3703</span>        @Override<a name="line.3703"></a>
+<span class="sourceLineNo">3704</span>        protected void run() throws IOException {<a name="line.3704"></a>
+<span class="sourceLineNo">3705</span>          submitProcedure(new ReopenTableRegionsProcedure(tableName, regionNames));<a name="line.3705"></a>
+<span class="sourceLineNo">3706</span>        }<a name="line.3706"></a>
+<span class="sourceLineNo">3707</span><a name="line.3707"></a>
+<span class="sourceLineNo">3708</span>        @Override<a name="line.3708"></a>
+<span class="sourceLineNo">3709</span>        protected String getDescription() {<a name="line.3709"></a>
+<span class="sourceLineNo">3710</span>          return "ReopenTableRegionsProcedure";<a name="line.3710"></a>
+<span class="sourceLineNo">3711</span>        }<a name="line.3711"></a>
 <span class="sourceLineNo">3712</span><a name="line.3712"></a>
-<span class="sourceLineNo">3713</span>  @Override<a name="line.3713"></a>
-<span class="sourceLineNo">3714</span>  public ReplicationPeerManager getReplicationPeerManager() {<a name="line.3714"></a>
-<span class="sourceLineNo">3715</span>    return replicationPeerManager;<a name="line.3715"></a>
-<span class="sourceLineNo">3716</span>  }<a name="line.3716"></a>
-<span class="sourceLineNo">3717</span><a name="line.3717"></a>
-<span class="sourceLineNo">3718</span>  public HashMap&lt;String, List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt;&gt;<a name="line.3718"></a>
-<span class="sourceLineNo">3719</span>      getReplicationLoad(ServerName[] serverNames) {<a name="line.3719"></a>
-<span class="sourceLineNo">3720</span>    List&lt;ReplicationPeerDescription&gt; peerList = this.getReplicationPeerManager().listPeers(null);<a name="line.3720"></a>
-<span class="sourceLineNo">3721</span>    if (peerList == null) {<a name="line.3721"></a>
-<span class="sourceLineNo">3722</span>      return null;<a name="line.3722"></a>
-<span class="sourceLineNo">3723</span>    }<a name="line.3723"></a>
-<span class="sourceLineNo">3724</span>    HashMap&lt;String, List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt;&gt; replicationLoadSourceMap =<a name="line.3724"></a>
-<span class="sourceLineNo">3725</span>        new HashMap&lt;&gt;(peerList.size());<a name="line.3725"></a>
-<span class="sourceLineNo">3726</span>    peerList.stream()<a name="line.3726"></a>
-<span class="sourceLineNo">3727</span>        .forEach(peer -&gt; replicationLoadSourceMap.put(peer.getPeerId(), new ArrayList&lt;&gt;()));<a name="line.3727"></a>
-<span class="sourceLineNo">3728</span>    for (ServerName serverName : serverNames) {<a name="line.3728"></a>
-<span class="sourceLineNo">3729</span>      List&lt;ReplicationLoadSource&gt; replicationLoadSources =<a name="line.3729"></a>
-<span class="sourceLineNo">3730</span>          getServerManager().getLoad(serverName).getReplicationLoadSourceList();<a name="line.3730"></a>
-<span class="sourceLineNo">3731</span>      for (ReplicationLoadSource replicationLoadSource : replicationLoadSources) {<a name="line.3731"></a>
-<span class="sourceLineNo">3732</span>        replicationLoadSourceMap.get(replicationLoadSource.getPeerID())<a name="line.3732"></a>
-<span class="sourceLineNo">3733</span>            .add(new Pair&lt;&gt;(serverName, replicationLoadSource));<a name="line.3733"></a>
-<span class="sourceLineNo">3734</span>      }<a name="line.3734"></a>
-<span class="sourceLineNo">3735</span>    }<a name="line.3735"></a>
-<span class="sourceLineNo">3736</span>    for (List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt; loads : replicationLoadSourceMap.values()) {<a name="line.3736"></a>
-<span class="sourceLineNo">3737</span>      if (loads.size() &gt; 0) {<a name="line.3737"></a>
-<span class="sourceLineNo">3738</span>        loads.sort(Comparator.comparingLong(load -&gt; (-1) * load.getSecond().getReplicationLag()));<a name="line.3738"></a>
-<span class="sourceLineNo">3739</span>      }<a name="line.3739"></a>
-<span class="sourceLineNo">3740</span>    }<a name="line.3740"></a>
-<span class="sourceLineNo">3741</span>    return replicationLoadSourceMap;<a name="line.3741"></a>
-<span class="sourceLineNo">3742</span>  }<a name="line.3742"></a>
-<span class="sourceLineNo">3743</span><a name="line.3743"></a>
-<span class="sourceLineNo">3744</span>  /**<a name="line.3744"></a>
-<span class="sourceLineNo">3745</span>   * This method modifies the master's configuration in order to inject replication-related features<a name="line.3745"></a>
-<span class="sourceLineNo">3746</span>   */<a name="line.3746"></a>
-<span class="sourceLineNo">3747</span>  @VisibleForTesting<a name="line.3747"></a>
-<span class="sourceLineNo">3748</span>  public static void decorateMasterConfiguration(Configuration conf) {<a name="line.3748"></a>
-<span class="sourceLineNo">3749</span>    String plugins = conf.get(HBASE_MASTER_LOGCLEANER_PLUGINS);<a name="line.3749"></a>
-<span class="sourceLineNo">3750</span>    String cleanerClass = ReplicationLogCleaner.class.getCanonicalName();<a name="line.3750"></a>
-<span class="sourceLineNo">3751</span>    if (plugins == null || !plugins.contains(cleanerClass)) {<a name="line.3751"></a>
-<span class="sourceLineNo">3752</span>      conf.set(HBASE_MASTER_LOGCLEANER_PLUGINS, plugins + "," + cleanerClass);<a name="line.3752"></a>
-<span class="sourceLineNo">3753</span>    }<a name="line.3753"></a>
-<span class="sourceLineNo">3754</span>    if (ReplicationUtils.isReplicationForBulkLoadDataEnabled(conf)) {<a name="line.3754"></a>
-<span class="sourceLineNo">3755</span>      plugins = conf.get(HFileCleaner.MASTER_HFILE_CLEANER_PLUGINS);<a name="line.3755"></a>
-<span class="sourceLineNo">3756</span>      cleanerClass = ReplicationHFileCleaner.class.getCanonicalName();<a name="line.3756"></a>
-<span class="sourceLineNo">3757</span>      if (!plugins.contains(cleanerClass)) {<a name="line.3757"></a>
-<span class="sourceLineNo">3758</span>        conf.set(HFileCleaner.MASTER_HFILE_CLEANER_PLUGINS, plugins + "," + cleanerClass);<a name="line.3758"></a>
-<span class="sourceLineNo">3759</span>      }<a name="line.3759"></a>
-<span class="sourceLineNo">3760</span>    }<a name="line.3760"></a>
-<span class="sourceLineNo">3761</span>  }<a name="line.3761"></a>
-<span class="sourceLineNo">3762</span><a name="line.3762"></a>
-<span class="sourceLineNo">3763</span>  public SnapshotQuotaObserverChore getSnapshotQuotaObserverChore() {<a name="line.3763"></a>
-<span class="sourceLineNo">3764</span>    return this.snapshotQuotaChore;<a name="line.3764"></a>
+<span class="sourceLineNo">3713</span>      });<a name="line.3713"></a>
+<span class="sourceLineNo">3714</span><a name="line.3714"></a>
+<span class="sourceLineNo">3715</span>  }<a name="line.3715"></a>
+<span class="sourceLineNo">3716</span><a name="line.3716"></a>
+<span class="sourceLineNo">3717</span>  @Override<a name="line.3717"></a>
+<span class="sourceLineNo">3718</span>  public ReplicationPeerManager getReplicationPeerManager() {<a name="line.3718"></a>
+<span class="sourceLineNo">3719</span>    return replicationPeerManager;<a name="line.3719"></a>
+<span class="sourceLineNo">3720</span>  }<a name="line.3720"></a>
+<span class="sourceLineNo">3721</span><a name="line.3721"></a>
+<span class="sourceLineNo">3722</span>  public HashMap&lt;String, List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt;&gt;<a name="line.3722"></a>
+<span class="sourceLineNo">3723</span>      getReplicationLoad(ServerName[] serverNames) {<a name="line.3723"></a>
+<span class="sourceLineNo">3724</span>    List&lt;ReplicationPeerDescription&gt; peerList = this.getReplicationPeerManager().listPeers(null);<a name="line.3724"></a>
+<span class="sourceLineNo">3725</span>    if (peerList == null) {<a name="line.3725"></a>
+<span class="sourceLineNo">3726</span>      return null;<a name="line.3726"></a>
+<span class="sourceLineNo">3727</span>    }<a name="line.3727"></a>
+<span class="sourceLineNo">3728</span>    HashMap&lt;String, List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt;&gt; replicationLoadSourceMap =<a name="line.3728"></a>
+<span class="sourceLineNo">3729</span>        new HashMap&lt;&gt;(peerList.size());<a name="line.3729"></a>
+<span class="sourceLineNo">3730</span>    peerList.stream()<a name="line.3730"></a>
+<span class="sourceLineNo">3731</span>        .forEach(peer -&gt; replicationLoadSourceMap.put(peer.getPeerId(), new ArrayList&lt;&gt;()));<a name="line.3731"></a>
+<span class="sourceLineNo">3732</span>    for (ServerName serverName : serverNames) {<a name="line.3732"></a>
+<span class="sourceLineNo">3733</span>      List&lt;ReplicationLoadSource&gt; replicationLoadSources =<a name="line.3733"></a>
+<span class="sourceLineNo">3734</span>          getServerManager().getLoad(serverName).getReplicationLoadSourceList();<a name="line.3734"></a>
+<span class="sourceLineNo">3735</span>      for (ReplicationLoadSource replicationLoadSource : replicationLoadSources) {<a name="line.3735"></a>
+<span class="sourceLineNo">3736</span>        replicationLoadSourceMap.get(replicationLoadSource.getPeerID())<a name="line.3736"></a>
+<span class="sourceLineNo">3737</span>            .add(new Pair&lt;&gt;(serverName, replicationLoadSource));<a name="line.3737"></a>
+<span class="sourceLineNo">3738</span>      }<a name="line.3738"></a>
+<span class="sourceLineNo">3739</span>    }<a name="line.3739"></a>
+<span class="sourceLineNo">3740</span>    for (List&lt;Pair&lt;ServerName, ReplicationLoadSource&gt;&gt; loads : replicationLoadSourceMap.values()) {<a name="line.3740"></a>
+<span class="sourceLineNo">3741</span>      if (loads.size() &gt; 0) {<a name="line.3741"></a>
+<span class="sourceLineNo">3742</span>        loads.sort(Comparator.comparingLong(load -&gt; (-1) * load.getSecond().getReplicationLag()));<a name="line.3742"></a>
+<span class="sourceLineNo">3743</span>      }<a name="line.3743"></a>
+<span class="sourceLineNo">3744</span>    }<a name="line.3744"></a>
+<span class="sourceLineNo">3745</span>    return replicationLoadSourceMap;<a name="line.3745"></a>
+<span class="sourceLineNo">3746</span>  }<a name="line.3746"></a>
+<span class="sourceLineNo">3747</span><a name="line.3747"></a>
+<span class="sourceLineNo">3748</span>  /**<a name="line.3748"></a>
+<span class="sourceLineNo">3749</span>   * This method modifies the master's configuration in order to inject replication-related features<a name="line.3749"></a>
+<span class="sourceLineNo">3750</span>   */<a name="line.3750"></a>
+<span class="sourceLineNo">3751</span>  @VisibleForTesting<a name="line.3751"></a>
+<span class="sourceLineNo">3752</span>  public static void decorateMasterConfiguration(Configuration conf) {<a name="line.3752"></a>
+<span class="sourceLineNo">3753</span>    String plugins = conf.get(HBASE_MASTER_LOGCLEANER_PLUGINS);<a name="line.3753"></a>
+<span class="sourceLineNo">3754</span>    String cleanerClass = ReplicationLogCleaner.class.getCanonicalName();<a name="line.3754"></a>
+<span class="sourceLineNo">3755</span>    if (plugins == null || !plugins.contains(cleanerClass)) {<a name="line.3755"></a>
+<span class="sourceLineNo">3756</span>      conf.set(HBASE_MASTER_LOGCLEANER_PLUGINS, plugins + "," + cleanerClass);<a name="line.3756"></a>
+<span class="sourceLineNo">3757</span>    }<a name="line.3757"></a>
+<span class="sourceLineNo">3758</span>    if (ReplicationUtils.isReplicationForBulkLoadDataEnabled(conf)) {<a name="line.3758"></a>
+<span class="sourceLineNo">3759</span>      plugins = conf.get(HFileCleaner.MASTER_HFILE_CLEANER_PLUGINS);<a name="line.3759"></a>
+<span class="sourceLineNo">3760</span>      cleanerClass = ReplicationHFileCleaner.class.getCanonicalName();<a name="line.3760"></a>
+<span class="sourceLineNo">3761</span>      if (!plugins.contains(cleanerClass)) {<a name="line.3761"></a>
+<span class="sourceLineNo">3762</span>        conf.set(HFileCleaner.MASTER_HFILE_CLEANER_PLUGINS, plugins + "," + cleanerClass);<a name="line.3762"></a>
+<span class="sourceLineNo">3763</span>      }<a name="line.3763"></a>
+<span class="sourceLineNo">3764</span>    }<a name="line.3764"></a>
 <span class="sourceLineNo">3765</span>  }<a name="line.3765"></a>
 <span class="sourceLineNo">3766</span><a name="line.3766"></a>
-<span class="sourceLineNo">3767</span>  @Override<a name="line.3767"></a>
-<span class="sourceLineNo">3768</span>  public SyncReplicationReplayWALManager getSyncReplicationReplayWALManager() {<a name="line.3768"></a>
-<span class="sourceLineNo">3769</span>    return this.syncReplicationReplayWALManager;<a name="line.3769"></a>
-<span class="sourceLineNo">3770</span>  }<a name="line.3770"></a>
-<span class="sourceLineNo">3771</span><a name="line.3771"></a>
-<span class="sourceLineNo">3772</span>  @Override<a name="line.3772"></a>
-<span class="sourceLineNo">3773</span>  public Map&lt;String, ReplicationStatus&gt; getWalGroupsReplicationStatus() {<a name="line.3773"></a>
-<span class="sourceLineNo">3774</span>    if (!this.isOnline() || !LoadBalancer.isMasterCanHostUserRegions(conf)) {<a name="line.3774"></a>
-<span class="sourceLineNo">3775</span>      return new HashMap&lt;&gt;();<a name="line.3775"></a>
-<span class="sourceLineNo">3776</span>    }<a name="line.3776"></a>
-<span class="sourceLineNo">3777</span>    return super.getWalGroupsReplicationStatus();<a name="line.3777"></a>
-<span class="sourceLineNo">3778</span>  }<a name="line.3778"></a>
-<span class="sourceLineNo">3779</span><a name="line.3779"></a>
-<span class="sourceLineNo">3780</span>  public HbckChore getHbckChore() {<a name="line.3780"></a>
-<span class="sourceLineNo">3781</span>    return this.hbckChore;<a name="line.3781"></a>
+<span class="sourceLineNo">3767</span>  public SnapshotQuotaObserverChore getSnapshotQuotaObserverChore() {<a name="line.3767"></a>
+<span class="sourceLineNo">3768</span>    return this.snapshotQuotaChore;<a name="line.3768"></a>
+<span class="sourceLineNo">3769</span>  }<a name="line.3769"></a>
+<span class="sourceLineNo">3770</span><a name="line.3770"></a>
+<span class="sourceLineNo">3771</span>  @Override<a name="line.3771"></a>
+<span class="sourceLineNo">3772</span>  public SyncReplicationReplayWALManager getSyncReplicationReplayWALManager() {<a name="line.3772"></a>
+<span class="sourceLineNo">3773</span>    return this.syncReplicationReplayWALManager;<a name="line.3773"></a>
+<span class="sourceLineNo">3774</span>  }<a name="line.3774"></a>
+<span class="sourceLineNo">3775</span><a name="line.3775"></a>
+<span class="sourceLineNo">3776</span>  @Override<a name="line.3776"></a>
+<span class="sourceLineNo">3777</span>  public Map&lt;String, ReplicationStatus&gt; getWalGroupsReplicationStatus() {<a name="line.3777"></a>
+<span class="sourceLineNo">3778</span>    if (!this.isOnline() || !LoadBalancer.isMasterCanHostUserRegions(conf)) {<a name="line.3778"></a>
+<span class="sourceLineNo">3779</span>      return new HashMap&lt;&gt;();<a name="line.3779"></a>
+<span class="sourceLineNo">3780</span>    }<a name="line.3780"></a>
+<span class="sourceLineNo">3781</span>    return super.getWalGroupsReplicationStatus();<a name="line.3781"></a>
 <span class="sourceLineNo">3782</span>  }<a name="line.3782"></a>
 <span class="sourceLineNo">3783</span><a name="line.3783"></a>
-<span class="sourceLineNo">3784</span>  @Override<a name="line.3784"></a>
-<span class="sourceLineNo">3785</span>  public String getClusterId() {<a name="line.3785"></a>
-<span class="sourceLineNo">3786</span>    if (activeMaster) {<a name="line.3786"></a>
-<span class="sourceLineNo">3787</span>      return super.getClusterId();<a name="line.3787"></a>
-<span class="sourceLineNo">3788</span>    }<a name="line.3788"></a>
-<span class="sourceLineNo">3789</span>    return cachedClusterId.getFromCacheOrFetch();<a name="line.3789"></a>
-<span class="sourceLineNo">3790</span>  }<a name="line.3790"></a>
-<span class="sourceLineNo">3791</span><a name="line.3791"></a>
-<span class="sourceLineNo">3792</span>  public Optional&lt;ServerName&gt; getActiveMaster() {<a name="line.3792"></a>
-<span class="sourceLineNo">3793</span>    return activeMasterManager.getActiveMasterServerName();<a name="line.3793"></a>
+<span class="sourceLineNo">3784</span>  public HbckChore getHbckChore() {<a name="line.3784"></a>
+<span class="sourceLineNo">3785</span>    return this.hbckChore;<a name="line.3785"></a>
+<span class="sourceLineNo">3786</span>  }<a name="line.3786"></a>
+<span class="sourceLineNo">3787</span><a name="line.3787"></a>
+<span class="sourceLineNo">3788</span>  @Override<a name="line.3788"></a>
+<span class="sourceLineNo">3789</span>  public String getClusterId() {<a name="line.3789"></a>
+<span class="sourceLineNo">3790</span>    if (activeMaster) {<a name="line.3790"></a>
+<span class="sourceLineNo">3791</span>      return super.getClusterId();<a name="line.3791"></a>
+<span class="sourceLineNo">3792</span>    }<a name="line.3792"></a>
+<span class="sourceLineNo">3793</span>    return cachedClusterId.getFromCacheOrFetch();<a name="line.3793"></a>
 <span class="sourceLineNo">3794</span>  }<a name="line.3794"></a>
 <span class="sourceLineNo">3795</span><a name="line.3795"></a>
-<span class="sourceLineNo">3796</span>  @Override<a name="line.3796"></a>
-<span class="sourceLineNo">3797</span>  public void runReplicationBarrierCleaner() {<a name="line.3797"></a>
-<span class="sourceLineNo">3798</span>    ReplicationBarrierCleaner rbc = this.replicationBarrierCleaner;<a name="line.3798"></a>
-<span class="sourceLineNo">3799</span>    if (rbc != null) {<a name="line.3799"></a>
-<span class="sourceLineNo">3800</span>      rbc.chore();<a name="line.3800"></a>
-<span class="sourceLineNo">3801</span>    }<a name="line.3801"></a>
-<span class="sourceLineNo">3802</span>  }<a name="line.3802"></a>
-<span class="sourceLineNo">3803</span><a name="line.3803"></a>
-<span class="sourceLineNo">3804</span>  public MetaRegionLocationCache getMetaRegionLocationCache() {<a name="line.3804"></a>
-<span class="sourceLineNo">3805</span>    return this.metaRegionLocationCache;<a name="line.3805"></a>
+<span class="sourceLineNo">3796</span>  public Optional&lt;ServerName&gt; getActiveMaster() {<a name="line.3796"></a>
+<span class="sourceLineNo">3797</span>    return activeMasterManager.getActiveMasterServerName();<a name="line.3797"></a>
+<span class="sourceLineNo">3798</span>  }<a name="line.3798"></a>
+<span class="sourceLineNo">3799</span><a name="line.3799"></a>
+<span class="sourceLineNo">3800</span>  @Override<a name="line.3800"></a>
+<span class="sourceLineNo">3801</span>  public void runReplicationBarrierCleaner() {<a name="line.3801"></a>
+<span class="sourceLineNo">3802</span>    ReplicationBarrierCleaner rbc = this.replicationBarrierCleaner;<a name="line.3802"></a>
+<span class="sourceLineNo">3803</span>    if (rbc != null) {<a name="line.3803"></a>
+<span class="sourceLineNo">3804</span>      rbc.chore();<a name="line.3804"></a>
+<span class="sourceLineNo">3805</span>    }<a name="line.3805"></a>
 <span class="sourceLineNo">3806</span>  }<a name="line.3806"></a>
 <span class="sourceLineNo">3807</span><a name="line.3807"></a>
-<span class="sourceLineNo">3808</span>  @Override<a name="line.3808"></a>
-<span class="sourceLineNo">3809</span>  public RSGroupInfoManager getRSGroupInfoManager() {<a name="line.3809"></a>
-<span class="sourceLineNo">3810</span>    return rsGroupInfoManager;<a name="line.3810"></a>
-<span class="sourceLineNo">3811</span>  }<a name="line.3811"></a>
-<span class="sourceLineNo">3812</span><a name="line.3812"></a>
-<span class="sourceLineNo">3813</span>  /**<a name="line.3813"></a>
-<span class="sourceLineNo">3814</span>   * Get the compaction state of the table<a name="line.3814"></a>
-<span class="sourceLineNo">3815</span>   *<a name="line.3815"></a>
-<span class="sourceLineNo">3816</span>   * @param tableName The table name<a name="line.3816"></a>
-<span class="sourceLineNo">3817</span>   * @return CompactionState Compaction state of the table<a name="line.3817"></a>
-<span class="sourceLineNo">3818</span>   */<a name="line.3818"></a>
-<span class="sourceLineNo">3819</span>  public CompactionState getCompactionState(final TableName tableName) {<a name="line.3819"></a>
-<span class="sourceLineNo">3820</span>    CompactionState compactionState = CompactionState.NONE;<a name="line.3820"></a>
-<span class="sourceLineNo">3821</span>    try {<a name="line.3821"></a>
-<span class="sourceLineNo">3822</span>      List&lt;RegionInfo&gt; regions =<a name="line.3822"></a>
-<span class="sourceLineNo">3823</span>        assignmentManager.getRegionStates().getRegionsOfTable(tableName, false);<a name="line.3823"></a>
-<span class="sourceLineNo">3824</span>      for (RegionInfo regionInfo : regions) {<a name="line.3824"></a>
-<span class="sourceLineNo">3825</span>        ServerName serverName =<a name="line.3825"></a>
-<span class="sourceLineNo">3826</span>          assignmentManager.getRegionStates().getRegionServerOfRegion(regionInfo);<a name="line.3826"></a>
-<span class="sourceLineNo">3827</span>        if (serverName == null) {<a name="line.3827"></a>
-<span class="sourceLineNo">3828</span>          continue;<a name="line.3828"></a>
-<span class="sourceLineNo">3829</span>        }<a name="line.3829"></a>
-<span class="sourceLineNo">3830</span>        ServerMetrics sl = serverManager.getLoad(serverName);<a name="line.3830"></a>
-<span class="sourceLineNo">3831</span>        if (sl == null) {<a name="line.3831"></a>
+<span class="sourceLineNo">3808</span>  public MetaRegionLocationCache getMetaRegionLocationCache() {<a name="line.3808"></a>
+<span class="sourceLineNo">3809</span>    return this.metaRegionLocationCache;<a name="line.3809"></a>
+<span class="sourceLineNo">3810</span>  }<a name="line.3810"></a>
+<span class="sourceLineNo">3811</span><a name="line.3811"></a>
+<span class="sourceLineNo">3812</span>  @Override<a name="line.3812"></a>
+<span class="sourceLineNo">3813</span>  public RSGroupInfoManager getRSGroupInfoManager() {<a name="line.3813"></a>
+<span class="sourceLineNo">3814</span>    return rsGroupInfoManager;<a name="line.3814"></a>
+<span class="sourceLineNo">3815</span>  }<a name="line.3815"></a>
+<span class="sourceLineNo">3816</span><a name="line.3816"></a>
+<span class="sourceLineNo">3817</span>  /**<a name="line.3817"></a>
+<span class="sourceLineNo">3818</span>   * Get the compaction state of the table<a name="line.3818"></a>
+<span class="sourceLineNo">3819</span>   *<a name="line.3819"></a>
+<span class="sourceLineNo">3820</span>   * @param tableName The table name<a name="line.3820"></a>
+<span class="sourceLineNo">3821</span>   * @return CompactionState Compaction state of the table<a name="line.3821"></a>
+<span class="sourceLineNo">3822</span>   */<a name="line.3822"></a>
+<span class="sourceLineNo">3823</span>  public CompactionState getCompactionState(final TableName tableName) {<a name="line.3823"></a>
+<span class="sourceLineNo">3824</span>    CompactionState compactionState = CompactionState.NONE;<a name="line.3824"></a>
+<span class="sourceLineNo">3825</span>    try {<a name="line.3825"></a>
+<span class="sourceLineNo">3826</span>      List&lt;RegionInfo&gt; regions =<a name="line.3826"></a>
+<span class="sourceLineNo">3827</span>        assignmentManager.getRegionStates().getRegionsOfTable(tableName, false);<a name="line.3827"></a>
+<span class="sourceLineNo">3828</span>      for (RegionInfo regionInfo : regions) {<a name="line.3828"></a>
+<span class="sourceLineNo">3829</span>        ServerName serverName =<a name="line.3829"></a>
+<span class="sourceLineNo">3830</span>          assignmentManager.getRegionStates().getRegionServerOfRegion(regionInfo);<a name="line.3830"></a>
+<span class="sourceLineNo">3831</span>        if (serverName == null) {<a name="line.3831"></a>
 <span class="sourceLineNo">3832</span>          continue;<a name="line.3832"></a>
 <span class="sourceLineNo">3833</span>        }<a name="line.3833"></a>
-<span class="sourceLineNo">3834</span>        RegionMetrics regionMetrics = sl.getRegionMetrics().get(regionInfo.getRegionName());<a name="line.3834"></a>
-<span class="sourceLineNo">3835</span>        if (regionMetrics.getCompactionState() == CompactionState.MAJOR) {<a name="line.3835"></a>
-<span class="sourceLineNo">3836</span>          if (compactionState == CompactionState.MINOR) {<a name="line.3836"></a>
-<span class="sourceLineNo">3837</span>            compactionState = CompactionState.MAJOR_AND_MINOR;<a name="line.3837"></a>
-<span class="sourceLineNo">3838</span>          } else {<a name="line.3838"></a>
-<span class="sourceLineNo">3839</span>            compactionState = CompactionState.MAJOR;<a name="line.3839"></a>
-<span class="sourceLineNo">3840</span>          }<a name="line.3840"></a>
-<span class="sourceLineNo">3841</span>        } else if (regionMetrics.getCompactionState() == CompactionState.MINOR) {<a name="line.3841"></a>
-<span class="sourceLineNo">3842</span>          if (compactionState == CompactionState.MAJOR) {<a name="line.3842"></a>
-<span class="sourceLineNo">3843</span>            compactionState = CompactionState.MAJOR_AND_MINOR;<a name="line.3843"></a>
-<span class="sourceLineNo">3844</span>          } else {<a name="line.3844"></a>
-<span class="sourceLineNo">3845</span>            compactionState = CompactionState.MINOR;<a name="line.3845"></a>
-<span class="sourceLineNo">3846</span>          }<a name="line.3846"></a>
-<span class="sourceLineNo">3847</span>        }<a name="line.3847"></a>
-<span class="sourceLineNo">3848</span>      }<a name="line.3848"></a>
-<span class="sourceLineNo">3849</span>    } catch (Exception e) {<a name="line.3849"></a>
-<span class="sourceLineNo">3850</span>      compactionState = null;<a name="line.3850"></a>
-<span class="sourceLineNo">3851</span>      LOG.error("Exception when get compaction state for " + tableName.getNameAsString(), e);<a name="line.3851"></a>
-<span class="sourceLineNo">3852</span>    }<a name="line.3852"></a>
-<span class="sourceLineNo">3853</span>    return compactionState;<a name="line.3853"></a>
-<span class="sourceLineNo">3854</span>  }<a name="line.3854"></a>
-<span class="sourceLineNo">3855</span>}<a name="line.3855"></a>
+<span class="sourceLineNo">3834</span>        ServerMetrics sl = serverManager.getLoad(serverName);<a name="line.3834"></a>
+<span class="sourceLineNo">3835</span>        if (sl == null) {<a name="line.3835"></a>
+<span class="sourceLineNo">3836</span>          continue;<a name="line.3836"></a>
+<span class="sourceLineNo">3837</span>        }<a name="line.3837"></a>
+<span class="sourceLineNo">3838</span>        RegionMetrics regionMetrics = sl.getRegionMetrics().get(regionInfo.getRegionName());<a name="line.3838"></a>
+<span class="sourceLineNo">3839</span>        if (regionMetrics.getCompactionState() == CompactionState.MAJOR) {<a name="line.3839"></a>
+<span class="sourceLineNo">3840</span>          if (compactionState == CompactionState.MINOR) {<a name="line.3840"></a>
+<span class="sourceLineNo">3841</span>            compactionState = CompactionState.MAJOR_AND_MINOR;<a name="line.3841"></a>
+<span class="sourceLineNo">3842</span>          } else {<a name="line.3842"></a>
+<span class="sourceLineNo">3843</span>            compactionState = CompactionState.MAJOR;<a name="line.3843"></a>
+<span class="sourceLineNo">3844</span>          }<a name="line.3844"></a>
+<span class="sourceLineNo">3845</span>        } else if (regionMetrics.getCompactionState() == CompactionState.MINOR) {<a name="line.3845"></a>
+<span class="sourceLineNo">3846</span>          if (compactionState == CompactionState.MAJOR) {<a name="line.3846"></a>
+<span class="sourceLineNo">3847</span>            compactionState = CompactionState.MAJOR_AND_MINOR;<a name="line.3847"></a>
+<span class="sourceLineNo">3848</span>          } else {<a name="line.3848"></a>
+<span class="sourceLineNo">3849</span>            compactionState = CompactionState.MINOR;<a name="line.3849"></a>
+<span class="sourceLineNo">3850</span>          }<a name="line.3850"></a>
+<span class="sourceLineNo">3851</span>        }<a name="line.3851"></a>
+<span class="sourceLineNo">3852</span>      }<a name="line.3852"></a>
+<span class="sourceLineNo">3853</span>    } catch (Exception e) {<a name="line.3853"></a>
+<span class="sourceLineNo">3854</span>      compactionState = null;<a name="line.3854"></a>
+<span class="sourceLineNo">3855</span>      LOG.error("Exception when get compaction state for " + tableName.getNameAsString(), e);<a name="line.3855"></a>
+<span class="sourceLineNo">3856</span>    }<a name="line.3856"></a>
+<span class="sourceLineNo">3857</span>    return compactionState;<a name="line.3857"></a>
+<span class="sourceLineNo">3858</span>  }<a name="line.3858"></a>
+<span class="sourceLineNo">3859</span>}<a name="line.3859"></a>
 
 
 
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
index 36df221..ed58524 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/master/HMaster.MasterStoppedException.html
@@ -1131,2736 +1131,2740 @@
 <span class="sourceLineNo">1123</span>    getChoreService().scheduleChore(clusterStatusChore);<a name="line.1123"></a>
 <span class="sourceLineNo">1124</span>    this.balancerChore = new BalancerChore(this);<a name="line.1124"></a>
 <span class="sourceLineNo">1125</span>    getChoreService().scheduleChore(balancerChore);<a name="line.1125"></a>
-<span class="sourceLineNo">1126</span>    getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1126"></a>
-<span class="sourceLineNo">1127</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1127"></a>
-<span class="sourceLineNo">1128</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1128"></a>
-<span class="sourceLineNo">1129</span>    this.hbckChore = new HbckChore(this);<a name="line.1129"></a>
-<span class="sourceLineNo">1130</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1130"></a>
-<span class="sourceLineNo">1131</span>    this.serverManager.startChore();<a name="line.1131"></a>
-<span class="sourceLineNo">1132</span><a name="line.1132"></a>
-<span class="sourceLineNo">1133</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1133"></a>
-<span class="sourceLineNo">1134</span>    if (!waitForNamespaceOnline()) {<a name="line.1134"></a>
-<span class="sourceLineNo">1135</span>      return;<a name="line.1135"></a>
-<span class="sourceLineNo">1136</span>    }<a name="line.1136"></a>
-<span class="sourceLineNo">1137</span>    status.setStatus("Starting cluster schema service");<a name="line.1137"></a>
-<span class="sourceLineNo">1138</span>    initClusterSchemaService();<a name="line.1138"></a>
-<span class="sourceLineNo">1139</span><a name="line.1139"></a>
-<span class="sourceLineNo">1140</span>    if (this.cpHost != null) {<a name="line.1140"></a>
-<span class="sourceLineNo">1141</span>      try {<a name="line.1141"></a>
-<span class="sourceLineNo">1142</span>        this.cpHost.preMasterInitialization();<a name="line.1142"></a>
-<span class="sourceLineNo">1143</span>      } catch (IOException e) {<a name="line.1143"></a>
-<span class="sourceLineNo">1144</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<a name="line.1144"></a>
-<span class="sourceLineNo">1145</span>      }<a name="line.1145"></a>
-<span class="sourceLineNo">1146</span>    }<a name="line.1146"></a>
-<span class="sourceLineNo">1147</span><a name="line.1147"></a>
-<span class="sourceLineNo">1148</span>    status.markComplete("Initialization successful");<a name="line.1148"></a>
-<span class="sourceLineNo">1149</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1149"></a>
-<span class="sourceLineNo">1150</span>       (System.currentTimeMillis() - masterActiveTime) / 1000.0f));<a name="line.1150"></a>
-<span class="sourceLineNo">1151</span>    this.masterFinishedInitializationTime = System.currentTimeMillis();<a name="line.1151"></a>
-<span class="sourceLineNo">1152</span>    configurationManager.registerObserver(this.balancer);<a name="line.1152"></a>
-<span class="sourceLineNo">1153</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1153"></a>
-<span class="sourceLineNo">1154</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1154"></a>
-<span class="sourceLineNo">1155</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1155"></a>
-<span class="sourceLineNo">1156</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1156"></a>
-<span class="sourceLineNo">1157</span>    // Set master as 'initialized'.<a name="line.1157"></a>
-<span class="sourceLineNo">1158</span>    setInitialized(true);<a name="line.1158"></a>
-<span class="sourceLineNo">1159</span><a name="line.1159"></a>
-<span class="sourceLineNo">1160</span>    if (maintenanceMode) {<a name="line.1160"></a>
-<span class="sourceLineNo">1161</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1161"></a>
-<span class="sourceLineNo">1162</span>      return;<a name="line.1162"></a>
-<span class="sourceLineNo">1163</span>    }<a name="line.1163"></a>
-<span class="sourceLineNo">1164</span><a name="line.1164"></a>
-<span class="sourceLineNo">1165</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1165"></a>
-<span class="sourceLineNo">1166</span>    status.setStatus("Starting quota manager");<a name="line.1166"></a>
-<span class="sourceLineNo">1167</span>    initQuotaManager();<a name="line.1167"></a>
-<span class="sourceLineNo">1168</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1168"></a>
-<span class="sourceLineNo">1169</span>      // Create the quota snapshot notifier<a name="line.1169"></a>
-<span class="sourceLineNo">1170</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1170"></a>
-<span class="sourceLineNo">1171</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1171"></a>
-<span class="sourceLineNo">1172</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1172"></a>
-<span class="sourceLineNo">1173</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1173"></a>
-<span class="sourceLineNo">1174</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1174"></a>
-<span class="sourceLineNo">1175</span><a name="line.1175"></a>
-<span class="sourceLineNo">1176</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1176"></a>
-<span class="sourceLineNo">1177</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1177"></a>
-<span class="sourceLineNo">1178</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1178"></a>
-<span class="sourceLineNo">1179</span>    }<a name="line.1179"></a>
-<span class="sourceLineNo">1180</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1180"></a>
-<span class="sourceLineNo">1181</span>    slowLogMasterService.init();<a name="line.1181"></a>
-<span class="sourceLineNo">1182</span><a name="line.1182"></a>
-<span class="sourceLineNo">1183</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1183"></a>
-<span class="sourceLineNo">1184</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1184"></a>
-<span class="sourceLineNo">1185</span>    // master initialization. See HBASE-5916.<a name="line.1185"></a>
-<span class="sourceLineNo">1186</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1186"></a>
-<span class="sourceLineNo">1187</span><a name="line.1187"></a>
-<span class="sourceLineNo">1188</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1188"></a>
-<span class="sourceLineNo">1189</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1189"></a>
-<span class="sourceLineNo">1190</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1190"></a>
-<span class="sourceLineNo">1191</span><a name="line.1191"></a>
-<span class="sourceLineNo">1192</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1192"></a>
-<span class="sourceLineNo">1193</span>    initMobCleaner();<a name="line.1193"></a>
-<span class="sourceLineNo">1194</span><a name="line.1194"></a>
-<span class="sourceLineNo">1195</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1195"></a>
-<span class="sourceLineNo">1196</span>    if (this.cpHost != null) {<a name="line.1196"></a>
-<span class="sourceLineNo">1197</span>      // don't let cp initialization errors kill the master<a name="line.1197"></a>
-<span class="sourceLineNo">1198</span>      try {<a name="line.1198"></a>
-<span class="sourceLineNo">1199</span>        this.cpHost.postStartMaster();<a name="line.1199"></a>
-<span class="sourceLineNo">1200</span>      } catch (IOException ioe) {<a name="line.1200"></a>
-<span class="sourceLineNo">1201</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1201"></a>
-<span class="sourceLineNo">1202</span>      }<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>    zombieDetector.interrupt();<a name="line.1205"></a>
+<span class="sourceLineNo">1126</span>    if (regionNormalizerManager != null) {<a name="line.1126"></a>
+<span class="sourceLineNo">1127</span>      getChoreService().scheduleChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1127"></a>
+<span class="sourceLineNo">1128</span>    }<a name="line.1128"></a>
+<span class="sourceLineNo">1129</span>    this.catalogJanitorChore = new CatalogJanitor(this);<a name="line.1129"></a>
+<span class="sourceLineNo">1130</span>    getChoreService().scheduleChore(catalogJanitorChore);<a name="line.1130"></a>
+<span class="sourceLineNo">1131</span>    this.hbckChore = new HbckChore(this);<a name="line.1131"></a>
+<span class="sourceLineNo">1132</span>    getChoreService().scheduleChore(hbckChore);<a name="line.1132"></a>
+<span class="sourceLineNo">1133</span>    this.serverManager.startChore();<a name="line.1133"></a>
+<span class="sourceLineNo">1134</span><a name="line.1134"></a>
+<span class="sourceLineNo">1135</span>    // Only for rolling upgrade, where we need to migrate the data in namespace table to meta table.<a name="line.1135"></a>
+<span class="sourceLineNo">1136</span>    if (!waitForNamespaceOnline()) {<a name="line.1136"></a>
+<span class="sourceLineNo">1137</span>      return;<a name="line.1137"></a>
+<span class="sourceLineNo">1138</span>    }<a name="line.1138"></a>
+<span class="sourceLineNo">1139</span>    status.setStatus("Starting cluster schema service");<a name="line.1139"></a>
+<span class="sourceLineNo">1140</span>    initClusterSchemaService();<a name="line.1140"></a>
+<span class="sourceLineNo">1141</span><a name="line.1141"></a>
+<span class="sourceLineNo">1142</span>    if (this.cpHost != null) {<a name="line.1142"></a>
+<span class="sourceLineNo">1143</span>      try {<a name="line.1143"></a>
+<span class="sourceLineNo">1144</span>        this.cpHost.preMasterInitialization();<a name="line.1144"></a>
+<span class="sourceLineNo">1145</span>      } catch (IOException e) {<a name="line.1145"></a>
+<span class="sourceLineNo">1146</span>        LOG.error("Coprocessor preMasterInitialization() hook failed", e);<a name="line.1146"></a>
+<span class="sourceLineNo">1147</span>      }<a name="line.1147"></a>
+<span class="sourceLineNo">1148</span>    }<a name="line.1148"></a>
+<span class="sourceLineNo">1149</span><a name="line.1149"></a>
+<span class="sourceLineNo">1150</span>    status.markComplete("Initialization successful");<a name="line.1150"></a>
+<span class="sourceLineNo">1151</span>    LOG.info(String.format("Master has completed initialization %.3fsec",<a name="line.1151"></a>
+<span class="sourceLineNo">1152</span>       (System.currentTimeMillis() - masterActiveTime) / 1000.0f));<a name="line.1152"></a>
+<span class="sourceLineNo">1153</span>    this.masterFinishedInitializationTime = System.currentTimeMillis();<a name="line.1153"></a>
+<span class="sourceLineNo">1154</span>    configurationManager.registerObserver(this.balancer);<a name="line.1154"></a>
+<span class="sourceLineNo">1155</span>    configurationManager.registerObserver(this.cleanerPool);<a name="line.1155"></a>
+<span class="sourceLineNo">1156</span>    configurationManager.registerObserver(this.hfileCleaner);<a name="line.1156"></a>
+<span class="sourceLineNo">1157</span>    configurationManager.registerObserver(this.logCleaner);<a name="line.1157"></a>
+<span class="sourceLineNo">1158</span>    configurationManager.registerObserver(this.regionsRecoveryConfigManager);<a name="line.1158"></a>
+<span class="sourceLineNo">1159</span>    // Set master as 'initialized'.<a name="line.1159"></a>
+<span class="sourceLineNo">1160</span>    setInitialized(true);<a name="line.1160"></a>
+<span class="sourceLineNo">1161</span><a name="line.1161"></a>
+<span class="sourceLineNo">1162</span>    if (maintenanceMode) {<a name="line.1162"></a>
+<span class="sourceLineNo">1163</span>      LOG.info("Detected repair mode, skipping final initialization steps.");<a name="line.1163"></a>
+<span class="sourceLineNo">1164</span>      return;<a name="line.1164"></a>
+<span class="sourceLineNo">1165</span>    }<a name="line.1165"></a>
+<span class="sourceLineNo">1166</span><a name="line.1166"></a>
+<span class="sourceLineNo">1167</span>    assignmentManager.checkIfShouldMoveSystemRegionAsync();<a name="line.1167"></a>
+<span class="sourceLineNo">1168</span>    status.setStatus("Starting quota manager");<a name="line.1168"></a>
+<span class="sourceLineNo">1169</span>    initQuotaManager();<a name="line.1169"></a>
+<span class="sourceLineNo">1170</span>    if (QuotaUtil.isQuotaEnabled(conf)) {<a name="line.1170"></a>
+<span class="sourceLineNo">1171</span>      // Create the quota snapshot notifier<a name="line.1171"></a>
+<span class="sourceLineNo">1172</span>      spaceQuotaSnapshotNotifier = createQuotaSnapshotNotifier();<a name="line.1172"></a>
+<span class="sourceLineNo">1173</span>      spaceQuotaSnapshotNotifier.initialize(getConnection());<a name="line.1173"></a>
+<span class="sourceLineNo">1174</span>      this.quotaObserverChore = new QuotaObserverChore(this, getMasterMetrics());<a name="line.1174"></a>
+<span class="sourceLineNo">1175</span>      // Start the chore to read the region FS space reports and act on them<a name="line.1175"></a>
+<span class="sourceLineNo">1176</span>      getChoreService().scheduleChore(quotaObserverChore);<a name="line.1176"></a>
+<span class="sourceLineNo">1177</span><a name="line.1177"></a>
+<span class="sourceLineNo">1178</span>      this.snapshotQuotaChore = new SnapshotQuotaObserverChore(this, getMasterMetrics());<a name="line.1178"></a>
+<span class="sourceLineNo">1179</span>      // Start the chore to read snapshots and add their usage to table/NS quotas<a name="line.1179"></a>
+<span class="sourceLineNo">1180</span>      getChoreService().scheduleChore(snapshotQuotaChore);<a name="line.1180"></a>
+<span class="sourceLineNo">1181</span>    }<a name="line.1181"></a>
+<span class="sourceLineNo">1182</span>    final SlowLogMasterService slowLogMasterService = new SlowLogMasterService(conf, this);<a name="line.1182"></a>
+<span class="sourceLineNo">1183</span>    slowLogMasterService.init();<a name="line.1183"></a>
+<span class="sourceLineNo">1184</span><a name="line.1184"></a>
+<span class="sourceLineNo">1185</span>    // clear the dead servers with same host name and port of online server because we are not<a name="line.1185"></a>
+<span class="sourceLineNo">1186</span>    // removing dead server with same hostname and port of rs which is trying to check in before<a name="line.1186"></a>
+<span class="sourceLineNo">1187</span>    // master initialization. See HBASE-5916.<a name="line.1187"></a>
+<span class="sourceLineNo">1188</span>    this.serverManager.clearDeadServersWithSameHostNameAndPortOfOnlineServer();<a name="line.1188"></a>
+<span class="sourceLineNo">1189</span><a name="line.1189"></a>
+<span class="sourceLineNo">1190</span>    // Check and set the znode ACLs if needed in case we are overtaking a non-secure configuration<a name="line.1190"></a>
+<span class="sourceLineNo">1191</span>    status.setStatus("Checking ZNode ACLs");<a name="line.1191"></a>
+<span class="sourceLineNo">1192</span>    zooKeeper.checkAndSetZNodeAcls();<a name="line.1192"></a>
+<span class="sourceLineNo">1193</span><a name="line.1193"></a>
+<span class="sourceLineNo">1194</span>    status.setStatus("Initializing MOB Cleaner");<a name="line.1194"></a>
+<span class="sourceLineNo">1195</span>    initMobCleaner();<a name="line.1195"></a>
+<span class="sourceLineNo">1196</span><a name="line.1196"></a>
+<span class="sourceLineNo">1197</span>    status.setStatus("Calling postStartMaster coprocessors");<a name="line.1197"></a>
+<span class="sourceLineNo">1198</span>    if (this.cpHost != null) {<a name="line.1198"></a>
+<span class="sourceLineNo">1199</span>      // don't let cp initialization errors kill the master<a name="line.1199"></a>
+<span class="sourceLineNo">1200</span>      try {<a name="line.1200"></a>
+<span class="sourceLineNo">1201</span>        this.cpHost.postStartMaster();<a name="line.1201"></a>
+<span class="sourceLineNo">1202</span>      } catch (IOException ioe) {<a name="line.1202"></a>
+<span class="sourceLineNo">1203</span>        LOG.error("Coprocessor postStartMaster() hook failed", ioe);<a name="line.1203"></a>
+<span class="sourceLineNo">1204</span>      }<a name="line.1204"></a>
+<span class="sourceLineNo">1205</span>    }<a name="line.1205"></a>
 <span class="sourceLineNo">1206</span><a name="line.1206"></a>
-<span class="sourceLineNo">1207</span>    /*<a name="line.1207"></a>
-<span class="sourceLineNo">1208</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1208"></a>
-<span class="sourceLineNo">1209</span>     * in activeMasterManager thread, it should be fine.<a name="line.1209"></a>
-<span class="sourceLineNo">1210</span>     */<a name="line.1210"></a>
-<span class="sourceLineNo">1211</span>    long start = System.currentTimeMillis();<a name="line.1211"></a>
-<span class="sourceLineNo">1212</span>    this.balancer.postMasterStartupInitialize();<a name="line.1212"></a>
-<span class="sourceLineNo">1213</span>    if (LOG.isDebugEnabled()) {<a name="line.1213"></a>
-<span class="sourceLineNo">1214</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1214"></a>
-<span class="sourceLineNo">1215</span>          (System.currentTimeMillis() - start) / 1000) + " seconds");<a name="line.1215"></a>
-<span class="sourceLineNo">1216</span>    }<a name="line.1216"></a>
-<span class="sourceLineNo">1217</span>  }<a name="line.1217"></a>
-<span class="sourceLineNo">1218</span><a name="line.1218"></a>
-<span class="sourceLineNo">1219</span>  /**<a name="line.1219"></a>
-<span class="sourceLineNo">1220</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1220"></a>
-<span class="sourceLineNo">1221</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1221"></a>
-<span class="sourceLineNo">1222</span>   *   and we will hold here until operator intervention.<a name="line.1222"></a>
-<span class="sourceLineNo">1223</span>   */<a name="line.1223"></a>
-<span class="sourceLineNo">1224</span>  @VisibleForTesting<a name="line.1224"></a>
-<span class="sourceLineNo">1225</span>  public boolean waitForMetaOnline() {<a name="line.1225"></a>
-<span class="sourceLineNo">1226</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.1226"></a>
-<span class="sourceLineNo">1227</span>  }<a name="line.1227"></a>
-<span class="sourceLineNo">1228</span><a name="line.1228"></a>
-<span class="sourceLineNo">1229</span>  /**<a name="line.1229"></a>
-<span class="sourceLineNo">1230</span>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1230"></a>
-<span class="sourceLineNo">1231</span>   *   we just block in here holding up all forward-progess).<a name="line.1231"></a>
-<span class="sourceLineNo">1232</span>   */<a name="line.1232"></a>
-<span class="sourceLineNo">1233</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1233"></a>
-<span class="sourceLineNo">1234</span>    RetryCounter rc = null;<a name="line.1234"></a>
-<span class="sourceLineNo">1235</span>    while (!isStopped()) {<a name="line.1235"></a>
-<span class="sourceLineNo">1236</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1236"></a>
-<span class="sourceLineNo">1237</span>      if (rs.isOpened()) {<a name="line.1237"></a>
-<span class="sourceLineNo">1238</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1238"></a>
-<span class="sourceLineNo">1239</span>          return true;<a name="line.1239"></a>
-<span class="sourceLineNo">1240</span>        }<a name="line.1240"></a>
-<span class="sourceLineNo">1241</span>      }<a name="line.1241"></a>
-<span class="sourceLineNo">1242</span>      // Region is not OPEN.<a name="line.1242"></a>
-<span class="sourceLineNo">1243</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1243"></a>
-<span class="sourceLineNo">1244</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1244"></a>
-<span class="sourceLineNo">1245</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1245"></a>
-<span class="sourceLineNo">1246</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1246"></a>
-<span class="sourceLineNo">1247</span>      // then how to assign including how to break region lock if one held.<a name="line.1247"></a>
-<span class="sourceLineNo">1248</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1248"></a>
-<span class="sourceLineNo">1249</span>          "progress, in holding-pattern until region onlined.",<a name="line.1249"></a>
-<span class="sourceLineNo">1250</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1250"></a>
-<span class="sourceLineNo">1251</span>      // Check once-a-minute.<a name="line.1251"></a>
-<span class="sourceLineNo">1252</span>      if (rc == null) {<a name="line.1252"></a>
-<span class="sourceLineNo">1253</span>        rc = new RetryCounterFactory(1000).create();<a name="line.1253"></a>
-<span class="sourceLineNo">1254</span>      }<a name="line.1254"></a>
-<span class="sourceLineNo">1255</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1255"></a>
-<span class="sourceLineNo">1256</span>    }<a name="line.1256"></a>
-<span class="sourceLineNo">1257</span>    return false;<a name="line.1257"></a>
-<span class="sourceLineNo">1258</span>  }<a name="line.1258"></a>
-<span class="sourceLineNo">1259</span><a name="line.1259"></a>
-<span class="sourceLineNo">1260</span>  /**<a name="line.1260"></a>
-<span class="sourceLineNo">1261</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1261"></a>
-<span class="sourceLineNo">1262</span>   * &lt;p/&gt;<a name="line.1262"></a>
-<span class="sourceLineNo">1263</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1263"></a>
-<span class="sourceLineNo">1264</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1264"></a>
-<span class="sourceLineNo">1265</span>   * no namespace table/region.<a name="line.1265"></a>
-<span class="sourceLineNo">1266</span>   * @return True if namespace table is up/online.<a name="line.1266"></a>
-<span class="sourceLineNo">1267</span>   */<a name="line.1267"></a>
-<span class="sourceLineNo">1268</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1268"></a>
-<span class="sourceLineNo">1269</span>    TableState nsTableState =<a name="line.1269"></a>
-<span class="sourceLineNo">1270</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1270"></a>
-<span class="sourceLineNo">1271</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1271"></a>
-<span class="sourceLineNo">1272</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1272"></a>
-<span class="sourceLineNo">1273</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1273"></a>
-<span class="sourceLineNo">1274</span>      return true;<a name="line.1274"></a>
-<span class="sourceLineNo">1275</span>    }<a name="line.1275"></a>
-<span class="sourceLineNo">1276</span>    List&lt;RegionInfo&gt; ris =<a name="line.1276"></a>
-<span class="sourceLineNo">1277</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1277"></a>
-<span class="sourceLineNo">1278</span>    if (ris.isEmpty()) {<a name="line.1278"></a>
-<span class="sourceLineNo">1279</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1279"></a>
-<span class="sourceLineNo">1280</span>      return true;<a name="line.1280"></a>
-<span class="sourceLineNo">1281</span>    }<a name="line.1281"></a>
-<span class="sourceLineNo">1282</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1282"></a>
-<span class="sourceLineNo">1283</span>    for (RegionInfo ri : ris) {<a name="line.1283"></a>
-<span class="sourceLineNo">1284</span>      if (!isRegionOnline(ri)) {<a name="line.1284"></a>
-<span class="sourceLineNo">1285</span>        return false;<a name="line.1285"></a>
-<span class="sourceLineNo">1286</span>      }<a name="line.1286"></a>
-<span class="sourceLineNo">1287</span>    }<a name="line.1287"></a>
-<span class="sourceLineNo">1288</span>    return true;<a name="line.1288"></a>
-<span class="sourceLineNo">1289</span>  }<a name="line.1289"></a>
-<span class="sourceLineNo">1290</span><a name="line.1290"></a>
-<span class="sourceLineNo">1291</span>  /**<a name="line.1291"></a>
-<span class="sourceLineNo">1292</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1292"></a>
-<span class="sourceLineNo">1293</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1293"></a>
-<span class="sourceLineNo">1294</span>   */<a name="line.1294"></a>
-<span class="sourceLineNo">1295</span>  @VisibleForTesting<a name="line.1295"></a>
-<span class="sourceLineNo">1296</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1296"></a>
-<span class="sourceLineNo">1297</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1297"></a>
-<span class="sourceLineNo">1298</span>    if (!conf.getBoolean(<a name="line.1298"></a>
-<span class="sourceLineNo">1299</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1299"></a>
-<span class="sourceLineNo">1300</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1300"></a>
-<span class="sourceLineNo">1301</span>      return;<a name="line.1301"></a>
-<span class="sourceLineNo">1302</span>    }<a name="line.1302"></a>
-<span class="sourceLineNo">1303</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1303"></a>
-<span class="sourceLineNo">1304</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1304"></a>
-<span class="sourceLineNo">1305</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1305"></a>
-<span class="sourceLineNo">1306</span>    if (length &gt; 0) {<a name="line.1306"></a>
-<span class="sourceLineNo">1307</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1307"></a>
-<span class="sourceLineNo">1308</span>    }<a name="line.1308"></a>
-<span class="sourceLineNo">1309</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1309"></a>
-<span class="sourceLineNo">1310</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1310"></a>
-<span class="sourceLineNo">1311</span>  }<a name="line.1311"></a>
-<span class="sourceLineNo">1312</span><a name="line.1312"></a>
-<span class="sourceLineNo">1313</span>  private void initMobCleaner() {<a name="line.1313"></a>
-<span class="sourceLineNo">1314</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1314"></a>
-<span class="sourceLineNo">1315</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1315"></a>
-<span class="sourceLineNo">1316</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1316"></a>
-<span class="sourceLineNo">1317</span>    getChoreService().scheduleChore(mobFileCompactionChore);<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>   * &lt;p&gt;<a name="line.1321"></a>
-<span class="sourceLineNo">1322</span>   * Create a {@link ServerManager} instance.<a name="line.1322"></a>
-<span class="sourceLineNo">1323</span>   * &lt;/p&gt;<a name="line.1323"></a>
-<span class="sourceLineNo">1324</span>   * &lt;p&gt;<a name="line.1324"></a>
-<span class="sourceLineNo">1325</span>   * Will be overridden in tests.<a name="line.1325"></a>
-<span class="sourceLineNo">1326</span>   * &lt;/p&gt;<a name="line.1326"></a>
-<span class="sourceLineNo">1327</span>   */<a name="line.1327"></a>
-<span class="sourceLineNo">1328</span>  @VisibleForTesting<a name="line.1328"></a>
-<span class="sourceLineNo">1329</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1329"></a>
-<span class="sourceLineNo">1330</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1330"></a>
-<span class="sourceLineNo">1331</span>    // w/ a mocked up ServerManager.<a name="line.1331"></a>
-<span class="sourceLineNo">1332</span>    setupClusterConnection();<a name="line.1332"></a>
-<span class="sourceLineNo">1333</span>    return new ServerManager(master);<a name="line.1333"></a>
-<span class="sourceLineNo">1334</span>  }<a name="line.1334"></a>
-<span class="sourceLineNo">1335</span><a name="line.1335"></a>
-<span class="sourceLineNo">1336</span>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1336"></a>
-<span class="sourceLineNo">1337</span>      throws IOException, InterruptedException {<a name="line.1337"></a>
-<span class="sourceLineNo">1338</span>    this.serverManager.waitForRegionServers(status);<a name="line.1338"></a>
-<span class="sourceLineNo">1339</span>  }<a name="line.1339"></a>
-<span class="sourceLineNo">1340</span><a name="line.1340"></a>
-<span class="sourceLineNo">1341</span>  // Will be overridden in tests<a name="line.1341"></a>
-<span class="sourceLineNo">1342</span>  @VisibleForTesting<a name="line.1342"></a>
-<span class="sourceLineNo">1343</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1343"></a>
-<span class="sourceLineNo">1344</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1344"></a>
-<span class="sourceLineNo">1345</span>    this.clusterSchemaService.startAsync();<a name="line.1345"></a>
-<span class="sourceLineNo">1346</span>    try {<a name="line.1346"></a>
-<span class="sourceLineNo">1347</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1347"></a>
-<span class="sourceLineNo">1348</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1348"></a>
-<span class="sourceLineNo">1349</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1349"></a>
-<span class="sourceLineNo">1350</span>    } catch (TimeoutException toe) {<a name="line.1350"></a>
-<span class="sourceLineNo">1351</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<a name="line.1351"></a>
-<span class="sourceLineNo">1352</span>    }<a name="line.1352"></a>
-<span class="sourceLineNo">1353</span>  }<a name="line.1353"></a>
-<span class="sourceLineNo">1354</span><a name="line.1354"></a>
-<span class="sourceLineNo">1355</span>  private void initQuotaManager() throws IOException {<a name="line.1355"></a>
-<span class="sourceLineNo">1356</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1356"></a>
-<span class="sourceLineNo">1357</span>    quotaManager.start();<a name="line.1357"></a>
-<span class="sourceLineNo">1358</span>    this.quotaManager = quotaManager;<a name="line.1358"></a>
-<span class="sourceLineNo">1359</span>  }<a name="line.1359"></a>
-<span class="sourceLineNo">1360</span><a name="line.1360"></a>
-<span class="sourceLineNo">1361</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1361"></a>
-<span class="sourceLineNo">1362</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1362"></a>
-<span class="sourceLineNo">1363</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1363"></a>
-<span class="sourceLineNo">1364</span>    return notifier;<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>  boolean isCatalogJanitorEnabled() {<a name="line.1367"></a>
-<span class="sourceLineNo">1368</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<a name="line.1368"></a>
-<span class="sourceLineNo">1369</span>  }<a name="line.1369"></a>
-<span class="sourceLineNo">1370</span><a name="line.1370"></a>
-<span class="sourceLineNo">1371</span>  boolean isCleanerChoreEnabled() {<a name="line.1371"></a>
-<span class="sourceLineNo">1372</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1372"></a>
-<span class="sourceLineNo">1373</span><a name="line.1373"></a>
-<span class="sourceLineNo">1374</span>    if (hfileCleaner != null) {<a name="line.1374"></a>
-<span class="sourceLineNo">1375</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<a name="line.1375"></a>
-<span class="sourceLineNo">1376</span>    }<a name="line.1376"></a>
-<span class="sourceLineNo">1377</span><a name="line.1377"></a>
-<span class="sourceLineNo">1378</span>    if (logCleaner != null) {<a name="line.1378"></a>
-<span class="sourceLineNo">1379</span>      logCleanerFlag = logCleaner.getEnabled();<a name="line.1379"></a>
-<span class="sourceLineNo">1380</span>    }<a name="line.1380"></a>
-<span class="sourceLineNo">1381</span><a name="line.1381"></a>
-<span class="sourceLineNo">1382</span>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<a name="line.1382"></a>
-<span class="sourceLineNo">1383</span>  }<a name="line.1383"></a>
-<span class="sourceLineNo">1384</span><a name="line.1384"></a>
-<span class="sourceLineNo">1385</span>  @Override<a name="line.1385"></a>
-<span class="sourceLineNo">1386</span>  public ServerManager getServerManager() {<a name="line.1386"></a>
-<span class="sourceLineNo">1387</span>    return this.serverManager;<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>  @Override<a name="line.1390"></a>
-<span class="sourceLineNo">1391</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1391"></a>
-<span class="sourceLineNo">1392</span>    return this.fileSystemManager;<a name="line.1392"></a>
-<span class="sourceLineNo">1393</span>  }<a name="line.1393"></a>
-<span class="sourceLineNo">1394</span><a name="line.1394"></a>
-<span class="sourceLineNo">1395</span>  @Override<a name="line.1395"></a>
-<span class="sourceLineNo">1396</span>  public MasterWalManager getMasterWalManager() {<a name="line.1396"></a>
-<span class="sourceLineNo">1397</span>    return this.walManager;<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>  @Override<a name="line.1400"></a>
-<span class="sourceLineNo">1401</span>  public SplitWALManager getSplitWALManager() {<a name="line.1401"></a>
-<span class="sourceLineNo">1402</span>    return splitWALManager;<a name="line.1402"></a>
-<span class="sourceLineNo">1403</span>  }<a name="line.1403"></a>
-<span class="sourceLineNo">1404</span><a name="line.1404"></a>
-<span class="sourceLineNo">1405</span>  @Override<a name="line.1405"></a>
-<span class="sourceLineNo">1406</span>  public TableStateManager getTableStateManager() {<a name="line.1406"></a>
-<span class="sourceLineNo">1407</span>    return tableStateManager;<a name="line.1407"></a>
-<span class="sourceLineNo">1408</span>  }<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>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1411"></a>
-<span class="sourceLineNo">1412</span>   * then they just die with a logged message.  This should be fine because<a name="line.1412"></a>
-<span class="sourceLineNo">1413</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1413"></a>
-<span class="sourceLineNo">1414</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1414"></a>
-<span class="sourceLineNo">1415</span>   *  need to install an unexpected exception handler.<a name="line.1415"></a>
-<span class="sourceLineNo">1416</span>   */<a name="line.1416"></a>
-<span class="sourceLineNo">1417</span>  private void startServiceThreads() throws IOException {<a name="line.1417"></a>
-<span class="sourceLineNo">1418</span>    // Start the executor service pools<a name="line.1418"></a>
-<span class="sourceLineNo">1419</span>    this.executorService.startExecutorService(ExecutorType.MASTER_OPEN_REGION, conf.getInt(<a name="line.1419"></a>
-<span class="sourceLineNo">1420</span>      HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT));<a name="line.1420"></a>
-<span class="sourceLineNo">1421</span>    this.executorService.startExecutorService(ExecutorType.MASTER_CLOSE_REGION, conf.getInt(<a name="line.1421"></a>
-<span class="sourceLineNo">1422</span>      HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT));<a name="line.1422"></a>
-<span class="sourceLineNo">1423</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SERVER_OPERATIONS,<a name="line.1423"></a>
-<span class="sourceLineNo">1424</span>      conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1424"></a>
-<span class="sourceLineNo">1425</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1425"></a>
-<span class="sourceLineNo">1426</span>    this.executorService.startExecutorService(ExecutorType.MASTER_META_SERVER_OPERATIONS,<a name="line.1426"></a>
-<span class="sourceLineNo">1427</span>      conf.getInt(HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1427"></a>
-<span class="sourceLineNo">1428</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1428"></a>
-<span class="sourceLineNo">1429</span>    this.executorService.startExecutorService(ExecutorType.M_LOG_REPLAY_OPS, conf.getInt(<a name="line.1429"></a>
-<span class="sourceLineNo">1430</span>      HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT));<a name="line.1430"></a>
-<span class="sourceLineNo">1431</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SNAPSHOT_OPERATIONS, conf.getInt(<a name="line.1431"></a>
-<span class="sourceLineNo">1432</span>      SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT));<a name="line.1432"></a>
-<span class="sourceLineNo">1433</span><a name="line.1433"></a>
-<span class="sourceLineNo">1434</span>    // We depend on there being only one instance of this executor running<a name="line.1434"></a>
-<span class="sourceLineNo">1435</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1435"></a>
-<span class="sourceLineNo">1436</span>    // tables.<a name="line.1436"></a>
-<span class="sourceLineNo">1437</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1437"></a>
-<span class="sourceLineNo">1438</span>    // AccessController#postCompletedCreateTableAction<a name="line.1438"></a>
-<span class="sourceLineNo">1439</span>    this.executorService.startExecutorService(ExecutorType.MASTER_TABLE_OPERATIONS, 1);<a name="line.1439"></a>
-<span class="sourceLineNo">1440</span>    startProcedureExecutor();<a name="line.1440"></a>
-<span class="sourceLineNo">1441</span><a name="line.1441"></a>
-<span class="sourceLineNo">1442</span>    // Create cleaner thread pool<a name="line.1442"></a>
-<span class="sourceLineNo">1443</span>    cleanerPool = new DirScanPool(conf);<a name="line.1443"></a>
-<span class="sourceLineNo">1444</span>    // Start log cleaner thread<a name="line.1444"></a>
-<span class="sourceLineNo">1445</span>    int cleanerInterval =<a name="line.1445"></a>
-<span class="sourceLineNo">1446</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1446"></a>
-<span class="sourceLineNo">1447</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1447"></a>
-<span class="sourceLineNo">1448</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool);<a name="line.1448"></a>
-<span class="sourceLineNo">1449</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1449"></a>
-<span class="sourceLineNo">1450</span><a name="line.1450"></a>
-<span class="sourceLineNo">1451</span>    // start the hfile archive cleaner thread<a name="line.1451"></a>
-<span class="sourceLineNo">1452</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1452"></a>
-<span class="sourceLineNo">1453</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1453"></a>
-<span class="sourceLineNo">1454</span>    params.put(MASTER, this);<a name="line.1454"></a>
-<span class="sourceLineNo">1455</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1455"></a>
-<span class="sourceLineNo">1456</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1456"></a>
-<span class="sourceLineNo">1457</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1457"></a>
-<span class="sourceLineNo">1458</span><a name="line.1458"></a>
-<span class="sourceLineNo">1459</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1459"></a>
-<span class="sourceLineNo">1460</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1460"></a>
-<span class="sourceLineNo">1461</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1461"></a>
-<span class="sourceLineNo">1462</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1462"></a>
-<span class="sourceLineNo">1463</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1463"></a>
-<span class="sourceLineNo">1464</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1464"></a>
-<span class="sourceLineNo">1465</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1465"></a>
-<span class="sourceLineNo">1466</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1466"></a>
-<span class="sourceLineNo">1467</span>    } else {<a name="line.1467"></a>
-<span class="sourceLineNo">1468</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1468"></a>
-<span class="sourceLineNo">1469</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1469"></a>
-<span class="sourceLineNo">1470</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1470"></a>
-<span class="sourceLineNo">1471</span>    }<a name="line.1471"></a>
-<span class="sourceLineNo">1472</span><a name="line.1472"></a>
-<span class="sourceLineNo">1473</span>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1473"></a>
+<span class="sourceLineNo">1207</span>    zombieDetector.interrupt();<a name="line.1207"></a>
+<span class="sourceLineNo">1208</span><a name="line.1208"></a>
+<span class="sourceLineNo">1209</span>    /*<a name="line.1209"></a>
+<span class="sourceLineNo">1210</span>     * After master has started up, lets do balancer post startup initialization. Since this runs<a name="line.1210"></a>
+<span class="sourceLineNo">1211</span>     * in activeMasterManager thread, it should be fine.<a name="line.1211"></a>
+<span class="sourceLineNo">1212</span>     */<a name="line.1212"></a>
+<span class="sourceLineNo">1213</span>    long start = System.currentTimeMillis();<a name="line.1213"></a>
+<span class="sourceLineNo">1214</span>    this.balancer.postMasterStartupInitialize();<a name="line.1214"></a>
+<span class="sourceLineNo">1215</span>    if (LOG.isDebugEnabled()) {<a name="line.1215"></a>
+<span class="sourceLineNo">1216</span>      LOG.debug("Balancer post startup initialization complete, took " + (<a name="line.1216"></a>
+<span class="sourceLineNo">1217</span>          (System.currentTimeMillis() - start) / 1000) + " seconds");<a name="line.1217"></a>
+<span class="sourceLineNo">1218</span>    }<a name="line.1218"></a>
+<span class="sourceLineNo">1219</span>  }<a name="line.1219"></a>
+<span class="sourceLineNo">1220</span><a name="line.1220"></a>
+<span class="sourceLineNo">1221</span>  /**<a name="line.1221"></a>
+<span class="sourceLineNo">1222</span>   * Check hbase:meta is up and ready for reading. For use during Master startup only.<a name="line.1222"></a>
+<span class="sourceLineNo">1223</span>   * @return True if meta is UP and online and startup can progress. Otherwise, meta is not online<a name="line.1223"></a>
+<span class="sourceLineNo">1224</span>   *   and we will hold here until operator intervention.<a name="line.1224"></a>
+<span class="sourceLineNo">1225</span>   */<a name="line.1225"></a>
+<span class="sourceLineNo">1226</span>  @VisibleForTesting<a name="line.1226"></a>
+<span class="sourceLineNo">1227</span>  public boolean waitForMetaOnline() {<a name="line.1227"></a>
+<span class="sourceLineNo">1228</span>    return isRegionOnline(RegionInfoBuilder.FIRST_META_REGIONINFO);<a name="line.1228"></a>
+<span class="sourceLineNo">1229</span>  }<a name="line.1229"></a>
+<span class="sourceLineNo">1230</span><a name="line.1230"></a>
+<span class="sourceLineNo">1231</span>  /**<a name="line.1231"></a>
+<span class="sourceLineNo">1232</span>   * @return True if region is online and scannable else false if an error or shutdown (Otherwise<a name="line.1232"></a>
+<span class="sourceLineNo">1233</span>   *   we just block in here holding up all forward-progess).<a name="line.1233"></a>
+<span class="sourceLineNo">1234</span>   */<a name="line.1234"></a>
+<span class="sourceLineNo">1235</span>  private boolean isRegionOnline(RegionInfo ri) {<a name="line.1235"></a>
+<span class="sourceLineNo">1236</span>    RetryCounter rc = null;<a name="line.1236"></a>
+<span class="sourceLineNo">1237</span>    while (!isStopped()) {<a name="line.1237"></a>
+<span class="sourceLineNo">1238</span>      RegionState rs = this.assignmentManager.getRegionStates().getRegionState(ri);<a name="line.1238"></a>
+<span class="sourceLineNo">1239</span>      if (rs.isOpened()) {<a name="line.1239"></a>
+<span class="sourceLineNo">1240</span>        if (this.getServerManager().isServerOnline(rs.getServerName())) {<a name="line.1240"></a>
+<span class="sourceLineNo">1241</span>          return true;<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>      // Region is not OPEN.<a name="line.1244"></a>
+<span class="sourceLineNo">1245</span>      Optional&lt;Procedure&lt;MasterProcedureEnv&gt;&gt; optProc = this.procedureExecutor.getProcedures().<a name="line.1245"></a>
+<span class="sourceLineNo">1246</span>          stream().filter(p -&gt; p instanceof ServerCrashProcedure).findAny();<a name="line.1246"></a>
+<span class="sourceLineNo">1247</span>      // TODO: Add a page to refguide on how to do repair. Have this log message point to it.<a name="line.1247"></a>
+<span class="sourceLineNo">1248</span>      // Page will talk about loss of edits, how to schedule at least the meta WAL recovery, and<a name="line.1248"></a>
+<span class="sourceLineNo">1249</span>      // then how to assign including how to break region lock if one held.<a name="line.1249"></a>
+<span class="sourceLineNo">1250</span>      LOG.warn("{} is NOT online; state={}; ServerCrashProcedures={}. Master startup cannot " +<a name="line.1250"></a>
+<span class="sourceLineNo">1251</span>          "progress, in holding-pattern until region onlined.",<a name="line.1251"></a>
+<span class="sourceLineNo">1252</span>          ri.getRegionNameAsString(), rs, optProc.isPresent());<a name="line.1252"></a>
+<span class="sourceLineNo">1253</span>      // Check once-a-minute.<a name="line.1253"></a>
+<span class="sourceLineNo">1254</span>      if (rc == null) {<a name="line.1254"></a>
+<span class="sourceLineNo">1255</span>        rc = new RetryCounterFactory(1000).create();<a name="line.1255"></a>
+<span class="sourceLineNo">1256</span>      }<a name="line.1256"></a>
+<span class="sourceLineNo">1257</span>      Threads.sleep(rc.getBackoffTimeAndIncrementAttempts());<a name="line.1257"></a>
+<span class="sourceLineNo">1258</span>    }<a name="line.1258"></a>
+<span class="sourceLineNo">1259</span>    return false;<a name="line.1259"></a>
+<span class="sourceLineNo">1260</span>  }<a name="line.1260"></a>
+<span class="sourceLineNo">1261</span><a name="line.1261"></a>
+<span class="sourceLineNo">1262</span>  /**<a name="line.1262"></a>
+<span class="sourceLineNo">1263</span>   * Check hbase:namespace table is assigned. If not, startup will hang looking for the ns table<a name="line.1263"></a>
+<span class="sourceLineNo">1264</span>   * &lt;p/&gt;<a name="line.1264"></a>
+<span class="sourceLineNo">1265</span>   * This is for rolling upgrading, later we will migrate the data in ns table to the ns family of<a name="line.1265"></a>
+<span class="sourceLineNo">1266</span>   * meta table. And if this is a new cluster, this method will return immediately as there will be<a name="line.1266"></a>
+<span class="sourceLineNo">1267</span>   * no namespace table/region.<a name="line.1267"></a>
+<span class="sourceLineNo">1268</span>   * @return True if namespace table is up/online.<a name="line.1268"></a>
+<span class="sourceLineNo">1269</span>   */<a name="line.1269"></a>
+<span class="sourceLineNo">1270</span>  private boolean waitForNamespaceOnline() throws IOException {<a name="line.1270"></a>
+<span class="sourceLineNo">1271</span>    TableState nsTableState =<a name="line.1271"></a>
+<span class="sourceLineNo">1272</span>      MetaTableAccessor.getTableState(getConnection(), TableName.NAMESPACE_TABLE_NAME);<a name="line.1272"></a>
+<span class="sourceLineNo">1273</span>    if (nsTableState == null || nsTableState.isDisabled()) {<a name="line.1273"></a>
+<span class="sourceLineNo">1274</span>      // this means we have already migrated the data and disabled or deleted the namespace table,<a name="line.1274"></a>
+<span class="sourceLineNo">1275</span>      // or this is a new deploy which does not have a namespace table from the beginning.<a name="line.1275"></a>
+<span class="sourceLineNo">1276</span>      return true;<a name="line.1276"></a>
+<span class="sourceLineNo">1277</span>    }<a name="line.1277"></a>
+<span class="sourceLineNo">1278</span>    List&lt;RegionInfo&gt; ris =<a name="line.1278"></a>
+<span class="sourceLineNo">1279</span>      this.assignmentManager.getRegionStates().getRegionsOfTable(TableName.NAMESPACE_TABLE_NAME);<a name="line.1279"></a>
+<span class="sourceLineNo">1280</span>    if (ris.isEmpty()) {<a name="line.1280"></a>
+<span class="sourceLineNo">1281</span>      // maybe this will not happen any more, but anyway, no harm to add a check here...<a name="line.1281"></a>
+<span class="sourceLineNo">1282</span>      return true;<a name="line.1282"></a>
+<span class="sourceLineNo">1283</span>    }<a name="line.1283"></a>
+<span class="sourceLineNo">1284</span>    // Else there are namespace regions up in meta. Ensure they are assigned before we go on.<a name="line.1284"></a>
+<span class="sourceLineNo">1285</span>    for (RegionInfo ri : ris) {<a name="line.1285"></a>
+<span class="sourceLineNo">1286</span>      if (!isRegionOnline(ri)) {<a name="line.1286"></a>
+<span class="sourceLineNo">1287</span>        return false;<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>    return true;<a name="line.1290"></a>
+<span class="sourceLineNo">1291</span>  }<a name="line.1291"></a>
+<span class="sourceLineNo">1292</span><a name="line.1292"></a>
+<span class="sourceLineNo">1293</span>  /**<a name="line.1293"></a>
+<span class="sourceLineNo">1294</span>   * Adds the {@code MasterQuotasObserver} to the list of configured Master observers to<a name="line.1294"></a>
+<span class="sourceLineNo">1295</span>   * automatically remove quotas for a table when that table is deleted.<a name="line.1295"></a>
+<span class="sourceLineNo">1296</span>   */<a name="line.1296"></a>
+<span class="sourceLineNo">1297</span>  @VisibleForTesting<a name="line.1297"></a>
+<span class="sourceLineNo">1298</span>  public void updateConfigurationForQuotasObserver(Configuration conf) {<a name="line.1298"></a>
+<span class="sourceLineNo">1299</span>    // We're configured to not delete quotas on table deletion, so we don't need to add the obs.<a name="line.1299"></a>
+<span class="sourceLineNo">1300</span>    if (!conf.getBoolean(<a name="line.1300"></a>
+<span class="sourceLineNo">1301</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE,<a name="line.1301"></a>
+<span class="sourceLineNo">1302</span>          MasterQuotasObserver.REMOVE_QUOTA_ON_TABLE_DELETE_DEFAULT)) {<a name="line.1302"></a>
+<span class="sourceLineNo">1303</span>      return;<a name="line.1303"></a>
+<span class="sourceLineNo">1304</span>    }<a name="line.1304"></a>
+<span class="sourceLineNo">1305</span>    String[] masterCoprocs = conf.getStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY);<a name="line.1305"></a>
+<span class="sourceLineNo">1306</span>    final int length = null == masterCoprocs ? 0 : masterCoprocs.length;<a name="line.1306"></a>
+<span class="sourceLineNo">1307</span>    String[] updatedCoprocs = new String[length + 1];<a name="line.1307"></a>
+<span class="sourceLineNo">1308</span>    if (length &gt; 0) {<a name="line.1308"></a>
+<span class="sourceLineNo">1309</span>      System.arraycopy(masterCoprocs, 0, updatedCoprocs, 0, masterCoprocs.length);<a name="line.1309"></a>
+<span class="sourceLineNo">1310</span>    }<a name="line.1310"></a>
+<span class="sourceLineNo">1311</span>    updatedCoprocs[length] = MasterQuotasObserver.class.getName();<a name="line.1311"></a>
+<span class="sourceLineNo">1312</span>    conf.setStrings(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, updatedCoprocs);<a name="line.1312"></a>
+<span class="sourceLineNo">1313</span>  }<a name="line.1313"></a>
+<span class="sourceLineNo">1314</span><a name="line.1314"></a>
+<span class="sourceLineNo">1315</span>  private void initMobCleaner() {<a name="line.1315"></a>
+<span class="sourceLineNo">1316</span>    this.mobFileCleanerChore = new MobFileCleanerChore(this);<a name="line.1316"></a>
+<span class="sourceLineNo">1317</span>    getChoreService().scheduleChore(mobFileCleanerChore);<a name="line.1317"></a>
+<span class="sourceLineNo">1318</span>    this.mobFileCompactionChore = new MobFileCompactionChore(this);<a name="line.1318"></a>
+<span class="sourceLineNo">1319</span>    getChoreService().scheduleChore(mobFileCompactionChore);<a name="line.1319"></a>
+<span class="sourceLineNo">1320</span>  }<a name="line.1320"></a>
+<span class="sourceLineNo">1321</span><a name="line.1321"></a>
+<span class="sourceLineNo">1322</span>  /**<a name="line.1322"></a>
+<span class="sourceLineNo">1323</span>   * &lt;p&gt;<a name="line.1323"></a>
+<span class="sourceLineNo">1324</span>   * Create a {@link ServerManager} instance.<a name="line.1324"></a>
+<span class="sourceLineNo">1325</span>   * &lt;/p&gt;<a name="line.1325"></a>
+<span class="sourceLineNo">1326</span>   * &lt;p&gt;<a name="line.1326"></a>
+<span class="sourceLineNo">1327</span>   * Will be overridden in tests.<a name="line.1327"></a>
+<span class="sourceLineNo">1328</span>   * &lt;/p&gt;<a name="line.1328"></a>
+<span class="sourceLineNo">1329</span>   */<a name="line.1329"></a>
+<span class="sourceLineNo">1330</span>  @VisibleForTesting<a name="line.1330"></a>
+<span class="sourceLineNo">1331</span>  protected ServerManager createServerManager(final MasterServices master) throws IOException {<a name="line.1331"></a>
+<span class="sourceLineNo">1332</span>    // We put this out here in a method so can do a Mockito.spy and stub it out<a name="line.1332"></a>
+<span class="sourceLineNo">1333</span>    // w/ a mocked up ServerManager.<a name="line.1333"></a>
+<span class="sourceLineNo">1334</span>    setupClusterConnection();<a name="line.1334"></a>
+<span class="sourceLineNo">1335</span>    return new ServerManager(master);<a name="line.1335"></a>
+<span class="sourceLineNo">1336</span>  }<a name="line.1336"></a>
+<span class="sourceLineNo">1337</span><a name="line.1337"></a>
+<span class="sourceLineNo">1338</span>  private void waitForRegionServers(final MonitoredTask status)<a name="line.1338"></a>
+<span class="sourceLineNo">1339</span>      throws IOException, InterruptedException {<a name="line.1339"></a>
+<span class="sourceLineNo">1340</span>    this.serverManager.waitForRegionServers(status);<a name="line.1340"></a>
+<span class="sourceLineNo">1341</span>  }<a name="line.1341"></a>
+<span class="sourceLineNo">1342</span><a name="line.1342"></a>
+<span class="sourceLineNo">1343</span>  // Will be overridden in tests<a name="line.1343"></a>
+<span class="sourceLineNo">1344</span>  @VisibleForTesting<a name="line.1344"></a>
+<span class="sourceLineNo">1345</span>  protected void initClusterSchemaService() throws IOException, InterruptedException {<a name="line.1345"></a>
+<span class="sourceLineNo">1346</span>    this.clusterSchemaService = new ClusterSchemaServiceImpl(this);<a name="line.1346"></a>
+<span class="sourceLineNo">1347</span>    this.clusterSchemaService.startAsync();<a name="line.1347"></a>
+<span class="sourceLineNo">1348</span>    try {<a name="line.1348"></a>
+<span class="sourceLineNo">1349</span>      this.clusterSchemaService.awaitRunning(getConfiguration().getInt(<a name="line.1349"></a>
+<span class="sourceLineNo">1350</span>        HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS,<a name="line.1350"></a>
+<span class="sourceLineNo">1351</span>        DEFAULT_HBASE_MASTER_WAIT_ON_SERVICE_IN_SECONDS), TimeUnit.SECONDS);<a name="line.1351"></a>
+<span class="sourceLineNo">1352</span>    } catch (TimeoutException toe) {<a name="line.1352"></a>
+<span class="sourceLineNo">1353</span>      throw new IOException("Timedout starting ClusterSchemaService", toe);<a name="line.1353"></a>
+<span class="sourceLineNo">1354</span>    }<a name="line.1354"></a>
+<span class="sourceLineNo">1355</span>  }<a name="line.1355"></a>
+<span class="sourceLineNo">1356</span><a name="line.1356"></a>
+<span class="sourceLineNo">1357</span>  private void initQuotaManager() throws IOException {<a name="line.1357"></a>
+<span class="sourceLineNo">1358</span>    MasterQuotaManager quotaManager = new MasterQuotaManager(this);<a name="line.1358"></a>
+<span class="sourceLineNo">1359</span>    quotaManager.start();<a name="line.1359"></a>
+<span class="sourceLineNo">1360</span>    this.quotaManager = quotaManager;<a name="line.1360"></a>
+<span class="sourceLineNo">1361</span>  }<a name="line.1361"></a>
+<span class="sourceLineNo">1362</span><a name="line.1362"></a>
+<span class="sourceLineNo">1363</span>  private SpaceQuotaSnapshotNotifier createQuotaSnapshotNotifier() {<a name="line.1363"></a>
+<span class="sourceLineNo">1364</span>    SpaceQuotaSnapshotNotifier notifier =<a name="line.1364"></a>
+<span class="sourceLineNo">1365</span>        SpaceQuotaSnapshotNotifierFactory.getInstance().create(getConfiguration());<a name="line.1365"></a>
+<span class="sourceLineNo">1366</span>    return notifier;<a name="line.1366"></a>
+<span class="sourceLineNo">1367</span>  }<a name="line.1367"></a>
+<span class="sourceLineNo">1368</span><a name="line.1368"></a>
+<span class="sourceLineNo">1369</span>  boolean isCatalogJanitorEnabled() {<a name="line.1369"></a>
+<span class="sourceLineNo">1370</span>    return catalogJanitorChore != null ? catalogJanitorChore.getEnabled() : false;<a name="line.1370"></a>
+<span class="sourceLineNo">1371</span>  }<a name="line.1371"></a>
+<span class="sourceLineNo">1372</span><a name="line.1372"></a>
+<span class="sourceLineNo">1373</span>  boolean isCleanerChoreEnabled() {<a name="line.1373"></a>
+<span class="sourceLineNo">1374</span>    boolean hfileCleanerFlag = true, logCleanerFlag = true;<a name="line.1374"></a>
+<span class="sourceLineNo">1375</span><a name="line.1375"></a>
+<span class="sourceLineNo">1376</span>    if (hfileCleaner != null) {<a name="line.1376"></a>
+<span class="sourceLineNo">1377</span>      hfileCleanerFlag = hfileCleaner.getEnabled();<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>    if (logCleaner != null) {<a name="line.1380"></a>
+<span class="sourceLineNo">1381</span>      logCleanerFlag = logCleaner.getEnabled();<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>    return (hfileCleanerFlag &amp;&amp; logCleanerFlag);<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>  @Override<a name="line.1387"></a>
+<span class="sourceLineNo">1388</span>  public ServerManager getServerManager() {<a name="line.1388"></a>
+<span class="sourceLineNo">1389</span>    return this.serverManager;<a name="line.1389"></a>
+<span class="sourceLineNo">1390</span>  }<a name="line.1390"></a>
+<span class="sourceLineNo">1391</span><a name="line.1391"></a>
+<span class="sourceLineNo">1392</span>  @Override<a name="line.1392"></a>
+<span class="sourceLineNo">1393</span>  public MasterFileSystem getMasterFileSystem() {<a name="line.1393"></a>
+<span class="sourceLineNo">1394</span>    return this.fileSystemManager;<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>  @Override<a name="line.1397"></a>
+<span class="sourceLineNo">1398</span>  public MasterWalManager getMasterWalManager() {<a name="line.1398"></a>
+<span class="sourceLineNo">1399</span>    return this.walManager;<a name="line.1399"></a>
+<span class="sourceLineNo">1400</span>  }<a name="line.1400"></a>
+<span class="sourceLineNo">1401</span><a name="line.1401"></a>
+<span class="sourceLineNo">1402</span>  @Override<a name="line.1402"></a>
+<span class="sourceLineNo">1403</span>  public SplitWALManager getSplitWALManager() {<a name="line.1403"></a>
+<span class="sourceLineNo">1404</span>    return splitWALManager;<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>  @Override<a name="line.1407"></a>
+<span class="sourceLineNo">1408</span>  public TableStateManager getTableStateManager() {<a name="line.1408"></a>
+<span class="sourceLineNo">1409</span>    return tableStateManager;<a name="line.1409"></a>
+<span class="sourceLineNo">1410</span>  }<a name="line.1410"></a>
+<span class="sourceLineNo">1411</span><a name="line.1411"></a>
+<span class="sourceLineNo">1412</span>  /*<a name="line.1412"></a>
+<span class="sourceLineNo">1413</span>   * Start up all services. If any of these threads gets an unhandled exception<a name="line.1413"></a>
+<span class="sourceLineNo">1414</span>   * then they just die with a logged message.  This should be fine because<a name="line.1414"></a>
+<span class="sourceLineNo">1415</span>   * in general, we do not expect the master to get such unhandled exceptions<a name="line.1415"></a>
+<span class="sourceLineNo">1416</span>   *  as OOMEs; it should be lightly loaded. See what HRegionServer does if<a name="line.1416"></a>
+<span class="sourceLineNo">1417</span>   *  need to install an unexpected exception handler.<a name="line.1417"></a>
+<span class="sourceLineNo">1418</span>   */<a name="line.1418"></a>
+<span class="sourceLineNo">1419</span>  private void startServiceThreads() throws IOException {<a name="line.1419"></a>
+<span class="sourceLineNo">1420</span>    // Start the executor service pools<a name="line.1420"></a>
+<span class="sourceLineNo">1421</span>    this.executorService.startExecutorService(ExecutorType.MASTER_OPEN_REGION, conf.getInt(<a name="line.1421"></a>
+<span class="sourceLineNo">1422</span>      HConstants.MASTER_OPEN_REGION_THREADS, HConstants.MASTER_OPEN_REGION_THREADS_DEFAULT));<a name="line.1422"></a>
+<span class="sourceLineNo">1423</span>    this.executorService.startExecutorService(ExecutorType.MASTER_CLOSE_REGION, conf.getInt(<a name="line.1423"></a>
+<span class="sourceLineNo">1424</span>      HConstants.MASTER_CLOSE_REGION_THREADS, HConstants.MASTER_CLOSE_REGION_THREADS_DEFAULT));<a name="line.1424"></a>
+<span class="sourceLineNo">1425</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SERVER_OPERATIONS,<a name="line.1425"></a>
+<span class="sourceLineNo">1426</span>      conf.getInt(HConstants.MASTER_SERVER_OPERATIONS_THREADS,<a name="line.1426"></a>
+<span class="sourceLineNo">1427</span>        HConstants.MASTER_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1427"></a>
+<span class="sourceLineNo">1428</span>    this.executorService.startExecutorService(ExecutorType.MASTER_META_SERVER_OPERATIONS,<a name="line.1428"></a>
+<span class="sourceLineNo">1429</span>      conf.getInt(HConstants.MASTER_META_SERVER_OPERATIONS_THREADS,<a name="line.1429"></a>
+<span class="sourceLineNo">1430</span>        HConstants.MASTER_META_SERVER_OPERATIONS_THREADS_DEFAULT));<a name="line.1430"></a>
+<span class="sourceLineNo">1431</span>    this.executorService.startExecutorService(ExecutorType.M_LOG_REPLAY_OPS, conf.getInt(<a name="line.1431"></a>
+<span class="sourceLineNo">1432</span>      HConstants.MASTER_LOG_REPLAY_OPS_THREADS, HConstants.MASTER_LOG_REPLAY_OPS_THREADS_DEFAULT));<a name="line.1432"></a>
+<span class="sourceLineNo">1433</span>    this.executorService.startExecutorService(ExecutorType.MASTER_SNAPSHOT_OPERATIONS, conf.getInt(<a name="line.1433"></a>
+<span class="sourceLineNo">1434</span>      SnapshotManager.SNAPSHOT_POOL_THREADS_KEY, SnapshotManager.SNAPSHOT_POOL_THREADS_DEFAULT));<a name="line.1434"></a>
+<span class="sourceLineNo">1435</span><a name="line.1435"></a>
+<span class="sourceLineNo">1436</span>    // We depend on there being only one instance of this executor running<a name="line.1436"></a>
+<span class="sourceLineNo">1437</span>    // at a time. To do concurrency, would need fencing of enable/disable of<a name="line.1437"></a>
+<span class="sourceLineNo">1438</span>    // tables.<a name="line.1438"></a>
+<span class="sourceLineNo">1439</span>    // Any time changing this maxThreads to &gt; 1, pls see the comment at<a name="line.1439"></a>
+<span class="sourceLineNo">1440</span>    // AccessController#postCompletedCreateTableAction<a name="line.1440"></a>
+<span class="sourceLineNo">1441</span>    this.executorService.startExecutorService(ExecutorType.MASTER_TABLE_OPERATIONS, 1);<a name="line.1441"></a>
+<span class="sourceLineNo">1442</span>    startProcedureExecutor();<a name="line.1442"></a>
+<span class="sourceLineNo">1443</span><a name="line.1443"></a>
+<span class="sourceLineNo">1444</span>    // Create cleaner thread pool<a name="line.1444"></a>
+<span class="sourceLineNo">1445</span>    cleanerPool = new DirScanPool(conf);<a name="line.1445"></a>
+<span class="sourceLineNo">1446</span>    // Start log cleaner thread<a name="line.1446"></a>
+<span class="sourceLineNo">1447</span>    int cleanerInterval =<a name="line.1447"></a>
+<span class="sourceLineNo">1448</span>      conf.getInt(HBASE_MASTER_CLEANER_INTERVAL, DEFAULT_HBASE_MASTER_CLEANER_INTERVAL);<a name="line.1448"></a>
+<span class="sourceLineNo">1449</span>    this.logCleaner = new LogCleaner(cleanerInterval, this, conf,<a name="line.1449"></a>
+<span class="sourceLineNo">1450</span>      getMasterWalManager().getFileSystem(), getMasterWalManager().getOldLogDir(), cleanerPool);<a name="line.1450"></a>
+<span class="sourceLineNo">1451</span>    getChoreService().scheduleChore(logCleaner);<a name="line.1451"></a>
+<span class="sourceLineNo">1452</span><a name="line.1452"></a>
+<span class="sourceLineNo">1453</span>    // start the hfile archive cleaner thread<a name="line.1453"></a>
+<span class="sourceLineNo">1454</span>    Path archiveDir = HFileArchiveUtil.getArchivePath(conf);<a name="line.1454"></a>
+<span class="sourceLineNo">1455</span>    Map&lt;String, Object&gt; params = new HashMap&lt;&gt;();<a name="line.1455"></a>
+<span class="sourceLineNo">1456</span>    params.put(MASTER, this);<a name="line.1456"></a>
+<span class="sourceLineNo">1457</span>    this.hfileCleaner = new HFileCleaner(cleanerInterval, this, conf,<a name="line.1457"></a>
+<span class="sourceLineNo">1458</span>      getMasterFileSystem().getFileSystem(), archiveDir, cleanerPool, params);<a name="line.1458"></a>
+<span class="sourceLineNo">1459</span>    getChoreService().scheduleChore(hfileCleaner);<a name="line.1459"></a>
+<span class="sourceLineNo">1460</span><a name="line.1460"></a>
+<span class="sourceLineNo">1461</span>    // Regions Reopen based on very high storeFileRefCount is considered enabled<a name="line.1461"></a>
+<span class="sourceLineNo">1462</span>    // only if hbase.regions.recovery.store.file.ref.count has value &gt; 0<a name="line.1462"></a>
+<span class="sourceLineNo">1463</span>    final int maxStoreFileRefCount = conf.getInt(<a name="line.1463"></a>
+<span class="sourceLineNo">1464</span>      HConstants.STORE_FILE_REF_COUNT_THRESHOLD,<a name="line.1464"></a>
+<span class="sourceLineNo">1465</span>      HConstants.DEFAULT_STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1465"></a>
+<span class="sourceLineNo">1466</span>    if (maxStoreFileRefCount &gt; 0) {<a name="line.1466"></a>
+<span class="sourceLineNo">1467</span>      this.regionsRecoveryChore = new RegionsRecoveryChore(this, conf, this);<a name="line.1467"></a>
+<span class="sourceLineNo">1468</span>      getChoreService().scheduleChore(this.regionsRecoveryChore);<a name="line.1468"></a>
+<span class="sourceLineNo">1469</span>    } else {<a name="line.1469"></a>
+<span class="sourceLineNo">1470</span>      LOG.info("Reopening regions with very high storeFileRefCount is disabled. " +<a name="line.1470"></a>
+<span class="sourceLineNo">1471</span>          "Provide threshold value &gt; 0 for {} to enable it.",<a name="line.1471"></a>
+<span class="sourceLineNo">1472</span>        HConstants.STORE_FILE_REF_COUNT_THRESHOLD);<a name="line.1472"></a>
+<span class="sourceLineNo">1473</span>    }<a name="line.1473"></a>
 <span class="sourceLineNo">1474</span><a name="line.1474"></a>
-<span class="sourceLineNo">1475</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1475"></a>
-<span class="sourceLineNo">1476</span>      replicationPeerManager);<a name="line.1476"></a>
-<span class="sourceLineNo">1477</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1477"></a>
-<span class="sourceLineNo">1478</span><a name="line.1478"></a>
-<span class="sourceLineNo">1479</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1479"></a>
-<span class="sourceLineNo">1480</span>        .isSnapshotCleanupEnabled();<a name="line.1480"></a>
-<span class="sourceLineNo">1481</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1481"></a>
-<span class="sourceLineNo">1482</span>    if (isSnapshotChoreEnabled) {<a name="line.1482"></a>
-<span class="sourceLineNo">1483</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1483"></a>
-<span class="sourceLineNo">1484</span>    } else {<a name="line.1484"></a>
-<span class="sourceLineNo">1485</span>      if (LOG.isTraceEnabled()) {<a name="line.1485"></a>
-<span class="sourceLineNo">1486</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1486"></a>
-<span class="sourceLineNo">1487</span>      }<a name="line.1487"></a>
-<span class="sourceLineNo">1488</span>    }<a name="line.1488"></a>
-<span class="sourceLineNo">1489</span>    serviceStarted = true;<a name="line.1489"></a>
-<span class="sourceLineNo">1490</span>    if (LOG.isTraceEnabled()) {<a name="line.1490"></a>
-<span class="sourceLineNo">1491</span>      LOG.trace("Started service threads");<a name="line.1491"></a>
-<span class="sourceLineNo">1492</span>    }<a name="line.1492"></a>
-<span class="sourceLineNo">1493</span>  }<a name="line.1493"></a>
-<span class="sourceLineNo">1494</span><a name="line.1494"></a>
-<span class="sourceLineNo">1495</span>  @Override<a name="line.1495"></a>
-<span class="sourceLineNo">1496</span>  protected void stopServiceThreads() {<a name="line.1496"></a>
-<span class="sourceLineNo">1497</span>    if (masterJettyServer != null) {<a name="line.1497"></a>
-<span class="sourceLineNo">1498</span>      LOG.info("Stopping master jetty server");<a name="line.1498"></a>
-<span class="sourceLineNo">1499</span>      try {<a name="line.1499"></a>
-<span class="sourceLineNo">1500</span>        masterJettyServer.stop();<a name="line.1500"></a>
-<span class="sourceLineNo">1501</span>      } catch (Exception e) {<a name="line.1501"></a>
-<span class="sourceLineNo">1502</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1502"></a>
-<span class="sourceLineNo">1503</span>      }<a name="line.1503"></a>
-<span class="sourceLineNo">1504</span>    }<a name="line.1504"></a>
-<span class="sourceLineNo">1505</span>    stopChores();<a name="line.1505"></a>
-<span class="sourceLineNo">1506</span><a name="line.1506"></a>
-<span class="sourceLineNo">1507</span>    super.stopServiceThreads();<a name="line.1507"></a>
-<span class="sourceLineNo">1508</span>    if (cleanerPool != null) {<a name="line.1508"></a>
-<span class="sourceLineNo">1509</span>      cleanerPool.shutdownNow();<a name="line.1509"></a>
-<span class="sourceLineNo">1510</span>      cleanerPool = null;<a name="line.1510"></a>
-<span class="sourceLineNo">1511</span>    }<a name="line.1511"></a>
-<span class="sourceLineNo">1512</span><a name="line.1512"></a>
-<span class="sourceLineNo">1513</span>    LOG.debug("Stopping service threads");<a name="line.1513"></a>
+<span class="sourceLineNo">1475</span>    this.regionsRecoveryConfigManager = new RegionsRecoveryConfigManager(this);<a name="line.1475"></a>
+<span class="sourceLineNo">1476</span><a name="line.1476"></a>
+<span class="sourceLineNo">1477</span>    replicationBarrierCleaner = new ReplicationBarrierCleaner(conf, this, getConnection(),<a name="line.1477"></a>
+<span class="sourceLineNo">1478</span>      replicationPeerManager);<a name="line.1478"></a>
+<span class="sourceLineNo">1479</span>    getChoreService().scheduleChore(replicationBarrierCleaner);<a name="line.1479"></a>
+<span class="sourceLineNo">1480</span><a name="line.1480"></a>
+<span class="sourceLineNo">1481</span>    final boolean isSnapshotChoreEnabled = this.snapshotCleanupTracker<a name="line.1481"></a>
+<span class="sourceLineNo">1482</span>        .isSnapshotCleanupEnabled();<a name="line.1482"></a>
+<span class="sourceLineNo">1483</span>    this.snapshotCleanerChore = new SnapshotCleanerChore(this, conf, getSnapshotManager());<a name="line.1483"></a>
+<span class="sourceLineNo">1484</span>    if (isSnapshotChoreEnabled) {<a name="line.1484"></a>
+<span class="sourceLineNo">1485</span>      getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1485"></a>
+<span class="sourceLineNo">1486</span>    } else {<a name="line.1486"></a>
+<span class="sourceLineNo">1487</span>      if (LOG.isTraceEnabled()) {<a name="line.1487"></a>
+<span class="sourceLineNo">1488</span>        LOG.trace("Snapshot Cleaner Chore is disabled. Not starting up the chore..");<a name="line.1488"></a>
+<span class="sourceLineNo">1489</span>      }<a name="line.1489"></a>
+<span class="sourceLineNo">1490</span>    }<a name="line.1490"></a>
+<span class="sourceLineNo">1491</span>    serviceStarted = true;<a name="line.1491"></a>
+<span class="sourceLineNo">1492</span>    if (LOG.isTraceEnabled()) {<a name="line.1492"></a>
+<span class="sourceLineNo">1493</span>      LOG.trace("Started service threads");<a name="line.1493"></a>
+<span class="sourceLineNo">1494</span>    }<a name="line.1494"></a>
+<span class="sourceLineNo">1495</span>  }<a name="line.1495"></a>
+<span class="sourceLineNo">1496</span><a name="line.1496"></a>
+<span class="sourceLineNo">1497</span>  @Override<a name="line.1497"></a>
+<span class="sourceLineNo">1498</span>  protected void stopServiceThreads() {<a name="line.1498"></a>
+<span class="sourceLineNo">1499</span>    if (masterJettyServer != null) {<a name="line.1499"></a>
+<span class="sourceLineNo">1500</span>      LOG.info("Stopping master jetty server");<a name="line.1500"></a>
+<span class="sourceLineNo">1501</span>      try {<a name="line.1501"></a>
+<span class="sourceLineNo">1502</span>        masterJettyServer.stop();<a name="line.1502"></a>
+<span class="sourceLineNo">1503</span>      } catch (Exception e) {<a name="line.1503"></a>
+<span class="sourceLineNo">1504</span>        LOG.error("Failed to stop master jetty server", e);<a name="line.1504"></a>
+<span class="sourceLineNo">1505</span>      }<a name="line.1505"></a>
+<span class="sourceLineNo">1506</span>    }<a name="line.1506"></a>
+<span class="sourceLineNo">1507</span>    stopChores();<a name="line.1507"></a>
+<span class="sourceLineNo">1508</span><a name="line.1508"></a>
+<span class="sourceLineNo">1509</span>    super.stopServiceThreads();<a name="line.1509"></a>
+<span class="sourceLineNo">1510</span>    if (cleanerPool != null) {<a name="line.1510"></a>
+<span class="sourceLineNo">1511</span>      cleanerPool.shutdownNow();<a name="line.1511"></a>
+<span class="sourceLineNo">1512</span>      cleanerPool = null;<a name="line.1512"></a>
+<span class="sourceLineNo">1513</span>    }<a name="line.1513"></a>
 <span class="sourceLineNo">1514</span><a name="line.1514"></a>
-<span class="sourceLineNo">1515</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1515"></a>
-<span class="sourceLineNo">1516</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1516"></a>
-<span class="sourceLineNo">1517</span>    // example.<a name="line.1517"></a>
-<span class="sourceLineNo">1518</span>    stopProcedureExecutor();<a name="line.1518"></a>
-<span class="sourceLineNo">1519</span><a name="line.1519"></a>
-<span class="sourceLineNo">1520</span>    if (regionNormalizerManager != null) {<a name="line.1520"></a>
-<span class="sourceLineNo">1521</span>      regionNormalizerManager.stop();<a name="line.1521"></a>
-<span class="sourceLineNo">1522</span>    }<a name="line.1522"></a>
-<span class="sourceLineNo">1523</span>    if (this.quotaManager != null) {<a name="line.1523"></a>
-<span class="sourceLineNo">1524</span>      this.quotaManager.stop();<a name="line.1524"></a>
-<span class="sourceLineNo">1525</span>    }<a name="line.1525"></a>
-<span class="sourceLineNo">1526</span><a name="line.1526"></a>
-<span class="sourceLineNo">1527</span>    if (this.activeMasterManager != null) {<a name="line.1527"></a>
-<span class="sourceLineNo">1528</span>      this.activeMasterManager.stop();<a name="line.1528"></a>
-<span class="sourceLineNo">1529</span>    }<a name="line.1529"></a>
-<span class="sourceLineNo">1530</span>    if (this.serverManager != null) {<a name="line.1530"></a>
-<span class="sourceLineNo">1531</span>      this.serverManager.stop();<a name="line.1531"></a>
-<span class="sourceLineNo">1532</span>    }<a name="line.1532"></a>
-<span class="sourceLineNo">1533</span>    if (this.assignmentManager != null) {<a name="line.1533"></a>
-<span class="sourceLineNo">1534</span>      this.assignmentManager.stop();<a name="line.1534"></a>
-<span class="sourceLineNo">1535</span>    }<a name="line.1535"></a>
-<span class="sourceLineNo">1536</span><a name="line.1536"></a>
-<span class="sourceLineNo">1537</span>    if (masterRegion != null) {<a name="line.1537"></a>
-<span class="sourceLineNo">1538</span>      masterRegion.close(isAborted());<a name="line.1538"></a>
-<span class="sourceLineNo">1539</span>    }<a name="line.1539"></a>
-<span class="sourceLineNo">1540</span>    if (this.walManager != null) {<a name="line.1540"></a>
-<span class="sourceLineNo">1541</span>      this.walManager.stop();<a name="line.1541"></a>
-<span class="sourceLineNo">1542</span>    }<a name="line.1542"></a>
-<span class="sourceLineNo">1543</span>    if (this.fileSystemManager != null) {<a name="line.1543"></a>
-<span class="sourceLineNo">1544</span>      this.fileSystemManager.stop();<a name="line.1544"></a>
-<span class="sourceLineNo">1545</span>    }<a name="line.1545"></a>
-<span class="sourceLineNo">1546</span>    if (this.mpmHost != null) {<a name="line.1546"></a>
-<span class="sourceLineNo">1547</span>      this.mpmHost.stop("server shutting down.");<a name="line.1547"></a>
-<span class="sourceLineNo">1548</span>    }<a name="line.1548"></a>
-<span class="sourceLineNo">1549</span>    if (this.regionServerTracker != null) {<a name="line.1549"></a>
-<span class="sourceLineNo">1550</span>      this.regionServerTracker.stop();<a name="line.1550"></a>
-<span class="sourceLineNo">1551</span>    }<a name="line.1551"></a>
-<span class="sourceLineNo">1552</span>  }<a name="line.1552"></a>
-<span class="sourceLineNo">1553</span><a name="line.1553"></a>
-<span class="sourceLineNo">1554</span>  private void createProcedureExecutor() throws IOException {<a name="line.1554"></a>
-<span class="sourceLineNo">1555</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1555"></a>
-<span class="sourceLineNo">1556</span>    procedureStore =<a name="line.1556"></a>
-<span class="sourceLineNo">1557</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1557"></a>
-<span class="sourceLineNo">1558</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1558"></a>
-<span class="sourceLineNo">1559</span><a name="line.1559"></a>
-<span class="sourceLineNo">1560</span>      @Override<a name="line.1560"></a>
-<span class="sourceLineNo">1561</span>      public void abortProcess() {<a name="line.1561"></a>
-<span class="sourceLineNo">1562</span>        abort("The Procedure Store lost the lease", null);<a name="line.1562"></a>
-<span class="sourceLineNo">1563</span>      }<a name="line.1563"></a>
-<span class="sourceLineNo">1564</span>    });<a name="line.1564"></a>
-<span class="sourceLineNo">1565</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1565"></a>
-<span class="sourceLineNo">1566</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1566"></a>
-<span class="sourceLineNo">1567</span>    configurationManager.registerObserver(procEnv);<a name="line.1567"></a>
-<span class="sourceLineNo">1568</span><a name="line.1568"></a>
-<span class="sourceLineNo">1569</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1569"></a>
-<span class="sourceLineNo">1570</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1570"></a>
-<span class="sourceLineNo">1571</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1571"></a>
-<span class="sourceLineNo">1572</span>    final boolean abortOnCorruption =<a name="line.1572"></a>
-<span class="sourceLineNo">1573</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1573"></a>
-<span class="sourceLineNo">1574</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1574"></a>
-<span class="sourceLineNo">1575</span>    procedureStore.start(numThreads);<a name="line.1575"></a>
-<span class="sourceLineNo">1576</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1576"></a>
-<span class="sourceLineNo">1577</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1577"></a>
-<span class="sourceLineNo">1578</span>    // details.<a name="line.1578"></a>
-<span class="sourceLineNo">1579</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1579"></a>
-<span class="sourceLineNo">1580</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1580"></a>
-<span class="sourceLineNo">1581</span>      throw new HBaseIOException("Failed start of remote dispatcher");<a name="line.1581"></a>
-<span class="sourceLineNo">1582</span>    }<a name="line.1582"></a>
-<span class="sourceLineNo">1583</span>  }<a name="line.1583"></a>
-<span class="sourceLineNo">1584</span><a name="line.1584"></a>
-<span class="sourceLineNo">1585</span>  private void startProcedureExecutor() throws IOException {<a name="line.1585"></a>
-<span class="sourceLineNo">1586</span>    procedureExecutor.startWorkers();<a name="line.1586"></a>
-<span class="sourceLineNo">1587</span>  }<a name="line.1587"></a>
-<span class="sourceLineNo">1588</span><a name="line.1588"></a>
-<span class="sourceLineNo">1589</span>  /**<a name="line.1589"></a>
-<span class="sourceLineNo">1590</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1590"></a>
-<span class="sourceLineNo">1591</span>   *<a name="line.1591"></a>
-<span class="sourceLineNo">1592</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1592"></a>
-<span class="sourceLineNo">1593</span>   */<a name="line.1593"></a>
-<span class="sourceLineNo">1594</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1594"></a>
-<span class="sourceLineNo">1595</span>    if (synchronous) {<a name="line.1595"></a>
-<span class="sourceLineNo">1596</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1596"></a>
-<span class="sourceLineNo">1597</span>        switchSnapshotCleanup(on);<a name="line.1597"></a>
-<span class="sourceLineNo">1598</span>      }<a name="line.1598"></a>
-<span class="sourceLineNo">1599</span>    } else {<a name="line.1599"></a>
-<span class="sourceLineNo">1600</span>      switchSnapshotCleanup(on);<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><a name="line.1603"></a>
-<span class="sourceLineNo">1604</span>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1604"></a>
-<span class="sourceLineNo">1605</span>    try {<a name="line.1605"></a>
-<span class="sourceLineNo">1606</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1606"></a>
-<span class="sourceLineNo">1607</span>      if (on) {<a name="line.1607"></a>
-<span class="sourceLineNo">1608</span>        if (!getChoreService().isChoreScheduled(this.snapshotCleanerChore)) {<a name="line.1608"></a>
-<span class="sourceLineNo">1609</span>          getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1609"></a>
-<span class="sourceLineNo">1610</span>        }<a name="line.1610"></a>
-<span class="sourceLineNo">1611</span>      } else {<a name="line.1611"></a>
-<span class="sourceLineNo">1612</span>        getChoreService().cancelChore(this.snapshotCleanerChore);<a name="line.1612"></a>
-<span class="sourceLineNo">1613</span>      }<a name="line.1613"></a>
-<span class="sourceLineNo">1614</span>    } catch (KeeperException e) {<a name="line.1614"></a>
-<span class="sourceLineNo">1615</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1615"></a>
-<span class="sourceLineNo">1616</span>    }<a name="line.1616"></a>
-<span class="sourceLineNo">1617</span>  }<a name="line.1617"></a>
-<span class="sourceLineNo">1618</span><a name="line.1618"></a>
-<span class="sourceLineNo">1619</span><a name="line.1619"></a>
-<span class="sourceLineNo">1620</span>  private void stopProcedureExecutor() {<a name="line.1620"></a>
-<span class="sourceLineNo">1621</span>    if (procedureExecutor != null) {<a name="line.1621"></a>
-<span class="sourceLineNo">1622</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1622"></a>
-<span class="sourceLineNo">1623</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1623"></a>
-<span class="sourceLineNo">1624</span>      procedureExecutor.stop();<a name="line.1624"></a>
-<span class="sourceLineNo">1625</span>      procedureExecutor.join();<a name="line.1625"></a>
-<span class="sourceLineNo">1626</span>      procedureExecutor = null;<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>    if (procedureStore != null) {<a name="line.1629"></a>
-<span class="sourceLineNo">1630</span>      procedureStore.stop(isAborted());<a name="line.1630"></a>
-<span class="sourceLineNo">1631</span>      procedureStore = null;<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>  private void stopChores() {<a name="line.1635"></a>
-<span class="sourceLineNo">1636</span>    ChoreService choreService = getChoreService();<a name="line.1636"></a>
-<span class="sourceLineNo">1637</span>    if (choreService != null) {<a name="line.1637"></a>
-<span class="sourceLineNo">1638</span>      choreService.cancelChore(this.mobFileCleanerChore);<a name="line.1638"></a>
-<span class="sourceLineNo">1639</span>      choreService.cancelChore(this.mobFileCompactionChore);<a name="line.1639"></a>
-<span class="sourceLineNo">1640</span>      choreService.cancelChore(this.balancerChore);<a name="line.1640"></a>
-<span class="sourceLineNo">1641</span>      choreService.cancelChore(getRegionNormalizerManager().getRegionNormalizerChore());<a name="line.1641"></a>
-<span class="sourceLineNo">1642</span>      choreService.cancelChore(this.clusterStatusChore);<a name="line.1642"></a>
-<span class="sourceLineNo">1643</span>      choreService.cancelChore(this.catalogJanitorChore);<a name="line.1643"></a>
-<span class="sourceLineNo">1644</span>      choreService.cancelChore(this.clusterStatusPublisherChore);<a name="line.1644"></a>
-<span class="sourceLineNo">1645</span>      choreService.cancelChore(this.snapshotQuotaChore);<a name="line.1645"></a>
-<span class="sourceLineNo">1646</span>      choreService.cancelChore(this.logCleaner);<a name="line.1646"></a>
-<span class="sourceLineNo">1647</span>      choreService.cancelChore(this.hfileCleaner);<a name="line.1647"></a>
-<span class="sourceLineNo">1648</span>      choreService.cancelChore(this.replicationBarrierCleaner);<a name="line.1648"></a>
-<span class="sourceLineNo">1649</span>      choreService.cancelChore(this.snapshotCleanerChore);<a name="line.1649"></a>
-<span class="sourceLineNo">1650</span>      choreService.cancelChore(this.hbckChore);<a name="line.1650"></a>
-<span class="sourceLineNo">1651</span>      choreService.cancelChore(this.regionsRecoveryChore);<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><a name="line.1654"></a>
-<span class="sourceLineNo">1655</span>  /**<a name="line.1655"></a>
-<span class="sourceLineNo">1656</span>   * @return Get remote side's InetAddress<a name="line.1656"></a>
-<span class="sourceLineNo">1657</span>   */<a name="line.1657"></a>
-<span class="sourceLineNo">1658</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1658"></a>
-<span class="sourceLineNo">1659</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1659"></a>
-<span class="sourceLineNo">1660</span>    // Do it out here in its own little method so can fake an address when<a name="line.1660"></a>
-<span class="sourceLineNo">1661</span>    // mocking up in tests.<a name="line.1661"></a>
-<span class="sourceLineNo">1662</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1662"></a>
-<span class="sourceLineNo">1663</span><a name="line.1663"></a>
-<span class="sourceLineNo">1664</span>    // The call could be from the local regionserver,<a name="line.1664"></a>
-<span class="sourceLineNo">1665</span>    // in which case, there is no remote address.<a name="line.1665"></a>
-<span class="sourceLineNo">1666</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1666"></a>
-<span class="sourceLineNo">1667</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1667"></a>
-<span class="sourceLineNo">1668</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1668"></a>
-<span class="sourceLineNo">1669</span>        ia = isa.getAddress();<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>    return ia;<a name="line.1672"></a>
-<span class="sourceLineNo">1673</span>  }<a name="line.1673"></a>
-<span class="sourceLineNo">1674</span><a name="line.1674"></a>
-<span class="sourceLineNo">1675</span>  /**<a name="line.1675"></a>
-<span class="sourceLineNo">1676</span>   * @return Maximum time we should run balancer for<a name="line.1676"></a>
-<span class="sourceLineNo">1677</span>   */<a name="line.1677"></a>
-<span class="sourceLineNo">1678</span>  private int getMaxBalancingTime() {<a name="line.1678"></a>
-<span class="sourceLineNo">1679</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1679"></a>
-<span class="sourceLineNo">1680</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1680"></a>
-<span class="sourceLineNo">1681</span>      getConfiguration()<a name="line.1681"></a>
-<span class="sourceLineNo">1682</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1682"></a>
-<span class="sourceLineNo">1683</span>    return maxBalancingTime;<a name="line.1683"></a>
-<span class="sourceLineNo">1684</span>  }<a name="line.1684"></a>
-<span class="sourceLineNo">1685</span><a name="line.1685"></a>
-<span class="sourceLineNo">1686</span>  /**<a name="line.1686"></a>
-<span class="sourceLineNo">1687</span>   * @return Maximum number of regions in transition<a name="line.1687"></a>
-<span class="sourceLineNo">1688</span>   */<a name="line.1688"></a>
-<span class="sourceLineNo">1689</span>  private int getMaxRegionsInTransition() {<a name="line.1689"></a>
-<span class="sourceLineNo">1690</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1690"></a>
-<span class="sourceLineNo">1691</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<a name="line.1691"></a>
-<span class="sourceLineNo">1692</span>  }<a name="line.1692"></a>
-<span class="sourceLineNo">1693</span><a name="line.1693"></a>
-<span class="sourceLineNo">1694</span>  /**<a name="line.1694"></a>
-<span class="sourceLineNo">1695</span>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1695"></a>
-<span class="sourceLineNo">1696</span>   * number regions in transition to protect availability.<a name="line.1696"></a>
-<span class="sourceLineNo">1697</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1697"></a>
-<span class="sourceLineNo">1698</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1698"></a>
-<span class="sourceLineNo">1699</span>   * @param cutoffTime when to exit balancer<a name="line.1699"></a>
-<span class="sourceLineNo">1700</span>   */<a name="line.1700"></a>
-<span class="sourceLineNo">1701</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1701"></a>
-<span class="sourceLineNo">1702</span>      long cutoffTime) {<a name="line.1702"></a>
-<span class="sourceLineNo">1703</span>    boolean interrupted = false;<a name="line.1703"></a>
-<span class="sourceLineNo">1704</span><a name="line.1704"></a>
-<span class="sourceLineNo">1705</span>    // Sleep to next balance plan start time<a name="line.1705"></a>
-<span class="sourceLineNo">1706</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1706"></a>
-<span class="sourceLineNo">1707</span>    while (!interrupted &amp;&amp; System.currentTimeMillis() &lt; nextBalanceStartTime<a name="line.1707"></a>
-<span class="sourceLineNo">1708</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1708"></a>
-<span class="sourceLineNo">1709</span>      try {<a name="line.1709"></a>
-<span class="sourceLineNo">1710</span>        Thread.sleep(100);<a name="line.1710"></a>
-<span class="sourceLineNo">1711</span>      } catch (InterruptedException ie) {<a name="line.1711"></a>
-<span class="sourceLineNo">1712</span>        interrupted = true;<a name="line.1712"></a>
-<span class="sourceLineNo">1713</span>      }<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>    // Throttling by max number regions in transition<a name="line.1716"></a>
-<span class="sourceLineNo">1717</span>    while (!interrupted<a name="line.1717"></a>
-<span class="sourceLineNo">1718</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1718"></a>
-<span class="sourceLineNo">1719</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1719"></a>
-<span class="sourceLineNo">1720</span>        &gt;= maxRegionsInTransition &amp;&amp; System.currentTimeMillis() &lt;= cutoffTime) {<a name="line.1720"></a>
-<span class="sourceLineNo">1721</span>      try {<a name="line.1721"></a>
-<span class="sourceLineNo">1722</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1722"></a>
-<span class="sourceLineNo">1723</span>        Thread.sleep(100);<a name="line.1723"></a>
-<span class="sourceLineNo">1724</span>      } catch (InterruptedException ie) {<a name="line.1724"></a>
-<span class="sourceLineNo">1725</span>        interrupted = true;<a name="line.1725"></a>
-<span class="sourceLineNo">1726</span>      }<a name="line.1726"></a>
-<span class="sourceLineNo">1727</span>    }<a name="line.1727"></a>
-<span class="sourceLineNo">1728</span><a name="line.1728"></a>
-<span class="sourceLineNo">1729</span>    if (interrupted) Thread.currentThread().interrupt();<a name="line.1729"></a>
-<span class="sourceLineNo">1730</span>  }<a name="line.1730"></a>
-<span class="sourceLineNo">1731</span><a name="line.1731"></a>
-<span class="sourceLineNo">1732</span>  public boolean balance() throws IOException {<a name="line.1732"></a>
-<span class="sourceLineNo">1733</span>    return balance(false);<a name="line.1733"></a>
+<span class="sourceLineNo">1515</span>    LOG.debug("Stopping service threads");<a name="line.1515"></a>
+<span class="sourceLineNo">1516</span><a name="line.1516"></a>
+<span class="sourceLineNo">1517</span>    // stop procedure executor prior to other services such as server manager and assignment<a name="line.1517"></a>
+<span class="sourceLineNo">1518</span>    // manager, as these services are important for some running procedures. See HBASE-24117 for<a name="line.1518"></a>
+<span class="sourceLineNo">1519</span>    // example.<a name="line.1519"></a>
+<span class="sourceLineNo">1520</span>    stopProcedureExecutor();<a name="line.1520"></a>
+<span class="sourceLineNo">1521</span><a name="line.1521"></a>
+<span class="sourceLineNo">1522</span>    if (regionNormalizerManager != null) {<a name="line.1522"></a>
+<span class="sourceLineNo">1523</span>      regionNormalizerManager.stop();<a name="line.1523"></a>
+<span class="sourceLineNo">1524</span>    }<a name="line.1524"></a>
+<span class="sourceLineNo">1525</span>    if (this.quotaManager != null) {<a name="line.1525"></a>
+<span class="sourceLineNo">1526</span>      this.quotaManager.stop();<a name="line.1526"></a>
+<span class="sourceLineNo">1527</span>    }<a name="line.1527"></a>
+<span class="sourceLineNo">1528</span><a name="line.1528"></a>
+<span class="sourceLineNo">1529</span>    if (this.activeMasterManager != null) {<a name="line.1529"></a>
+<span class="sourceLineNo">1530</span>      this.activeMasterManager.stop();<a name="line.1530"></a>
+<span class="sourceLineNo">1531</span>    }<a name="line.1531"></a>
+<span class="sourceLineNo">1532</span>    if (this.serverManager != null) {<a name="line.1532"></a>
+<span class="sourceLineNo">1533</span>      this.serverManager.stop();<a name="line.1533"></a>
+<span class="sourceLineNo">1534</span>    }<a name="line.1534"></a>
+<span class="sourceLineNo">1535</span>    if (this.assignmentManager != null) {<a name="line.1535"></a>
+<span class="sourceLineNo">1536</span>      this.assignmentManager.stop();<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>    if (masterRegion != null) {<a name="line.1539"></a>
+<span class="sourceLineNo">1540</span>      masterRegion.close(isAborted());<a name="line.1540"></a>
+<span class="sourceLineNo">1541</span>    }<a name="line.1541"></a>
+<span class="sourceLineNo">1542</span>    if (this.walManager != null) {<a name="line.1542"></a>
+<span class="sourceLineNo">1543</span>      this.walManager.stop();<a name="line.1543"></a>
+<span class="sourceLineNo">1544</span>    }<a name="line.1544"></a>
+<span class="sourceLineNo">1545</span>    if (this.fileSystemManager != null) {<a name="line.1545"></a>
+<span class="sourceLineNo">1546</span>      this.fileSystemManager.stop();<a name="line.1546"></a>
+<span class="sourceLineNo">1547</span>    }<a name="line.1547"></a>
+<span class="sourceLineNo">1548</span>    if (this.mpmHost != null) {<a name="line.1548"></a>
+<span class="sourceLineNo">1549</span>      this.mpmHost.stop("server shutting down.");<a name="line.1549"></a>
+<span class="sourceLineNo">1550</span>    }<a name="line.1550"></a>
+<span class="sourceLineNo">1551</span>    if (this.regionServerTracker != null) {<a name="line.1551"></a>
+<span class="sourceLineNo">1552</span>      this.regionServerTracker.stop();<a name="line.1552"></a>
+<span class="sourceLineNo">1553</span>    }<a name="line.1553"></a>
+<span class="sourceLineNo">1554</span>  }<a name="line.1554"></a>
+<span class="sourceLineNo">1555</span><a name="line.1555"></a>
+<span class="sourceLineNo">1556</span>  private void createProcedureExecutor() throws IOException {<a name="line.1556"></a>
+<span class="sourceLineNo">1557</span>    MasterProcedureEnv procEnv = new MasterProcedureEnv(this);<a name="line.1557"></a>
+<span class="sourceLineNo">1558</span>    procedureStore =<a name="line.1558"></a>
+<span class="sourceLineNo">1559</span>      new RegionProcedureStore(this, masterRegion, new MasterProcedureEnv.FsUtilsLeaseRecovery(this));<a name="line.1559"></a>
+<span class="sourceLineNo">1560</span>    procedureStore.registerListener(new ProcedureStoreListener() {<a name="line.1560"></a>
+<span class="sourceLineNo">1561</span><a name="line.1561"></a>
+<span class="sourceLineNo">1562</span>      @Override<a name="line.1562"></a>
+<span class="sourceLineNo">1563</span>      public void abortProcess() {<a name="line.1563"></a>
+<span class="sourceLineNo">1564</span>        abort("The Procedure Store lost the lease", null);<a name="line.1564"></a>
+<span class="sourceLineNo">1565</span>      }<a name="line.1565"></a>
+<span class="sourceLineNo">1566</span>    });<a name="line.1566"></a>
+<span class="sourceLineNo">1567</span>    MasterProcedureScheduler procedureScheduler = procEnv.getProcedureScheduler();<a name="line.1567"></a>
+<span class="sourceLineNo">1568</span>    procedureExecutor = new ProcedureExecutor&lt;&gt;(conf, procEnv, procedureStore, procedureScheduler);<a name="line.1568"></a>
+<span class="sourceLineNo">1569</span>    configurationManager.registerObserver(procEnv);<a name="line.1569"></a>
+<span class="sourceLineNo">1570</span><a name="line.1570"></a>
+<span class="sourceLineNo">1571</span>    int cpus = Runtime.getRuntime().availableProcessors();<a name="line.1571"></a>
+<span class="sourceLineNo">1572</span>    final int numThreads = conf.getInt(MasterProcedureConstants.MASTER_PROCEDURE_THREADS, Math.max(<a name="line.1572"></a>
+<span class="sourceLineNo">1573</span>      (cpus &gt; 0 ? cpus / 4 : 0), MasterProcedureConstants.DEFAULT_MIN_MASTER_PROCEDURE_THREADS));<a name="line.1573"></a>
+<span class="sourceLineNo">1574</span>    final boolean abortOnCorruption =<a name="line.1574"></a>
+<span class="sourceLineNo">1575</span>      conf.getBoolean(MasterProcedureConstants.EXECUTOR_ABORT_ON_CORRUPTION,<a name="line.1575"></a>
+<span class="sourceLineNo">1576</span>        MasterProcedureConstants.DEFAULT_EXECUTOR_ABORT_ON_CORRUPTION);<a name="line.1576"></a>
+<span class="sourceLineNo">1577</span>    procedureStore.start(numThreads);<a name="line.1577"></a>
+<span class="sourceLineNo">1578</span>    // Just initialize it but do not start the workers, we will start the workers later by calling<a name="line.1578"></a>
+<span class="sourceLineNo">1579</span>    // startProcedureExecutor. See the javadoc for finishActiveMasterInitialization for more<a name="line.1579"></a>
+<span class="sourceLineNo">1580</span>    // details.<a name="line.1580"></a>
+<span class="sourceLineNo">1581</span>    procedureExecutor.init(numThreads, abortOnCorruption);<a name="line.1581"></a>
+<span class="sourceLineNo">1582</span>    if (!procEnv.getRemoteDispatcher().start()) {<a name="line.1582"></a>
+<span class="sourceLineNo">1583</span>      throw new HBaseIOException("Failed start of remote dispatcher");<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><a name="line.1586"></a>
+<span class="sourceLineNo">1587</span>  private void startProcedureExecutor() throws IOException {<a name="line.1587"></a>
+<span class="sourceLineNo">1588</span>    procedureExecutor.startWorkers();<a name="line.1588"></a>
+<span class="sourceLineNo">1589</span>  }<a name="line.1589"></a>
+<span class="sourceLineNo">1590</span><a name="line.1590"></a>
+<span class="sourceLineNo">1591</span>  /**<a name="line.1591"></a>
+<span class="sourceLineNo">1592</span>   * Turn on/off Snapshot Cleanup Chore<a name="line.1592"></a>
+<span class="sourceLineNo">1593</span>   *<a name="line.1593"></a>
+<span class="sourceLineNo">1594</span>   * @param on indicates whether Snapshot Cleanup Chore is to be run<a name="line.1594"></a>
+<span class="sourceLineNo">1595</span>   */<a name="line.1595"></a>
+<span class="sourceLineNo">1596</span>  void switchSnapshotCleanup(final boolean on, final boolean synchronous) {<a name="line.1596"></a>
+<span class="sourceLineNo">1597</span>    if (synchronous) {<a name="line.1597"></a>
+<span class="sourceLineNo">1598</span>      synchronized (this.snapshotCleanerChore) {<a name="line.1598"></a>
+<span class="sourceLineNo">1599</span>        switchSnapshotCleanup(on);<a name="line.1599"></a>
+<span class="sourceLineNo">1600</span>      }<a name="line.1600"></a>
+<span class="sourceLineNo">1601</span>    } else {<a name="line.1601"></a>
+<span class="sourceLineNo">1602</span>      switchSnapshotCleanup(on);<a name="line.1602"></a>
+<span class="sourceLineNo">1603</span>    }<a name="line.1603"></a>
+<span class="sourceLineNo">1604</span>  }<a name="line.1604"></a>
+<span class="sourceLineNo">1605</span><a name="line.1605"></a>
+<span class="sourceLineNo">1606</span>  private void switchSnapshotCleanup(final boolean on) {<a name="line.1606"></a>
+<span class="sourceLineNo">1607</span>    try {<a name="line.1607"></a>
+<span class="sourceLineNo">1608</span>      snapshotCleanupTracker.setSnapshotCleanupEnabled(on);<a name="line.1608"></a>
+<span class="sourceLineNo">1609</span>      if (on) {<a name="line.1609"></a>
+<span class="sourceLineNo">1610</span>        if (!getChoreService().isChoreScheduled(this.snapshotCleanerChore)) {<a name="line.1610"></a>
+<span class="sourceLineNo">1611</span>          getChoreService().scheduleChore(this.snapshotCleanerChore);<a name="line.1611"></a>
+<span class="sourceLineNo">1612</span>        }<a name="line.1612"></a>
+<span class="sourceLineNo">1613</span>      } else {<a name="line.1613"></a>
+<span class="sourceLineNo">1614</span>        getChoreService().cancelChore(this.snapshotCleanerChore);<a name="line.1614"></a>
+<span class="sourceLineNo">1615</span>      }<a name="line.1615"></a>
+<span class="sourceLineNo">1616</span>    } catch (KeeperException e) {<a name="line.1616"></a>
+<span class="sourceLineNo">1617</span>      LOG.error("Error updating snapshot cleanup mode to {}", on, e);<a name="line.1617"></a>
+<span class="sourceLineNo">1618</span>    }<a name="line.1618"></a>
+<span class="sourceLineNo">1619</span>  }<a name="line.1619"></a>
+<span class="sourceLineNo">1620</span><a name="line.1620"></a>
+<span class="sourceLineNo">1621</span><a name="line.1621"></a>
+<span class="sourceLineNo">1622</span>  private void stopProcedureExecutor() {<a name="line.1622"></a>
+<span class="sourceLineNo">1623</span>    if (procedureExecutor != null) {<a name="line.1623"></a>
+<span class="sourceLineNo">1624</span>      configurationManager.deregisterObserver(procedureExecutor.getEnvironment());<a name="line.1624"></a>
+<span class="sourceLineNo">1625</span>      procedureExecutor.getEnvironment().getRemoteDispatcher().stop();<a name="line.1625"></a>
+<span class="sourceLineNo">1626</span>      procedureExecutor.stop();<a name="line.1626"></a>
+<span class="sourceLineNo">1627</span>      procedureExecutor.join();<a name="line.1627"></a>
+<span class="sourceLineNo">1628</span>      procedureExecutor = null;<a name="line.1628"></a>
+<span class="sourceLineNo">1629</span>    }<a name="line.1629"></a>
+<span class="sourceLineNo">1630</span><a name="line.1630"></a>
+<span class="sourceLineNo">1631</span>    if (procedureStore != null) {<a name="line.1631"></a>
+<span class="sourceLineNo">1632</span>      procedureStore.stop(isAborted());<a name="line.1632"></a>
+<span class="sourceLineNo">1633</span>      procedureStore = null;<a name="line.1633"></a>
+<span class="sourceLineNo">1634</span>    }<a name="line.1634"></a>
+<span class="sourceLineNo">1635</span>  }<a name="line.1635"></a>
+<span class="sourceLineNo">1636</span><a name="line.1636"></a>
+<span class="sourceLineNo">1637</span>  private void stopChores() {<a name="line.1637"></a>
+<span class="sourceLineNo">1638</span>    ChoreService choreService = getChoreService();<a name="line.1638"></a>
+<span class="sourceLineNo">1639</span>    if (choreService != null) {<a name="line.1639"></a>
+<span class="sourceLineNo">1640</span>      choreService.cancelChore(this.mobFileCleanerChore);<a name="line.1640"></a>
+<span class="sourceLineNo">1641</span>      choreService.cancelChore(this.mobFileCompactionChore);<a name="line.1641"></a>
+<span class="sourceLineNo">1642</span>      choreService.cancelChore(this.balancerChore);<a name="line.1642"></a>
+<span class="sourceLineNo">1643</span>      if (regionNormalizerManager != null) {<a name="line.1643"></a>
+<span class="sourceLineNo">1644</span>        choreService.cancelChore(regionNormalizerManager.getRegionNormalizerChore());<a name="line.1644"></a>
+<span class="sourceLineNo">1645</span>      }<a name="line.1645"></a>
+<span class="sourceLineNo">1646</span>      choreService.cancelChore(this.clusterStatusChore);<a name="line.1646"></a>
+<span class="sourceLineNo">1647</span>      choreService.cancelChore(this.catalogJanitorChore);<a name="line.1647"></a>
+<span class="sourceLineNo">1648</span>      choreService.cancelChore(this.clusterStatusPublisherChore);<a name="line.1648"></a>
+<span class="sourceLineNo">1649</span>      choreService.cancelChore(this.snapshotQuotaChore);<a name="line.1649"></a>
+<span class="sourceLineNo">1650</span>      choreService.cancelChore(this.logCleaner);<a name="line.1650"></a>
+<span class="sourceLineNo">1651</span>      choreService.cancelChore(this.hfileCleaner);<a name="line.1651"></a>
+<span class="sourceLineNo">1652</span>      choreService.cancelChore(this.replicationBarrierCleaner);<a name="line.1652"></a>
+<span class="sourceLineNo">1653</span>      choreService.cancelChore(this.snapshotCleanerChore);<a name="line.1653"></a>
+<span class="sourceLineNo">1654</span>      choreService.cancelChore(this.hbckChore);<a name="line.1654"></a>
+<span class="sourceLineNo">1655</span>      choreService.cancelChore(this.regionsRecoveryChore);<a name="line.1655"></a>
+<span class="sourceLineNo">1656</span>    }<a name="line.1656"></a>
+<span class="sourceLineNo">1657</span>  }<a name="line.1657"></a>
+<span class="sourceLineNo">1658</span><a name="line.1658"></a>
+<span class="sourceLineNo">1659</span>  /**<a name="line.1659"></a>
+<span class="sourceLineNo">1660</span>   * @return Get remote side's InetAddress<a name="line.1660"></a>
+<span class="sourceLineNo">1661</span>   */<a name="line.1661"></a>
+<span class="sourceLineNo">1662</span>  InetAddress getRemoteInetAddress(final int port,<a name="line.1662"></a>
+<span class="sourceLineNo">1663</span>      final long serverStartCode) throws UnknownHostException {<a name="line.1663"></a>
+<span class="sourceLineNo">1664</span>    // Do it out here in its own little method so can fake an address when<a name="line.1664"></a>
+<span class="sourceLineNo">1665</span>    // mocking up in tests.<a name="line.1665"></a>
+<span class="sourceLineNo">1666</span>    InetAddress ia = RpcServer.getRemoteIp();<a name="line.1666"></a>
+<span class="sourceLineNo">1667</span><a name="line.1667"></a>
+<span class="sourceLineNo">1668</span>    // The call could be from the local regionserver,<a name="line.1668"></a>
+<span class="sourceLineNo">1669</span>    // in which case, there is no remote address.<a name="line.1669"></a>
+<span class="sourceLineNo">1670</span>    if (ia == null &amp;&amp; serverStartCode == startcode) {<a name="line.1670"></a>
+<span class="sourceLineNo">1671</span>      InetSocketAddress isa = rpcServices.getSocketAddress();<a name="line.1671"></a>
+<span class="sourceLineNo">1672</span>      if (isa != null &amp;&amp; isa.getPort() == port) {<a name="line.1672"></a>
+<span class="sourceLineNo">1673</span>        ia = isa.getAddress();<a name="line.1673"></a>
+<span class="sourceLineNo">1674</span>      }<a name="line.1674"></a>
+<span class="sourceLineNo">1675</span>    }<a name="line.1675"></a>
+<span class="sourceLineNo">1676</span>    return ia;<a name="line.1676"></a>
+<span class="sourceLineNo">1677</span>  }<a name="line.1677"></a>
+<span class="sourceLineNo">1678</span><a name="line.1678"></a>
+<span class="sourceLineNo">1679</span>  /**<a name="line.1679"></a>
+<span class="sourceLineNo">1680</span>   * @return Maximum time we should run balancer for<a name="line.1680"></a>
+<span class="sourceLineNo">1681</span>   */<a name="line.1681"></a>
+<span class="sourceLineNo">1682</span>  private int getMaxBalancingTime() {<a name="line.1682"></a>
+<span class="sourceLineNo">1683</span>    // if max balancing time isn't set, defaulting it to period time<a name="line.1683"></a>
+<span class="sourceLineNo">1684</span>    int maxBalancingTime = getConfiguration().getInt(HConstants.HBASE_BALANCER_MAX_BALANCING,<a name="line.1684"></a>
+<span class="sourceLineNo">1685</span>      getConfiguration()<a name="line.1685"></a>
+<span class="sourceLineNo">1686</span>        .getInt(HConstants.HBASE_BALANCER_PERIOD, HConstants.DEFAULT_HBASE_BALANCER_PERIOD));<a name="line.1686"></a>
+<span class="sourceLineNo">1687</span>    return maxBalancingTime;<a name="line.1687"></a>
+<span class="sourceLineNo">1688</span>  }<a name="line.1688"></a>
+<span class="sourceLineNo">1689</span><a name="line.1689"></a>
+<span class="sourceLineNo">1690</span>  /**<a name="line.1690"></a>
+<span class="sourceLineNo">1691</span>   * @return Maximum number of regions in transition<a name="line.1691"></a>
+<span class="sourceLineNo">1692</span>   */<a name="line.1692"></a>
+<span class="sourceLineNo">1693</span>  private int getMaxRegionsInTransition() {<a name="line.1693"></a>
+<span class="sourceLineNo">1694</span>    int numRegions = this.assignmentManager.getRegionStates().getRegionAssignments().size();<a name="line.1694"></a>
+<span class="sourceLineNo">1695</span>    return Math.max((int) Math.floor(numRegions * this.maxRitPercent), 1);<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>   * It first sleep to the next balance plan start time. Meanwhile, throttling by the max<a name="line.1699"></a>
+<span class="sourceLineNo">1700</span>   * number regions in transition to protect availability.<a name="line.1700"></a>
+<span class="sourceLineNo">1701</span>   * @param nextBalanceStartTime The next balance plan start time<a name="line.1701"></a>
+<span class="sourceLineNo">1702</span>   * @param maxRegionsInTransition max number of regions in transition<a name="line.1702"></a>
+<span class="sourceLineNo">1703</span>   * @param cutoffTime when to exit balancer<a name="line.1703"></a>
+<span class="sourceLineNo">1704</span>   */<a name="line.1704"></a>
+<span class="sourceLineNo">1705</span>  private void balanceThrottling(long nextBalanceStartTime, int maxRegionsInTransition,<a name="line.1705"></a>
+<span class="sourceLineNo">1706</span>      long cutoffTime) {<a name="line.1706"></a>
+<span class="sourceLineNo">1707</span>    boolean interrupted = false;<a name="line.1707"></a>
+<span class="sourceLineNo">1708</span><a name="line.1708"></a>
+<span class="sourceLineNo">1709</span>    // Sleep to next balance plan start time<a name="line.1709"></a>
+<span class="sourceLineNo">1710</span>    // But if there are zero regions in transition, it can skip sleep to speed up.<a name="line.1710"></a>
+<span class="sourceLineNo">1711</span>    while (!interrupted &amp;&amp; System.currentTimeMillis() &lt; nextBalanceStartTime<a name="line.1711"></a>
+<span class="sourceLineNo">1712</span>        &amp;&amp; this.assignmentManager.getRegionStates().hasRegionsInTransition()) {<a name="line.1712"></a>
+<span class="sourceLineNo">1713</span>      try {<a name="line.1713"></a>
+<span class="sourceLineNo">1714</span>        Thread.sleep(100);<a name="line.1714"></a>
+<span class="sourceLineNo">1715</span>      } catch (InterruptedException ie) {<a name="line.1715"></a>
+<span class="sourceLineNo">1716</span>        interrupted = true;<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>    // Throttling by max number regions in transition<a name="line.1720"></a>
+<span class="sourceLineNo">1721</span>    while (!interrupted<a name="line.1721"></a>
+<span class="sourceLineNo">1722</span>        &amp;&amp; maxRegionsInTransition &gt; 0<a name="line.1722"></a>
+<span class="sourceLineNo">1723</span>        &amp;&amp; this.assignmentManager.getRegionStates().getRegionsInTransitionCount()<a name="line.1723"></a>
+<span class="sourceLineNo">1724</span>        &gt;= maxRegionsInTransition &amp;&amp; System.currentTimeMillis() &lt;= cutoffTime) {<a name="line.1724"></a>
+<span class="sourceLineNo">1725</span>      try {<a name="line.1725"></a>
+<span class="sourceLineNo">1726</span>        // sleep if the number of regions in transition exceeds the limit<a name="line.1726"></a>
+<span class="sourceLineNo">1727</span>        Thread.sleep(100);<a name="line.1727"></a>
+<span class="sourceLineNo">1728</span>      } catch (InterruptedException ie) {<a name="line.1728"></a>
+<span class="sourceLineNo">1729</span>        interrupted = true;<a name="line.1729"></a>
+<span class="sourceLineNo">1730</span>      }<a name="line.1730"></a>
+<span class="sourceLineNo">1731</span>    }<a name="line.1731"></a>
+<span class="sourceLineNo">1732</span><a name="line.1732"></a>
+<span class="sourceLineNo">1733</span>    if (interrupted) Thread.currentThread().interrupt();<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>  /**<a name="line.1736"></a>
-<span class="sourceLineNo">1737</span>   * Checks master state before initiating action over region topology.<a name="line.1737"></a>
-<span class="sourceLineNo">1738</span>   * @param action the name of the action under consideration, for logging.<a name="line.1738"></a>
-<span class="sourceLineNo">1739</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1739"></a>
-<span class="sourceLineNo">1740</span>   */<a name="line.1740"></a>
-<span class="sourceLineNo">1741</span>  @Override<a name="line.1741"></a>
-<span class="sourceLineNo">1742</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1742"></a>
-<span class="sourceLineNo">1743</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1743"></a>
-<span class="sourceLineNo">1744</span>    if (!isInitialized()) {<a name="line.1744"></a>
-<span class="sourceLineNo">1745</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1745"></a>
-<span class="sourceLineNo">1746</span>      return true;<a name="line.1746"></a>
-<span class="sourceLineNo">1747</span>    }<a name="line.1747"></a>
-<span class="sourceLineNo">1748</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1748"></a>
-<span class="sourceLineNo">1749</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1749"></a>
+<span class="sourceLineNo">1736</span>  public boolean balance() throws IOException {<a name="line.1736"></a>
+<span class="sourceLineNo">1737</span>    return balance(false);<a name="line.1737"></a>
+<span class="sourceLineNo">1738</span>  }<a name="line.1738"></a>
+<span class="sourceLineNo">1739</span><a name="line.1739"></a>
+<span class="sourceLineNo">1740</span>  /**<a name="line.1740"></a>
+<span class="sourceLineNo">1741</span>   * Checks master state before initiating action over region topology.<a name="line.1741"></a>
+<span class="sourceLineNo">1742</span>   * @param action the name of the action under consideration, for logging.<a name="line.1742"></a>
+<span class="sourceLineNo">1743</span>   * @return {@code true} when the caller should exit early, {@code false} otherwise.<a name="line.1743"></a>
+<span class="sourceLineNo">1744</span>   */<a name="line.1744"></a>
+<span class="sourceLineNo">1745</span>  @Override<a name="line.1745"></a>
+<span class="sourceLineNo">1746</span>  public boolean skipRegionManagementAction(final String action) {<a name="line.1746"></a>
+<span class="sourceLineNo">1747</span>    // Note: this method could be `default` on MasterServices if but for logging.<a name="line.1747"></a>
+<span class="sourceLineNo">1748</span>    if (!isInitialized()) {<a name="line.1748"></a>
+<span class="sourceLineNo">1749</span>      LOG.debug("Master has not been initialized, don't run {}.", action);<a name="line.1749"></a>
 <span class="sourceLineNo">1750</span>      return true;<a name="line.1750"></a>
 <span class="sourceLineNo">1751</span>    }<a name="line.1751"></a>
-<span class="sourceLineNo">1752</span>    if (isInMaintenanceMode()) {<a name="line.1752"></a>
-<span class="sourceLineNo">1753</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1753"></a>
+<span class="sourceLineNo">1752</span>    if (this.getServerManager().isClusterShutdown()) {<a name="line.1752"></a>
+<span class="sourceLineNo">1753</span>      LOG.info("Cluster is shutting down, don't run {}.", action);<a name="line.1753"></a>
 <span class="sourceLineNo">1754</span>      return true;<a name="line.1754"></a>
 <span class="sourceLineNo">1755</span>    }<a name="line.1755"></a>
-<span class="sourceLineNo">1756</span>    return false;<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>  public boolean balance(boolean force) throws IOException {<a name="line.1759"></a>
-<span class="sourceLineNo">1760</span>    if (loadBalancerTracker == null || !loadBalancerTracker.isBalancerOn()) {<a name="line.1760"></a>
-<span class="sourceLineNo">1761</span>      return false;<a name="line.1761"></a>
-<span class="sourceLineNo">1762</span>    }<a name="line.1762"></a>
-<span class="sourceLineNo">1763</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1763"></a>
-<span class="sourceLineNo">1764</span>      return false;<a name="line.1764"></a>
-<span class="sourceLineNo">1765</span>    }<a name="line.1765"></a>
-<span class="sourceLineNo">1766</span><a name="line.1766"></a>
-<span class="sourceLineNo">1767</span>    synchronized (this.balancer) {<a name="line.1767"></a>
-<span class="sourceLineNo">1768</span>        // Only allow one balance run at at time.<a name="line.1768"></a>
-<span class="sourceLineNo">1769</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1769"></a>
-<span class="sourceLineNo">1770</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1770"></a>
-<span class="sourceLineNo">1771</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1771"></a>
-<span class="sourceLineNo">1772</span>        // ignore the force flag in that case<a name="line.1772"></a>
-<span class="sourceLineNo">1773</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1773"></a>
-<span class="sourceLineNo">1774</span>        String prefix = force &amp;&amp; !metaInTransition ? "R" : "Not r";<a name="line.1774"></a>
-<span class="sourceLineNo">1775</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1775"></a>
-<span class="sourceLineNo">1776</span>        int max = 5;<a name="line.1776"></a>
-<span class="sourceLineNo">1777</span>        boolean truncated = false;<a name="line.1777"></a>
-<span class="sourceLineNo">1778</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1778"></a>
-<span class="sourceLineNo">1779</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1779"></a>
-<span class="sourceLineNo">1780</span>          truncated = true;<a name="line.1780"></a>
-<span class="sourceLineNo">1781</span>        }<a name="line.1781"></a>
-<span class="sourceLineNo">1782</span>        LOG.info(prefix + " not running balancer because " + regionsInTransition.size() +<a name="line.1782"></a>
-<span class="sourceLineNo">1783</span>          " region(s) in transition: " + toPrint + (truncated? "(truncated list)": ""));<a name="line.1783"></a>
-<span class="sourceLineNo">1784</span>        if (!force || metaInTransition) return false;<a name="line.1784"></a>
-<span class="sourceLineNo">1785</span>      }<a name="line.1785"></a>
-<span class="sourceLineNo">1786</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1786"></a>
-<span class="sourceLineNo">1787</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1787"></a>
-<span class="sourceLineNo">1788</span>          this.serverManager.getDeadServers());<a name="line.1788"></a>
-<span class="sourceLineNo">1789</span>        return false;<a name="line.1789"></a>
-<span class="sourceLineNo">1790</span>      }<a name="line.1790"></a>
-<span class="sourceLineNo">1791</span><a name="line.1791"></a>
-<span class="sourceLineNo">1792</span>      if (this.cpHost != null) {<a name="line.1792"></a>
-<span class="sourceLineNo">1793</span>        try {<a name="line.1793"></a>
-<span class="sourceLineNo">1794</span>          if (this.cpHost.preBalance()) {<a name="line.1794"></a>
-<span class="sourceLineNo">1795</span>            LOG.debug("Coprocessor bypassing balancer request");<a name="line.1795"></a>
-<span class="sourceLineNo">1796</span>            return false;<a name="line.1796"></a>
-<span class="sourceLineNo">1797</span>          }<a name="line.1797"></a>
-<span class="sourceLineNo">1798</span>        } catch (IOException ioe) {<a name="line.1798"></a>
-<span class="sourceLineNo">1799</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<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><a name="line.1803"></a>
-<span class="sourceLineNo">1804</span>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1804"></a>
-<span class="sourceLineNo">1805</span>        this.assignmentManager.getRegionStates()<a name="line.1805"></a>
-<span class="sourceLineNo">1806</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1806"></a>
-<span class="sourceLineNo">1807</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1807"></a>
-<span class="sourceLineNo">1808</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<a name="line.1808"></a>
-<span class="sourceLineNo">1809</span>      }<a name="line.1809"></a>
-<span class="sourceLineNo">1810</span><a name="line.1810"></a>
-<span class="sourceLineNo">1811</span>      //Give the balancer the current cluster state.<a name="line.1811"></a>
-<span class="sourceLineNo">1812</span>      this.balancer.setClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1812"></a>
-<span class="sourceLineNo">1813</span><a name="line.1813"></a>
-<span class="sourceLineNo">1814</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<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>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1817"></a>
-<span class="sourceLineNo">1818</span>        return false;<a name="line.1818"></a>
-<span class="sourceLineNo">1819</span>      }<a name="line.1819"></a>
-<span class="sourceLineNo">1820</span><a name="line.1820"></a>
-<span class="sourceLineNo">1821</span>      List&lt;RegionPlan&gt; sucRPs = executeRegionPlansWithThrottling(plans);<a name="line.1821"></a>
-<span class="sourceLineNo">1822</span><a name="line.1822"></a>
-<span class="sourceLineNo">1823</span>      if (this.cpHost != null) {<a name="line.1823"></a>
-<span class="sourceLineNo">1824</span>        try {<a name="line.1824"></a>
-<span class="sourceLineNo">1825</span>          this.cpHost.postBalance(sucRPs);<a name="line.1825"></a>
-<span class="sourceLineNo">1826</span>        } catch (IOException ioe) {<a name="line.1826"></a>
-<span class="sourceLineNo">1827</span>          // balancing already succeeded so don't change the result<a name="line.1827"></a>
-<span class="sourceLineNo">1828</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<a name="line.1828"></a>
-<span class="sourceLineNo">1829</span>        }<a name="line.1829"></a>
-<span class="sourceLineNo">1830</span>      }<a name="line.1830"></a>
-<span class="sourceLineNo">1831</span>    }<a name="line.1831"></a>
-<span class="sourceLineNo">1832</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1832"></a>
-<span class="sourceLineNo">1833</span>    // Return true indicating a success.<a name="line.1833"></a>
-<span class="sourceLineNo">1834</span>    return true;<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>  /**<a name="line.1837"></a>
-<span class="sourceLineNo">1838</span>   * Execute region plans with throttling<a name="line.1838"></a>
-<span class="sourceLineNo">1839</span>   * @param plans to execute<a name="line.1839"></a>
-<span class="sourceLineNo">1840</span>   * @return succeeded plans<a name="line.1840"></a>
-<span class="sourceLineNo">1841</span>   */<a name="line.1841"></a>
-<span class="sourceLineNo">1842</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1842"></a>
-<span class="sourceLineNo">1843</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1843"></a>
-<span class="sourceLineNo">1844</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1844"></a>
-<span class="sourceLineNo">1845</span>    long balanceStartTime = System.currentTimeMillis();<a name="line.1845"></a>
-<span class="sourceLineNo">1846</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1846"></a>
-<span class="sourceLineNo">1847</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1847"></a>
-<span class="sourceLineNo">1848</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1848"></a>
-<span class="sourceLineNo">1849</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1849"></a>
-<span class="sourceLineNo">1850</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1850"></a>
-<span class="sourceLineNo">1851</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1851"></a>
-<span class="sourceLineNo">1852</span>          + maxRegionsInTransition);<a name="line.1852"></a>
-<span class="sourceLineNo">1853</span><a name="line.1853"></a>
-<span class="sourceLineNo">1854</span>      for (RegionPlan plan: plans) {<a name="line.1854"></a>
-<span class="sourceLineNo">1855</span>        LOG.info("balance " + plan);<a name="line.1855"></a>
-<span class="sourceLineNo">1856</span>        //TODO: bulk assign<a name="line.1856"></a>
-<span class="sourceLineNo">1857</span>        try {<a name="line.1857"></a>
-<span class="sourceLineNo">1858</span>          this.assignmentManager.moveAsync(plan);<a name="line.1858"></a>
-<span class="sourceLineNo">1859</span>        } catch (HBaseIOException hioe) {<a name="line.1859"></a>
-<span class="sourceLineNo">1860</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1860"></a>
-<span class="sourceLineNo">1861</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1861"></a>
-<span class="sourceLineNo">1862</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1862"></a>
-<span class="sourceLineNo">1863</span>        }<a name="line.1863"></a>
-<span class="sourceLineNo">1864</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1864"></a>
-<span class="sourceLineNo">1865</span>        rpCount++;<a name="line.1865"></a>
-<span class="sourceLineNo">1866</span>        successRegionPlans.add(plan);<a name="line.1866"></a>
-<span class="sourceLineNo">1867</span><a name="line.1867"></a>
-<span class="sourceLineNo">1868</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1868"></a>
-<span class="sourceLineNo">1869</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1869"></a>
-<span class="sourceLineNo">1870</span>            cutoffTime);<a name="line.1870"></a>
-<span class="sourceLineNo">1871</span>        }<a name="line.1871"></a>
-<span class="sourceLineNo">1872</span><a name="line.1872"></a>
-<span class="sourceLineNo">1873</span>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1873"></a>
-<span class="sourceLineNo">1874</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1874"></a>
-<span class="sourceLineNo">1875</span>          &amp;&amp; System.currentTimeMillis() &gt; cutoffTime) {<a name="line.1875"></a>
-<span class="sourceLineNo">1876</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1876"></a>
-<span class="sourceLineNo">1877</span>          // a security net for now)<a name="line.1877"></a>
-<span class="sourceLineNo">1878</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1878"></a>
-<span class="sourceLineNo">1879</span>              + this.maxBalancingTime);<a name="line.1879"></a>
-<span class="sourceLineNo">1880</span>          break;<a name="line.1880"></a>
-<span class="sourceLineNo">1881</span>        }<a name="line.1881"></a>
-<span class="sourceLineNo">1882</span>      }<a name="line.1882"></a>
-<span class="sourceLineNo">1883</span>    }<a name="line.1883"></a>
-<span class="sourceLineNo">1884</span>    return successRegionPlans;<a name="line.1884"></a>
-<span class="sourceLineNo">1885</span>  }<a name="line.1885"></a>
-<span class="sourceLineNo">1886</span><a name="line.1886"></a>
-<span class="sourceLineNo">1887</span>  @Override<a name="line.1887"></a>
-<span class="sourceLineNo">1888</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1888"></a>
-<span class="sourceLineNo">1889</span>    return regionNormalizerManager;<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>  @Override<a name="line.1892"></a>
-<span class="sourceLineNo">1893</span>  public boolean normalizeRegions(<a name="line.1893"></a>
-<span class="sourceLineNo">1894</span>    final NormalizeTableFilterParams ntfp,<a name="line.1894"></a>
-<span class="sourceLineNo">1895</span>    final boolean isHighPriority<a name="line.1895"></a>
-<span class="sourceLineNo">1896</span>  ) throws IOException {<a name="line.1896"></a>
-<span class="sourceLineNo">1897</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1897"></a>
-<span class="sourceLineNo">1898</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1898"></a>
-<span class="sourceLineNo">1899</span>      return false;<a name="line.1899"></a>
-<span class="sourceLineNo">1900</span>    }<a name="line.1900"></a>
-<span class="sourceLineNo">1901</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1901"></a>
-<span class="sourceLineNo">1902</span>      return false;<a name="line.1902"></a>
-<span class="sourceLineNo">1903</span>    }<a name="line.1903"></a>
-<span class="sourceLineNo">1904</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1904"></a>
-<span class="sourceLineNo">1905</span>      return false;<a name="line.1905"></a>
-<span class="sourceLineNo">1906</span>    }<a name="line.1906"></a>
-<span class="sourceLineNo">1907</span><a name="line.1907"></a>
-<span class="sourceLineNo">1908</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1908"></a>
-<span class="sourceLineNo">1909</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1909"></a>
-<span class="sourceLineNo">1910</span>      .stream()<a name="line.1910"></a>
-<span class="sourceLineNo">1911</span>      .map(TableDescriptor::getTableName)<a name="line.1911"></a>
-<span class="sourceLineNo">1912</span>      .collect(Collectors.toSet());<a name="line.1912"></a>
-<span class="sourceLineNo">1913</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1913"></a>
-<span class="sourceLineNo">1914</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1914"></a>
-<span class="sourceLineNo">1915</span>    final List&lt;TableName&gt; targetTables =<a name="line.1915"></a>
-<span class="sourceLineNo">1916</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1916"></a>
-<span class="sourceLineNo">1917</span>    Collections.shuffle(targetTables);<a name="line.1917"></a>
-<span class="sourceLineNo">1918</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1918"></a>
-<span class="sourceLineNo">1919</span>  }<a name="line.1919"></a>
-<span class="sourceLineNo">1920</span><a name="line.1920"></a>
-<span class="sourceLineNo">1921</span>  /**<a name="line.1921"></a>
-<span class="sourceLineNo">1922</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1922"></a>
-<span class="sourceLineNo">1923</span>   */<a name="line.1923"></a>
-<span class="sourceLineNo">1924</span>  @Override<a name="line.1924"></a>
-<span class="sourceLineNo">1925</span>  public String getClientIdAuditPrefix() {<a name="line.1925"></a>
-<span class="sourceLineNo">1926</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1926"></a>
-<span class="sourceLineNo">1927</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<a name="line.1927"></a>
-<span class="sourceLineNo">1928</span>  }<a name="line.1928"></a>
-<span class="sourceLineNo">1929</span><a name="line.1929"></a>
-<span class="sourceLineNo">1930</span>  /**<a name="line.1930"></a>
-<span class="sourceLineNo">1931</span>   * Switch for the background CatalogJanitor thread.<a name="line.1931"></a>
-<span class="sourceLineNo">1932</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1932"></a>
-<span class="sourceLineNo">1933</span>   * if disabled.<a name="line.1933"></a>
-<span class="sourceLineNo">1934</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.1934"></a>
-<span class="sourceLineNo">1935</span>   */<a name="line.1935"></a>
-<span class="sourceLineNo">1936</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.1936"></a>
-<span class="sourceLineNo">1937</span>    this.catalogJanitorChore.setEnabled(b);<a name="line.1937"></a>
-<span class="sourceLineNo">1938</span>  }<a name="line.1938"></a>
-<span class="sourceLineNo">1939</span><a name="line.1939"></a>
-<span class="sourceLineNo">1940</span>  @Override<a name="line.1940"></a>
-<span class="sourceLineNo">1941</span>  public long mergeRegions(<a name="line.1941"></a>
-<span class="sourceLineNo">1942</span>      final RegionInfo[] regionsToMerge,<a name="line.1942"></a>
-<span class="sourceLineNo">1943</span>      final boolean forcible,<a name="line.1943"></a>
-<span class="sourceLineNo">1944</span>      final long ng,<a name="line.1944"></a>
-<span class="sourceLineNo">1945</span>      final long nonce) throws IOException {<a name="line.1945"></a>
-<span class="sourceLineNo">1946</span>    checkInitialized();<a name="line.1946"></a>
-<span class="sourceLineNo">1947</span><a name="line.1947"></a>
-<span class="sourceLineNo">1948</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.1948"></a>
-<span class="sourceLineNo">1949</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.1949"></a>
-<span class="sourceLineNo">1950</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.1950"></a>
-<span class="sourceLineNo">1951</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.1951"></a>
-<span class="sourceLineNo">1952</span>          " failed because merge switch is off");<a name="line.1952"></a>
-<span class="sourceLineNo">1953</span>    }<a name="line.1953"></a>
-<span class="sourceLineNo">1954</span><a name="line.1954"></a>
-<span class="sourceLineNo">1955</span>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.1955"></a>
-<span class="sourceLineNo">1956</span>      .collect(Collectors.joining(", "));<a name="line.1956"></a>
-<span class="sourceLineNo">1957</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.1957"></a>
-<span class="sourceLineNo">1958</span>      @Override<a name="line.1958"></a>
-<span class="sourceLineNo">1959</span>      protected void run() throws IOException {<a name="line.1959"></a>
-<span class="sourceLineNo">1960</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.1960"></a>
-<span class="sourceLineNo">1961</span>        String aid = getClientIdAuditPrefix();<a name="line.1961"></a>
-<span class="sourceLineNo">1962</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.1962"></a>
-<span class="sourceLineNo">1963</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.1963"></a>
-<span class="sourceLineNo">1964</span>            regionsToMerge, forcible));<a name="line.1964"></a>
-<span class="sourceLineNo">1965</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<a name="line.1965"></a>
-<span class="sourceLineNo">1966</span>      }<a name="line.1966"></a>
-<span class="sourceLineNo">1967</span><a name="line.1967"></a>
-<span class="sourceLineNo">1968</span>      @Override<a name="line.1968"></a>
-<span class="sourceLineNo">1969</span>      protected String getDescription() {<a name="line.1969"></a>
-<span class="sourceLineNo">1970</span>        return "MergeTableProcedure";<a name="line.1970"></a>
-<span class="sourceLineNo">1971</span>      }<a name="line.1971"></a>
-<span class="sourceLineNo">1972</span>    });<a name="line.1972"></a>
-<span class="sourceLineNo">1973</span>  }<a name="line.1973"></a>
-<span class="sourceLineNo">1974</span><a name="line.1974"></a>
-<span class="sourceLineNo">1975</span>  @Override<a name="line.1975"></a>
-<span class="sourceLineNo">1976</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.1976"></a>
-<span class="sourceLineNo">1977</span>      final long nonceGroup, final long nonce)<a name="line.1977"></a>
-<span class="sourceLineNo">1978</span>  throws IOException {<a name="line.1978"></a>
-<span class="sourceLineNo">1979</span>    checkInitialized();<a name="line.1979"></a>
-<span class="sourceLineNo">1980</span><a name="line.1980"></a>
-<span class="sourceLineNo">1981</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.1981"></a>
-<span class="sourceLineNo">1982</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.1982"></a>
-<span class="sourceLineNo">1983</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.1983"></a>
-<span class="sourceLineNo">1984</span>          " failed due to split switch off");<a name="line.1984"></a>
-<span class="sourceLineNo">1985</span>    }<a name="line.1985"></a>
-<span class="sourceLineNo">1986</span><a name="line.1986"></a>
-<span class="sourceLineNo">1987</span>    return MasterProcedureUtil.submitProcedure(<a name="line.1987"></a>
-<span class="sourceLineNo">1988</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.1988"></a>
-<span class="sourceLineNo">1989</span>      @Override<a name="line.1989"></a>
-<span class="sourceLineNo">1990</span>      protected void run() throws IOException {<a name="line.1990"></a>
-<span class="sourceLineNo">1991</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.1991"></a>
-<span class="sourceLineNo">1992</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.1992"></a>
-<span class="sourceLineNo">1993</span><a name="line.1993"></a>
-<span class="sourceLineNo">1994</span>        // Execute the operation asynchronously<a name="line.1994"></a>
-<span class="sourceLineNo">1995</span>        submitProcedure(getAssignmentManager().createSplitProcedure(regionInfo, splitRow));<a name="line.1995"></a>
-<span class="sourceLineNo">1996</span>      }<a name="line.1996"></a>
+<span class="sourceLineNo">1756</span>    if (isInMaintenanceMode()) {<a name="line.1756"></a>
+<span class="sourceLineNo">1757</span>      LOG.info("Master is in maintenance mode, don't run {}.", action);<a name="line.1757"></a>
+<span class="sourceLineNo">1758</span>      return true;<a name="line.1758"></a>
+<span class="sourceLineNo">1759</span>    }<a name="line.1759"></a>
+<span class="sourceLineNo">1760</span>    return false;<a name="line.1760"></a>
+<span class="sourceLineNo">1761</span>  }<a name="line.1761"></a>
+<span class="sourceLineNo">1762</span><a name="line.1762"></a>
+<span class="sourceLineNo">1763</span>  public boolean balance(boolean force) throws IOException {<a name="line.1763"></a>
+<span class="sourceLineNo">1764</span>    if (loadBalancerTracker == null || !loadBalancerTracker.isBalancerOn()) {<a name="line.1764"></a>
+<span class="sourceLineNo">1765</span>      return false;<a name="line.1765"></a>
+<span class="sourceLineNo">1766</span>    }<a name="line.1766"></a>
+<span class="sourceLineNo">1767</span>    if (skipRegionManagementAction("balancer")) {<a name="line.1767"></a>
+<span class="sourceLineNo">1768</span>      return false;<a name="line.1768"></a>
+<span class="sourceLineNo">1769</span>    }<a name="line.1769"></a>
+<span class="sourceLineNo">1770</span><a name="line.1770"></a>
+<span class="sourceLineNo">1771</span>    synchronized (this.balancer) {<a name="line.1771"></a>
+<span class="sourceLineNo">1772</span>        // Only allow one balance run at at time.<a name="line.1772"></a>
+<span class="sourceLineNo">1773</span>      if (this.assignmentManager.hasRegionsInTransition()) {<a name="line.1773"></a>
+<span class="sourceLineNo">1774</span>        List&lt;RegionStateNode&gt; regionsInTransition = assignmentManager.getRegionsInTransition();<a name="line.1774"></a>
+<span class="sourceLineNo">1775</span>        // if hbase:meta region is in transition, result of assignment cannot be recorded<a name="line.1775"></a>
+<span class="sourceLineNo">1776</span>        // ignore the force flag in that case<a name="line.1776"></a>
+<span class="sourceLineNo">1777</span>        boolean metaInTransition = assignmentManager.isMetaRegionInTransition();<a name="line.1777"></a>
+<span class="sourceLineNo">1778</span>        String prefix = force &amp;&amp; !metaInTransition ? "R" : "Not r";<a name="line.1778"></a>
+<span class="sourceLineNo">1779</span>        List&lt;RegionStateNode&gt; toPrint = regionsInTransition;<a name="line.1779"></a>
+<span class="sourceLineNo">1780</span>        int max = 5;<a name="line.1780"></a>
+<span class="sourceLineNo">1781</span>        boolean truncated = false;<a name="line.1781"></a>
+<span class="sourceLineNo">1782</span>        if (regionsInTransition.size() &gt; max) {<a name="line.1782"></a>
+<span class="sourceLineNo">1783</span>          toPrint = regionsInTransition.subList(0, max);<a name="line.1783"></a>
+<span class="sourceLineNo">1784</span>          truncated = true;<a name="line.1784"></a>
+<span class="sourceLineNo">1785</span>        }<a name="line.1785"></a>
+<span class="sourceLineNo">1786</span>        LOG.info(prefix + " not running balancer because " + regionsInTransition.size() +<a name="line.1786"></a>
+<span class="sourceLineNo">1787</span>          " region(s) in transition: " + toPrint + (truncated? "(truncated list)": ""));<a name="line.1787"></a>
+<span class="sourceLineNo">1788</span>        if (!force || metaInTransition) return false;<a name="line.1788"></a>
+<span class="sourceLineNo">1789</span>      }<a name="line.1789"></a>
+<span class="sourceLineNo">1790</span>      if (this.serverManager.areDeadServersInProgress()) {<a name="line.1790"></a>
+<span class="sourceLineNo">1791</span>        LOG.info("Not running balancer because processing dead regionserver(s): " +<a name="line.1791"></a>
+<span class="sourceLineNo">1792</span>          this.serverManager.getDeadServers());<a name="line.1792"></a>
+<span class="sourceLineNo">1793</span>        return false;<a name="line.1793"></a>
+<span class="sourceLineNo">1794</span>      }<a name="line.1794"></a>
+<span class="sourceLineNo">1795</span><a name="line.1795"></a>
+<span class="sourceLineNo">1796</span>      if (this.cpHost != null) {<a name="line.1796"></a>
+<span class="sourceLineNo">1797</span>        try {<a name="line.1797"></a>
+<span class="sourceLineNo">1798</span>          if (this.cpHost.preBalance()) {<a name="line.1798"></a>
+<span class="sourceLineNo">1799</span>            LOG.debug("Coprocessor bypassing balancer request");<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>        } catch (IOException ioe) {<a name="line.1802"></a>
+<span class="sourceLineNo">1803</span>          LOG.error("Error invoking master coprocessor preBalance()", ioe);<a name="line.1803"></a>
+<span class="sourceLineNo">1804</span>          return false;<a name="line.1804"></a>
+<span class="sourceLineNo">1805</span>        }<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>      Map&lt;TableName, Map&lt;ServerName, List&lt;RegionInfo&gt;&gt;&gt; assignments =<a name="line.1808"></a>
+<span class="sourceLineNo">1809</span>        this.assignmentManager.getRegionStates()<a name="line.1809"></a>
+<span class="sourceLineNo">1810</span>          .getAssignmentsForBalancer(tableStateManager, this.serverManager.getOnlineServersList());<a name="line.1810"></a>
+<span class="sourceLineNo">1811</span>      for (Map&lt;ServerName, List&lt;RegionInfo&gt;&gt; serverMap : assignments.values()) {<a name="line.1811"></a>
+<span class="sourceLineNo">1812</span>        serverMap.keySet().removeAll(this.serverManager.getDrainingServersList());<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>      //Give the balancer the current cluster state.<a name="line.1815"></a>
+<span class="sourceLineNo">1816</span>      this.balancer.setClusterMetrics(getClusterMetricsWithoutCoprocessor());<a name="line.1816"></a>
+<span class="sourceLineNo">1817</span><a name="line.1817"></a>
+<span class="sourceLineNo">1818</span>      List&lt;RegionPlan&gt; plans = this.balancer.balanceCluster(assignments);<a name="line.1818"></a>
+<span class="sourceLineNo">1819</span><a name="line.1819"></a>
+<span class="sourceLineNo">1820</span>      if (skipRegionManagementAction("balancer")) {<a name="line.1820"></a>
+<span class="sourceLineNo">1821</span>        // make one last check that the cluster isn't shutting down before proceeding.<a name="line.1821"></a>
+<span class="sourceLineNo">1822</span>        return false;<a name="line.1822"></a>
+<span class="sourceLineNo">1823</span>      }<a name="line.1823"></a>
+<span class="sourceLineNo">1824</span><a name="line.1824"></a>
+<span class="sourceLineNo">1825</span>      List&lt;RegionPlan&gt; sucRPs = executeRegionPlansWithThrottling(plans);<a name="line.1825"></a>
+<span class="sourceLineNo">1826</span><a name="line.1826"></a>
+<span class="sourceLineNo">1827</span>      if (this.cpHost != null) {<a name="line.1827"></a>
+<span class="sourceLineNo">1828</span>        try {<a name="line.1828"></a>
+<span class="sourceLineNo">1829</span>          this.cpHost.postBalance(sucRPs);<a name="line.1829"></a>
+<span class="sourceLineNo">1830</span>        } catch (IOException ioe) {<a name="line.1830"></a>
+<span class="sourceLineNo">1831</span>          // balancing already succeeded so don't change the result<a name="line.1831"></a>
+<span class="sourceLineNo">1832</span>          LOG.error("Error invoking master coprocessor postBalance()", ioe);<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>    }<a name="line.1835"></a>
+<span class="sourceLineNo">1836</span>    // If LoadBalancer did not generate any plans, it means the cluster is already balanced.<a name="line.1836"></a>
+<span class="sourceLineNo">1837</span>    // Return true indicating a success.<a name="line.1837"></a>
+<span class="sourceLineNo">1838</span>    return true;<a name="line.1838"></a>
+<span class="sourceLineNo">1839</span>  }<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>   * Execute region plans with throttling<a name="line.1842"></a>
+<span class="sourceLineNo">1843</span>   * @param plans to execute<a name="line.1843"></a>
+<span class="sourceLineNo">1844</span>   * @return succeeded plans<a name="line.1844"></a>
+<span class="sourceLineNo">1845</span>   */<a name="line.1845"></a>
+<span class="sourceLineNo">1846</span>  public List&lt;RegionPlan&gt; executeRegionPlansWithThrottling(List&lt;RegionPlan&gt; plans) {<a name="line.1846"></a>
+<span class="sourceLineNo">1847</span>    List&lt;RegionPlan&gt; successRegionPlans = new ArrayList&lt;&gt;();<a name="line.1847"></a>
+<span class="sourceLineNo">1848</span>    int maxRegionsInTransition = getMaxRegionsInTransition();<a name="line.1848"></a>
+<span class="sourceLineNo">1849</span>    long balanceStartTime = System.currentTimeMillis();<a name="line.1849"></a>
+<span class="sourceLineNo">1850</span>    long cutoffTime = balanceStartTime + this.maxBalancingTime;<a name="line.1850"></a>
+<span class="sourceLineNo">1851</span>    int rpCount = 0;  // number of RegionPlans balanced so far<a name="line.1851"></a>
+<span class="sourceLineNo">1852</span>    if (plans != null &amp;&amp; !plans.isEmpty()) {<a name="line.1852"></a>
+<span class="sourceLineNo">1853</span>      int balanceInterval = this.maxBalancingTime / plans.size();<a name="line.1853"></a>
+<span class="sourceLineNo">1854</span>      LOG.info("Balancer plans size is " + plans.size() + ", the balance interval is "<a name="line.1854"></a>
+<span class="sourceLineNo">1855</span>          + balanceInterval + " ms, and the max number regions in transition is "<a name="line.1855"></a>
+<span class="sourceLineNo">1856</span>          + maxRegionsInTransition);<a name="line.1856"></a>
+<span class="sourceLineNo">1857</span><a name="line.1857"></a>
+<span class="sourceLineNo">1858</span>      for (RegionPlan plan: plans) {<a name="line.1858"></a>
+<span class="sourceLineNo">1859</span>        LOG.info("balance " + plan);<a name="line.1859"></a>
+<span class="sourceLineNo">1860</span>        //TODO: bulk assign<a name="line.1860"></a>
+<span class="sourceLineNo">1861</span>        try {<a name="line.1861"></a>
+<span class="sourceLineNo">1862</span>          this.assignmentManager.moveAsync(plan);<a name="line.1862"></a>
+<span class="sourceLineNo">1863</span>        } catch (HBaseIOException hioe) {<a name="line.1863"></a>
+<span class="sourceLineNo">1864</span>          //should ignore failed plans here, avoiding the whole balance plans be aborted<a name="line.1864"></a>
+<span class="sourceLineNo">1865</span>          //later calls of balance() can fetch up the failed and skipped plans<a name="line.1865"></a>
+<span class="sourceLineNo">1866</span>          LOG.warn("Failed balance plan {}, skipping...", plan, hioe);<a name="line.1866"></a>
+<span class="sourceLineNo">1867</span>        }<a name="line.1867"></a>
+<span class="sourceLineNo">1868</span>        //rpCount records balance plans processed, does not care if a plan succeeds<a name="line.1868"></a>
+<span class="sourceLineNo">1869</span>        rpCount++;<a name="line.1869"></a>
+<span class="sourceLineNo">1870</span>        successRegionPlans.add(plan);<a name="line.1870"></a>
+<span class="sourceLineNo">1871</span><a name="line.1871"></a>
+<span class="sourceLineNo">1872</span>        if (this.maxBalancingTime &gt; 0) {<a name="line.1872"></a>
+<span class="sourceLineNo">1873</span>          balanceThrottling(balanceStartTime + rpCount * balanceInterval, maxRegionsInTransition,<a name="line.1873"></a>
+<span class="sourceLineNo">1874</span>            cutoffTime);<a name="line.1874"></a>
+<span class="sourceLineNo">1875</span>        }<a name="line.1875"></a>
+<span class="sourceLineNo">1876</span><a name="line.1876"></a>
+<span class="sourceLineNo">1877</span>        // if performing next balance exceeds cutoff time, exit the loop<a name="line.1877"></a>
+<span class="sourceLineNo">1878</span>        if (this.maxBalancingTime &gt; 0 &amp;&amp; rpCount &lt; plans.size()<a name="line.1878"></a>
+<span class="sourceLineNo">1879</span>          &amp;&amp; System.currentTimeMillis() &gt; cutoffTime) {<a name="line.1879"></a>
+<span class="sourceLineNo">1880</span>          // TODO: After balance, there should not be a cutoff time (keeping it as<a name="line.1880"></a>
+<span class="sourceLineNo">1881</span>          // a security net for now)<a name="line.1881"></a>
+<span class="sourceLineNo">1882</span>          LOG.debug("No more balancing till next balance run; maxBalanceTime="<a name="line.1882"></a>
+<span class="sourceLineNo">1883</span>              + this.maxBalancingTime);<a name="line.1883"></a>
+<span class="sourceLineNo">1884</span>          break;<a name="line.1884"></a>
+<span class="sourceLineNo">1885</span>        }<a name="line.1885"></a>
+<span class="sourceLineNo">1886</span>      }<a name="line.1886"></a>
+<span class="sourceLineNo">1887</span>    }<a name="line.1887"></a>
+<span class="sourceLineNo">1888</span>    return successRegionPlans;<a name="line.1888"></a>
+<span class="sourceLineNo">1889</span>  }<a name="line.1889"></a>
+<span class="sourceLineNo">1890</span><a name="line.1890"></a>
+<span class="sourceLineNo">1891</span>  @Override<a name="line.1891"></a>
+<span class="sourceLineNo">1892</span>  public RegionNormalizerManager getRegionNormalizerManager() {<a name="line.1892"></a>
+<span class="sourceLineNo">1893</span>    return regionNormalizerManager;<a name="line.1893"></a>
+<span class="sourceLineNo">1894</span>  }<a name="line.1894"></a>
+<span class="sourceLineNo">1895</span><a name="line.1895"></a>
+<span class="sourceLineNo">1896</span>  @Override<a name="line.1896"></a>
+<span class="sourceLineNo">1897</span>  public boolean normalizeRegions(<a name="line.1897"></a>
+<span class="sourceLineNo">1898</span>    final NormalizeTableFilterParams ntfp,<a name="line.1898"></a>
+<span class="sourceLineNo">1899</span>    final boolean isHighPriority<a name="line.1899"></a>
+<span class="sourceLineNo">1900</span>  ) throws IOException {<a name="line.1900"></a>
+<span class="sourceLineNo">1901</span>    if (regionNormalizerManager == null || !regionNormalizerManager.isNormalizerOn()) {<a name="line.1901"></a>
+<span class="sourceLineNo">1902</span>      LOG.debug("Region normalization is disabled, don't run region normalizer.");<a name="line.1902"></a>
+<span class="sourceLineNo">1903</span>      return false;<a name="line.1903"></a>
+<span class="sourceLineNo">1904</span>    }<a name="line.1904"></a>
+<span class="sourceLineNo">1905</span>    if (skipRegionManagementAction("region normalizer")) {<a name="line.1905"></a>
+<span class="sourceLineNo">1906</span>      return false;<a name="line.1906"></a>
+<span class="sourceLineNo">1907</span>    }<a name="line.1907"></a>
+<span class="sourceLineNo">1908</span>    if (assignmentManager.hasRegionsInTransition()) {<a name="line.1908"></a>
+<span class="sourceLineNo">1909</span>      return false;<a name="line.1909"></a>
+<span class="sourceLineNo">1910</span>    }<a name="line.1910"></a>
+<span class="sourceLineNo">1911</span><a name="line.1911"></a>
+<span class="sourceLineNo">1912</span>    final Set&lt;TableName&gt; matchingTables = getTableDescriptors(new LinkedList&lt;&gt;(),<a name="line.1912"></a>
+<span class="sourceLineNo">1913</span>      ntfp.getNamespace(), ntfp.getRegex(), ntfp.getTableNames(), false)<a name="line.1913"></a>
+<span class="sourceLineNo">1914</span>      .stream()<a name="line.1914"></a>
+<span class="sourceLineNo">1915</span>      .map(TableDescriptor::getTableName)<a name="line.1915"></a>
+<span class="sourceLineNo">1916</span>      .collect(Collectors.toSet());<a name="line.1916"></a>
+<span class="sourceLineNo">1917</span>    final Set&lt;TableName&gt; allEnabledTables =<a name="line.1917"></a>
+<span class="sourceLineNo">1918</span>      tableStateManager.getTablesInStates(TableState.State.ENABLED);<a name="line.1918"></a>
+<span class="sourceLineNo">1919</span>    final List&lt;TableName&gt; targetTables =<a name="line.1919"></a>
+<span class="sourceLineNo">1920</span>      new ArrayList&lt;&gt;(Sets.intersection(matchingTables, allEnabledTables));<a name="line.1920"></a>
+<span class="sourceLineNo">1921</span>    Collections.shuffle(targetTables);<a name="line.1921"></a>
+<span class="sourceLineNo">1922</span>    return regionNormalizerManager.normalizeRegions(targetTables, isHighPriority);<a name="line.1922"></a>
+<span class="sourceLineNo">1923</span>  }<a name="line.1923"></a>
+<span class="sourceLineNo">1924</span><a name="line.1924"></a>
+<span class="sourceLineNo">1925</span>  /**<a name="line.1925"></a>
+<span class="sourceLineNo">1926</span>   * @return Client info for use as prefix on an audit log string; who did an action<a name="line.1926"></a>
+<span class="sourceLineNo">1927</span>   */<a name="line.1927"></a>
+<span class="sourceLineNo">1928</span>  @Override<a name="line.1928"></a>
+<span class="sourceLineNo">1929</span>  public String getClientIdAuditPrefix() {<a name="line.1929"></a>
+<span class="sourceLineNo">1930</span>    return "Client=" + RpcServer.getRequestUserName().orElse(null)<a name="line.1930"></a>
+<span class="sourceLineNo">1931</span>        + "/" + RpcServer.getRemoteAddress().orElse(null);<a name="line.1931"></a>
+<span class="sourceLineNo">1932</span>  }<a name="line.1932"></a>
+<span class="sourceLineNo">1933</span><a name="line.1933"></a>
+<span class="sourceLineNo">1934</span>  /**<a name="line.1934"></a>
+<span class="sourceLineNo">1935</span>   * Switch for the background CatalogJanitor thread.<a name="line.1935"></a>
+<span class="sourceLineNo">1936</span>   * Used for testing.  The thread will continue to run.  It will just be a noop<a name="line.1936"></a>
+<span class="sourceLineNo">1937</span>   * if disabled.<a name="line.1937"></a>
+<span class="sourceLineNo">1938</span>   * @param b If false, the catalog janitor won't do anything.<a name="line.1938"></a>
+<span class="sourceLineNo">1939</span>   */<a name="line.1939"></a>
+<span class="sourceLineNo">1940</span>  public void setCatalogJanitorEnabled(final boolean b) {<a name="line.1940"></a>
+<span class="sourceLineNo">1941</span>    this.catalogJanitorChore.setEnabled(b);<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>  @Override<a name="line.1944"></a>
+<span class="sourceLineNo">1945</span>  public long mergeRegions(<a name="line.1945"></a>
+<span class="sourceLineNo">1946</span>      final RegionInfo[] regionsToMerge,<a name="line.1946"></a>
+<span class="sourceLineNo">1947</span>      final boolean forcible,<a name="line.1947"></a>
+<span class="sourceLineNo">1948</span>      final long ng,<a name="line.1948"></a>
+<span class="sourceLineNo">1949</span>      final long nonce) throws IOException {<a name="line.1949"></a>
+<span class="sourceLineNo">1950</span>    checkInitialized();<a name="line.1950"></a>
+<span class="sourceLineNo">1951</span><a name="line.1951"></a>
+<span class="sourceLineNo">1952</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.MERGE)) {<a name="line.1952"></a>
+<span class="sourceLineNo">1953</span>      String regionsStr = Arrays.deepToString(regionsToMerge);<a name="line.1953"></a>
+<span class="sourceLineNo">1954</span>      LOG.warn("Merge switch is off! skip merge of " + regionsStr);<a name="line.1954"></a>
+<span class="sourceLineNo">1955</span>      throw new DoNotRetryIOException("Merge of " + regionsStr +<a name="line.1955"></a>
+<span class="sourceLineNo">1956</span>          " failed because merge switch is off");<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>    final String mergeRegionsStr = Arrays.stream(regionsToMerge).map(RegionInfo::getEncodedName)<a name="line.1959"></a>
+<span class="sourceLineNo">1960</span>      .collect(Collectors.joining(", "));<a name="line.1960"></a>
+<span class="sourceLineNo">1961</span>    return MasterProcedureUtil.submitProcedure(new NonceProcedureRunnable(this, ng, nonce) {<a name="line.1961"></a>
+<span class="sourceLineNo">1962</span>      @Override<a name="line.1962"></a>
+<span class="sourceLineNo">1963</span>      protected void run() throws IOException {<a name="line.1963"></a>
+<span class="sourceLineNo">1964</span>        getMaster().getMasterCoprocessorHost().preMergeRegions(regionsToMerge);<a name="line.1964"></a>
+<span class="sourceLineNo">1965</span>        String aid = getClientIdAuditPrefix();<a name="line.1965"></a>
+<span class="sourceLineNo">1966</span>        LOG.info("{} merge regions {}", aid, mergeRegionsStr);<a name="line.1966"></a>
+<span class="sourceLineNo">1967</span>        submitProcedure(new MergeTableRegionsProcedure(procedureExecutor.getEnvironment(),<a name="line.1967"></a>
+<span class="sourceLineNo">1968</span>            regionsToMerge, forcible));<a name="line.1968"></a>
+<span class="sourceLineNo">1969</span>        getMaster().getMasterCoprocessorHost().postMergeRegions(regionsToMerge);<a name="line.1969"></a>
+<span class="sourceLineNo">1970</span>      }<a name="line.1970"></a>
+<span class="sourceLineNo">1971</span><a name="line.1971"></a>
+<span class="sourceLineNo">1972</span>      @Override<a name="line.1972"></a>
+<span class="sourceLineNo">1973</span>      protected String getDescription() {<a name="line.1973"></a>
+<span class="sourceLineNo">1974</span>        return "MergeTableProcedure";<a name="line.1974"></a>
+<span class="sourceLineNo">1975</span>      }<a name="line.1975"></a>
+<span class="sourceLineNo">1976</span>    });<a name="line.1976"></a>
+<span class="sourceLineNo">1977</span>  }<a name="line.1977"></a>
+<span class="sourceLineNo">1978</span><a name="line.1978"></a>
+<span class="sourceLineNo">1979</span>  @Override<a name="line.1979"></a>
+<span class="sourceLineNo">1980</span>  public long splitRegion(final RegionInfo regionInfo, final byte[] splitRow,<a name="line.1980"></a>
+<span class="sourceLineNo">1981</span>      final long nonceGroup, final long nonce)<a name="line.1981"></a>
+<span class="sourceLineNo">1982</span>  throws IOException {<a name="line.1982"></a>
+<span class="sourceLineNo">1983</span>    checkInitialized();<a name="line.1983"></a>
+<span class="sourceLineNo">1984</span><a name="line.1984"></a>
+<span class="sourceLineNo">1985</span>    if (!isSplitOrMergeEnabled(MasterSwitchType.SPLIT)) {<a name="line.1985"></a>
+<span class="sourceLineNo">1986</span>      LOG.warn("Split switch is off! skip split of " + regionInfo);<a name="line.1986"></a>
+<span class="sourceLineNo">1987</span>      throw new DoNotRetryIOException("Split region " + regionInfo.getRegionNameAsString() +<a name="line.1987"></a>
+<span class="sourceLineNo">1988</span>          " failed due to split switch off");<a name="line.1988"></a>
+<span class="sourceLineNo">1989</span>    }<a name="line.1989"></a>
+<span class="sourceLineNo">1990</span><a name="line.1990"></a>
+<span class="sourceLineNo">1991</span>    return MasterProcedureUtil.submitProcedure(<a name="line.1991"></a>
+<span class="sourceLineNo">1992</span>        new MasterProcedureUtil.NonceProcedureRunnable(this, nonceGroup, nonce) {<a name="line.1992"></a>
+<span class="sourceLineNo">1993</span>      @Override<a name="line.1993"></a>
+<span class="sourceLineNo">1994</span>      protected void run() throws IOException {<a name="line.1994"></a>
+<span class="sourceLineNo">1995</span>        getMaster().getMasterCoprocessorHost().preSplitRegion(regionInfo.getTable(), splitRow);<a name="line.1995"></a>
+<span class="sourceLineNo">1996</span>        LOG.info(getClientIdAuditPrefix() + " split " + regionInfo.getRegionNameAsString());<a name="line.1996"></a>
 <span class="sourceLineNo">1997</span><a name="line.1997"></a>
-<span class="sourceLineNo">1998</span>      @Override<a name="line.1998"></a>
-<span class="sourceLineNo">1999</span>      protected String getDescription() {<a name="line.1999"></a>
-<span class="sourceLineNo">2000</span>        return "SplitTableProcedure";<a name="line.2000"></a>
-<span class="sourceLineNo">2001</span>      }<a name="line.2001"></a>
-<span class="sourceLineNo">2002</span>    });<a name="line.2002"></a>
-<span class="sourceLineNo">2003</span>  }<a name="line.2003"></a>
-<span class="sourceLineNo">2004</span><a name="line.2004"></a>
-<span class="sourceLineNo">2005</span>  private void warmUpRegion(ServerName server, RegionInfo region) {<a name="line.2005"></a>
-<span class="sourceLineNo">2006</span>    FutureUtils.addListener(asyncClusterConnection.getRegionServerAdmin(server)<a name="line.2006"></a>
-<span class="sourceLineNo">2007</span>      .warmupRegion(RequestConverter.buildWarmupRegionRequest(region)), (r, e) -&gt; {<a name="line.2007"></a>
... 21387 lines suppressed ...