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 2018/04/23 14:48:26 UTC

[01/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Repository: hbase-site
Updated Branches:
  refs/heads/asf-site 9021c033b -> 952146b40


http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/testdevapidocs/src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
index e001cfb..7459c87 100644
--- a/testdevapidocs/src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
@@ -399,303 +399,306 @@
 <span class="sourceLineNo">391</span>      // CF1 Should have been flushed<a name="line.391"></a>
 <span class="sourceLineNo">392</span>      assertEquals(0, cf1MemstoreSize);<a name="line.392"></a>
 <span class="sourceLineNo">393</span>      // CF2 and CF3 shouldn't have been flushed.<a name="line.393"></a>
-<span class="sourceLineNo">394</span>      assertTrue(cf2MemstoreSize &gt; 0);<a name="line.394"></a>
-<span class="sourceLineNo">395</span>      assertTrue(cf3MemstoreSize &gt; 0);<a name="line.395"></a>
-<span class="sourceLineNo">396</span>      assertEquals(totalMemstoreSize, cf2MemstoreSize + cf3MemstoreSize);<a name="line.396"></a>
-<span class="sourceLineNo">397</span><a name="line.397"></a>
-<span class="sourceLineNo">398</span>      // Wait for the RS report to go across to the master, so that the master<a name="line.398"></a>
-<span class="sourceLineNo">399</span>      // is aware of which sequence ids have been flushed, before we kill the RS.<a name="line.399"></a>
-<span class="sourceLineNo">400</span>      // If in production, the RS dies before the report goes across, we will<a name="line.400"></a>
-<span class="sourceLineNo">401</span>      // safely replay all the edits.<a name="line.401"></a>
-<span class="sourceLineNo">402</span>      Thread.sleep(2000);<a name="line.402"></a>
-<span class="sourceLineNo">403</span><a name="line.403"></a>
-<span class="sourceLineNo">404</span>      // Abort the region server where we have the region hosted.<a name="line.404"></a>
-<span class="sourceLineNo">405</span>      HRegionServer rs = desiredRegionAndServer.getSecond();<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      rs.abort("testing");<a name="line.406"></a>
-<span class="sourceLineNo">407</span><a name="line.407"></a>
-<span class="sourceLineNo">408</span>      // The aborted region server's regions will be eventually assigned to some<a name="line.408"></a>
-<span class="sourceLineNo">409</span>      // other region server, and the get RPC call (inside verifyEdit()) will<a name="line.409"></a>
-<span class="sourceLineNo">410</span>      // retry for some time till the regions come back up.<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>      // Verify that all the edits are safe.<a name="line.412"></a>
-<span class="sourceLineNo">413</span>      for (int i = 1; i &lt;= 80; i++) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>        verifyEdit(1, i, table);<a name="line.414"></a>
-<span class="sourceLineNo">415</span>        if (i &lt;= 10) {<a name="line.415"></a>
-<span class="sourceLineNo">416</span>          verifyEdit(2, i, table);<a name="line.416"></a>
-<span class="sourceLineNo">417</span>          verifyEdit(3, i, table);<a name="line.417"></a>
-<span class="sourceLineNo">418</span>        }<a name="line.418"></a>
-<span class="sourceLineNo">419</span>      }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    } finally {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.421"></a>
-<span class="sourceLineNo">422</span>    }<a name="line.422"></a>
-<span class="sourceLineNo">423</span>  }<a name="line.423"></a>
-<span class="sourceLineNo">424</span><a name="line.424"></a>
-<span class="sourceLineNo">425</span>  // Test Log Replay with Distributed log split on.<a name="line.425"></a>
-<span class="sourceLineNo">426</span>  @Test<a name="line.426"></a>
-<span class="sourceLineNo">427</span>  public void testLogReplayWithDistributedLogSplit() throws Exception {<a name="line.427"></a>
-<span class="sourceLineNo">428</span>    doTestLogReplay();<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private WAL getWAL(Region region) {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    return ((HRegion)region).getWAL();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>  }<a name="line.433"></a>
-<span class="sourceLineNo">434</span><a name="line.434"></a>
-<span class="sourceLineNo">435</span>  private int getNumRolledLogFiles(Region region) {<a name="line.435"></a>
-<span class="sourceLineNo">436</span>    return AbstractFSWALProvider.getNumRolledLogFiles(getWAL(region));<a name="line.436"></a>
-<span class="sourceLineNo">437</span>  }<a name="line.437"></a>
-<span class="sourceLineNo">438</span><a name="line.438"></a>
-<span class="sourceLineNo">439</span>  /**<a name="line.439"></a>
-<span class="sourceLineNo">440</span>   * When a log roll is about to happen, we do a flush of the regions who will be affected by the<a name="line.440"></a>
-<span class="sourceLineNo">441</span>   * log roll. These flushes cannot be a selective flushes, otherwise we cannot roll the logs. This<a name="line.441"></a>
-<span class="sourceLineNo">442</span>   * test ensures that we do a full-flush in that scenario.<a name="line.442"></a>
-<span class="sourceLineNo">443</span>   * @throws IOException<a name="line.443"></a>
-<span class="sourceLineNo">444</span>   */<a name="line.444"></a>
-<span class="sourceLineNo">445</span>  @Test<a name="line.445"></a>
-<span class="sourceLineNo">446</span>  public void testFlushingWhenLogRolling() throws Exception {<a name="line.446"></a>
-<span class="sourceLineNo">447</span>    TableName tableName = TableName.valueOf("testFlushingWhenLogRolling");<a name="line.447"></a>
-<span class="sourceLineNo">448</span>    Configuration conf = TEST_UTIL.getConfiguration();<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, 128 * 1024 * 1024);<a name="line.449"></a>
-<span class="sourceLineNo">450</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllLargeStoresPolicy.class.getName());<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    long cfFlushSizeLowerBound = 2048;<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    conf.setLong(FlushLargeStoresPolicy.HREGION_COLUMNFAMILY_FLUSH_SIZE_LOWER_BOUND_MIN,<a name="line.452"></a>
-<span class="sourceLineNo">453</span>      cfFlushSizeLowerBound);<a name="line.453"></a>
-<span class="sourceLineNo">454</span><a name="line.454"></a>
-<span class="sourceLineNo">455</span>    // One hour, prevent periodic rolling<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    conf.setLong("hbase.regionserver.logroll.period", 60L * 60 * 1000);<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    // prevent rolling by size<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    conf.setLong("hbase.regionserver.hlog.blocksize", 128L * 1024 * 1024);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    // Make it 10 as max logs before a flush comes on.<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    final int maxLogs = 10;<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    conf.setInt("hbase.regionserver.maxlogs", maxLogs);<a name="line.461"></a>
-<span class="sourceLineNo">462</span><a name="line.462"></a>
-<span class="sourceLineNo">463</span>    final int numRegionServers = 1;<a name="line.463"></a>
-<span class="sourceLineNo">464</span>    TEST_UTIL.startMiniCluster(numRegionServers);<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    try {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      Table table = TEST_UTIL.createTable(tableName, FAMILIES);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      // Force flush the namespace table so edits to it are not hanging around as oldest<a name="line.467"></a>
-<span class="sourceLineNo">468</span>      // edits. Otherwise, below, when we make maximum number of WAL files, then it will be<a name="line.468"></a>
-<span class="sourceLineNo">469</span>      // the namespace region that is flushed and not the below 'desiredRegion'.<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      try (Admin admin = TEST_UTIL.getConnection().getAdmin()) {<a name="line.470"></a>
-<span class="sourceLineNo">471</span>        admin.flush(TableName.NAMESPACE_TABLE_NAME);<a name="line.471"></a>
-<span class="sourceLineNo">472</span>      }<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      Pair&lt;HRegion, HRegionServer&gt; desiredRegionAndServer = getRegionWithName(tableName);<a name="line.473"></a>
-<span class="sourceLineNo">474</span>      final HRegion desiredRegion = desiredRegionAndServer.getFirst();<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      assertTrue("Could not find a region which hosts the new region.", desiredRegion != null);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      LOG.info("Writing to region=" + desiredRegion);<a name="line.476"></a>
-<span class="sourceLineNo">477</span><a name="line.477"></a>
-<span class="sourceLineNo">478</span>      // Add one row for both CFs.<a name="line.478"></a>
-<span class="sourceLineNo">479</span>      for (int i = 1; i &lt;= 3; i++) {<a name="line.479"></a>
-<span class="sourceLineNo">480</span>        table.put(createPut(i, 0));<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      }<a name="line.481"></a>
-<span class="sourceLineNo">482</span>      // Now only add row to CF1, make sure when we force a flush, CF1 is larger than the lower<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      // bound and CF2 and CF3 are smaller than the lower bound.<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      for (int i = 0; i &lt; maxLogs; i++) {<a name="line.484"></a>
-<span class="sourceLineNo">485</span>        for (int j = 0; j &lt; 100; j++) {<a name="line.485"></a>
-<span class="sourceLineNo">486</span>          table.put(createPut(1, i * 100 + j));<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        }<a name="line.487"></a>
-<span class="sourceLineNo">488</span>        // Roll the WAL. The log file count is less than maxLogs so no flush is triggered.<a name="line.488"></a>
-<span class="sourceLineNo">489</span>        int currentNumRolledLogFiles = getNumRolledLogFiles(desiredRegion);<a name="line.489"></a>
-<span class="sourceLineNo">490</span>        assertNull(getWAL(desiredRegion).rollWriter());<a name="line.490"></a>
-<span class="sourceLineNo">491</span>        while (getNumRolledLogFiles(desiredRegion) &lt;= currentNumRolledLogFiles) {<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          Thread.sleep(100);<a name="line.492"></a>
-<span class="sourceLineNo">493</span>        }<a name="line.493"></a>
-<span class="sourceLineNo">494</span>      }<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      assertEquals(maxLogs, getNumRolledLogFiles(desiredRegion));<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      assertTrue(desiredRegion.getStore(FAMILY1).getMemStoreSize().getHeapSize() &gt; cfFlushSizeLowerBound);<a name="line.496"></a>
-<span class="sourceLineNo">497</span>      assertTrue(desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize() &lt; cfFlushSizeLowerBound);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      assertTrue(desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize() &lt; cfFlushSizeLowerBound);<a name="line.498"></a>
-<span class="sourceLineNo">499</span>      table.put(createPut(1, 12345678));<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      // Make numRolledLogFiles greater than maxLogs<a name="line.500"></a>
-<span class="sourceLineNo">501</span>      desiredRegionAndServer.getSecond().walRoller.requestRollAll();<a name="line.501"></a>
-<span class="sourceLineNo">502</span>      // Wait for some time till the flush caused by log rolling happens.<a name="line.502"></a>
-<span class="sourceLineNo">503</span>      TEST_UTIL.waitFor(30000, new Waiter.ExplainingPredicate&lt;Exception&gt;() {<a name="line.503"></a>
-<span class="sourceLineNo">504</span><a name="line.504"></a>
-<span class="sourceLineNo">505</span>        @Override<a name="line.505"></a>
-<span class="sourceLineNo">506</span>        public boolean evaluate() throws Exception {<a name="line.506"></a>
-<span class="sourceLineNo">507</span>          return desiredRegion.getMemStoreDataSize() == 0;<a name="line.507"></a>
-<span class="sourceLineNo">508</span>        }<a name="line.508"></a>
-<span class="sourceLineNo">509</span><a name="line.509"></a>
-<span class="sourceLineNo">510</span>        @Override<a name="line.510"></a>
-<span class="sourceLineNo">511</span>        public String explainFailure() throws Exception {<a name="line.511"></a>
-<span class="sourceLineNo">512</span>          long memstoreSize = desiredRegion.getMemStoreDataSize();<a name="line.512"></a>
-<span class="sourceLineNo">513</span>          if (memstoreSize &gt; 0) {<a name="line.513"></a>
-<span class="sourceLineNo">514</span>            return "Still have unflushed entries in memstore, memstore size is " + memstoreSize;<a name="line.514"></a>
-<span class="sourceLineNo">515</span>          }<a name="line.515"></a>
-<span class="sourceLineNo">516</span>          return "Unknown";<a name="line.516"></a>
-<span class="sourceLineNo">517</span>        }<a name="line.517"></a>
-<span class="sourceLineNo">518</span>      });<a name="line.518"></a>
-<span class="sourceLineNo">519</span>      LOG.info("Finished waiting on flush after too many WALs...");<a name="line.519"></a>
-<span class="sourceLineNo">520</span>      // Individual families should have been flushed.<a name="line.520"></a>
-<span class="sourceLineNo">521</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.521"></a>
-<span class="sourceLineNo">522</span>        desiredRegion.getStore(FAMILY1).getMemStoreSize().getHeapSize());<a name="line.522"></a>
-<span class="sourceLineNo">523</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.523"></a>
-<span class="sourceLineNo">524</span>        desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize());<a name="line.524"></a>
-<span class="sourceLineNo">525</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.525"></a>
-<span class="sourceLineNo">526</span>        desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize());<a name="line.526"></a>
-<span class="sourceLineNo">527</span>      // let WAL cleanOldLogs<a name="line.527"></a>
-<span class="sourceLineNo">528</span>      assertNull(getWAL(desiredRegion).rollWriter(true));<a name="line.528"></a>
-<span class="sourceLineNo">529</span>      assertTrue(getNumRolledLogFiles(desiredRegion) &lt; maxLogs);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    } finally {<a name="line.530"></a>
-<span class="sourceLineNo">531</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.531"></a>
-<span class="sourceLineNo">532</span>    }<a name="line.532"></a>
-<span class="sourceLineNo">533</span>  }<a name="line.533"></a>
-<span class="sourceLineNo">534</span><a name="line.534"></a>
-<span class="sourceLineNo">535</span>  private void doPut(Table table, long memstoreFlushSize) throws IOException, InterruptedException {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>    Region region = getRegionWithName(table.getName()).getFirst();<a name="line.536"></a>
-<span class="sourceLineNo">537</span>    // cf1 4B per row, cf2 40B per row and cf3 400B per row<a name="line.537"></a>
-<span class="sourceLineNo">538</span>    byte[] qf = Bytes.toBytes("qf");<a name="line.538"></a>
-<span class="sourceLineNo">539</span>    Random rand = new Random();<a name="line.539"></a>
-<span class="sourceLineNo">540</span>    byte[] value1 = new byte[100];<a name="line.540"></a>
-<span class="sourceLineNo">541</span>    byte[] value2 = new byte[200];<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    byte[] value3 = new byte[400];<a name="line.542"></a>
-<span class="sourceLineNo">543</span>    for (int i = 0; i &lt; 10000; i++) {<a name="line.543"></a>
-<span class="sourceLineNo">544</span>      Put put = new Put(Bytes.toBytes("row-" + i));<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      rand.setSeed(i);<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      rand.nextBytes(value1);<a name="line.546"></a>
-<span class="sourceLineNo">547</span>      rand.nextBytes(value2);<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      rand.nextBytes(value3);<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      put.addColumn(FAMILY1, qf, value1);<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      put.addColumn(FAMILY2, qf, value2);<a name="line.550"></a>
-<span class="sourceLineNo">551</span>      put.addColumn(FAMILY3, qf, value3);<a name="line.551"></a>
-<span class="sourceLineNo">552</span>      table.put(put);<a name="line.552"></a>
-<span class="sourceLineNo">553</span>      // slow down to let regionserver flush region.<a name="line.553"></a>
-<span class="sourceLineNo">554</span>      while (region.getMemStoreHeapSize() &gt; memstoreFlushSize) {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>        Thread.sleep(100);<a name="line.555"></a>
-<span class="sourceLineNo">556</span>      }<a name="line.556"></a>
-<span class="sourceLineNo">557</span>    }<a name="line.557"></a>
-<span class="sourceLineNo">558</span>  }<a name="line.558"></a>
-<span class="sourceLineNo">559</span><a name="line.559"></a>
-<span class="sourceLineNo">560</span>  // Under the same write load, small stores should have less store files when<a name="line.560"></a>
-<span class="sourceLineNo">561</span>  // percolumnfamilyflush enabled.<a name="line.561"></a>
-<span class="sourceLineNo">562</span>  @Test<a name="line.562"></a>
-<span class="sourceLineNo">563</span>  public void testCompareStoreFileCount() throws Exception {<a name="line.563"></a>
-<span class="sourceLineNo">564</span>    long memstoreFlushSize = 1024L * 1024;<a name="line.564"></a>
-<span class="sourceLineNo">565</span>    Configuration conf = TEST_UTIL.getConfiguration();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>    conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, memstoreFlushSize);<a name="line.566"></a>
-<span class="sourceLineNo">567</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllStoresPolicy.class.getName());<a name="line.567"></a>
-<span class="sourceLineNo">568</span>    conf.setInt(HStore.BLOCKING_STOREFILES_KEY, 10000);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>    conf.set(HConstants.HBASE_REGION_SPLIT_POLICY_KEY,<a name="line.569"></a>
-<span class="sourceLineNo">570</span>      ConstantSizeRegionSplitPolicy.class.getName());<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span>    HTableDescriptor htd = new HTableDescriptor(TABLENAME);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>    htd.setCompactionEnabled(false);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>    htd.addFamily(new HColumnDescriptor(FAMILY1));<a name="line.574"></a>
-<span class="sourceLineNo">575</span>    htd.addFamily(new HColumnDescriptor(FAMILY2));<a name="line.575"></a>
-<span class="sourceLineNo">576</span>    htd.addFamily(new HColumnDescriptor(FAMILY3));<a name="line.576"></a>
-<span class="sourceLineNo">577</span><a name="line.577"></a>
-<span class="sourceLineNo">578</span>    LOG.info("==============Test with selective flush disabled===============");<a name="line.578"></a>
-<span class="sourceLineNo">579</span>    int cf1StoreFileCount = -1;<a name="line.579"></a>
-<span class="sourceLineNo">580</span>    int cf2StoreFileCount = -1;<a name="line.580"></a>
-<span class="sourceLineNo">581</span>    int cf3StoreFileCount = -1;<a name="line.581"></a>
-<span class="sourceLineNo">582</span>    int cf1StoreFileCount1 = -1;<a name="line.582"></a>
-<span class="sourceLineNo">583</span>    int cf2StoreFileCount1 = -1;<a name="line.583"></a>
-<span class="sourceLineNo">584</span>    int cf3StoreFileCount1 = -1;<a name="line.584"></a>
-<span class="sourceLineNo">585</span>    try {<a name="line.585"></a>
-<span class="sourceLineNo">586</span>      TEST_UTIL.startMiniCluster(1);<a name="line.586"></a>
-<span class="sourceLineNo">587</span>      TEST_UTIL.getAdmin().createNamespace(<a name="line.587"></a>
-<span class="sourceLineNo">588</span>        NamespaceDescriptor.create(TABLENAME.getNamespaceAsString()).build());<a name="line.588"></a>
-<span class="sourceLineNo">589</span>      TEST_UTIL.getAdmin().createTable(htd);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>      TEST_UTIL.waitTableAvailable(TABLENAME);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>      Connection conn = ConnectionFactory.createConnection(conf);<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      Table table = conn.getTable(TABLENAME);<a name="line.592"></a>
-<span class="sourceLineNo">593</span>      doPut(table, memstoreFlushSize);<a name="line.593"></a>
-<span class="sourceLineNo">594</span>      table.close();<a name="line.594"></a>
-<span class="sourceLineNo">595</span>      conn.close();<a name="line.595"></a>
-<span class="sourceLineNo">596</span><a name="line.596"></a>
-<span class="sourceLineNo">597</span>      Region region = getRegionWithName(TABLENAME).getFirst();<a name="line.597"></a>
-<span class="sourceLineNo">598</span>      cf1StoreFileCount = region.getStore(FAMILY1).getStorefilesCount();<a name="line.598"></a>
-<span class="sourceLineNo">599</span>      cf2StoreFileCount = region.getStore(FAMILY2).getStorefilesCount();<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      cf3StoreFileCount = region.getStore(FAMILY3).getStorefilesCount();<a name="line.600"></a>
-<span class="sourceLineNo">601</span>    } finally {<a name="line.601"></a>
-<span class="sourceLineNo">602</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.602"></a>
-<span class="sourceLineNo">603</span>    }<a name="line.603"></a>
-<span class="sourceLineNo">604</span><a name="line.604"></a>
-<span class="sourceLineNo">605</span>    LOG.info("==============Test with selective flush enabled===============");<a name="line.605"></a>
-<span class="sourceLineNo">606</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllLargeStoresPolicy.class.getName());<a name="line.606"></a>
-<span class="sourceLineNo">607</span>    // default value of per-cf flush lower bound is too big, set to a small enough value<a name="line.607"></a>
-<span class="sourceLineNo">608</span>    conf.setLong(FlushLargeStoresPolicy.HREGION_COLUMNFAMILY_FLUSH_SIZE_LOWER_BOUND_MIN, 0);<a name="line.608"></a>
-<span class="sourceLineNo">609</span>    try {<a name="line.609"></a>
-<span class="sourceLineNo">610</span>      TEST_UTIL.startMiniCluster(1);<a name="line.610"></a>
-<span class="sourceLineNo">611</span>      TEST_UTIL.getAdmin().createNamespace(<a name="line.611"></a>
-<span class="sourceLineNo">612</span>        NamespaceDescriptor.create(TABLENAME.getNamespaceAsString()).build());<a name="line.612"></a>
-<span class="sourceLineNo">613</span>      TEST_UTIL.getAdmin().createTable(htd);<a name="line.613"></a>
-<span class="sourceLineNo">614</span>      Connection conn = ConnectionFactory.createConnection(conf);<a name="line.614"></a>
-<span class="sourceLineNo">615</span>      Table table = conn.getTable(TABLENAME);<a name="line.615"></a>
-<span class="sourceLineNo">616</span>      doPut(table, memstoreFlushSize);<a name="line.616"></a>
-<span class="sourceLineNo">617</span>      table.close();<a name="line.617"></a>
-<span class="sourceLineNo">618</span>      conn.close();<a name="line.618"></a>
-<span class="sourceLineNo">619</span><a name="line.619"></a>
-<span class="sourceLineNo">620</span>      Region region = getRegionWithName(TABLENAME).getFirst();<a name="line.620"></a>
-<span class="sourceLineNo">621</span>      cf1StoreFileCount1 = region.getStore(FAMILY1).getStorefilesCount();<a name="line.621"></a>
-<span class="sourceLineNo">622</span>      cf2StoreFileCount1 = region.getStore(FAMILY2).getStorefilesCount();<a name="line.622"></a>
-<span class="sourceLineNo">623</span>      cf3StoreFileCount1 = region.getStore(FAMILY3).getStorefilesCount();<a name="line.623"></a>
-<span class="sourceLineNo">624</span>    } finally {<a name="line.624"></a>
-<span class="sourceLineNo">625</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.625"></a>
-<span class="sourceLineNo">626</span>    }<a name="line.626"></a>
-<span class="sourceLineNo">627</span><a name="line.627"></a>
-<span class="sourceLineNo">628</span>    LOG.info("disable selective flush: " + Bytes.toString(FAMILY1) + "=&gt;" + cf1StoreFileCount<a name="line.628"></a>
-<span class="sourceLineNo">629</span>        + ", " + Bytes.toString(FAMILY2) + "=&gt;" + cf2StoreFileCount + ", "<a name="line.629"></a>
-<span class="sourceLineNo">630</span>        + Bytes.toString(FAMILY3) + "=&gt;" + cf3StoreFileCount);<a name="line.630"></a>
-<span class="sourceLineNo">631</span>    LOG.info("enable selective flush: " + Bytes.toString(FAMILY1) + "=&gt;" + cf1StoreFileCount1<a name="line.631"></a>
-<span class="sourceLineNo">632</span>        + ", " + Bytes.toString(FAMILY2) + "=&gt;" + cf2StoreFileCount1 + ", "<a name="line.632"></a>
-<span class="sourceLineNo">633</span>        + Bytes.toString(FAMILY3) + "=&gt;" + cf3StoreFileCount1);<a name="line.633"></a>
-<span class="sourceLineNo">634</span>    // small CF will have less store files.<a name="line.634"></a>
-<span class="sourceLineNo">635</span>    assertTrue(cf1StoreFileCount1 &lt; cf1StoreFileCount);<a name="line.635"></a>
-<span class="sourceLineNo">636</span>    assertTrue(cf2StoreFileCount1 &lt; cf2StoreFileCount);<a name="line.636"></a>
-<span class="sourceLineNo">637</span>  }<a name="line.637"></a>
-<span class="sourceLineNo">638</span><a name="line.638"></a>
-<span class="sourceLineNo">639</span>  public static void main(String[] args) throws Exception {<a name="line.639"></a>
-<span class="sourceLineNo">640</span>    int numRegions = Integer.parseInt(args[0]);<a name="line.640"></a>
-<span class="sourceLineNo">641</span>    long numRows = Long.parseLong(args[1]);<a name="line.641"></a>
-<span class="sourceLineNo">642</span><a name="line.642"></a>
-<span class="sourceLineNo">643</span>    HTableDescriptor htd = new HTableDescriptor(TABLENAME);<a name="line.643"></a>
-<span class="sourceLineNo">644</span>    htd.setMaxFileSize(10L * 1024 * 1024 * 1024);<a name="line.644"></a>
-<span class="sourceLineNo">645</span>    htd.setValue(HTableDescriptor.SPLIT_POLICY, ConstantSizeRegionSplitPolicy.class.getName());<a name="line.645"></a>
-<span class="sourceLineNo">646</span>    htd.addFamily(new HColumnDescriptor(FAMILY1));<a name="line.646"></a>
-<span class="sourceLineNo">647</span>    htd.addFamily(new HColumnDescriptor(FAMILY2));<a name="line.647"></a>
-<span class="sourceLineNo">648</span>    htd.addFamily(new HColumnDescriptor(FAMILY3));<a name="line.648"></a>
-<span class="sourceLineNo">649</span><a name="line.649"></a>
-<span class="sourceLineNo">650</span>    Configuration conf = HBaseConfiguration.create();<a name="line.650"></a>
-<span class="sourceLineNo">651</span>    Connection conn = ConnectionFactory.createConnection(conf);<a name="line.651"></a>
-<span class="sourceLineNo">652</span>    Admin admin = conn.getAdmin();<a name="line.652"></a>
-<span class="sourceLineNo">653</span>    if (admin.tableExists(TABLENAME)) {<a name="line.653"></a>
-<span class="sourceLineNo">654</span>      admin.disableTable(TABLENAME);<a name="line.654"></a>
-<span class="sourceLineNo">655</span>      admin.deleteTable(TABLENAME);<a name="line.655"></a>
-<span class="sourceLineNo">656</span>    }<a name="line.656"></a>
-<span class="sourceLineNo">657</span>    if (numRegions &gt;= 3) {<a name="line.657"></a>
-<span class="sourceLineNo">658</span>      byte[] startKey = new byte[16];<a name="line.658"></a>
-<span class="sourceLineNo">659</span>      byte[] endKey = new byte[16];<a name="line.659"></a>
-<span class="sourceLineNo">660</span>      Arrays.fill(endKey, (byte) 0xFF);<a name="line.660"></a>
-<span class="sourceLineNo">661</span>      admin.createTable(htd, startKey, endKey, numRegions);<a name="line.661"></a>
-<span class="sourceLineNo">662</span>    } else {<a name="line.662"></a>
-<span class="sourceLineNo">663</span>      admin.createTable(htd);<a name="line.663"></a>
-<span class="sourceLineNo">664</span>    }<a name="line.664"></a>
-<span class="sourceLineNo">665</span>    admin.close();<a name="line.665"></a>
-<span class="sourceLineNo">666</span><a name="line.666"></a>
-<span class="sourceLineNo">667</span>    Table table = conn.getTable(TABLENAME);<a name="line.667"></a>
-<span class="sourceLineNo">668</span>    byte[] qf = Bytes.toBytes("qf");<a name="line.668"></a>
-<span class="sourceLineNo">669</span>    Random rand = new Random();<a name="line.669"></a>
-<span class="sourceLineNo">670</span>    byte[] value1 = new byte[16];<a name="line.670"></a>
-<span class="sourceLineNo">671</span>    byte[] value2 = new byte[256];<a name="line.671"></a>
-<span class="sourceLineNo">672</span>    byte[] value3 = new byte[4096];<a name="line.672"></a>
-<span class="sourceLineNo">673</span>    for (long i = 0; i &lt; numRows; i++) {<a name="line.673"></a>
-<span class="sourceLineNo">674</span>      Put put = new Put(Hashing.md5().hashLong(i).asBytes());<a name="line.674"></a>
-<span class="sourceLineNo">675</span>      rand.setSeed(i);<a name="line.675"></a>
-<span class="sourceLineNo">676</span>      rand.nextBytes(value1);<a name="line.676"></a>
-<span class="sourceLineNo">677</span>      rand.nextBytes(value2);<a name="line.677"></a>
-<span class="sourceLineNo">678</span>      rand.nextBytes(value3);<a name="line.678"></a>
-<span class="sourceLineNo">679</span>      put.addColumn(FAMILY1, qf, value1);<a name="line.679"></a>
-<span class="sourceLineNo">680</span>      put.addColumn(FAMILY2, qf, value2);<a name="line.680"></a>
-<span class="sourceLineNo">681</span>      put.addColumn(FAMILY3, qf, value3);<a name="line.681"></a>
-<span class="sourceLineNo">682</span>      table.put(put);<a name="line.682"></a>
-<span class="sourceLineNo">683</span>      if (i % 10000 == 0) {<a name="line.683"></a>
-<span class="sourceLineNo">684</span>        LOG.info(i + " rows put");<a name="line.684"></a>
-<span class="sourceLineNo">685</span>      }<a name="line.685"></a>
-<span class="sourceLineNo">686</span>    }<a name="line.686"></a>
-<span class="sourceLineNo">687</span>    table.close();<a name="line.687"></a>
-<span class="sourceLineNo">688</span>    conn.close();<a name="line.688"></a>
-<span class="sourceLineNo">689</span>  }<a name="line.689"></a>
-<span class="sourceLineNo">690</span>}<a name="line.690"></a>
+<span class="sourceLineNo">394</span>      // TODO: This test doesn't allow for this case:<a name="line.394"></a>
+<span class="sourceLineNo">395</span>      // " Since none of the CFs were above the size, flushing all."<a name="line.395"></a>
+<span class="sourceLineNo">396</span>      // i.e. a flush happens before we get to here and its a flush-all.<a name="line.396"></a>
+<span class="sourceLineNo">397</span>      assertTrue(cf2MemstoreSize &gt;= 0);<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      assertTrue(cf3MemstoreSize &gt;= 0);<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      assertEquals(totalMemstoreSize, cf2MemstoreSize + cf3MemstoreSize);<a name="line.399"></a>
+<span class="sourceLineNo">400</span><a name="line.400"></a>
+<span class="sourceLineNo">401</span>      // Wait for the RS report to go across to the master, so that the master<a name="line.401"></a>
+<span class="sourceLineNo">402</span>      // is aware of which sequence ids have been flushed, before we kill the RS.<a name="line.402"></a>
+<span class="sourceLineNo">403</span>      // If in production, the RS dies before the report goes across, we will<a name="line.403"></a>
+<span class="sourceLineNo">404</span>      // safely replay all the edits.<a name="line.404"></a>
+<span class="sourceLineNo">405</span>      Thread.sleep(2000);<a name="line.405"></a>
+<span class="sourceLineNo">406</span><a name="line.406"></a>
+<span class="sourceLineNo">407</span>      // Abort the region server where we have the region hosted.<a name="line.407"></a>
+<span class="sourceLineNo">408</span>      HRegionServer rs = desiredRegionAndServer.getSecond();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>      rs.abort("testing");<a name="line.409"></a>
+<span class="sourceLineNo">410</span><a name="line.410"></a>
+<span class="sourceLineNo">411</span>      // The aborted region server's regions will be eventually assigned to some<a name="line.411"></a>
+<span class="sourceLineNo">412</span>      // other region server, and the get RPC call (inside verifyEdit()) will<a name="line.412"></a>
+<span class="sourceLineNo">413</span>      // retry for some time till the regions come back up.<a name="line.413"></a>
+<span class="sourceLineNo">414</span><a name="line.414"></a>
+<span class="sourceLineNo">415</span>      // Verify that all the edits are safe.<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      for (int i = 1; i &lt;= 80; i++) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span>        verifyEdit(1, i, table);<a name="line.417"></a>
+<span class="sourceLineNo">418</span>        if (i &lt;= 10) {<a name="line.418"></a>
+<span class="sourceLineNo">419</span>          verifyEdit(2, i, table);<a name="line.419"></a>
+<span class="sourceLineNo">420</span>          verifyEdit(3, i, table);<a name="line.420"></a>
+<span class="sourceLineNo">421</span>        }<a name="line.421"></a>
+<span class="sourceLineNo">422</span>      }<a name="line.422"></a>
+<span class="sourceLineNo">423</span>    } finally {<a name="line.423"></a>
+<span class="sourceLineNo">424</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    }<a name="line.425"></a>
+<span class="sourceLineNo">426</span>  }<a name="line.426"></a>
+<span class="sourceLineNo">427</span><a name="line.427"></a>
+<span class="sourceLineNo">428</span>  // Test Log Replay with Distributed log split on.<a name="line.428"></a>
+<span class="sourceLineNo">429</span>  @Test<a name="line.429"></a>
+<span class="sourceLineNo">430</span>  public void testLogReplayWithDistributedLogSplit() throws Exception {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>    doTestLogReplay();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>  }<a name="line.432"></a>
+<span class="sourceLineNo">433</span><a name="line.433"></a>
+<span class="sourceLineNo">434</span>  private WAL getWAL(Region region) {<a name="line.434"></a>
+<span class="sourceLineNo">435</span>    return ((HRegion)region).getWAL();<a name="line.435"></a>
+<span class="sourceLineNo">436</span>  }<a name="line.436"></a>
+<span class="sourceLineNo">437</span><a name="line.437"></a>
+<span class="sourceLineNo">438</span>  private int getNumRolledLogFiles(Region region) {<a name="line.438"></a>
+<span class="sourceLineNo">439</span>    return AbstractFSWALProvider.getNumRolledLogFiles(getWAL(region));<a name="line.439"></a>
+<span class="sourceLineNo">440</span>  }<a name="line.440"></a>
+<span class="sourceLineNo">441</span><a name="line.441"></a>
+<span class="sourceLineNo">442</span>  /**<a name="line.442"></a>
+<span class="sourceLineNo">443</span>   * When a log roll is about to happen, we do a flush of the regions who will be affected by the<a name="line.443"></a>
+<span class="sourceLineNo">444</span>   * log roll. These flushes cannot be a selective flushes, otherwise we cannot roll the logs. This<a name="line.444"></a>
+<span class="sourceLineNo">445</span>   * test ensures that we do a full-flush in that scenario.<a name="line.445"></a>
+<span class="sourceLineNo">446</span>   * @throws IOException<a name="line.446"></a>
+<span class="sourceLineNo">447</span>   */<a name="line.447"></a>
+<span class="sourceLineNo">448</span>  @Test<a name="line.448"></a>
+<span class="sourceLineNo">449</span>  public void testFlushingWhenLogRolling() throws Exception {<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    TableName tableName = TableName.valueOf("testFlushingWhenLogRolling");<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    Configuration conf = TEST_UTIL.getConfiguration();<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, 128 * 1024 * 1024);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllLargeStoresPolicy.class.getName());<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    long cfFlushSizeLowerBound = 2048;<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    conf.setLong(FlushLargeStoresPolicy.HREGION_COLUMNFAMILY_FLUSH_SIZE_LOWER_BOUND_MIN,<a name="line.455"></a>
+<span class="sourceLineNo">456</span>      cfFlushSizeLowerBound);<a name="line.456"></a>
+<span class="sourceLineNo">457</span><a name="line.457"></a>
+<span class="sourceLineNo">458</span>    // One hour, prevent periodic rolling<a name="line.458"></a>
+<span class="sourceLineNo">459</span>    conf.setLong("hbase.regionserver.logroll.period", 60L * 60 * 1000);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    // prevent rolling by size<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    conf.setLong("hbase.regionserver.hlog.blocksize", 128L * 1024 * 1024);<a name="line.461"></a>
+<span class="sourceLineNo">462</span>    // Make it 10 as max logs before a flush comes on.<a name="line.462"></a>
+<span class="sourceLineNo">463</span>    final int maxLogs = 10;<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    conf.setInt("hbase.regionserver.maxlogs", maxLogs);<a name="line.464"></a>
+<span class="sourceLineNo">465</span><a name="line.465"></a>
+<span class="sourceLineNo">466</span>    final int numRegionServers = 1;<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    TEST_UTIL.startMiniCluster(numRegionServers);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    try {<a name="line.468"></a>
+<span class="sourceLineNo">469</span>      Table table = TEST_UTIL.createTable(tableName, FAMILIES);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>      // Force flush the namespace table so edits to it are not hanging around as oldest<a name="line.470"></a>
+<span class="sourceLineNo">471</span>      // edits. Otherwise, below, when we make maximum number of WAL files, then it will be<a name="line.471"></a>
+<span class="sourceLineNo">472</span>      // the namespace region that is flushed and not the below 'desiredRegion'.<a name="line.472"></a>
+<span class="sourceLineNo">473</span>      try (Admin admin = TEST_UTIL.getConnection().getAdmin()) {<a name="line.473"></a>
+<span class="sourceLineNo">474</span>        admin.flush(TableName.NAMESPACE_TABLE_NAME);<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      }<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      Pair&lt;HRegion, HRegionServer&gt; desiredRegionAndServer = getRegionWithName(tableName);<a name="line.476"></a>
+<span class="sourceLineNo">477</span>      final HRegion desiredRegion = desiredRegionAndServer.getFirst();<a name="line.477"></a>
+<span class="sourceLineNo">478</span>      assertTrue("Could not find a region which hosts the new region.", desiredRegion != null);<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      LOG.info("Writing to region=" + desiredRegion);<a name="line.479"></a>
+<span class="sourceLineNo">480</span><a name="line.480"></a>
+<span class="sourceLineNo">481</span>      // Add one row for both CFs.<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      for (int i = 1; i &lt;= 3; i++) {<a name="line.482"></a>
+<span class="sourceLineNo">483</span>        table.put(createPut(i, 0));<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      }<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      // Now only add row to CF1, make sure when we force a flush, CF1 is larger than the lower<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      // bound and CF2 and CF3 are smaller than the lower bound.<a name="line.486"></a>
+<span class="sourceLineNo">487</span>      for (int i = 0; i &lt; maxLogs; i++) {<a name="line.487"></a>
+<span class="sourceLineNo">488</span>        for (int j = 0; j &lt; 100; j++) {<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          table.put(createPut(1, i * 100 + j));<a name="line.489"></a>
+<span class="sourceLineNo">490</span>        }<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        // Roll the WAL. The log file count is less than maxLogs so no flush is triggered.<a name="line.491"></a>
+<span class="sourceLineNo">492</span>        int currentNumRolledLogFiles = getNumRolledLogFiles(desiredRegion);<a name="line.492"></a>
+<span class="sourceLineNo">493</span>        assertNull(getWAL(desiredRegion).rollWriter());<a name="line.493"></a>
+<span class="sourceLineNo">494</span>        while (getNumRolledLogFiles(desiredRegion) &lt;= currentNumRolledLogFiles) {<a name="line.494"></a>
+<span class="sourceLineNo">495</span>          Thread.sleep(100);<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        }<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span>      assertEquals(maxLogs, getNumRolledLogFiles(desiredRegion));<a name="line.498"></a>
+<span class="sourceLineNo">499</span>      assertTrue(desiredRegion.getStore(FAMILY1).getMemStoreSize().getHeapSize() &gt; cfFlushSizeLowerBound);<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      assertTrue(desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize() &lt; cfFlushSizeLowerBound);<a name="line.500"></a>
+<span class="sourceLineNo">501</span>      assertTrue(desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize() &lt; cfFlushSizeLowerBound);<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      table.put(createPut(1, 12345678));<a name="line.502"></a>
+<span class="sourceLineNo">503</span>      // Make numRolledLogFiles greater than maxLogs<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      desiredRegionAndServer.getSecond().walRoller.requestRollAll();<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      // Wait for some time till the flush caused by log rolling happens.<a name="line.505"></a>
+<span class="sourceLineNo">506</span>      TEST_UTIL.waitFor(30000, new Waiter.ExplainingPredicate&lt;Exception&gt;() {<a name="line.506"></a>
+<span class="sourceLineNo">507</span><a name="line.507"></a>
+<span class="sourceLineNo">508</span>        @Override<a name="line.508"></a>
+<span class="sourceLineNo">509</span>        public boolean evaluate() throws Exception {<a name="line.509"></a>
+<span class="sourceLineNo">510</span>          return desiredRegion.getMemStoreDataSize() == 0;<a name="line.510"></a>
+<span class="sourceLineNo">511</span>        }<a name="line.511"></a>
+<span class="sourceLineNo">512</span><a name="line.512"></a>
+<span class="sourceLineNo">513</span>        @Override<a name="line.513"></a>
+<span class="sourceLineNo">514</span>        public String explainFailure() throws Exception {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>          long memstoreSize = desiredRegion.getMemStoreDataSize();<a name="line.515"></a>
+<span class="sourceLineNo">516</span>          if (memstoreSize &gt; 0) {<a name="line.516"></a>
+<span class="sourceLineNo">517</span>            return "Still have unflushed entries in memstore, memstore size is " + memstoreSize;<a name="line.517"></a>
+<span class="sourceLineNo">518</span>          }<a name="line.518"></a>
+<span class="sourceLineNo">519</span>          return "Unknown";<a name="line.519"></a>
+<span class="sourceLineNo">520</span>        }<a name="line.520"></a>
+<span class="sourceLineNo">521</span>      });<a name="line.521"></a>
+<span class="sourceLineNo">522</span>      LOG.info("Finished waiting on flush after too many WALs...");<a name="line.522"></a>
+<span class="sourceLineNo">523</span>      // Individual families should have been flushed.<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.524"></a>
+<span class="sourceLineNo">525</span>        desiredRegion.getStore(FAMILY1).getMemStoreSize().getHeapSize());<a name="line.525"></a>
+<span class="sourceLineNo">526</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.526"></a>
+<span class="sourceLineNo">527</span>        desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize());<a name="line.527"></a>
+<span class="sourceLineNo">528</span>      assertEquals(MutableSegment.DEEP_OVERHEAD,<a name="line.528"></a>
+<span class="sourceLineNo">529</span>        desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize());<a name="line.529"></a>
+<span class="sourceLineNo">530</span>      // let WAL cleanOldLogs<a name="line.530"></a>
+<span class="sourceLineNo">531</span>      assertNull(getWAL(desiredRegion).rollWriter(true));<a name="line.531"></a>
+<span class="sourceLineNo">532</span>      assertTrue(getNumRolledLogFiles(desiredRegion) &lt; maxLogs);<a name="line.532"></a>
+<span class="sourceLineNo">533</span>    } finally {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    }<a name="line.535"></a>
+<span class="sourceLineNo">536</span>  }<a name="line.536"></a>
+<span class="sourceLineNo">537</span><a name="line.537"></a>
+<span class="sourceLineNo">538</span>  private void doPut(Table table, long memstoreFlushSize) throws IOException, InterruptedException {<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    Region region = getRegionWithName(table.getName()).getFirst();<a name="line.539"></a>
+<span class="sourceLineNo">540</span>    // cf1 4B per row, cf2 40B per row and cf3 400B per row<a name="line.540"></a>
+<span class="sourceLineNo">541</span>    byte[] qf = Bytes.toBytes("qf");<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    Random rand = new Random();<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    byte[] value1 = new byte[100];<a name="line.543"></a>
+<span class="sourceLineNo">544</span>    byte[] value2 = new byte[200];<a name="line.544"></a>
+<span class="sourceLineNo">545</span>    byte[] value3 = new byte[400];<a name="line.545"></a>
+<span class="sourceLineNo">546</span>    for (int i = 0; i &lt; 10000; i++) {<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      Put put = new Put(Bytes.toBytes("row-" + i));<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      rand.setSeed(i);<a name="line.548"></a>
+<span class="sourceLineNo">549</span>      rand.nextBytes(value1);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      rand.nextBytes(value2);<a name="line.550"></a>
+<span class="sourceLineNo">551</span>      rand.nextBytes(value3);<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      put.addColumn(FAMILY1, qf, value1);<a name="line.552"></a>
+<span class="sourceLineNo">553</span>      put.addColumn(FAMILY2, qf, value2);<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      put.addColumn(FAMILY3, qf, value3);<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      table.put(put);<a name="line.555"></a>
+<span class="sourceLineNo">556</span>      // slow down to let regionserver flush region.<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      while (region.getMemStoreHeapSize() &gt; memstoreFlushSize) {<a name="line.557"></a>
+<span class="sourceLineNo">558</span>        Thread.sleep(100);<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      }<a name="line.559"></a>
+<span class="sourceLineNo">560</span>    }<a name="line.560"></a>
+<span class="sourceLineNo">561</span>  }<a name="line.561"></a>
+<span class="sourceLineNo">562</span><a name="line.562"></a>
+<span class="sourceLineNo">563</span>  // Under the same write load, small stores should have less store files when<a name="line.563"></a>
+<span class="sourceLineNo">564</span>  // percolumnfamilyflush enabled.<a name="line.564"></a>
+<span class="sourceLineNo">565</span>  @Test<a name="line.565"></a>
+<span class="sourceLineNo">566</span>  public void testCompareStoreFileCount() throws Exception {<a name="line.566"></a>
+<span class="sourceLineNo">567</span>    long memstoreFlushSize = 1024L * 1024;<a name="line.567"></a>
+<span class="sourceLineNo">568</span>    Configuration conf = TEST_UTIL.getConfiguration();<a name="line.568"></a>
+<span class="sourceLineNo">569</span>    conf.setLong(HConstants.HREGION_MEMSTORE_FLUSH_SIZE, memstoreFlushSize);<a name="line.569"></a>
+<span class="sourceLineNo">570</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllStoresPolicy.class.getName());<a name="line.570"></a>
+<span class="sourceLineNo">571</span>    conf.setInt(HStore.BLOCKING_STOREFILES_KEY, 10000);<a name="line.571"></a>
+<span class="sourceLineNo">572</span>    conf.set(HConstants.HBASE_REGION_SPLIT_POLICY_KEY,<a name="line.572"></a>
+<span class="sourceLineNo">573</span>      ConstantSizeRegionSplitPolicy.class.getName());<a name="line.573"></a>
+<span class="sourceLineNo">574</span><a name="line.574"></a>
+<span class="sourceLineNo">575</span>    HTableDescriptor htd = new HTableDescriptor(TABLENAME);<a name="line.575"></a>
+<span class="sourceLineNo">576</span>    htd.setCompactionEnabled(false);<a name="line.576"></a>
+<span class="sourceLineNo">577</span>    htd.addFamily(new HColumnDescriptor(FAMILY1));<a name="line.577"></a>
+<span class="sourceLineNo">578</span>    htd.addFamily(new HColumnDescriptor(FAMILY2));<a name="line.578"></a>
+<span class="sourceLineNo">579</span>    htd.addFamily(new HColumnDescriptor(FAMILY3));<a name="line.579"></a>
+<span class="sourceLineNo">580</span><a name="line.580"></a>
+<span class="sourceLineNo">581</span>    LOG.info("==============Test with selective flush disabled===============");<a name="line.581"></a>
+<span class="sourceLineNo">582</span>    int cf1StoreFileCount = -1;<a name="line.582"></a>
+<span class="sourceLineNo">583</span>    int cf2StoreFileCount = -1;<a name="line.583"></a>
+<span class="sourceLineNo">584</span>    int cf3StoreFileCount = -1;<a name="line.584"></a>
+<span class="sourceLineNo">585</span>    int cf1StoreFileCount1 = -1;<a name="line.585"></a>
+<span class="sourceLineNo">586</span>    int cf2StoreFileCount1 = -1;<a name="line.586"></a>
+<span class="sourceLineNo">587</span>    int cf3StoreFileCount1 = -1;<a name="line.587"></a>
+<span class="sourceLineNo">588</span>    try {<a name="line.588"></a>
+<span class="sourceLineNo">589</span>      TEST_UTIL.startMiniCluster(1);<a name="line.589"></a>
+<span class="sourceLineNo">590</span>      TEST_UTIL.getAdmin().createNamespace(<a name="line.590"></a>
+<span class="sourceLineNo">591</span>        NamespaceDescriptor.create(TABLENAME.getNamespaceAsString()).build());<a name="line.591"></a>
+<span class="sourceLineNo">592</span>      TEST_UTIL.getAdmin().createTable(htd);<a name="line.592"></a>
+<span class="sourceLineNo">593</span>      TEST_UTIL.waitTableAvailable(TABLENAME);<a name="line.593"></a>
+<span class="sourceLineNo">594</span>      Connection conn = ConnectionFactory.createConnection(conf);<a name="line.594"></a>
+<span class="sourceLineNo">595</span>      Table table = conn.getTable(TABLENAME);<a name="line.595"></a>
+<span class="sourceLineNo">596</span>      doPut(table, memstoreFlushSize);<a name="line.596"></a>
+<span class="sourceLineNo">597</span>      table.close();<a name="line.597"></a>
+<span class="sourceLineNo">598</span>      conn.close();<a name="line.598"></a>
+<span class="sourceLineNo">599</span><a name="line.599"></a>
+<span class="sourceLineNo">600</span>      Region region = getRegionWithName(TABLENAME).getFirst();<a name="line.600"></a>
+<span class="sourceLineNo">601</span>      cf1StoreFileCount = region.getStore(FAMILY1).getStorefilesCount();<a name="line.601"></a>
+<span class="sourceLineNo">602</span>      cf2StoreFileCount = region.getStore(FAMILY2).getStorefilesCount();<a name="line.602"></a>
+<span class="sourceLineNo">603</span>      cf3StoreFileCount = region.getStore(FAMILY3).getStorefilesCount();<a name="line.603"></a>
+<span class="sourceLineNo">604</span>    } finally {<a name="line.604"></a>
+<span class="sourceLineNo">605</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.605"></a>
+<span class="sourceLineNo">606</span>    }<a name="line.606"></a>
+<span class="sourceLineNo">607</span><a name="line.607"></a>
+<span class="sourceLineNo">608</span>    LOG.info("==============Test with selective flush enabled===============");<a name="line.608"></a>
+<span class="sourceLineNo">609</span>    conf.set(FlushPolicyFactory.HBASE_FLUSH_POLICY_KEY, FlushAllLargeStoresPolicy.class.getName());<a name="line.609"></a>
+<span class="sourceLineNo">610</span>    // default value of per-cf flush lower bound is too big, set to a small enough value<a name="line.610"></a>
+<span class="sourceLineNo">611</span>    conf.setLong(FlushLargeStoresPolicy.HREGION_COLUMNFAMILY_FLUSH_SIZE_LOWER_BOUND_MIN, 0);<a name="line.611"></a>
+<span class="sourceLineNo">612</span>    try {<a name="line.612"></a>
+<span class="sourceLineNo">613</span>      TEST_UTIL.startMiniCluster(1);<a name="line.613"></a>
+<span class="sourceLineNo">614</span>      TEST_UTIL.getAdmin().createNamespace(<a name="line.614"></a>
+<span class="sourceLineNo">615</span>        NamespaceDescriptor.create(TABLENAME.getNamespaceAsString()).build());<a name="line.615"></a>
+<span class="sourceLineNo">616</span>      TEST_UTIL.getAdmin().createTable(htd);<a name="line.616"></a>
+<span class="sourceLineNo">617</span>      Connection conn = ConnectionFactory.createConnection(conf);<a name="line.617"></a>
+<span class="sourceLineNo">618</span>      Table table = conn.getTable(TABLENAME);<a name="line.618"></a>
+<span class="sourceLineNo">619</span>      doPut(table, memstoreFlushSize);<a name="line.619"></a>
+<span class="sourceLineNo">620</span>      table.close();<a name="line.620"></a>
+<span class="sourceLineNo">621</span>      conn.close();<a name="line.621"></a>
+<span class="sourceLineNo">622</span><a name="line.622"></a>
+<span class="sourceLineNo">623</span>      Region region = getRegionWithName(TABLENAME).getFirst();<a name="line.623"></a>
+<span class="sourceLineNo">624</span>      cf1StoreFileCount1 = region.getStore(FAMILY1).getStorefilesCount();<a name="line.624"></a>
+<span class="sourceLineNo">625</span>      cf2StoreFileCount1 = region.getStore(FAMILY2).getStorefilesCount();<a name="line.625"></a>
+<span class="sourceLineNo">626</span>      cf3StoreFileCount1 = region.getStore(FAMILY3).getStorefilesCount();<a name="line.626"></a>
+<span class="sourceLineNo">627</span>    } finally {<a name="line.627"></a>
+<span class="sourceLineNo">628</span>      TEST_UTIL.shutdownMiniCluster();<a name="line.628"></a>
+<span class="sourceLineNo">629</span>    }<a name="line.629"></a>
+<span class="sourceLineNo">630</span><a name="line.630"></a>
+<span class="sourceLineNo">631</span>    LOG.info("disable selective flush: " + Bytes.toString(FAMILY1) + "=&gt;" + cf1StoreFileCount<a name="line.631"></a>
+<span class="sourceLineNo">632</span>        + ", " + Bytes.toString(FAMILY2) + "=&gt;" + cf2StoreFileCount + ", "<a name="line.632"></a>
+<span class="sourceLineNo">633</span>        + Bytes.toString(FAMILY3) + "=&gt;" + cf3StoreFileCount);<a name="line.633"></a>
+<span class="sourceLineNo">634</span>    LOG.info("enable selective flush: " + Bytes.toString(FAMILY1) + "=&gt;" + cf1StoreFileCount1<a name="line.634"></a>
+<span class="sourceLineNo">635</span>        + ", " + Bytes.toString(FAMILY2) + "=&gt;" + cf2StoreFileCount1 + ", "<a name="line.635"></a>
+<span class="sourceLineNo">636</span>        + Bytes.toString(FAMILY3) + "=&gt;" + cf3StoreFileCount1);<a name="line.636"></a>
+<span class="sourceLineNo">637</span>    // small CF will have less store files.<a name="line.637"></a>
+<span class="sourceLineNo">638</span>    assertTrue(cf1StoreFileCount1 &lt; cf1StoreFileCount);<a name="line.638"></a>
+<span class="sourceLineNo">639</span>    assertTrue(cf2StoreFileCount1 &lt; cf2StoreFileCount);<a name="line.639"></a>
+<span class="sourceLineNo">640</span>  }<a name="line.640"></a>
+<span class="sourceLineNo">641</span><a name="line.641"></a>
+<span class="sourceLineNo">642</span>  public static void main(String[] args) throws Exception {<a name="line.642"></a>
+<span class="sourceLineNo">643</span>    int numRegions = Integer.parseInt(args[0]);<a name="line.643"></a>
+<span class="sourceLineNo">644</span>    long numRows = Long.parseLong(args[1]);<a name="line.644"></a>
+<span class="sourceLineNo">645</span><a name="line.645"></a>
+<span class="sourceLineNo">646</span>    HTableDescriptor htd = new HTableDescriptor(TABLENAME);<a name="line.646"></a>
+<span class="sourceLineNo">647</span>    htd.setMaxFileSize(10L * 1024 * 1024 * 1024);<a name="line.647"></a>
+<span class="sourceLineNo">648</span>    htd.setValue(HTableDescriptor.SPLIT_POLICY, ConstantSizeRegionSplitPolicy.class.getName());<a name="line.648"></a>
+<span class="sourceLineNo">649</span>    htd.addFamily(new HColumnDescriptor(FAMILY1));<a name="line.649"></a>
+<span class="sourceLineNo">650</span>    htd.addFamily(new HColumnDescriptor(FAMILY2));<a name="line.650"></a>
+<span class="sourceLineNo">651</span>    htd.addFamily(new HColumnDescriptor(FAMILY3));<a name="line.651"></a>
+<span class="sourceLineNo">652</span><a name="line.652"></a>
+<span class="sourceLineNo">653</span>    Configuration conf = HBaseConfiguration.create();<a name="line.653"></a>
+<span class="sourceLineNo">654</span>    Connection conn = ConnectionFactory.createConnection(conf);<a name="line.654"></a>
+<span class="sourceLineNo">655</span>    Admin admin = conn.getAdmin();<a name="line.655"></a>
+<span class="sourceLineNo">656</span>    if (admin.tableExists(TABLENAME)) {<a name="line.656"></a>
+<span class="sourceLineNo">657</span>      admin.disableTable(TABLENAME);<a name="line.657"></a>
+<span class="sourceLineNo">658</span>      admin.deleteTable(TABLENAME);<a name="line.658"></a>
+<span class="sourceLineNo">659</span>    }<a name="line.659"></a>
+<span class="sourceLineNo">660</span>    if (numRegions &gt;= 3) {<a name="line.660"></a>
+<span class="sourceLineNo">661</span>      byte[] startKey = new byte[16];<a name="line.661"></a>
+<span class="sourceLineNo">662</span>      byte[] endKey = new byte[16];<a name="line.662"></a>
+<span class="sourceLineNo">663</span>      Arrays.fill(endKey, (byte) 0xFF);<a name="line.663"></a>
+<span class="sourceLineNo">664</span>      admin.createTable(htd, startKey, endKey, numRegions);<a name="line.664"></a>
+<span class="sourceLineNo">665</span>    } else {<a name="line.665"></a>
+<span class="sourceLineNo">666</span>      admin.createTable(htd);<a name="line.666"></a>
+<span class="sourceLineNo">667</span>    }<a name="line.667"></a>
+<span class="sourceLineNo">668</span>    admin.close();<a name="line.668"></a>
+<span class="sourceLineNo">669</span><a name="line.669"></a>
+<span class="sourceLineNo">670</span>    Table table = conn.getTable(TABLENAME);<a name="line.670"></a>
+<span class="sourceLineNo">671</span>    byte[] qf = Bytes.toBytes("qf");<a name="line.671"></a>
+<span class="sourceLineNo">672</span>    Random rand = new Random();<a name="line.672"></a>
+<span class="sourceLineNo">673</span>    byte[] value1 = new byte[16];<a name="line.673"></a>
+<span class="sourceLineNo">674</span>    byte[] value2 = new byte[256];<a name="line.674"></a>
+<span class="sourceLineNo">675</span>    byte[] value3 = new byte[4096];<a name="line.675"></a>
+<span class="sourceLineNo">676</span>    for (long i = 0; i &lt; numRows; i++) {<a name="line.676"></a>
+<span class="sourceLineNo">677</span>      Put put = new Put(Hashing.md5().hashLong(i).asBytes());<a name="line.677"></a>
+<span class="sourceLineNo">678</span>      rand.setSeed(i);<a name="line.678"></a>
+<span class="sourceLineNo">679</span>      rand.nextBytes(value1);<a name="line.679"></a>
+<span class="sourceLineNo">680</span>      rand.nextBytes(value2);<a name="line.680"></a>
+<span class="sourceLineNo">681</span>      rand.nextBytes(value3);<a name="line.681"></a>
+<span class="sourceLineNo">682</span>      put.addColumn(FAMILY1, qf, value1);<a name="line.682"></a>
+<span class="sourceLineNo">683</span>      put.addColumn(FAMILY2, qf, value2);<a name="line.683"></a>
+<span class="sourceLineNo">684</span>      put.addColumn(FAMILY3, qf, value3);<a name="line.684"></a>
+<span class="sourceLineNo">685</span>      table.put(put);<a name="line.685"></a>
+<span class="sourceLineNo">686</span>      if (i % 10000 == 0) {<a name="line.686"></a>
+<span class="sourceLineNo">687</span>        LOG.info(i + " rows put");<a name="line.687"></a>
+<span class="sourceLineNo">688</span>      }<a name="line.688"></a>
+<span class="sourceLineNo">689</span>    }<a name="line.689"></a>
+<span class="sourceLineNo">690</span>    table.close();<a name="line.690"></a>
+<span class="sourceLineNo">691</span>    conn.close();<a name="line.691"></a>
+<span class="sourceLineNo">692</span>  }<a name="line.692"></a>
+<span class="sourceLineNo">693</span>}<a name="line.693"></a>
 
 
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/testdevapidocs/src-html/org/apache/hadoop/hbase/rsgroup/TestEnableRSGroup.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/rsgroup/TestEnableRSGroup.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/rsgroup/TestEnableRSGroup.html
index a4f682c..754450b 100644
--- a/testdevapidocs/src-html/org/apache/hadoop/hbase/rsgroup/TestEnableRSGroup.html
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/rsgroup/TestEnableRSGroup.html
@@ -74,32 +74,33 @@
 <span class="sourceLineNo">066</span>  @Test<a name="line.66"></a>
 <span class="sourceLineNo">067</span>  public void testEnableRSGroup() throws IOException, InterruptedException {<a name="line.67"></a>
 <span class="sourceLineNo">068</span>    TEST_UTIL.getMiniHBaseCluster().stopMaster(0);<a name="line.68"></a>
-<span class="sourceLineNo">069</span><a name="line.69"></a>
-<span class="sourceLineNo">070</span>    LOG.info("stopped master...");<a name="line.70"></a>
-<span class="sourceLineNo">071</span>    conf.set(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, RSGroupAdminEndpoint.class.getName());<a name="line.71"></a>
-<span class="sourceLineNo">072</span>    conf.set(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, RSGroupBasedLoadBalancer.class.getName());<a name="line.72"></a>
-<span class="sourceLineNo">073</span>    TEST_UTIL.getMiniHBaseCluster().setConf(conf);<a name="line.73"></a>
-<span class="sourceLineNo">074</span><a name="line.74"></a>
-<span class="sourceLineNo">075</span>    TEST_UTIL.getMiniHBaseCluster().startMaster();<a name="line.75"></a>
-<span class="sourceLineNo">076</span>    TEST_UTIL.getMiniHBaseCluster().waitForActiveAndReadyMaster(60000);<a name="line.76"></a>
-<span class="sourceLineNo">077</span>    LOG.info("started master...");<a name="line.77"></a>
-<span class="sourceLineNo">078</span><a name="line.78"></a>
-<span class="sourceLineNo">079</span>    // check if master started successfully<a name="line.79"></a>
-<span class="sourceLineNo">080</span>    assertTrue(TEST_UTIL.getMiniHBaseCluster().getMaster() != null);<a name="line.80"></a>
-<span class="sourceLineNo">081</span><a name="line.81"></a>
-<span class="sourceLineNo">082</span>    // wait RSGroupBasedLoadBalancer online<a name="line.82"></a>
-<span class="sourceLineNo">083</span>    RSGroupBasedLoadBalancer loadBalancer =<a name="line.83"></a>
-<span class="sourceLineNo">084</span>        (RSGroupBasedLoadBalancer) TEST_UTIL.getMiniHBaseCluster().getMaster().getLoadBalancer();<a name="line.84"></a>
-<span class="sourceLineNo">085</span>    long start = System.currentTimeMillis();<a name="line.85"></a>
-<span class="sourceLineNo">086</span>    while (System.currentTimeMillis() - start &lt;= 60000 &amp;&amp; !loadBalancer.isOnline()) {<a name="line.86"></a>
-<span class="sourceLineNo">087</span>      LOG.info("waiting for rsgroup load balancer onLine...");<a name="line.87"></a>
-<span class="sourceLineNo">088</span>      sleep(200);<a name="line.88"></a>
-<span class="sourceLineNo">089</span>    }<a name="line.89"></a>
-<span class="sourceLineNo">090</span><a name="line.90"></a>
-<span class="sourceLineNo">091</span>    assertTrue(loadBalancer.isOnline());<a name="line.91"></a>
-<span class="sourceLineNo">092</span>  }<a name="line.92"></a>
-<span class="sourceLineNo">093</span><a name="line.93"></a>
-<span class="sourceLineNo">094</span>}<a name="line.94"></a>
+<span class="sourceLineNo">069</span>    TEST_UTIL.getMiniHBaseCluster().waitOnMaster(0);<a name="line.69"></a>
+<span class="sourceLineNo">070</span><a name="line.70"></a>
+<span class="sourceLineNo">071</span>    LOG.info("stopped master...");<a name="line.71"></a>
+<span class="sourceLineNo">072</span>    conf.set(CoprocessorHost.MASTER_COPROCESSOR_CONF_KEY, RSGroupAdminEndpoint.class.getName());<a name="line.72"></a>
+<span class="sourceLineNo">073</span>    conf.set(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, RSGroupBasedLoadBalancer.class.getName());<a name="line.73"></a>
+<span class="sourceLineNo">074</span>    TEST_UTIL.getMiniHBaseCluster().setConf(conf);<a name="line.74"></a>
+<span class="sourceLineNo">075</span><a name="line.75"></a>
+<span class="sourceLineNo">076</span>    TEST_UTIL.getMiniHBaseCluster().startMaster();<a name="line.76"></a>
+<span class="sourceLineNo">077</span>    TEST_UTIL.getMiniHBaseCluster().waitForActiveAndReadyMaster(60000);<a name="line.77"></a>
+<span class="sourceLineNo">078</span>    LOG.info("started master...");<a name="line.78"></a>
+<span class="sourceLineNo">079</span><a name="line.79"></a>
+<span class="sourceLineNo">080</span>    // check if master started successfully<a name="line.80"></a>
+<span class="sourceLineNo">081</span>    assertTrue(TEST_UTIL.getMiniHBaseCluster().getMaster() != null);<a name="line.81"></a>
+<span class="sourceLineNo">082</span><a name="line.82"></a>
+<span class="sourceLineNo">083</span>    // wait RSGroupBasedLoadBalancer online<a name="line.83"></a>
+<span class="sourceLineNo">084</span>    RSGroupBasedLoadBalancer loadBalancer =<a name="line.84"></a>
+<span class="sourceLineNo">085</span>        (RSGroupBasedLoadBalancer) TEST_UTIL.getMiniHBaseCluster().getMaster().getLoadBalancer();<a name="line.85"></a>
+<span class="sourceLineNo">086</span>    long start = System.currentTimeMillis();<a name="line.86"></a>
+<span class="sourceLineNo">087</span>    while (System.currentTimeMillis() - start &lt;= 60000 &amp;&amp; !loadBalancer.isOnline()) {<a name="line.87"></a>
+<span class="sourceLineNo">088</span>      LOG.info("waiting for rsgroup load balancer onLine...");<a name="line.88"></a>
+<span class="sourceLineNo">089</span>      sleep(200);<a name="line.89"></a>
+<span class="sourceLineNo">090</span>    }<a name="line.90"></a>
+<span class="sourceLineNo">091</span><a name="line.91"></a>
+<span class="sourceLineNo">092</span>    assertTrue(loadBalancer.isOnline());<a name="line.92"></a>
+<span class="sourceLineNo">093</span>  }<a name="line.93"></a>
+<span class="sourceLineNo">094</span><a name="line.94"></a>
+<span class="sourceLineNo">095</span>}<a name="line.95"></a>
 
 
 


[03/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
index fd7ab7a..021207f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
@@ -147,1891 +147,1901 @@
 <span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
 <span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
 <span class="sourceLineNo">141</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.150"></a>
-<span class="sourceLineNo">151</span> */<a name="line.151"></a>
-<span class="sourceLineNo">152</span>@InterfaceAudience.Private<a name="line.152"></a>
-<span class="sourceLineNo">153</span>public class ThriftServerRunner implements Runnable {<a name="line.153"></a>
-<span class="sourceLineNo">154</span><a name="line.154"></a>
-<span class="sourceLineNo">155</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.155"></a>
-<span class="sourceLineNo">156</span><a name="line.156"></a>
-<span class="sourceLineNo">157</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.157"></a>
-<span class="sourceLineNo">158</span><a name="line.158"></a>
-<span class="sourceLineNo">159</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      "hbase.regionserver.thrift.server.type";<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.164"></a>
-<span class="sourceLineNo">165</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.167"></a>
-<span class="sourceLineNo">168</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.169"></a>
-<span class="sourceLineNo">170</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.170"></a>
-<span class="sourceLineNo">171</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.171"></a>
-<span class="sourceLineNo">172</span><a name="line.172"></a>
-<span class="sourceLineNo">173</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.174"></a>
-<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.175"></a>
-<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.177"></a>
-<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.179"></a>
-<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * applies only to TBoundedThreadPoolServer<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Splitter;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.147"></a>
+<span class="sourceLineNo">148</span><a name="line.148"></a>
+<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> */<a name="line.152"></a>
+<span class="sourceLineNo">153</span>@InterfaceAudience.Private<a name="line.153"></a>
+<span class="sourceLineNo">154</span>public class ThriftServerRunner implements Runnable {<a name="line.154"></a>
+<span class="sourceLineNo">155</span><a name="line.155"></a>
+<span class="sourceLineNo">156</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      "hbase.regionserver.thrift.server.type";<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.164"></a>
+<span class="sourceLineNo">165</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.169"></a>
+<span class="sourceLineNo">170</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.176"></a>
+<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  /**<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * applies only to TBoundedThreadPoolServer<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   */<a name="line.187"></a>
+<span class="sourceLineNo">188</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.188"></a>
+<span class="sourceLineNo">189</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.190"></a>
 <span class="sourceLineNo">191</span><a name="line.191"></a>
-<span class="sourceLineNo">192</span>  /**<a name="line.192"></a>
-<span class="sourceLineNo">193</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * auth-int: authentication and integrity checking<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * auth: authentication only<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   *<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * This is used to authenticate the callers and support impersonation.<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   */<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  public static final int HREGION_VERSION = 1;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private final int listenPort;<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  private Configuration conf;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>  volatile TServer tserver;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  volatile Server httpServer;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>  private final Hbase.Iface handler;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  private final ThriftMetrics metrics;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  private final HBaseHandler hbaseHandler;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  private final UserGroupInformation realUser;<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private SaslUtil.QualityOfProtection qop;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private String host;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  private final boolean securityEnabled;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  private final boolean doAsEnabled;<a name="line.222"></a>
-<span class="sourceLineNo">223</span><a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  /** An enum of server implementation selections */<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  enum ImplType {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.230"></a>
-<span class="sourceLineNo">231</span>    THREADED_SELECTOR(<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.232"></a>
-<span class="sourceLineNo">233</span><a name="line.233"></a>
-<span class="sourceLineNo">234</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>    final String option;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    final boolean isAlwaysFramed;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>    final boolean canSpecifyBindIP;<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>    ImplType(String option, boolean isAlwaysFramed,<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      this.option = option;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>      this.serverClass = serverClass;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>    /**<a name="line.249"></a>
-<span class="sourceLineNo">250</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.250"></a>
-<span class="sourceLineNo">251</span>     *         {@link #values()}<a name="line.251"></a>
-<span class="sourceLineNo">252</span>     */<a name="line.252"></a>
-<span class="sourceLineNo">253</span>    @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>    public String toString() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>      return "-" + option;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>    }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>    String getDescription() {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.259"></a>
-<span class="sourceLineNo">260</span>          serverClass.getSimpleName());<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      if (isAlwaysFramed) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span>        sb.append(" This implies the framed transport.");<a name="line.262"></a>
-<span class="sourceLineNo">263</span>      }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      if (this == DEFAULT) {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>        sb.append("This is the default.");<a name="line.265"></a>
-<span class="sourceLineNo">266</span>      }<a name="line.266"></a>
-<span class="sourceLineNo">267</span>      return sb.toString();<a name="line.267"></a>
-<span class="sourceLineNo">268</span>    }<a name="line.268"></a>
-<span class="sourceLineNo">269</span><a name="line.269"></a>
-<span class="sourceLineNo">270</span>    static OptionGroup createOptionGroup() {<a name="line.270"></a>
-<span class="sourceLineNo">271</span>      OptionGroup group = new OptionGroup();<a name="line.271"></a>
-<span class="sourceLineNo">272</span>      for (ImplType t : values()) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>      }<a name="line.274"></a>
-<span class="sourceLineNo">275</span>      return group;<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    }<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>    static ImplType getServerImpl(Configuration conf) {<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.279"></a>
-<span class="sourceLineNo">280</span>      for (ImplType t : values()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span>        if (confType.equals(t.option)) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>          return t;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>        }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      }<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>      ImplType chosenType = null;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      int numChosen = 0;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>      for (ImplType t : values()) {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        if (cmd.hasOption(t.option)) {<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          chosenType = t;<a name="line.293"></a>
-<span class="sourceLineNo">294</span>          ++numChosen;<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        }<a name="line.295"></a>
-<span class="sourceLineNo">296</span>      }<a name="line.296"></a>
-<span class="sourceLineNo">297</span>      if (numChosen &lt; 1) {<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        LOG.info("Using default thrift server type");<a name="line.298"></a>
-<span class="sourceLineNo">299</span>        chosenType = DEFAULT;<a name="line.299"></a>
-<span class="sourceLineNo">300</span>      } else if (numChosen &gt; 1) {<a name="line.300"></a>
-<span class="sourceLineNo">301</span>        throw new AssertionError("Exactly one option out of " +<a name="line.301"></a>
-<span class="sourceLineNo">302</span>          Arrays.toString(values()) + " has to be specified");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>      }<a name="line.303"></a>
-<span class="sourceLineNo">304</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.304"></a>
-<span class="sourceLineNo">305</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    }<a name="line.306"></a>
-<span class="sourceLineNo">307</span><a name="line.307"></a>
-<span class="sourceLineNo">308</span>    public String simpleClassName() {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      return serverClass.getSimpleName();<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.313"></a>
-<span class="sourceLineNo">314</span>      for (ImplType t : values()) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>        if (!t.canSpecifyBindIP) {<a name="line.315"></a>
-<span class="sourceLineNo">316</span>          l.add(t.simpleClassName());<a name="line.316"></a>
-<span class="sourceLineNo">317</span>        }<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      }<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      return l;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>    }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  }<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.324"></a>
-<span class="sourceLineNo">325</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.325"></a>
-<span class="sourceLineNo">326</span>    // login the server principal (if using secure Hadoop)<a name="line.326"></a>
-<span class="sourceLineNo">327</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.327"></a>
-<span class="sourceLineNo">328</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.328"></a>
-<span class="sourceLineNo">329</span>    if (securityEnabled) {<a name="line.329"></a>
-<span class="sourceLineNo">330</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.330"></a>
-<span class="sourceLineNo">331</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.333"></a>
-<span class="sourceLineNo">334</span>        "hbase.thrift.kerberos.principal", host);<a name="line.334"></a>
-<span class="sourceLineNo">335</span>    }<a name="line.335"></a>
-<span class="sourceLineNo">336</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.336"></a>
-<span class="sourceLineNo">337</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.338"></a>
-<span class="sourceLineNo">339</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.340"></a>
-<span class="sourceLineNo">341</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.341"></a>
-<span class="sourceLineNo">342</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      hbaseHandler, metrics, conf);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    if (strQop != null) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    }<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    if (doAsEnabled) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.351"></a>
-<span class="sourceLineNo">352</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.352"></a>
-<span class="sourceLineNo">353</span>                "configured ");<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      }<a name="line.354"></a>
-<span class="sourceLineNo">355</span>    }<a name="line.355"></a>
-<span class="sourceLineNo">356</span>    if (qop != null) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.360"></a>
-<span class="sourceLineNo">361</span>                              THRIFT_QOP_KEY,<a name="line.361"></a>
-<span class="sourceLineNo">362</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.362"></a>
-<span class="sourceLineNo">363</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.363"></a>
-<span class="sourceLineNo">364</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      }<a name="line.365"></a>
-<span class="sourceLineNo">366</span>      checkHttpSecurity(qop, conf);<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      if (!securityEnabled) {<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        throw new IOException("Thrift server must"<a name="line.368"></a>
-<span class="sourceLineNo">369</span>          + " run in secure mode to support authentication");<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
-<span class="sourceLineNo">371</span>    }<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
-<span class="sourceLineNo">373</span><a name="line.373"></a>
-<span class="sourceLineNo">374</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.375"></a>
-<span class="sourceLineNo">376</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.376"></a>
-<span class="sourceLineNo">377</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.378"></a>
-<span class="sourceLineNo">379</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.379"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * auth-int: authentication and integrity checking<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * auth: authentication only<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   *<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   * This is used to authenticate the callers and support impersonation.<a name="line.199"></a>
+<span class="sourceLineNo">200</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.200"></a>
+<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
+<span class="sourceLineNo">202</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.203"></a>
+<span class="sourceLineNo">204</span><a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  public static final int HREGION_VERSION = 1;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  private final int listenPort;<a name="line.209"></a>
+<span class="sourceLineNo">210</span><a name="line.210"></a>
+<span class="sourceLineNo">211</span>  private Configuration conf;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>  volatile TServer tserver;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>  volatile Server httpServer;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  private final Hbase.Iface handler;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  private final ThriftMetrics metrics;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private final HBaseHandler hbaseHandler;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private final UserGroupInformation realUser;<a name="line.217"></a>
+<span class="sourceLineNo">218</span><a name="line.218"></a>
+<span class="sourceLineNo">219</span>  private SaslUtil.QualityOfProtection qop;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  private String host;<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span>  private final boolean securityEnabled;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private final boolean doAsEnabled;<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.225"></a>
+<span class="sourceLineNo">226</span><a name="line.226"></a>
+<span class="sourceLineNo">227</span>  /** An enum of server implementation selections */<a name="line.227"></a>
+<span class="sourceLineNo">228</span>  public enum ImplType {<a name="line.228"></a>
+<span class="sourceLineNo">229</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.231"></a>
+<span class="sourceLineNo">232</span>    THREADED_SELECTOR(<a name="line.232"></a>
+<span class="sourceLineNo">233</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.233"></a>
+<span class="sourceLineNo">234</span><a name="line.234"></a>
+<span class="sourceLineNo">235</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.235"></a>
+<span class="sourceLineNo">236</span><a name="line.236"></a>
+<span class="sourceLineNo">237</span>    final String option;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>    final boolean isAlwaysFramed;<a name="line.238"></a>
+<span class="sourceLineNo">239</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    final boolean canSpecifyBindIP;<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span>    private ImplType(String option, boolean isAlwaysFramed,<a name="line.242"></a>
+<span class="sourceLineNo">243</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span>      this.option = option;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>      this.serverClass = serverClass;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>    }<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span>    /**<a name="line.250"></a>
+<span class="sourceLineNo">251</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.251"></a>
+<span class="sourceLineNo">252</span>     *         {@link #values()}<a name="line.252"></a>
+<span class="sourceLineNo">253</span>     */<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    @Override<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    public String toString() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>      return "-" + option;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>    }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>    public String getOption() {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>      return option;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>    }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>    public boolean isAlwaysFramed() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>      return isAlwaysFramed;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    }<a name="line.265"></a>
+<span class="sourceLineNo">266</span><a name="line.266"></a>
+<span class="sourceLineNo">267</span>    public String getDescription() {<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.268"></a>
+<span class="sourceLineNo">269</span>          serverClass.getSimpleName());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>      if (isAlwaysFramed) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span>        sb.append(" This implies the framed transport.");<a name="line.271"></a>
+<span class="sourceLineNo">272</span>      }<a name="line.272"></a>
+<span class="sourceLineNo">273</span>      if (this == DEFAULT) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>        sb.append("This is the default.");<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      }<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      return sb.toString();<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    }<a name="line.277"></a>
+<span class="sourceLineNo">278</span><a name="line.278"></a>
+<span class="sourceLineNo">279</span>    static OptionGroup createOptionGroup() {<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      OptionGroup group = new OptionGroup();<a name="line.280"></a>
+<span class="sourceLineNo">281</span>      for (ImplType t : values()) {<a name="line.281"></a>
+<span class="sourceLineNo">282</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.282"></a>
+<span class="sourceLineNo">283</span>      }<a name="line.283"></a>
+<span class="sourceLineNo">284</span>      return group;<a name="line.284"></a>
+<span class="sourceLineNo">285</span>    }<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>    public static ImplType getServerImpl(Configuration conf) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      for (ImplType t : values()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>        if (confType.equals(t.option)) {<a name="line.290"></a>
+<span class="sourceLineNo">291</span>          return t;<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        }<a name="line.292"></a>
+<span class="sourceLineNo">293</span>      }<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.294"></a>
+<span class="sourceLineNo">295</span>    }<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      ImplType chosenType = null;<a name="line.298"></a>
+<span class="sourceLineNo">299</span>      int numChosen = 0;<a name="line.299"></a>
+<span class="sourceLineNo">300</span>      for (ImplType t : values()) {<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        if (cmd.hasOption(t.option)) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span>          chosenType = t;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>          ++numChosen;<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        }<a name="line.304"></a>
+<span class="sourceLineNo">305</span>      }<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      if (numChosen &lt; 1) {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>        LOG.info("Using default thrift server type");<a name="line.307"></a>
+<span class="sourceLineNo">308</span>        chosenType = DEFAULT;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>      } else if (numChosen &gt; 1) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>        throw new AssertionError("Exactly one option out of " +<a name="line.310"></a>
+<span class="sourceLineNo">311</span>          Arrays.toString(values()) + " has to be specified");<a name="line.311"></a>
+<span class="sourceLineNo">312</span>      }<a name="line.312"></a>
+<span class="sourceLineNo">313</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.313"></a>
+<span class="sourceLineNo">314</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.314"></a>
+<span class="sourceLineNo">315</span>    }<a name="line.315"></a>
+<span class="sourceLineNo">316</span><a name="line.316"></a>
+<span class="sourceLineNo">317</span>    public String simpleClassName() {<a name="line.317"></a>
+<span class="sourceLineNo">318</span>      return serverClass.getSimpleName();<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    }<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.322"></a>
+<span class="sourceLineNo">323</span>      for (ImplType t : values()) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>        if (!t.canSpecifyBindIP) {<a name="line.324"></a>
+<span class="sourceLineNo">325</span>          l.add(t.simpleClassName());<a name="line.325"></a>
+<span class="sourceLineNo">326</span>        }<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      }<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      return l;<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    }<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.333"></a>
+<span class="sourceLineNo">334</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    // login the server principal (if using secure Hadoop)<a name="line.335"></a>
+<span class="sourceLineNo">336</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.336"></a>
+<span class="sourceLineNo">337</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    if (securityEnabled) {<a name="line.338"></a>
+<span class="sourceLineNo">339</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.339"></a>
+<span class="sourceLineNo">340</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.340"></a>
+<span class="sourceLineNo">341</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.341"></a>
+<span class="sourceLineNo">342</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.342"></a>
+<span class="sourceLineNo">343</span>        "hbase.thrift.kerberos.principal", host);<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    }<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.345"></a>
+<span class="sourceLineNo">346</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.349"></a>
+<span class="sourceLineNo">350</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      hbaseHandler, metrics, conf);<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.354"></a>
+<span class="sourceLineNo">355</span>    if (strQop != null) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    }<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    if (doAsEnabled) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.360"></a>
+<span class="sourceLineNo">361</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.361"></a>
+<span class="sourceLineNo">362</span>                "configured ");<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      }<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    }<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    if (qop != null) {<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.369"></a>
+<span class="sourceLineNo">370</span>                              THRIFT_QOP_KEY,<a name="line.370"></a>
+<span class="sourceLineNo">371</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.371"></a>
+<span class="sourceLineNo">372</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.372"></a>
+<span class="sourceLineNo">373</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      }<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      checkHttpSecurity(qop, conf);<a name="line.375"></a>
+<span class="sourceLineNo">376</span>      if (!securityEnabled) {<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        throw new IOException("Thrift server must"<a name="line.377"></a>
+<span class="sourceLineNo">378</span>          + " run in secure mode to support authentication");<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      }<a name="line.379"></a>
 <span class="sourceLineNo">380</span>    }<a name="line.380"></a>
 <span class="sourceLineNo">381</span>  }<a name="line.381"></a>
 <span class="sourceLineNo">382</span><a name="line.382"></a>
-<span class="sourceLineNo">383</span>  /*<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * Runs the Thrift server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
-<span class="sourceLineNo">387</span>  public void run() {<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      @Override<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      public Object run() {<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        try {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>          pauseMonitor.start();<a name="line.392"></a>
-<span class="sourceLineNo">393</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            setupHTTPServer();<a name="line.394"></a>
-<span class="sourceLineNo">395</span>            httpServer.start();<a name="line.395"></a>
-<span class="sourceLineNo">396</span>            httpServer.join();<a name="line.396"></a>
-<span class="sourceLineNo">397</span>          } else {<a name="line.397"></a>
-<span class="sourceLineNo">398</span>            setupServer();<a name="line.398"></a>
-<span class="sourceLineNo">399</span>            tserver.serve();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>          }<a name="line.400"></a>
-<span class="sourceLineNo">401</span>        } catch (Exception e) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>          // Crash the process if the ThriftServer is not running<a name="line.403"></a>
-<span class="sourceLineNo">404</span>          System.exit(-1);<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        }<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        return null;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      }<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    });<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  }<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>  public void shutdown() {<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    if (pauseMonitor != null) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      pauseMonitor.stop();<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    }<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    if (tserver != null) {<a name="line.416"></a>
-<span class="sourceLineNo">417</span>      tserver.stop();<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      tserver = null;<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    if (httpServer != null) {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      try {<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        httpServer.stop();<a name="line.422"></a>
-<span class="sourceLineNo">423</span>        httpServer = null;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      } catch (Exception e) {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      }<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      httpServer = null;<a name="line.427"></a>
+<span class="sourceLineNo">383</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.383"></a>
+<span class="sourceLineNo">384</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.384"></a>
+<span class="sourceLineNo">385</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.385"></a>
+<span class="sourceLineNo">386</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.387"></a>
+<span class="sourceLineNo">388</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  }<a name="line.390"></a>
+<span class="sourceLineNo">391</span><a name="line.391"></a>
+<span class="sourceLineNo">392</span>  /*<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * Runs the Thrift server<a name="line.393"></a>
+<span class="sourceLineNo">394</span>   */<a name="line.394"></a>
+<span class="sourceLineNo">395</span>  @Override<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  public void run() {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      @Override<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      public Object run() {<a name="line.399"></a>
+<span class="sourceLineNo">400</span>        try {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>          pauseMonitor.start();<a name="line.401"></a>
+<span class="sourceLineNo">402</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>            setupHTTPServer();<a name="line.403"></a>
+<span class="sourceLineNo">404</span>            httpServer.start();<a name="line.404"></a>
+<span class="sourceLineNo">405</span>            httpServer.join();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>          } else {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>            setupServer();<a name="line.407"></a>
+<span class="sourceLineNo">408</span>            tserver.serve();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>          }<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        } catch (Exception e) {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>          // Crash the process if the ThriftServer is not running<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          System.exit(-1);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        return null;<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      }<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    });<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public void shutdown() {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    if (pauseMonitor != null) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      pauseMonitor.stop();<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    }<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    if (tserver != null) {<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      tserver.stop();<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      tserver = null;<a name="line.427"></a>
 <span class="sourceLineNo">428</span>    }<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private void setupHTTPServer() throws IOException {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.434"></a>
-<span class="sourceLineNo">435</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.435"></a>
-<span class="sourceLineNo">436</span><a name="line.436"></a>
-<span class="sourceLineNo">437</span>    // Set the default max thread number to 100 to limit<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.439"></a>
-<span class="sourceLineNo">440</span>    //<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.442"></a>
-<span class="sourceLineNo">443</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.443"></a>
-<span class="sourceLineNo">444</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.444"></a>
-<span class="sourceLineNo">445</span>    threadPool.setMinThreads(minThreads);<a name="line.445"></a>
-<span class="sourceLineNo">446</span>    httpServer = new Server(threadPool);<a name="line.446"></a>
-<span class="sourceLineNo">447</span><a name="line.447"></a>
-<span class="sourceLineNo">448</span>    // Context handler<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.449"></a>
-<span class="sourceLineNo">450</span>            ServletContextHandler.SESSIONS);<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>    // set up Jetty and run the embedded server<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    httpConfig.setSecureScheme("https");<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    httpConfig.setSecurePort(listenPort);<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    httpConfig.setSendServerVersion(false);<a name="line.461"></a>
-<span class="sourceLineNo">462</span>    httpConfig.setSendDateHeader(false);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span>    ServerConnector serverConnector;<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.467"></a>
-<span class="sourceLineNo">468</span><a name="line.468"></a>
-<span class="sourceLineNo">469</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.470"></a>
-<span class="sourceLineNo">471</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.471"></a>
-<span class="sourceLineNo">472</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.473"></a>
-<span class="sourceLineNo">474</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.476"></a>
-<span class="sourceLineNo">477</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      String[] excludeCiphers = conf.getStrings(<a name="line.479"></a>
-<span class="sourceLineNo">480</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      if (excludeCiphers.length != 0) {<a name="line.481"></a>
-<span class="sourceLineNo">482</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      }<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      String[] includeCiphers = conf.getStrings(<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>      if (includeCiphers.length != 0) {<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>      }<a name="line.488"></a>
-<span class="sourceLineNo">489</span><a name="line.489"></a>
-<span class="sourceLineNo">490</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.490"></a>
-<span class="sourceLineNo">491</span>      String[] excludeProtocols = conf.getStrings(<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.492"></a>
-<span class="sourceLineNo">493</span>      if (excludeProtocols.length != 0) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      }<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      String[] includeProtocols = conf.getStrings(<a name="line.496"></a>
-<span class="sourceLineNo">497</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      if (includeProtocols.length != 0) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      }<a name="line.500"></a>
-<span class="sourceLineNo">501</span><a name="line.501"></a>
-<span class="sourceLineNo">502</span>      serverConnector = new ServerConnector(httpServer,<a name="line.502"></a>
-<span class="sourceLineNo">503</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.503"></a>
-<span class="sourceLineNo">504</span>          new HttpConnectionFactory(httpsConfig));<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    } else {<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.506"></a>
-<span class="sourceLineNo">507</span>    }<a name="line.507"></a>
-<span class="sourceLineNo">508</span>    serverConnector.setPort(listenPort);<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    serverConnector.setHost(host);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    httpServer.addConnector(serverConnector);<a name="line.511"></a>
-<span class="sourceLineNo">512</span>    httpServer.setStopAtShutdown(true);<a name="line.512"></a>
-<span class="sourceLineNo">513</span><a name="line.513"></a>
-<span class="sourceLineNo">514</span>    if (doAsEnabled) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.515"></a>
+<span class="sourceLineNo">429</span>    if (httpServer != null) {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>      try {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        httpServer.stop();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        httpServer = null;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>      } catch (Exception e) {<a name="line.433"></a>
+<span class="sourceLineNo">434</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      }<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      httpServer = null;<a name="line.436"></a>
+<span class="sourceLineNo">437</span>    }<a name="line.437"></a>
+<span class="sourceLineNo">438</span>  }<a name="line.438"></a>
+<span class="sourceLineNo">439</span><a name="line.439"></a>
+<span class="sourceLineNo">440</span>  private void setupHTTPServer() throws IOException {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.442"></a>
+<span class="sourceLineNo">443</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.444"></a>
+<span class="sourceLineNo">445</span><a name="line.445"></a>
+<span class="sourceLineNo">446</span>    // Set the default max thread number to 100 to limit<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.448"></a>
+<span class="sourceLineNo">449</span>    //<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    threadPool.setMinThreads(minThreads);<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    httpServer = new Server(threadPool);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>    // Context handler<a name="line.457"></a>
+<span class="sourceLineNo">458</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.458"></a>
+<span class="sourceLineNo">459</span>            ServletContextHandler.SESSIONS);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.461"></a>
+<span class="sourceLineNo">462</span><a name="line.462"></a>
+<span class="sourceLineNo">463</span>    // set up Jetty and run the embedded server<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    httpConfig.setSecureScheme("https");<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    httpConfig.setSecurePort(listenPort);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    httpConfig.setSendServerVersion(false);<a name="line.470"></a>
+<span class="sourceLineNo">471</span>    httpConfig.setSendDateHeader(false);<a name="line.471"></a>
+<span class="sourceLineNo">472</span><a name="line.472"></a>
+<span class="sourceLineNo">473</span>    ServerConnector serverConnector;<a name="line.473"></a>
+<span class="sourceLineNo">474</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.476"></a>
+<span class="sourceLineNo">477</span><a name="line.477"></a>
+<span class="sourceLineNo">478</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.479"></a>
+<span class="sourceLineNo">480</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.482"></a>
+<span class="sourceLineNo">483</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.486"></a>
+<span class="sourceLineNo">487</span><a name="line.487"></a>
+<span class="sourceLineNo">488</span>      String[] excludeCiphers = conf.getStrings(<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>      if (excludeCiphers.length != 0) {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>      }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      String[] includeCiphers = conf.getStrings(<a name="line.493"></a>
+<span class="sourceLineNo">494</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      if (includeCiphers.length != 0) {<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      String[] excludeProtocols = conf.getStrings(<a name="line.500"></a>
+<span class="sourceLineNo">501</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      if (excludeProtocols.length != 0) {<a name="line.502"></a>
+<span class="sourceLineNo">503</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      }<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      String[] includeProtocols = conf.getStrings(<a name="line.505"></a>
+<span class="sourceLineNo">506</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.506"></a>
+<span class="sourceLineNo">507</span>      if (includeProtocols.length != 0) {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      }<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span>      serverConnector = new ServerConnector(httpServer,<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          new HttpConnectionFactory(httpsConfig));<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    } else {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.515"></a>
 <span class="sourceLineNo">516</span>    }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
-<span class="sourceLineNo">520</span><a name="line.520"></a>
-<span class="sourceLineNo">521</span>  /**<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * Setting up the thrift TServer<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   */<a name="line.523"></a>
-<span class="sourceLineNo">524</span>  private void setupServer() throws Exception {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>    // Construct correct ProtocolFactory<a name="line.525"></a>
-<span class="sourceLineNo">526</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.526"></a>
-<span class="sourceLineNo">527</span><a name="line.527"></a>
-<span class="sourceLineNo">528</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    TProcessor processor = p;<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>    // Construct correct TransportFactory<a name="line.532"></a>
-<span class="sourceLineNo">533</span>    TTransportFactory transportFactory;<a name="line.533"></a>
-<span class="sourceLineNo">534</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span>      if (qop != null) {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>        throw new RuntimeException("Thrift server authentication"<a name="line.536"></a>
-<span class="sourceLineNo">537</span>          + " doesn't work with framed transport yet");<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      }<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      transportFactory = new TFramedTransport.Factory(<a name="line.539"></a>
-<span class="sourceLineNo">540</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      LOG.debug("Using framed transport");<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    } else if (qop == null) {<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      transportFactory = new TTransportFactory();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>    } else {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      // Extract the name from the principal<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.546"></a>
-<span class="sourceLineNo">547</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        new SaslGssCallbackHandler() {<a name="line.551"></a>
-<span class="sourceLineNo">552</span>          @Override<a name="line.552"></a>
-<span class="sourceLineNo">553</span>          public void handle(Callback[] callbacks)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>              throws UnsupportedCallbackException {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>            AuthorizeCallback ac = null;<a name="line.555"></a>
-<span class="sourceLineNo">556</span>            for (Callback callback : callbacks) {<a name="line.556"></a>
-<span class="sourceLineNo">557</span>              if (callback instanceof AuthorizeCallback) {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>                ac = (AuthorizeCallback) callback;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>              } else {<a name="line.559"></a>
-<span class="sourceLineNo">560</span>                throw new UnsupportedCallbackException(callback,<a name="line.560"></a>
-<span class="sourceLineNo">561</span>                    "Unrecognized SASL GSSAPI Callback");<a name="line.561"></a>
-<span class="sourceLineNo">562</span>              }<a name="line.562"></a>
-<span class="sourceLineNo">563</span>            }<a name="line.563"></a>
-<span class="sourceLineNo">564</span>            if (ac != null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>              String authid = ac.getAuthenticationID();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>              String authzid = ac.getAuthorizationID();<a name="line.566"></a>
-<span class="sourceLineNo">567</span>              if (!authid.equals(authzid)) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>                ac.setAuthorized(false);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>              } else {<a name="line.569"></a>
-<span class="sourceLineNo">570</span>                ac.setAuthorized(true);<a name="line.570"></a>
-<span class="sourceLineNo">571</span>                String userName = SecurityUtil.getUserFromPrincipal(authzid);<a name="line.571"></a>
-<span class="sourceLineNo">572</span>                LOG.info("Effective user: " + userName);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>                ac.setAuthorizedID(userName);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>              }<a name="line.574"></a>
-<span class="sourceLineNo">575</span>            }<a name="line.575"></a>
-<span class="sourceLineNo">576</span>          }<a name="line.576"></a>
-<span class="sourceLineNo">577</span>        });<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      transportFactory = saslFactory;<a name="line.578"></a>
-<span class="sourceLineNo">579</span><a name="line.579"></a>
-<span class="sourceLineNo">580</span>      // Create a processor wrapper, to get the caller<a name="line.580"></a>
-<span class="sourceLineNo">581</span>      processor = new TProcessor() {<a name="line.581"></a>
-<span class="sourceLineNo">582</span>        @Override<a name="line.582"></a>
-<span class="sourceLineNo">583</span>        public boolean process(TProtocol inProt,<a name="line.583"></a>
-<span class="sourceLineNo">584</span>            TProtocol outProt) throws TException {<a name="line.584"></a>
-<span class="sourceLineNo">585</span>          TSaslServerTransport saslServerTransport =<a name="line.585"></a>
-<span class="sourceLineNo">586</span>            (TSaslServerTransport)inProt.getTransport();<a name="line.586"></a>
-<span class="sourceLineNo">587</span>          SaslServer saslServer = saslServerTransport.getSaslServer();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>          String principal = saslServer.getAuthorizationID();<a name="line.588"></a>
-<span class="sourceLineNo">589</span>          hbaseHandler.setEffectiveUser(principal);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>          return p.process(inProt, outProt);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        }<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      };<a name="line.592"></a>
-<span class="sourceLineNo">593</span>    }<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    if (conf.get(BIND_CONF_KEY) != null &amp;&amp; !implType.canSpecifyBindIP) {<a name="line.595"></a>
-<span class="sourceLineNo">596</span>      LOG.error("Server types " + Joiner.on(", ").join(<a name="line.596"></a>
-<span class="sourceLineNo">597</span>          ImplType.serversThatCannotSpecifyBindIP()) + " don't support IP " +<a name="line.597"></a>
-<span class="sourceLineNo">598</span>          "address binding at the moment. See " +<a name="line.598"></a>
-<span class="sourceLineNo">599</span>          "https://issues.apache.org/jira/browse/HBASE-2155 for details.");<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      throw new RuntimeException(<a name="line.600"></a>
-<span class="sourceLineNo">601</span>          "-" + BIND_CONF_KEY + " not supported with " + implType);<a name="line.601"></a>
+<span class="sourceLineNo">517</span>    serverConnector.setPort(listenPort);<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    serverConnector.setHost(host);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>    httpServer.addConnector(serverConnector);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>    httpServer.setStopAtShutdown(true);<a name="line.521"></a>
+<span class="sourceLineNo">522</span><a name="line.522"></a>
+<span class="sourceLineNo">523</span>    if (doAsEnabled) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.524"></a>
+<span class="sourceLineNo">525</span>    }<a name="line.525"></a>
+<span class="sourceLineNo">526</span><a name="line.526"></a>
+<span class="sourceLineNo">527</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.527"></a>
+<span class="sourceLineNo">528</span>  }<a name="line.528"></a>
+<span class="sourceLineNo">529</span><a name="line.529"></a>
+<span class="sourceLineNo">530</span>  /**<a name="line.530"></a>
+<span class="sourceLineNo">531</span>   * Setting up the thrift TServer<a name="line.531"></a>
+<span class="sourceLineNo">532</span>   */<a name="line.532"></a>
+<span class="sourceLineNo">533</span>  private void setupServer() throws Exception {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>    // Construct correct ProtocolFactory<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    TProcessor processor = p;<a name="line.539"></a>
+<span class="sourceLineNo">540</span><a name="line.540"></a>
+<span class="sourceLineNo">541</span>    // Construct correct TransportFactory<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    TTransportFactory transportFactory;<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      if (qop != null) {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>        throw new RuntimeException("Thrift server authentication"<a name="line.545"></a>
+<span class="sourceLineNo">546</span>          + " doesn't work with framed transport yet");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      }<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      transportFactory = new TFramedTransport.Factory(<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      LOG.debug("Using framed transport");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>    } else if (qop == null) {<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      transportFactory = new TTransportFactory();<a name="line.552"></a>
+<span class="sourceLineNo">553</span>    } else {<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Extract the name from the principal<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.555"></a>
+<span class="sourceLineNo">556</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.557"></a>
+<span class="sourceLineNo">558</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.559"></a>
+<span class="sourceLineNo">560</span>        new SaslGssCallbackHandler() {<a name="line.560"></a>
+<span class="sourceLineNo">561</span>          @Override<a name="line.561"></a>
+<span class="sourceLineNo">562</span>          public void handle(Callback[] callbacks)<a name="line.562"></a>
+<span class="sourceLineNo">563</span>              throws UnsupportedCallbackException {<a name="line.563"></a>
+<span class="sourceLineNo">564</span>            AuthorizeCallback ac = null;<a name="line.564"></a>
+<span class="sourceLineNo">565</sp

<TRUNCATED>

[06/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
index fd7ab7a..021207f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
@@ -147,1891 +147,1901 @@
 <span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
 <span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
 <span class="sourceLineNo">141</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.150"></a>
-<span class="sourceLineNo">151</span> */<a name="line.151"></a>
-<span class="sourceLineNo">152</span>@InterfaceAudience.Private<a name="line.152"></a>
-<span class="sourceLineNo">153</span>public class ThriftServerRunner implements Runnable {<a name="line.153"></a>
-<span class="sourceLineNo">154</span><a name="line.154"></a>
-<span class="sourceLineNo">155</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.155"></a>
-<span class="sourceLineNo">156</span><a name="line.156"></a>
-<span class="sourceLineNo">157</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.157"></a>
-<span class="sourceLineNo">158</span><a name="line.158"></a>
-<span class="sourceLineNo">159</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      "hbase.regionserver.thrift.server.type";<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.164"></a>
-<span class="sourceLineNo">165</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.167"></a>
-<span class="sourceLineNo">168</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.169"></a>
-<span class="sourceLineNo">170</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.170"></a>
-<span class="sourceLineNo">171</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.171"></a>
-<span class="sourceLineNo">172</span><a name="line.172"></a>
-<span class="sourceLineNo">173</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.174"></a>
-<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.175"></a>
-<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.177"></a>
-<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.179"></a>
-<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * applies only to TBoundedThreadPoolServer<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Splitter;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.147"></a>
+<span class="sourceLineNo">148</span><a name="line.148"></a>
+<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> */<a name="line.152"></a>
+<span class="sourceLineNo">153</span>@InterfaceAudience.Private<a name="line.153"></a>
+<span class="sourceLineNo">154</span>public class ThriftServerRunner implements Runnable {<a name="line.154"></a>
+<span class="sourceLineNo">155</span><a name="line.155"></a>
+<span class="sourceLineNo">156</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      "hbase.regionserver.thrift.server.type";<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.164"></a>
+<span class="sourceLineNo">165</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.169"></a>
+<span class="sourceLineNo">170</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.176"></a>
+<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  /**<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * applies only to TBoundedThreadPoolServer<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   */<a name="line.187"></a>
+<span class="sourceLineNo">188</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.188"></a>
+<span class="sourceLineNo">189</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.190"></a>
 <span class="sourceLineNo">191</span><a name="line.191"></a>
-<span class="sourceLineNo">192</span>  /**<a name="line.192"></a>
-<span class="sourceLineNo">193</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * auth-int: authentication and integrity checking<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * auth: authentication only<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   *<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * This is used to authenticate the callers and support impersonation.<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   */<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  public static final int HREGION_VERSION = 1;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private final int listenPort;<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  private Configuration conf;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>  volatile TServer tserver;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  volatile Server httpServer;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>  private final Hbase.Iface handler;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  private final ThriftMetrics metrics;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  private final HBaseHandler hbaseHandler;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  private final UserGroupInformation realUser;<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private SaslUtil.QualityOfProtection qop;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private String host;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  private final boolean securityEnabled;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  private final boolean doAsEnabled;<a name="line.222"></a>
-<span class="sourceLineNo">223</span><a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  /** An enum of server implementation selections */<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  enum ImplType {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.230"></a>
-<span class="sourceLineNo">231</span>    THREADED_SELECTOR(<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.232"></a>
-<span class="sourceLineNo">233</span><a name="line.233"></a>
-<span class="sourceLineNo">234</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>    final String option;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    final boolean isAlwaysFramed;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>    final boolean canSpecifyBindIP;<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>    ImplType(String option, boolean isAlwaysFramed,<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      this.option = option;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>      this.serverClass = serverClass;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>    /**<a name="line.249"></a>
-<span class="sourceLineNo">250</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.250"></a>
-<span class="sourceLineNo">251</span>     *         {@link #values()}<a name="line.251"></a>
-<span class="sourceLineNo">252</span>     */<a name="line.252"></a>
-<span class="sourceLineNo">253</span>    @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>    public String toString() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>      return "-" + option;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>    }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>    String getDescription() {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.259"></a>
-<span class="sourceLineNo">260</span>          serverClass.getSimpleName());<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      if (isAlwaysFramed) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span>        sb.append(" This implies the framed transport.");<a name="line.262"></a>
-<span class="sourceLineNo">263</span>      }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      if (this == DEFAULT) {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>        sb.append("This is the default.");<a name="line.265"></a>
-<span class="sourceLineNo">266</span>      }<a name="line.266"></a>
-<span class="sourceLineNo">267</span>      return sb.toString();<a name="line.267"></a>
-<span class="sourceLineNo">268</span>    }<a name="line.268"></a>
-<span class="sourceLineNo">269</span><a name="line.269"></a>
-<span class="sourceLineNo">270</span>    static OptionGroup createOptionGroup() {<a name="line.270"></a>
-<span class="sourceLineNo">271</span>      OptionGroup group = new OptionGroup();<a name="line.271"></a>
-<span class="sourceLineNo">272</span>      for (ImplType t : values()) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>      }<a name="line.274"></a>
-<span class="sourceLineNo">275</span>      return group;<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    }<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>    static ImplType getServerImpl(Configuration conf) {<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.279"></a>
-<span class="sourceLineNo">280</span>      for (ImplType t : values()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span>        if (confType.equals(t.option)) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>          return t;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>        }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      }<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>      ImplType chosenType = null;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      int numChosen = 0;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>      for (ImplType t : values()) {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        if (cmd.hasOption(t.option)) {<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          chosenType = t;<a name="line.293"></a>
-<span class="sourceLineNo">294</span>          ++numChosen;<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        }<a name="line.295"></a>
-<span class="sourceLineNo">296</span>      }<a name="line.296"></a>
-<span class="sourceLineNo">297</span>      if (numChosen &lt; 1) {<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        LOG.info("Using default thrift server type");<a name="line.298"></a>
-<span class="sourceLineNo">299</span>        chosenType = DEFAULT;<a name="line.299"></a>
-<span class="sourceLineNo">300</span>      } else if (numChosen &gt; 1) {<a name="line.300"></a>
-<span class="sourceLineNo">301</span>        throw new AssertionError("Exactly one option out of " +<a name="line.301"></a>
-<span class="sourceLineNo">302</span>          Arrays.toString(values()) + " has to be specified");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>      }<a name="line.303"></a>
-<span class="sourceLineNo">304</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.304"></a>
-<span class="sourceLineNo">305</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    }<a name="line.306"></a>
-<span class="sourceLineNo">307</span><a name="line.307"></a>
-<span class="sourceLineNo">308</span>    public String simpleClassName() {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      return serverClass.getSimpleName();<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.313"></a>
-<span class="sourceLineNo">314</span>      for (ImplType t : values()) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>        if (!t.canSpecifyBindIP) {<a name="line.315"></a>
-<span class="sourceLineNo">316</span>          l.add(t.simpleClassName());<a name="line.316"></a>
-<span class="sourceLineNo">317</span>        }<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      }<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      return l;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>    }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  }<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.324"></a>
-<span class="sourceLineNo">325</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.325"></a>
-<span class="sourceLineNo">326</span>    // login the server principal (if using secure Hadoop)<a name="line.326"></a>
-<span class="sourceLineNo">327</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.327"></a>
-<span class="sourceLineNo">328</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.328"></a>
-<span class="sourceLineNo">329</span>    if (securityEnabled) {<a name="line.329"></a>
-<span class="sourceLineNo">330</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.330"></a>
-<span class="sourceLineNo">331</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.333"></a>
-<span class="sourceLineNo">334</span>        "hbase.thrift.kerberos.principal", host);<a name="line.334"></a>
-<span class="sourceLineNo">335</span>    }<a name="line.335"></a>
-<span class="sourceLineNo">336</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.336"></a>
-<span class="sourceLineNo">337</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.338"></a>
-<span class="sourceLineNo">339</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.340"></a>
-<span class="sourceLineNo">341</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.341"></a>
-<span class="sourceLineNo">342</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      hbaseHandler, metrics, conf);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    if (strQop != null) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    }<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    if (doAsEnabled) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.351"></a>
-<span class="sourceLineNo">352</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.352"></a>
-<span class="sourceLineNo">353</span>                "configured ");<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      }<a name="line.354"></a>
-<span class="sourceLineNo">355</span>    }<a name="line.355"></a>
-<span class="sourceLineNo">356</span>    if (qop != null) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.360"></a>
-<span class="sourceLineNo">361</span>                              THRIFT_QOP_KEY,<a name="line.361"></a>
-<span class="sourceLineNo">362</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.362"></a>
-<span class="sourceLineNo">363</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.363"></a>
-<span class="sourceLineNo">364</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      }<a name="line.365"></a>
-<span class="sourceLineNo">366</span>      checkHttpSecurity(qop, conf);<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      if (!securityEnabled) {<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        throw new IOException("Thrift server must"<a name="line.368"></a>
-<span class="sourceLineNo">369</span>          + " run in secure mode to support authentication");<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
-<span class="sourceLineNo">371</span>    }<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
-<span class="sourceLineNo">373</span><a name="line.373"></a>
-<span class="sourceLineNo">374</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.375"></a>
-<span class="sourceLineNo">376</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.376"></a>
-<span class="sourceLineNo">377</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.378"></a>
-<span class="sourceLineNo">379</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.379"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * auth-int: authentication and integrity checking<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * auth: authentication only<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   *<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   * This is used to authenticate the callers and support impersonation.<a name="line.199"></a>
+<span class="sourceLineNo">200</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.200"></a>
+<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
+<span class="sourceLineNo">202</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.203"></a>
+<span class="sourceLineNo">204</span><a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  public static final int HREGION_VERSION = 1;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  private final int listenPort;<a name="line.209"></a>
+<span class="sourceLineNo">210</span><a name="line.210"></a>
+<span class="sourceLineNo">211</span>  private Configuration conf;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>  volatile TServer tserver;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>  volatile Server httpServer;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  private final Hbase.Iface handler;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  private final ThriftMetrics metrics;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private final HBaseHandler hbaseHandler;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private final UserGroupInformation realUser;<a name="line.217"></a>
+<span class="sourceLineNo">218</span><a name="line.218"></a>
+<span class="sourceLineNo">219</span>  private SaslUtil.QualityOfProtection qop;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  private String host;<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span>  private final boolean securityEnabled;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private final boolean doAsEnabled;<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.225"></a>
+<span class="sourceLineNo">226</span><a name="line.226"></a>
+<span class="sourceLineNo">227</span>  /** An enum of server implementation selections */<a name="line.227"></a>
+<span class="sourceLineNo">228</span>  public enum ImplType {<a name="line.228"></a>
+<span class="sourceLineNo">229</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.231"></a>
+<span class="sourceLineNo">232</span>    THREADED_SELECTOR(<a name="line.232"></a>
+<span class="sourceLineNo">233</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.233"></a>
+<span class="sourceLineNo">234</span><a name="line.234"></a>
+<span class="sourceLineNo">235</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.235"></a>
+<span class="sourceLineNo">236</span><a name="line.236"></a>
+<span class="sourceLineNo">237</span>    final String option;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>    final boolean isAlwaysFramed;<a name="line.238"></a>
+<span class="sourceLineNo">239</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    final boolean canSpecifyBindIP;<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span>    private ImplType(String option, boolean isAlwaysFramed,<a name="line.242"></a>
+<span class="sourceLineNo">243</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span>      this.option = option;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>      this.serverClass = serverClass;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>    }<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span>    /**<a name="line.250"></a>
+<span class="sourceLineNo">251</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.251"></a>
+<span class="sourceLineNo">252</span>     *         {@link #values()}<a name="line.252"></a>
+<span class="sourceLineNo">253</span>     */<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    @Override<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    public String toString() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>      return "-" + option;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>    }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>    public String getOption() {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>      return option;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>    }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>    public boolean isAlwaysFramed() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>      return isAlwaysFramed;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    }<a name="line.265"></a>
+<span class="sourceLineNo">266</span><a name="line.266"></a>
+<span class="sourceLineNo">267</span>    public String getDescription() {<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.268"></a>
+<span class="sourceLineNo">269</span>          serverClass.getSimpleName());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>      if (isAlwaysFramed) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span>        sb.append(" This implies the framed transport.");<a name="line.271"></a>
+<span class="sourceLineNo">272</span>      }<a name="line.272"></a>
+<span class="sourceLineNo">273</span>      if (this == DEFAULT) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>        sb.append("This is the default.");<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      }<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      return sb.toString();<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    }<a name="line.277"></a>
+<span class="sourceLineNo">278</span><a name="line.278"></a>
+<span class="sourceLineNo">279</span>    static OptionGroup createOptionGroup() {<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      OptionGroup group = new OptionGroup();<a name="line.280"></a>
+<span class="sourceLineNo">281</span>      for (ImplType t : values()) {<a name="line.281"></a>
+<span class="sourceLineNo">282</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.282"></a>
+<span class="sourceLineNo">283</span>      }<a name="line.283"></a>
+<span class="sourceLineNo">284</span>      return group;<a name="line.284"></a>
+<span class="sourceLineNo">285</span>    }<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>    public static ImplType getServerImpl(Configuration conf) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      for (ImplType t : values()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>        if (confType.equals(t.option)) {<a name="line.290"></a>
+<span class="sourceLineNo">291</span>          return t;<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        }<a name="line.292"></a>
+<span class="sourceLineNo">293</span>      }<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.294"></a>
+<span class="sourceLineNo">295</span>    }<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      ImplType chosenType = null;<a name="line.298"></a>
+<span class="sourceLineNo">299</span>      int numChosen = 0;<a name="line.299"></a>
+<span class="sourceLineNo">300</span>      for (ImplType t : values()) {<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        if (cmd.hasOption(t.option)) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span>          chosenType = t;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>          ++numChosen;<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        }<a name="line.304"></a>
+<span class="sourceLineNo">305</span>      }<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      if (numChosen &lt; 1) {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>        LOG.info("Using default thrift server type");<a name="line.307"></a>
+<span class="sourceLineNo">308</span>        chosenType = DEFAULT;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>      } else if (numChosen &gt; 1) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>        throw new AssertionError("Exactly one option out of " +<a name="line.310"></a>
+<span class="sourceLineNo">311</span>          Arrays.toString(values()) + " has to be specified");<a name="line.311"></a>
+<span class="sourceLineNo">312</span>      }<a name="line.312"></a>
+<span class="sourceLineNo">313</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.313"></a>
+<span class="sourceLineNo">314</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.314"></a>
+<span class="sourceLineNo">315</span>    }<a name="line.315"></a>
+<span class="sourceLineNo">316</span><a name="line.316"></a>
+<span class="sourceLineNo">317</span>    public String simpleClassName() {<a name="line.317"></a>
+<span class="sourceLineNo">318</span>      return serverClass.getSimpleName();<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    }<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.322"></a>
+<span class="sourceLineNo">323</span>      for (ImplType t : values()) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>        if (!t.canSpecifyBindIP) {<a name="line.324"></a>
+<span class="sourceLineNo">325</span>          l.add(t.simpleClassName());<a name="line.325"></a>
+<span class="sourceLineNo">326</span>        }<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      }<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      return l;<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    }<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.333"></a>
+<span class="sourceLineNo">334</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    // login the server principal (if using secure Hadoop)<a name="line.335"></a>
+<span class="sourceLineNo">336</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.336"></a>
+<span class="sourceLineNo">337</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    if (securityEnabled) {<a name="line.338"></a>
+<span class="sourceLineNo">339</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.339"></a>
+<span class="sourceLineNo">340</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.340"></a>
+<span class="sourceLineNo">341</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.341"></a>
+<span class="sourceLineNo">342</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.342"></a>
+<span class="sourceLineNo">343</span>        "hbase.thrift.kerberos.principal", host);<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    }<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.345"></a>
+<span class="sourceLineNo">346</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.349"></a>
+<span class="sourceLineNo">350</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      hbaseHandler, metrics, conf);<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.354"></a>
+<span class="sourceLineNo">355</span>    if (strQop != null) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    }<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    if (doAsEnabled) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.360"></a>
+<span class="sourceLineNo">361</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.361"></a>
+<span class="sourceLineNo">362</span>                "configured ");<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      }<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    }<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    if (qop != null) {<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.369"></a>
+<span class="sourceLineNo">370</span>                              THRIFT_QOP_KEY,<a name="line.370"></a>
+<span class="sourceLineNo">371</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.371"></a>
+<span class="sourceLineNo">372</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.372"></a>
+<span class="sourceLineNo">373</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      }<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      checkHttpSecurity(qop, conf);<a name="line.375"></a>
+<span class="sourceLineNo">376</span>      if (!securityEnabled) {<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        throw new IOException("Thrift server must"<a name="line.377"></a>
+<span class="sourceLineNo">378</span>          + " run in secure mode to support authentication");<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      }<a name="line.379"></a>
 <span class="sourceLineNo">380</span>    }<a name="line.380"></a>
 <span class="sourceLineNo">381</span>  }<a name="line.381"></a>
 <span class="sourceLineNo">382</span><a name="line.382"></a>
-<span class="sourceLineNo">383</span>  /*<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * Runs the Thrift server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
-<span class="sourceLineNo">387</span>  public void run() {<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      @Override<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      public Object run() {<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        try {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>          pauseMonitor.start();<a name="line.392"></a>
-<span class="sourceLineNo">393</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            setupHTTPServer();<a name="line.394"></a>
-<span class="sourceLineNo">395</span>            httpServer.start();<a name="line.395"></a>
-<span class="sourceLineNo">396</span>            httpServer.join();<a name="line.396"></a>
-<span class="sourceLineNo">397</span>          } else {<a name="line.397"></a>
-<span class="sourceLineNo">398</span>            setupServer();<a name="line.398"></a>
-<span class="sourceLineNo">399</span>            tserver.serve();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>          }<a name="line.400"></a>
-<span class="sourceLineNo">401</span>        } catch (Exception e) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>          // Crash the process if the ThriftServer is not running<a name="line.403"></a>
-<span class="sourceLineNo">404</span>          System.exit(-1);<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        }<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        return null;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      }<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    });<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  }<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>  public void shutdown() {<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    if (pauseMonitor != null) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      pauseMonitor.stop();<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    }<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    if (tserver != null) {<a name="line.416"></a>
-<span class="sourceLineNo">417</span>      tserver.stop();<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      tserver = null;<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    if (httpServer != null) {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      try {<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        httpServer.stop();<a name="line.422"></a>
-<span class="sourceLineNo">423</span>        httpServer = null;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      } catch (Exception e) {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      }<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      httpServer = null;<a name="line.427"></a>
+<span class="sourceLineNo">383</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.383"></a>
+<span class="sourceLineNo">384</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.384"></a>
+<span class="sourceLineNo">385</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.385"></a>
+<span class="sourceLineNo">386</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.387"></a>
+<span class="sourceLineNo">388</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  }<a name="line.390"></a>
+<span class="sourceLineNo">391</span><a name="line.391"></a>
+<span class="sourceLineNo">392</span>  /*<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * Runs the Thrift server<a name="line.393"></a>
+<span class="sourceLineNo">394</span>   */<a name="line.394"></a>
+<span class="sourceLineNo">395</span>  @Override<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  public void run() {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      @Override<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      public Object run() {<a name="line.399"></a>
+<span class="sourceLineNo">400</span>        try {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>          pauseMonitor.start();<a name="line.401"></a>
+<span class="sourceLineNo">402</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>            setupHTTPServer();<a name="line.403"></a>
+<span class="sourceLineNo">404</span>            httpServer.start();<a name="line.404"></a>
+<span class="sourceLineNo">405</span>            httpServer.join();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>          } else {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>            setupServer();<a name="line.407"></a>
+<span class="sourceLineNo">408</span>            tserver.serve();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>          }<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        } catch (Exception e) {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>          // Crash the process if the ThriftServer is not running<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          System.exit(-1);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        return null;<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      }<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    });<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public void shutdown() {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    if (pauseMonitor != null) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      pauseMonitor.stop();<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    }<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    if (tserver != null) {<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      tserver.stop();<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      tserver = null;<a name="line.427"></a>
 <span class="sourceLineNo">428</span>    }<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private void setupHTTPServer() throws IOException {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.434"></a>
-<span class="sourceLineNo">435</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.435"></a>
-<span class="sourceLineNo">436</span><a name="line.436"></a>
-<span class="sourceLineNo">437</span>    // Set the default max thread number to 100 to limit<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.439"></a>
-<span class="sourceLineNo">440</span>    //<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.442"></a>
-<span class="sourceLineNo">443</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.443"></a>
-<span class="sourceLineNo">444</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.444"></a>
-<span class="sourceLineNo">445</span>    threadPool.setMinThreads(minThreads);<a name="line.445"></a>
-<span class="sourceLineNo">446</span>    httpServer = new Server(threadPool);<a name="line.446"></a>
-<span class="sourceLineNo">447</span><a name="line.447"></a>
-<span class="sourceLineNo">448</span>    // Context handler<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.449"></a>
-<span class="sourceLineNo">450</span>            ServletContextHandler.SESSIONS);<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>    // set up Jetty and run the embedded server<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    httpConfig.setSecureScheme("https");<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    httpConfig.setSecurePort(listenPort);<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    httpConfig.setSendServerVersion(false);<a name="line.461"></a>
-<span class="sourceLineNo">462</span>    httpConfig.setSendDateHeader(false);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span>    ServerConnector serverConnector;<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.467"></a>
-<span class="sourceLineNo">468</span><a name="line.468"></a>
-<span class="sourceLineNo">469</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.470"></a>
-<span class="sourceLineNo">471</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.471"></a>
-<span class="sourceLineNo">472</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.473"></a>
-<span class="sourceLineNo">474</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.476"></a>
-<span class="sourceLineNo">477</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      String[] excludeCiphers = conf.getStrings(<a name="line.479"></a>
-<span class="sourceLineNo">480</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      if (excludeCiphers.length != 0) {<a name="line.481"></a>
-<span class="sourceLineNo">482</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      }<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      String[] includeCiphers = conf.getStrings(<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>      if (includeCiphers.length != 0) {<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>      }<a name="line.488"></a>
-<span class="sourceLineNo">489</span><a name="line.489"></a>
-<span class="sourceLineNo">490</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.490"></a>
-<span class="sourceLineNo">491</span>      String[] excludeProtocols = conf.getStrings(<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.492"></a>
-<span class="sourceLineNo">493</span>      if (excludeProtocols.length != 0) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      }<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      String[] includeProtocols = conf.getStrings(<a name="line.496"></a>
-<span class="sourceLineNo">497</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      if (includeProtocols.length != 0) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      }<a name="line.500"></a>
-<span class="sourceLineNo">501</span><a name="line.501"></a>
-<span class="sourceLineNo">502</span>      serverConnector = new ServerConnector(httpServer,<a name="line.502"></a>
-<span class="sourceLineNo">503</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.503"></a>
-<span class="sourceLineNo">504</span>          new HttpConnectionFactory(httpsConfig));<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    } else {<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.506"></a>
-<span class="sourceLineNo">507</span>    }<a name="line.507"></a>
-<span class="sourceLineNo">508</span>    serverConnector.setPort(listenPort);<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    serverConnector.setHost(host);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    httpServer.addConnector(serverConnector);<a name="line.511"></a>
-<span class="sourceLineNo">512</span>    httpServer.setStopAtShutdown(true);<a name="line.512"></a>
-<span class="sourceLineNo">513</span><a name="line.513"></a>
-<span class="sourceLineNo">514</span>    if (doAsEnabled) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.515"></a>
+<span class="sourceLineNo">429</span>    if (httpServer != null) {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>      try {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        httpServer.stop();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        httpServer = null;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>      } catch (Exception e) {<a name="line.433"></a>
+<span class="sourceLineNo">434</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      }<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      httpServer = null;<a name="line.436"></a>
+<span class="sourceLineNo">437</span>    }<a name="line.437"></a>
+<span class="sourceLineNo">438</span>  }<a name="line.438"></a>
+<span class="sourceLineNo">439</span><a name="line.439"></a>
+<span class="sourceLineNo">440</span>  private void setupHTTPServer() throws IOException {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.442"></a>
+<span class="sourceLineNo">443</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.444"></a>
+<span class="sourceLineNo">445</span><a name="line.445"></a>
+<span class="sourceLineNo">446</span>    // Set the default max thread number to 100 to limit<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.448"></a>
+<span class="sourceLineNo">449</span>    //<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    threadPool.setMinThreads(minThreads);<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    httpServer = new Server(threadPool);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>    // Context handler<a name="line.457"></a>
+<span class="sourceLineNo">458</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.458"></a>
+<span class="sourceLineNo">459</span>            ServletContextHandler.SESSIONS);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.461"></a>
+<span class="sourceLineNo">462</span><a name="line.462"></a>
+<span class="sourceLineNo">463</span>    // set up Jetty and run the embedded server<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    httpConfig.setSecureScheme("https");<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    httpConfig.setSecurePort(listenPort);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    httpConfig.setSendServerVersion(false);<a name="line.470"></a>
+<span class="sourceLineNo">471</span>    httpConfig.setSendDateHeader(false);<a name="line.471"></a>
+<span class="sourceLineNo">472</span><a name="line.472"></a>
+<span class="sourceLineNo">473</span>    ServerConnector serverConnector;<a name="line.473"></a>
+<span class="sourceLineNo">474</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.476"></a>
+<span class="sourceLineNo">477</span><a name="line.477"></a>
+<span class="sourceLineNo">478</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.479"></a>
+<span class="sourceLineNo">480</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.482"></a>
+<span class="sourceLineNo">483</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.486"></a>
+<span class="sourceLineNo">487</span><a name="line.487"></a>
+<span class="sourceLineNo">488</span>      String[] excludeCiphers = conf.getStrings(<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>      if (excludeCiphers.length != 0) {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>      }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      String[] includeCiphers = conf.getStrings(<a name="line.493"></a>
+<span class="sourceLineNo">494</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      if (includeCiphers.length != 0) {<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      String[] excludeProtocols = conf.getStrings(<a name="line.500"></a>
+<span class="sourceLineNo">501</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      if (excludeProtocols.length != 0) {<a name="line.502"></a>
+<span class="sourceLineNo">503</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      }<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      String[] includeProtocols = conf.getStrings(<a name="line.505"></a>
+<span class="sourceLineNo">506</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.506"></a>
+<span class="sourceLineNo">507</span>      if (includeProtocols.length != 0) {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      }<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span>      serverConnector = new ServerConnector(httpServer,<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          new HttpConnectionFactory(httpsConfig));<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    } else {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.515"></a>
 <span class="sourceLineNo">516</span>    }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
-<span class="sourceLineNo">520</span><a name="line.520"></a>
-<span class="sourceLineNo">521</span>  /**<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * Setting up the thrift TServer<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   */<a name="line.523"></a>
-<span class="sourceLineNo">524</span>  private void setupServer() throws Exception {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>    // Construct correct ProtocolFactory<a name="line.525"></a>
-<span class="sourceLineNo">526</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.526"></a>
-<span class="sourceLineNo">527</span><a name="line.527"></a>
-<span class="sourceLineNo">528</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    TProcessor processor = p;<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>    // Construct correct TransportFactory<a name="line.532"></a>
-<span class="sourceLineNo">533</span>    TTransportFactory transportFactory;<a name="line.533"></a>
-<span class="sourceLineNo">534</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span>      if (qop != null) {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>        throw new RuntimeException("Thrift server authentication"<a name="line.536"></a>
-<span class="sourceLineNo">537</span>          + " doesn't work with framed transport yet");<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      }<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      transportFactory = new TFramedTransport.Factory(<a name="line.539"></a>
-<span class="sourceLineNo">540</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      LOG.debug("Using framed transport");<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    } else if (qop == null) {<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      transportFactory = new TTransportFactory();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>    } else {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      // Extract the name from the principal<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.546"></a>
-<span class="sourceLineNo">547</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        new SaslGssCallbackHandler() {<a name="line.551"></a>
-<span class="sourceLineNo">552</span>          @Override<a name="line.552"></a>
-<span class="sourceLineNo">553</span>          public void handle(Callback[] callbacks)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>              throws UnsupportedCallbackException {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>            AuthorizeCallback ac = null;<a name="line.555"></a>
-<span class="sourceLineNo">556</span>            for (Callback callback : callbacks) {<a name="line.556"></a>
-<span class="sourceLineNo">557</span>              if (callback instanceof AuthorizeCallback) {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>                ac = (AuthorizeCallback) callback;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>              } else {<a name="line.559"></a>
-<span class="sourceLineNo">560</span>                throw new UnsupportedCallbackException(callback,<a name="line.560"></a>
-<span class="sourceLineNo">561</span>                    "Unrecognized SASL GSSAPI Callback");<a name="line.561"></a>
-<span class="sourceLineNo">562</span>              }<a name="line.562"></a>
-<span class="sourceLineNo">563</span>            }<a name="line.563"></a>
-<span class="sourceLineNo">564</span>            if (ac != null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>              String authid = ac.getAuthenticationID();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>              String authzid = ac.getAuthorizationID();<a name="line.566"></a>
-<span class="sourceLineNo">567</span>              if (!authid.equals(authzid)) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>                ac.setAuthorized(false);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>              } else {<a name="line.569"></a>
-<span class="sourceLineNo">570</span>                ac.setAuthorized(true);<a name="line.570"></a>
-<span class="sourceLineNo">571</span>                String userName = SecurityUtil.getUserFromPrincipal(authzid);<a name="line.571"></a>
-<span class="sourceLineNo">572</span>                LOG.info("Effective user: " + userName);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>                ac.setAuthorizedID(userName);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>              }<a name="line.574"></a>
-<span class="sourceLineNo">575</span>            }<a name="line.575"></a>
-<span class="sourceLineNo">576</span>          }<a name="line.576"></a>
-<span class="sourceLineNo">577</span>        });<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      transportFactory = saslFactory;<a name="line.578"></a>
-<span class="sourceLineNo">579</span><a name="line.579"></a>
-<span class="sourceLineNo">580</span>      // Create a processor wrapper, to get the caller<a name="line.580"></a>
-<span class="sourceLineNo">581</span>      processor = new TProcessor() {<a name="line.581"></a>
-<span class="sourceLineNo">582</span>        @Override<a name="line.582"></a>
-<span class="sourceLineNo">583</span>        public boolean process(TProtocol inProt,<a name="line.583"></a>
-<span class="sourceLineNo">584</span>            TProtocol outProt) throws TException {<a name="line.584"></a>
-<span class="sourceLineNo">585</span>          TSaslServerTransport saslServerTransport =<a name="line.585"></a>
-<span class="sourceLineNo">586</span>            (TSaslServerTransport)inProt.getTransport();<a name="line.586"></a>
-<span class="sourceLineNo">587</span>          SaslServer saslServer = saslServerTransport.getSaslServer();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>          String principal = saslServer.getAuthorizationID();<a name="line.588"></a>
-<span class="sourceLineNo">589</span>          hbaseHandler.setEffectiveUser(principal);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>          return p.process(inProt, outProt);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        }<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      };<a name="line.592"></a>
-<span class="sourceLineNo">593</span>    }<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    if (conf.get(BIND_CONF_KEY) != null &amp;&amp; !implType.canSpecifyBindIP) {<a name="line.595"></a>
-<span class="sourceLineNo">596</span>      LOG.error("Server types " + Joiner.on(", ").join(<a name="line.596"></a>
-<span class="sourceLineNo">597</span>          ImplType.serversThatCannotSpecifyBindIP()) + " don't support IP " +<a name="line.597"></a>
-<span class="sourceLineNo">598</span>          "address binding at the moment. See " +<a name="line.598"></a>
-<span class="sourceLineNo">599</span>          "https://issues.apache.org/jira/browse/HBASE-2155 for details.");<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      throw new RuntimeException(<a name="line.600"></a>
-<span class="sourceLineNo">601</span>          "-" + BIND_CONF_KEY + " not supported with " + implType);<a name="line.601"></a>
+<span class="sourceLineNo">517</span>    serverConnector.setPort(listenPort);<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    serverConnector.setHost(host);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>    httpServer.addConnector(serverConnector);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>    httpServer.setStopAtShutdown(true);<a name="line.521"></a>
+<span class="sourceLineNo">522</span><a name="line.522"></a>
+<span class="sourceLineNo">523</span>    if (doAsEnabled) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.524"></a>
+<span class="sourceLineNo">525</span>    }<a name="line.525"></a>
+<span class="sourceLineNo">526</span><a name="line.526"></a>
+<span class="sourceLineNo">527</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.527"></a>
+<span class="sourceLineNo">528</span>  }<a name="line.528"></a>
+<span class="sourceLineNo">529</span><a name="line.529"></a>
+<span class="sourceLineNo">530</span>  /**<a name="line.530"></a>
+<span class="sourceLineNo">531</span>   * Setting up the thrift TServer<a name="line.531"></a>
+<span class="sourceLineNo">532</span>   */<a name="line.532"></a>
+<span class="sourceLineNo">533</span>  private void setupServer() throws Exception {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>    // Construct correct ProtocolFactory<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    TProcessor processor = p;<a name="line.539"></a>
+<span class="sourceLineNo">540</span><a name="line.540"></a>
+<span class="sourceLineNo">541</span>    // Construct correct TransportFactory<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    TTransportFactory transportFactory;<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      if (qop != null) {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>        throw new RuntimeException("Thrift server authentication"<a name="line.545"></a>
+<span class="sourceLineNo">546</span>          + " doesn't work with framed transport yet");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      }<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      transportFactory = new TFramedTransport.Factory(<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      LOG.debug("Using framed transport");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>    } else if (qop == null) {<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      transportFactory = new TTransportFactory();<a name="line.552"></a>
+<span class="sourceLineNo">553</span>    } else {<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Extract the name from the principal<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.555"></a>
+<span class="sourceLineNo">556</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.557"></a>
+<span class="sourceLineNo">558</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.559"></a>
+<span class="sourceLineNo">560</span>        new SaslGssCallbackHandler() {<a name="line.560"></a>
+<span class="sourceLineNo">561</span>          @Override<a name="line.561"></a>
+<span class="sourceLineNo">562</span>          public void handle(Callback[] callbacks)<a name="line.562"></a>
+<span class="sourceLineNo">563</span>              throws UnsupportedCallbackException {<a name="line.563"></a>
+<span class="sourceLineNo">564</span>            Au

<TRUNCATED>

[07/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
index fd7ab7a..021207f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
@@ -147,1891 +147,1901 @@
 <span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
 <span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
 <span class="sourceLineNo">141</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.150"></a>
-<span class="sourceLineNo">151</span> */<a name="line.151"></a>
-<span class="sourceLineNo">152</span>@InterfaceAudience.Private<a name="line.152"></a>
-<span class="sourceLineNo">153</span>public class ThriftServerRunner implements Runnable {<a name="line.153"></a>
-<span class="sourceLineNo">154</span><a name="line.154"></a>
-<span class="sourceLineNo">155</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.155"></a>
-<span class="sourceLineNo">156</span><a name="line.156"></a>
-<span class="sourceLineNo">157</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.157"></a>
-<span class="sourceLineNo">158</span><a name="line.158"></a>
-<span class="sourceLineNo">159</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      "hbase.regionserver.thrift.server.type";<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.164"></a>
-<span class="sourceLineNo">165</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.167"></a>
-<span class="sourceLineNo">168</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.169"></a>
-<span class="sourceLineNo">170</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.170"></a>
-<span class="sourceLineNo">171</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.171"></a>
-<span class="sourceLineNo">172</span><a name="line.172"></a>
-<span class="sourceLineNo">173</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.174"></a>
-<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.175"></a>
-<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.177"></a>
-<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.179"></a>
-<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * applies only to TBoundedThreadPoolServer<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Splitter;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.147"></a>
+<span class="sourceLineNo">148</span><a name="line.148"></a>
+<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> */<a name="line.152"></a>
+<span class="sourceLineNo">153</span>@InterfaceAudience.Private<a name="line.153"></a>
+<span class="sourceLineNo">154</span>public class ThriftServerRunner implements Runnable {<a name="line.154"></a>
+<span class="sourceLineNo">155</span><a name="line.155"></a>
+<span class="sourceLineNo">156</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      "hbase.regionserver.thrift.server.type";<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.164"></a>
+<span class="sourceLineNo">165</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.169"></a>
+<span class="sourceLineNo">170</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.176"></a>
+<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  /**<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * applies only to TBoundedThreadPoolServer<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   */<a name="line.187"></a>
+<span class="sourceLineNo">188</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.188"></a>
+<span class="sourceLineNo">189</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.190"></a>
 <span class="sourceLineNo">191</span><a name="line.191"></a>
-<span class="sourceLineNo">192</span>  /**<a name="line.192"></a>
-<span class="sourceLineNo">193</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * auth-int: authentication and integrity checking<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * auth: authentication only<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   *<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * This is used to authenticate the callers and support impersonation.<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   */<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  public static final int HREGION_VERSION = 1;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private final int listenPort;<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  private Configuration conf;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>  volatile TServer tserver;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  volatile Server httpServer;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>  private final Hbase.Iface handler;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  private final ThriftMetrics metrics;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  private final HBaseHandler hbaseHandler;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  private final UserGroupInformation realUser;<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private SaslUtil.QualityOfProtection qop;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private String host;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  private final boolean securityEnabled;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  private final boolean doAsEnabled;<a name="line.222"></a>
-<span class="sourceLineNo">223</span><a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  /** An enum of server implementation selections */<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  enum ImplType {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.230"></a>
-<span class="sourceLineNo">231</span>    THREADED_SELECTOR(<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.232"></a>
-<span class="sourceLineNo">233</span><a name="line.233"></a>
-<span class="sourceLineNo">234</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>    final String option;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    final boolean isAlwaysFramed;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>    final boolean canSpecifyBindIP;<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>    ImplType(String option, boolean isAlwaysFramed,<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      this.option = option;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>      this.serverClass = serverClass;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>    /**<a name="line.249"></a>
-<span class="sourceLineNo">250</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.250"></a>
-<span class="sourceLineNo">251</span>     *         {@link #values()}<a name="line.251"></a>
-<span class="sourceLineNo">252</span>     */<a name="line.252"></a>
-<span class="sourceLineNo">253</span>    @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>    public String toString() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>      return "-" + option;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>    }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>    String getDescription() {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.259"></a>
-<span class="sourceLineNo">260</span>          serverClass.getSimpleName());<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      if (isAlwaysFramed) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span>        sb.append(" This implies the framed transport.");<a name="line.262"></a>
-<span class="sourceLineNo">263</span>      }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      if (this == DEFAULT) {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>        sb.append("This is the default.");<a name="line.265"></a>
-<span class="sourceLineNo">266</span>      }<a name="line.266"></a>
-<span class="sourceLineNo">267</span>      return sb.toString();<a name="line.267"></a>
-<span class="sourceLineNo">268</span>    }<a name="line.268"></a>
-<span class="sourceLineNo">269</span><a name="line.269"></a>
-<span class="sourceLineNo">270</span>    static OptionGroup createOptionGroup() {<a name="line.270"></a>
-<span class="sourceLineNo">271</span>      OptionGroup group = new OptionGroup();<a name="line.271"></a>
-<span class="sourceLineNo">272</span>      for (ImplType t : values()) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>      }<a name="line.274"></a>
-<span class="sourceLineNo">275</span>      return group;<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    }<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>    static ImplType getServerImpl(Configuration conf) {<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.279"></a>
-<span class="sourceLineNo">280</span>      for (ImplType t : values()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span>        if (confType.equals(t.option)) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>          return t;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>        }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      }<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>      ImplType chosenType = null;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      int numChosen = 0;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>      for (ImplType t : values()) {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        if (cmd.hasOption(t.option)) {<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          chosenType = t;<a name="line.293"></a>
-<span class="sourceLineNo">294</span>          ++numChosen;<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        }<a name="line.295"></a>
-<span class="sourceLineNo">296</span>      }<a name="line.296"></a>
-<span class="sourceLineNo">297</span>      if (numChosen &lt; 1) {<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        LOG.info("Using default thrift server type");<a name="line.298"></a>
-<span class="sourceLineNo">299</span>        chosenType = DEFAULT;<a name="line.299"></a>
-<span class="sourceLineNo">300</span>      } else if (numChosen &gt; 1) {<a name="line.300"></a>
-<span class="sourceLineNo">301</span>        throw new AssertionError("Exactly one option out of " +<a name="line.301"></a>
-<span class="sourceLineNo">302</span>          Arrays.toString(values()) + " has to be specified");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>      }<a name="line.303"></a>
-<span class="sourceLineNo">304</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.304"></a>
-<span class="sourceLineNo">305</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    }<a name="line.306"></a>
-<span class="sourceLineNo">307</span><a name="line.307"></a>
-<span class="sourceLineNo">308</span>    public String simpleClassName() {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      return serverClass.getSimpleName();<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.313"></a>
-<span class="sourceLineNo">314</span>      for (ImplType t : values()) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>        if (!t.canSpecifyBindIP) {<a name="line.315"></a>
-<span class="sourceLineNo">316</span>          l.add(t.simpleClassName());<a name="line.316"></a>
-<span class="sourceLineNo">317</span>        }<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      }<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      return l;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>    }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  }<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.324"></a>
-<span class="sourceLineNo">325</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.325"></a>
-<span class="sourceLineNo">326</span>    // login the server principal (if using secure Hadoop)<a name="line.326"></a>
-<span class="sourceLineNo">327</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.327"></a>
-<span class="sourceLineNo">328</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.328"></a>
-<span class="sourceLineNo">329</span>    if (securityEnabled) {<a name="line.329"></a>
-<span class="sourceLineNo">330</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.330"></a>
-<span class="sourceLineNo">331</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.333"></a>
-<span class="sourceLineNo">334</span>        "hbase.thrift.kerberos.principal", host);<a name="line.334"></a>
-<span class="sourceLineNo">335</span>    }<a name="line.335"></a>
-<span class="sourceLineNo">336</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.336"></a>
-<span class="sourceLineNo">337</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.338"></a>
-<span class="sourceLineNo">339</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.340"></a>
-<span class="sourceLineNo">341</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.341"></a>
-<span class="sourceLineNo">342</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      hbaseHandler, metrics, conf);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    if (strQop != null) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    }<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    if (doAsEnabled) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.351"></a>
-<span class="sourceLineNo">352</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.352"></a>
-<span class="sourceLineNo">353</span>                "configured ");<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      }<a name="line.354"></a>
-<span class="sourceLineNo">355</span>    }<a name="line.355"></a>
-<span class="sourceLineNo">356</span>    if (qop != null) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.360"></a>
-<span class="sourceLineNo">361</span>                              THRIFT_QOP_KEY,<a name="line.361"></a>
-<span class="sourceLineNo">362</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.362"></a>
-<span class="sourceLineNo">363</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.363"></a>
-<span class="sourceLineNo">364</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      }<a name="line.365"></a>
-<span class="sourceLineNo">366</span>      checkHttpSecurity(qop, conf);<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      if (!securityEnabled) {<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        throw new IOException("Thrift server must"<a name="line.368"></a>
-<span class="sourceLineNo">369</span>          + " run in secure mode to support authentication");<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
-<span class="sourceLineNo">371</span>    }<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
-<span class="sourceLineNo">373</span><a name="line.373"></a>
-<span class="sourceLineNo">374</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.375"></a>
-<span class="sourceLineNo">376</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.376"></a>
-<span class="sourceLineNo">377</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.378"></a>
-<span class="sourceLineNo">379</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.379"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * auth-int: authentication and integrity checking<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * auth: authentication only<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   *<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   * This is used to authenticate the callers and support impersonation.<a name="line.199"></a>
+<span class="sourceLineNo">200</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.200"></a>
+<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
+<span class="sourceLineNo">202</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.203"></a>
+<span class="sourceLineNo">204</span><a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  public static final int HREGION_VERSION = 1;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  private final int listenPort;<a name="line.209"></a>
+<span class="sourceLineNo">210</span><a name="line.210"></a>
+<span class="sourceLineNo">211</span>  private Configuration conf;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>  volatile TServer tserver;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>  volatile Server httpServer;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  private final Hbase.Iface handler;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  private final ThriftMetrics metrics;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private final HBaseHandler hbaseHandler;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private final UserGroupInformation realUser;<a name="line.217"></a>
+<span class="sourceLineNo">218</span><a name="line.218"></a>
+<span class="sourceLineNo">219</span>  private SaslUtil.QualityOfProtection qop;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  private String host;<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span>  private final boolean securityEnabled;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private final boolean doAsEnabled;<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.225"></a>
+<span class="sourceLineNo">226</span><a name="line.226"></a>
+<span class="sourceLineNo">227</span>  /** An enum of server implementation selections */<a name="line.227"></a>
+<span class="sourceLineNo">228</span>  public enum ImplType {<a name="line.228"></a>
+<span class="sourceLineNo">229</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.231"></a>
+<span class="sourceLineNo">232</span>    THREADED_SELECTOR(<a name="line.232"></a>
+<span class="sourceLineNo">233</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.233"></a>
+<span class="sourceLineNo">234</span><a name="line.234"></a>
+<span class="sourceLineNo">235</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.235"></a>
+<span class="sourceLineNo">236</span><a name="line.236"></a>
+<span class="sourceLineNo">237</span>    final String option;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>    final boolean isAlwaysFramed;<a name="line.238"></a>
+<span class="sourceLineNo">239</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    final boolean canSpecifyBindIP;<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span>    private ImplType(String option, boolean isAlwaysFramed,<a name="line.242"></a>
+<span class="sourceLineNo">243</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span>      this.option = option;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>      this.serverClass = serverClass;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>    }<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span>    /**<a name="line.250"></a>
+<span class="sourceLineNo">251</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.251"></a>
+<span class="sourceLineNo">252</span>     *         {@link #values()}<a name="line.252"></a>
+<span class="sourceLineNo">253</span>     */<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    @Override<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    public String toString() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>      return "-" + option;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>    }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>    public String getOption() {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>      return option;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>    }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>    public boolean isAlwaysFramed() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>      return isAlwaysFramed;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    }<a name="line.265"></a>
+<span class="sourceLineNo">266</span><a name="line.266"></a>
+<span class="sourceLineNo">267</span>    public String getDescription() {<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.268"></a>
+<span class="sourceLineNo">269</span>          serverClass.getSimpleName());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>      if (isAlwaysFramed) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span>        sb.append(" This implies the framed transport.");<a name="line.271"></a>
+<span class="sourceLineNo">272</span>      }<a name="line.272"></a>
+<span class="sourceLineNo">273</span>      if (this == DEFAULT) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>        sb.append("This is the default.");<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      }<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      return sb.toString();<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    }<a name="line.277"></a>
+<span class="sourceLineNo">278</span><a name="line.278"></a>
+<span class="sourceLineNo">279</span>    static OptionGroup createOptionGroup() {<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      OptionGroup group = new OptionGroup();<a name="line.280"></a>
+<span class="sourceLineNo">281</span>      for (ImplType t : values()) {<a name="line.281"></a>
+<span class="sourceLineNo">282</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.282"></a>
+<span class="sourceLineNo">283</span>      }<a name="line.283"></a>
+<span class="sourceLineNo">284</span>      return group;<a name="line.284"></a>
+<span class="sourceLineNo">285</span>    }<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>    public static ImplType getServerImpl(Configuration conf) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      for (ImplType t : values()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>        if (confType.equals(t.option)) {<a name="line.290"></a>
+<span class="sourceLineNo">291</span>          return t;<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        }<a name="line.292"></a>
+<span class="sourceLineNo">293</span>      }<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.294"></a>
+<span class="sourceLineNo">295</span>    }<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      ImplType chosenType = null;<a name="line.298"></a>
+<span class="sourceLineNo">299</span>      int numChosen = 0;<a name="line.299"></a>
+<span class="sourceLineNo">300</span>      for (ImplType t : values()) {<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        if (cmd.hasOption(t.option)) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span>          chosenType = t;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>          ++numChosen;<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        }<a name="line.304"></a>
+<span class="sourceLineNo">305</span>      }<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      if (numChosen &lt; 1) {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>        LOG.info("Using default thrift server type");<a name="line.307"></a>
+<span class="sourceLineNo">308</span>        chosenType = DEFAULT;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>      } else if (numChosen &gt; 1) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>        throw new AssertionError("Exactly one option out of " +<a name="line.310"></a>
+<span class="sourceLineNo">311</span>          Arrays.toString(values()) + " has to be specified");<a name="line.311"></a>
+<span class="sourceLineNo">312</span>      }<a name="line.312"></a>
+<span class="sourceLineNo">313</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.313"></a>
+<span class="sourceLineNo">314</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.314"></a>
+<span class="sourceLineNo">315</span>    }<a name="line.315"></a>
+<span class="sourceLineNo">316</span><a name="line.316"></a>
+<span class="sourceLineNo">317</span>    public String simpleClassName() {<a name="line.317"></a>
+<span class="sourceLineNo">318</span>      return serverClass.getSimpleName();<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    }<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.322"></a>
+<span class="sourceLineNo">323</span>      for (ImplType t : values()) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>        if (!t.canSpecifyBindIP) {<a name="line.324"></a>
+<span class="sourceLineNo">325</span>          l.add(t.simpleClassName());<a name="line.325"></a>
+<span class="sourceLineNo">326</span>        }<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      }<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      return l;<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    }<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.333"></a>
+<span class="sourceLineNo">334</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    // login the server principal (if using secure Hadoop)<a name="line.335"></a>
+<span class="sourceLineNo">336</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.336"></a>
+<span class="sourceLineNo">337</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    if (securityEnabled) {<a name="line.338"></a>
+<span class="sourceLineNo">339</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.339"></a>
+<span class="sourceLineNo">340</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.340"></a>
+<span class="sourceLineNo">341</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.341"></a>
+<span class="sourceLineNo">342</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.342"></a>
+<span class="sourceLineNo">343</span>        "hbase.thrift.kerberos.principal", host);<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    }<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.345"></a>
+<span class="sourceLineNo">346</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.349"></a>
+<span class="sourceLineNo">350</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      hbaseHandler, metrics, conf);<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.354"></a>
+<span class="sourceLineNo">355</span>    if (strQop != null) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    }<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    if (doAsEnabled) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.360"></a>
+<span class="sourceLineNo">361</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.361"></a>
+<span class="sourceLineNo">362</span>                "configured ");<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      }<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    }<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    if (qop != null) {<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.369"></a>
+<span class="sourceLineNo">370</span>                              THRIFT_QOP_KEY,<a name="line.370"></a>
+<span class="sourceLineNo">371</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.371"></a>
+<span class="sourceLineNo">372</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.372"></a>
+<span class="sourceLineNo">373</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      }<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      checkHttpSecurity(qop, conf);<a name="line.375"></a>
+<span class="sourceLineNo">376</span>      if (!securityEnabled) {<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        throw new IOException("Thrift server must"<a name="line.377"></a>
+<span class="sourceLineNo">378</span>          + " run in secure mode to support authentication");<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      }<a name="line.379"></a>
 <span class="sourceLineNo">380</span>    }<a name="line.380"></a>
 <span class="sourceLineNo">381</span>  }<a name="line.381"></a>
 <span class="sourceLineNo">382</span><a name="line.382"></a>
-<span class="sourceLineNo">383</span>  /*<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * Runs the Thrift server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
-<span class="sourceLineNo">387</span>  public void run() {<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      @Override<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      public Object run() {<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        try {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>          pauseMonitor.start();<a name="line.392"></a>
-<span class="sourceLineNo">393</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            setupHTTPServer();<a name="line.394"></a>
-<span class="sourceLineNo">395</span>            httpServer.start();<a name="line.395"></a>
-<span class="sourceLineNo">396</span>            httpServer.join();<a name="line.396"></a>
-<span class="sourceLineNo">397</span>          } else {<a name="line.397"></a>
-<span class="sourceLineNo">398</span>            setupServer();<a name="line.398"></a>
-<span class="sourceLineNo">399</span>            tserver.serve();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>          }<a name="line.400"></a>
-<span class="sourceLineNo">401</span>        } catch (Exception e) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>          // Crash the process if the ThriftServer is not running<a name="line.403"></a>
-<span class="sourceLineNo">404</span>          System.exit(-1);<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        }<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        return null;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      }<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    });<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  }<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>  public void shutdown() {<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    if (pauseMonitor != null) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      pauseMonitor.stop();<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    }<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    if (tserver != null) {<a name="line.416"></a>
-<span class="sourceLineNo">417</span>      tserver.stop();<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      tserver = null;<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    if (httpServer != null) {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      try {<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        httpServer.stop();<a name="line.422"></a>
-<span class="sourceLineNo">423</span>        httpServer = null;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      } catch (Exception e) {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      }<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      httpServer = null;<a name="line.427"></a>
+<span class="sourceLineNo">383</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.383"></a>
+<span class="sourceLineNo">384</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.384"></a>
+<span class="sourceLineNo">385</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.385"></a>
+<span class="sourceLineNo">386</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.387"></a>
+<span class="sourceLineNo">388</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  }<a name="line.390"></a>
+<span class="sourceLineNo">391</span><a name="line.391"></a>
+<span class="sourceLineNo">392</span>  /*<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * Runs the Thrift server<a name="line.393"></a>
+<span class="sourceLineNo">394</span>   */<a name="line.394"></a>
+<span class="sourceLineNo">395</span>  @Override<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  public void run() {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      @Override<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      public Object run() {<a name="line.399"></a>
+<span class="sourceLineNo">400</span>        try {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>          pauseMonitor.start();<a name="line.401"></a>
+<span class="sourceLineNo">402</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>            setupHTTPServer();<a name="line.403"></a>
+<span class="sourceLineNo">404</span>            httpServer.start();<a name="line.404"></a>
+<span class="sourceLineNo">405</span>            httpServer.join();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>          } else {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>            setupServer();<a name="line.407"></a>
+<span class="sourceLineNo">408</span>            tserver.serve();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>          }<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        } catch (Exception e) {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>          // Crash the process if the ThriftServer is not running<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          System.exit(-1);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        return null;<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      }<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    });<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public void shutdown() {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    if (pauseMonitor != null) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      pauseMonitor.stop();<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    }<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    if (tserver != null) {<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      tserver.stop();<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      tserver = null;<a name="line.427"></a>
 <span class="sourceLineNo">428</span>    }<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private void setupHTTPServer() throws IOException {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.434"></a>
-<span class="sourceLineNo">435</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.435"></a>
-<span class="sourceLineNo">436</span><a name="line.436"></a>
-<span class="sourceLineNo">437</span>    // Set the default max thread number to 100 to limit<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.439"></a>
-<span class="sourceLineNo">440</span>    //<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.442"></a>
-<span class="sourceLineNo">443</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.443"></a>
-<span class="sourceLineNo">444</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.444"></a>
-<span class="sourceLineNo">445</span>    threadPool.setMinThreads(minThreads);<a name="line.445"></a>
-<span class="sourceLineNo">446</span>    httpServer = new Server(threadPool);<a name="line.446"></a>
-<span class="sourceLineNo">447</span><a name="line.447"></a>
-<span class="sourceLineNo">448</span>    // Context handler<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.449"></a>
-<span class="sourceLineNo">450</span>            ServletContextHandler.SESSIONS);<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>    // set up Jetty and run the embedded server<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    httpConfig.setSecureScheme("https");<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    httpConfig.setSecurePort(listenPort);<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    httpConfig.setSendServerVersion(false);<a name="line.461"></a>
-<span class="sourceLineNo">462</span>    httpConfig.setSendDateHeader(false);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span>    ServerConnector serverConnector;<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.467"></a>
-<span class="sourceLineNo">468</span><a name="line.468"></a>
-<span class="sourceLineNo">469</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.470"></a>
-<span class="sourceLineNo">471</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.471"></a>
-<span class="sourceLineNo">472</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.473"></a>
-<span class="sourceLineNo">474</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.476"></a>
-<span class="sourceLineNo">477</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      String[] excludeCiphers = conf.getStrings(<a name="line.479"></a>
-<span class="sourceLineNo">480</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      if (excludeCiphers.length != 0) {<a name="line.481"></a>
-<span class="sourceLineNo">482</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      }<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      String[] includeCiphers = conf.getStrings(<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>      if (includeCiphers.length != 0) {<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>      }<a name="line.488"></a>
-<span class="sourceLineNo">489</span><a name="line.489"></a>
-<span class="sourceLineNo">490</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.490"></a>
-<span class="sourceLineNo">491</span>      String[] excludeProtocols = conf.getStrings(<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.492"></a>
-<span class="sourceLineNo">493</span>      if (excludeProtocols.length != 0) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      }<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      String[] includeProtocols = conf.getStrings(<a name="line.496"></a>
-<span class="sourceLineNo">497</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      if (includeProtocols.length != 0) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      }<a name="line.500"></a>
-<span class="sourceLineNo">501</span><a name="line.501"></a>
-<span class="sourceLineNo">502</span>      serverConnector = new ServerConnector(httpServer,<a name="line.502"></a>
-<span class="sourceLineNo">503</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.503"></a>
-<span class="sourceLineNo">504</span>          new HttpConnectionFactory(httpsConfig));<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    } else {<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.506"></a>
-<span class="sourceLineNo">507</span>    }<a name="line.507"></a>
-<span class="sourceLineNo">508</span>    serverConnector.setPort(listenPort);<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    serverConnector.setHost(host);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    httpServer.addConnector(serverConnector);<a name="line.511"></a>
-<span class="sourceLineNo">512</span>    httpServer.setStopAtShutdown(true);<a name="line.512"></a>
-<span class="sourceLineNo">513</span><a name="line.513"></a>
-<span class="sourceLineNo">514</span>    if (doAsEnabled) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.515"></a>
+<span class="sourceLineNo">429</span>    if (httpServer != null) {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>      try {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        httpServer.stop();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        httpServer = null;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>      } catch (Exception e) {<a name="line.433"></a>
+<span class="sourceLineNo">434</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      }<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      httpServer = null;<a name="line.436"></a>
+<span class="sourceLineNo">437</span>    }<a name="line.437"></a>
+<span class="sourceLineNo">438</span>  }<a name="line.438"></a>
+<span class="sourceLineNo">439</span><a name="line.439"></a>
+<span class="sourceLineNo">440</span>  private void setupHTTPServer() throws IOException {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.442"></a>
+<span class="sourceLineNo">443</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.444"></a>
+<span class="sourceLineNo">445</span><a name="line.445"></a>
+<span class="sourceLineNo">446</span>    // Set the default max thread number to 100 to limit<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.448"></a>
+<span class="sourceLineNo">449</span>    //<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    threadPool.setMinThreads(minThreads);<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    httpServer = new Server(threadPool);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>    // Context handler<a name="line.457"></a>
+<span class="sourceLineNo">458</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.458"></a>
+<span class="sourceLineNo">459</span>            ServletContextHandler.SESSIONS);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.461"></a>
+<span class="sourceLineNo">462</span><a name="line.462"></a>
+<span class="sourceLineNo">463</span>    // set up Jetty and run the embedded server<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    httpConfig.setSecureScheme("https");<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    httpConfig.setSecurePort(listenPort);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    httpConfig.setSendServerVersion(false);<a name="line.470"></a>
+<span class="sourceLineNo">471</span>    httpConfig.setSendDateHeader(false);<a name="line.471"></a>
+<span class="sourceLineNo">472</span><a name="line.472"></a>
+<span class="sourceLineNo">473</span>    ServerConnector serverConnector;<a name="line.473"></a>
+<span class="sourceLineNo">474</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.476"></a>
+<span class="sourceLineNo">477</span><a name="line.477"></a>
+<span class="sourceLineNo">478</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.479"></a>
+<span class="sourceLineNo">480</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.482"></a>
+<span class="sourceLineNo">483</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.486"></a>
+<span class="sourceLineNo">487</span><a name="line.487"></a>
+<span class="sourceLineNo">488</span>      String[] excludeCiphers = conf.getStrings(<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>      if (excludeCiphers.length != 0) {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>      }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      String[] includeCiphers = conf.getStrings(<a name="line.493"></a>
+<span class="sourceLineNo">494</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      if (includeCiphers.length != 0) {<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      String[] excludeProtocols = conf.getStrings(<a name="line.500"></a>
+<span class="sourceLineNo">501</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      if (excludeProtocols.length != 0) {<a name="line.502"></a>
+<span class="sourceLineNo">503</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      }<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      String[] includeProtocols = conf.getStrings(<a name="line.505"></a>
+<span class="sourceLineNo">506</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.506"></a>
+<span class="sourceLineNo">507</span>      if (includeProtocols.length != 0) {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      }<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span>      serverConnector = new ServerConnector(httpServer,<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          new HttpConnectionFactory(httpsConfig));<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    } else {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.515"></a>
 <span class="sourceLineNo">516</span>    }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
-<span class="sourceLineNo">520</span><a name="line.520"></a>
-<span class="sourceLineNo">521</span>  /**<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * Setting up the thrift TServer<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   */<a name="line.523"></a>
-<span class="sourceLineNo">524</span>  private void setupServer() throws Exception {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>    // Construct correct ProtocolFactory<a name="line.525"></a>
-<span class="sourceLineNo">526</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.526"></a>
-<span class="sourceLineNo">527</span><a name="line.527"></a>
-<span class="sourceLineNo">528</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    TProcessor processor = p;<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>    // Construct correct TransportFactory<a name="line.532"></a>
-<span class="sourceLineNo">533</span>    TTransportFactory transportFactory;<a name="line.533"></a>
-<span class="sourceLineNo">534</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span>      if (qop != null) {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>        throw new RuntimeException("Thrift server authentication"<a name="line.536"></a>
-<span class="sourceLineNo">537</span>          + " doesn't work with framed transport yet");<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      }<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      transportFactory = new TFramedTransport.Factory(<a name="line.539"></a>
-<span class="sourceLineNo">540</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      LOG.debug("Using framed transport");<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    } else if (qop == null) {<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      transportFactory = new TTransportFactory();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>    } else {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      // Extract the name from the principal<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.546"></a>
-<span class="sourceLineNo">547</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        new SaslGssCallbackHandler() {<a name="line.551"></a>
-<span class="sourceLineNo">552</span>          @Override<a name="line.552"></a>
-<span class="sourceLineNo">553</span>          public void handle(Callback[] callbacks)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>              throws UnsupportedCallbackException {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>            AuthorizeCallback ac = null;<a name="line.555"></a>
-<span class="sourceLineNo">556</span>            for (Callback callback : callbacks) {<a name="line.556"></a>
-<span class="sourceLineNo">557</span>              if (callback instanceof AuthorizeCallback) {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>                ac = (AuthorizeCallback) callback;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>              } else {<a name="line.559"></a>
-<span class="sourceLineNo">560</span>                throw new UnsupportedCallbackException(callback,<a name="line.560"></a>
-<span class="sourceLineNo">561</span>                    "Unrecognized SASL GSSAPI Callback");<a name="line.561"></a>
-<span class="sourceLineNo">562</span>              }<a name="line.562"></a>
-<span class="sourceLineNo">563</span>            }<a name="line.563"></a>
-<span class="sourceLineNo">564</span>            if (ac != null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>              String authid = ac.getAuthenticationID();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>              String authzid = ac.getAuthorizationID();<a name="line.566"></a>
-<span class="sourceLineNo">567</span>              if (!authid.equals(authzid)) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>                ac.setAuthorized(false);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>              } else {<a name="line.569"></a>
-<span class="sourceLineNo">570</span>                ac.setAuthorized(true);<a name="line.570"></a>
-<span class="sourceLineNo">571</span>                String userName = SecurityUtil.getUserFromPrincipal(authzid);<a name="line.571"></a>
-<span class="sourceLineNo">572</span>                LOG.info("Effective user: " + userName);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>                ac.setAuthorizedID(userName);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>              }<a name="line.574"></a>
-<span class="sourceLineNo">575</span>            }<a name="line.575"></a>
-<span class="sourceLineNo">576</span>          }<a name="line.576"></a>
-<span class="sourceLineNo">577</span>        });<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      transportFactory = saslFactory;<a name="line.578"></a>
-<span class="sourceLineNo">579</span><a name="line.579"></a>
-<span class="sourceLineNo">580</span>      // Create a processor wrapper, to get the caller<a name="line.580"></a>
-<span class="sourceLineNo">581</span>      processor = new TProcessor() {<a name="line.581"></a>
-<span class="sourceLineNo">582</span>        @Override<a name="line.582"></a>
-<span class="sourceLineNo">583</span>        public boolean process(TProtocol inProt,<a name="line.583"></a>
-<span class="sourceLineNo">584</span>            TProtocol outProt) throws TException {<a name="line.584"></a>
-<span class="sourceLineNo">585</span>          TSaslServerTransport saslServerTransport =<a name="line.585"></a>
-<span class="sourceLineNo">586</span>            (TSaslServerTransport)inProt.getTransport();<a name="line.586"></a>
-<span class="sourceLineNo">587</span>          SaslServer saslServer = saslServerTransport.getSaslServer();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>          String principal = saslServer.getAuthorizationID();<a name="line.588"></a>
-<span class="sourceLineNo">589</span>          hbaseHandler.setEffectiveUser(principal);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>          return p.process(inProt, outProt);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        }<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      };<a name="line.592"></a>
-<span class="sourceLineNo">593</span>    }<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    if (conf.get(BIND_CONF_KEY) != null &amp;&amp; !implType.canSpecifyBindIP) {<a name="line.595"></a>
-<span class="sourceLineNo">596</span>      LOG.error("Server types " + Joiner.on(", ").join(<a name="line.596"></a>
-<span class="sourceLineNo">597</span>          ImplType.serversThatCannotSpecifyBindIP()) + " don't support IP " +<a name="line.597"></a>
-<span class="sourceLineNo">598</span>          "address binding at the moment. See " +<a name="line.598"></a>
-<span class="sourceLineNo">599</span>          "https://issues.apache.org/jira/browse/HBASE-2155 for details.");<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      throw new RuntimeException(<a name="line.600"></a>
-<span class="sourceLineNo">601</span>          "-" + BIND_CONF_KEY + " not supported with " + implType);<a name="line.601"></a>
+<span class="sourceLineNo">517</span>    serverConnector.setPort(listenPort);<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    serverConnector.setHost(host);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>    httpServer.addConnector(serverConnector);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>    httpServer.setStopAtShutdown(true);<a name="line.521"></a>
+<span class="sourceLineNo">522</span><a name="line.522"></a>
+<span class="sourceLineNo">523</span>    if (doAsEnabled) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.524"></a>
+<span class="sourceLineNo">525</span>    }<a name="line.525"></a>
+<span class="sourceLineNo">526</span><a name="line.526"></a>
+<span class="sourceLineNo">527</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.527"></a>
+<span class="sourceLineNo">528</span>  }<a name="line.528"></a>
+<span class="sourceLineNo">529</span><a name="line.529"></a>
+<span class="sourceLineNo">530</span>  /**<a name="line.530"></a>
+<span class="sourceLineNo">531</span>   * Setting up the thrift TServer<a name="line.531"></a>
+<span class="sourceLineNo">532</span>   */<a name="line.532"></a>
+<span class="sourceLineNo">533</span>  private void setupServer() throws Exception {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>    // Construct correct ProtocolFactory<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    TProcessor processor = p;<a name="line.539"></a>
+<span class="sourceLineNo">540</span><a name="line.540"></a>
+<span class="sourceLineNo">541</span>    // Construct correct TransportFactory<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    TTransportFactory transportFactory;<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      if (qop != null) {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>        throw new RuntimeException("Thrift server authentication"<a name="line.545"></a>
+<span class="sourceLineNo">546</span>          + " doesn't work with framed transport yet");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      }<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      transportFactory = new TFramedTransport.Factory(<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      LOG.debug("Using framed transport");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>    } else if (qop == null) {<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      transportFactory = new TTransportFactory();<a name="line.552"></a>
+<span class="sourceLineNo">553</span>    } else {<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Extract the name from the principal<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.555"></a>
+<span class="sourceLineNo">556</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.557"></a>
+<span class="sourceLineNo">558</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.559"></a>
+<span class="sourceLineNo">560</span>        new SaslGssCallbackHandler() {<a name="line.560"></a>
+<span class="sourceLineNo">561</span>          @Override<a name="line.561"></a>
+<span class="sourceLineNo">562</span>          public void handle(Callback[] callbacks)<a name="line.562"></a>
+<span class="sourceLineNo">563</span>              throws UnsupportedCallbackException {<a name="line.563"></a>
+<span class="sourceLineNo">564</span>            AuthorizeCallback ac =

<TRUNCATED>

[04/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
index fd7ab7a..021207f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
@@ -147,1891 +147,1901 @@
 <span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
 <span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
 <span class="sourceLineNo">141</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.150"></a>
-<span class="sourceLineNo">151</span> */<a name="line.151"></a>
-<span class="sourceLineNo">152</span>@InterfaceAudience.Private<a name="line.152"></a>
-<span class="sourceLineNo">153</span>public class ThriftServerRunner implements Runnable {<a name="line.153"></a>
-<span class="sourceLineNo">154</span><a name="line.154"></a>
-<span class="sourceLineNo">155</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.155"></a>
-<span class="sourceLineNo">156</span><a name="line.156"></a>
-<span class="sourceLineNo">157</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.157"></a>
-<span class="sourceLineNo">158</span><a name="line.158"></a>
-<span class="sourceLineNo">159</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      "hbase.regionserver.thrift.server.type";<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.164"></a>
-<span class="sourceLineNo">165</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.167"></a>
-<span class="sourceLineNo">168</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.169"></a>
-<span class="sourceLineNo">170</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.170"></a>
-<span class="sourceLineNo">171</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.171"></a>
-<span class="sourceLineNo">172</span><a name="line.172"></a>
-<span class="sourceLineNo">173</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.174"></a>
-<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.175"></a>
-<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.177"></a>
-<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.179"></a>
-<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * applies only to TBoundedThreadPoolServer<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Splitter;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.147"></a>
+<span class="sourceLineNo">148</span><a name="line.148"></a>
+<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> */<a name="line.152"></a>
+<span class="sourceLineNo">153</span>@InterfaceAudience.Private<a name="line.153"></a>
+<span class="sourceLineNo">154</span>public class ThriftServerRunner implements Runnable {<a name="line.154"></a>
+<span class="sourceLineNo">155</span><a name="line.155"></a>
+<span class="sourceLineNo">156</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      "hbase.regionserver.thrift.server.type";<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.164"></a>
+<span class="sourceLineNo">165</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.169"></a>
+<span class="sourceLineNo">170</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.176"></a>
+<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  /**<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * applies only to TBoundedThreadPoolServer<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   */<a name="line.187"></a>
+<span class="sourceLineNo">188</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.188"></a>
+<span class="sourceLineNo">189</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.190"></a>
 <span class="sourceLineNo">191</span><a name="line.191"></a>
-<span class="sourceLineNo">192</span>  /**<a name="line.192"></a>
-<span class="sourceLineNo">193</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * auth-int: authentication and integrity checking<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * auth: authentication only<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   *<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * This is used to authenticate the callers and support impersonation.<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   */<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  public static final int HREGION_VERSION = 1;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private final int listenPort;<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  private Configuration conf;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>  volatile TServer tserver;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  volatile Server httpServer;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>  private final Hbase.Iface handler;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  private final ThriftMetrics metrics;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  private final HBaseHandler hbaseHandler;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  private final UserGroupInformation realUser;<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private SaslUtil.QualityOfProtection qop;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private String host;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  private final boolean securityEnabled;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  private final boolean doAsEnabled;<a name="line.222"></a>
-<span class="sourceLineNo">223</span><a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  /** An enum of server implementation selections */<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  enum ImplType {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.230"></a>
-<span class="sourceLineNo">231</span>    THREADED_SELECTOR(<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.232"></a>
-<span class="sourceLineNo">233</span><a name="line.233"></a>
-<span class="sourceLineNo">234</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>    final String option;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    final boolean isAlwaysFramed;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>    final boolean canSpecifyBindIP;<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>    ImplType(String option, boolean isAlwaysFramed,<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      this.option = option;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>      this.serverClass = serverClass;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>    /**<a name="line.249"></a>
-<span class="sourceLineNo">250</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.250"></a>
-<span class="sourceLineNo">251</span>     *         {@link #values()}<a name="line.251"></a>
-<span class="sourceLineNo">252</span>     */<a name="line.252"></a>
-<span class="sourceLineNo">253</span>    @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>    public String toString() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>      return "-" + option;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>    }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>    String getDescription() {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.259"></a>
-<span class="sourceLineNo">260</span>          serverClass.getSimpleName());<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      if (isAlwaysFramed) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span>        sb.append(" This implies the framed transport.");<a name="line.262"></a>
-<span class="sourceLineNo">263</span>      }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      if (this == DEFAULT) {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>        sb.append("This is the default.");<a name="line.265"></a>
-<span class="sourceLineNo">266</span>      }<a name="line.266"></a>
-<span class="sourceLineNo">267</span>      return sb.toString();<a name="line.267"></a>
-<span class="sourceLineNo">268</span>    }<a name="line.268"></a>
-<span class="sourceLineNo">269</span><a name="line.269"></a>
-<span class="sourceLineNo">270</span>    static OptionGroup createOptionGroup() {<a name="line.270"></a>
-<span class="sourceLineNo">271</span>      OptionGroup group = new OptionGroup();<a name="line.271"></a>
-<span class="sourceLineNo">272</span>      for (ImplType t : values()) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>      }<a name="line.274"></a>
-<span class="sourceLineNo">275</span>      return group;<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    }<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>    static ImplType getServerImpl(Configuration conf) {<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.279"></a>
-<span class="sourceLineNo">280</span>      for (ImplType t : values()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span>        if (confType.equals(t.option)) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>          return t;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>        }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      }<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>      ImplType chosenType = null;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      int numChosen = 0;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>      for (ImplType t : values()) {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        if (cmd.hasOption(t.option)) {<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          chosenType = t;<a name="line.293"></a>
-<span class="sourceLineNo">294</span>          ++numChosen;<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        }<a name="line.295"></a>
-<span class="sourceLineNo">296</span>      }<a name="line.296"></a>
-<span class="sourceLineNo">297</span>      if (numChosen &lt; 1) {<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        LOG.info("Using default thrift server type");<a name="line.298"></a>
-<span class="sourceLineNo">299</span>        chosenType = DEFAULT;<a name="line.299"></a>
-<span class="sourceLineNo">300</span>      } else if (numChosen &gt; 1) {<a name="line.300"></a>
-<span class="sourceLineNo">301</span>        throw new AssertionError("Exactly one option out of " +<a name="line.301"></a>
-<span class="sourceLineNo">302</span>          Arrays.toString(values()) + " has to be specified");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>      }<a name="line.303"></a>
-<span class="sourceLineNo">304</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.304"></a>
-<span class="sourceLineNo">305</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    }<a name="line.306"></a>
-<span class="sourceLineNo">307</span><a name="line.307"></a>
-<span class="sourceLineNo">308</span>    public String simpleClassName() {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      return serverClass.getSimpleName();<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.313"></a>
-<span class="sourceLineNo">314</span>      for (ImplType t : values()) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>        if (!t.canSpecifyBindIP) {<a name="line.315"></a>
-<span class="sourceLineNo">316</span>          l.add(t.simpleClassName());<a name="line.316"></a>
-<span class="sourceLineNo">317</span>        }<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      }<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      return l;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>    }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  }<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.324"></a>
-<span class="sourceLineNo">325</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.325"></a>
-<span class="sourceLineNo">326</span>    // login the server principal (if using secure Hadoop)<a name="line.326"></a>
-<span class="sourceLineNo">327</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.327"></a>
-<span class="sourceLineNo">328</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.328"></a>
-<span class="sourceLineNo">329</span>    if (securityEnabled) {<a name="line.329"></a>
-<span class="sourceLineNo">330</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.330"></a>
-<span class="sourceLineNo">331</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.333"></a>
-<span class="sourceLineNo">334</span>        "hbase.thrift.kerberos.principal", host);<a name="line.334"></a>
-<span class="sourceLineNo">335</span>    }<a name="line.335"></a>
-<span class="sourceLineNo">336</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.336"></a>
-<span class="sourceLineNo">337</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.338"></a>
-<span class="sourceLineNo">339</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.340"></a>
-<span class="sourceLineNo">341</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.341"></a>
-<span class="sourceLineNo">342</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      hbaseHandler, metrics, conf);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    if (strQop != null) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    }<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    if (doAsEnabled) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.351"></a>
-<span class="sourceLineNo">352</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.352"></a>
-<span class="sourceLineNo">353</span>                "configured ");<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      }<a name="line.354"></a>
-<span class="sourceLineNo">355</span>    }<a name="line.355"></a>
-<span class="sourceLineNo">356</span>    if (qop != null) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.360"></a>
-<span class="sourceLineNo">361</span>                              THRIFT_QOP_KEY,<a name="line.361"></a>
-<span class="sourceLineNo">362</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.362"></a>
-<span class="sourceLineNo">363</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.363"></a>
-<span class="sourceLineNo">364</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      }<a name="line.365"></a>
-<span class="sourceLineNo">366</span>      checkHttpSecurity(qop, conf);<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      if (!securityEnabled) {<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        throw new IOException("Thrift server must"<a name="line.368"></a>
-<span class="sourceLineNo">369</span>          + " run in secure mode to support authentication");<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
-<span class="sourceLineNo">371</span>    }<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
-<span class="sourceLineNo">373</span><a name="line.373"></a>
-<span class="sourceLineNo">374</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.375"></a>
-<span class="sourceLineNo">376</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.376"></a>
-<span class="sourceLineNo">377</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.378"></a>
-<span class="sourceLineNo">379</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.379"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * auth-int: authentication and integrity checking<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * auth: authentication only<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   *<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   * This is used to authenticate the callers and support impersonation.<a name="line.199"></a>
+<span class="sourceLineNo">200</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.200"></a>
+<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
+<span class="sourceLineNo">202</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.203"></a>
+<span class="sourceLineNo">204</span><a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  public static final int HREGION_VERSION = 1;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  private final int listenPort;<a name="line.209"></a>
+<span class="sourceLineNo">210</span><a name="line.210"></a>
+<span class="sourceLineNo">211</span>  private Configuration conf;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>  volatile TServer tserver;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>  volatile Server httpServer;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  private final Hbase.Iface handler;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  private final ThriftMetrics metrics;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private final HBaseHandler hbaseHandler;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private final UserGroupInformation realUser;<a name="line.217"></a>
+<span class="sourceLineNo">218</span><a name="line.218"></a>
+<span class="sourceLineNo">219</span>  private SaslUtil.QualityOfProtection qop;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  private String host;<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span>  private final boolean securityEnabled;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private final boolean doAsEnabled;<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.225"></a>
+<span class="sourceLineNo">226</span><a name="line.226"></a>
+<span class="sourceLineNo">227</span>  /** An enum of server implementation selections */<a name="line.227"></a>
+<span class="sourceLineNo">228</span>  public enum ImplType {<a name="line.228"></a>
+<span class="sourceLineNo">229</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.231"></a>
+<span class="sourceLineNo">232</span>    THREADED_SELECTOR(<a name="line.232"></a>
+<span class="sourceLineNo">233</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.233"></a>
+<span class="sourceLineNo">234</span><a name="line.234"></a>
+<span class="sourceLineNo">235</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.235"></a>
+<span class="sourceLineNo">236</span><a name="line.236"></a>
+<span class="sourceLineNo">237</span>    final String option;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>    final boolean isAlwaysFramed;<a name="line.238"></a>
+<span class="sourceLineNo">239</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    final boolean canSpecifyBindIP;<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span>    private ImplType(String option, boolean isAlwaysFramed,<a name="line.242"></a>
+<span class="sourceLineNo">243</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span>      this.option = option;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>      this.serverClass = serverClass;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>    }<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span>    /**<a name="line.250"></a>
+<span class="sourceLineNo">251</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.251"></a>
+<span class="sourceLineNo">252</span>     *         {@link #values()}<a name="line.252"></a>
+<span class="sourceLineNo">253</span>     */<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    @Override<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    public String toString() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>      return "-" + option;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>    }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>    public String getOption() {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>      return option;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>    }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>    public boolean isAlwaysFramed() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>      return isAlwaysFramed;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    }<a name="line.265"></a>
+<span class="sourceLineNo">266</span><a name="line.266"></a>
+<span class="sourceLineNo">267</span>    public String getDescription() {<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.268"></a>
+<span class="sourceLineNo">269</span>          serverClass.getSimpleName());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>      if (isAlwaysFramed) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span>        sb.append(" This implies the framed transport.");<a name="line.271"></a>
+<span class="sourceLineNo">272</span>      }<a name="line.272"></a>
+<span class="sourceLineNo">273</span>      if (this == DEFAULT) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>        sb.append("This is the default.");<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      }<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      return sb.toString();<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    }<a name="line.277"></a>
+<span class="sourceLineNo">278</span><a name="line.278"></a>
+<span class="sourceLineNo">279</span>    static OptionGroup createOptionGroup() {<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      OptionGroup group = new OptionGroup();<a name="line.280"></a>
+<span class="sourceLineNo">281</span>      for (ImplType t : values()) {<a name="line.281"></a>
+<span class="sourceLineNo">282</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.282"></a>
+<span class="sourceLineNo">283</span>      }<a name="line.283"></a>
+<span class="sourceLineNo">284</span>      return group;<a name="line.284"></a>
+<span class="sourceLineNo">285</span>    }<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>    public static ImplType getServerImpl(Configuration conf) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      for (ImplType t : values()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>        if (confType.equals(t.option)) {<a name="line.290"></a>
+<span class="sourceLineNo">291</span>          return t;<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        }<a name="line.292"></a>
+<span class="sourceLineNo">293</span>      }<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.294"></a>
+<span class="sourceLineNo">295</span>    }<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      ImplType chosenType = null;<a name="line.298"></a>
+<span class="sourceLineNo">299</span>      int numChosen = 0;<a name="line.299"></a>
+<span class="sourceLineNo">300</span>      for (ImplType t : values()) {<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        if (cmd.hasOption(t.option)) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span>          chosenType = t;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>          ++numChosen;<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        }<a name="line.304"></a>
+<span class="sourceLineNo">305</span>      }<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      if (numChosen &lt; 1) {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>        LOG.info("Using default thrift server type");<a name="line.307"></a>
+<span class="sourceLineNo">308</span>        chosenType = DEFAULT;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>      } else if (numChosen &gt; 1) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>        throw new AssertionError("Exactly one option out of " +<a name="line.310"></a>
+<span class="sourceLineNo">311</span>          Arrays.toString(values()) + " has to be specified");<a name="line.311"></a>
+<span class="sourceLineNo">312</span>      }<a name="line.312"></a>
+<span class="sourceLineNo">313</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.313"></a>
+<span class="sourceLineNo">314</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.314"></a>
+<span class="sourceLineNo">315</span>    }<a name="line.315"></a>
+<span class="sourceLineNo">316</span><a name="line.316"></a>
+<span class="sourceLineNo">317</span>    public String simpleClassName() {<a name="line.317"></a>
+<span class="sourceLineNo">318</span>      return serverClass.getSimpleName();<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    }<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.322"></a>
+<span class="sourceLineNo">323</span>      for (ImplType t : values()) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>        if (!t.canSpecifyBindIP) {<a name="line.324"></a>
+<span class="sourceLineNo">325</span>          l.add(t.simpleClassName());<a name="line.325"></a>
+<span class="sourceLineNo">326</span>        }<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      }<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      return l;<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    }<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.333"></a>
+<span class="sourceLineNo">334</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    // login the server principal (if using secure Hadoop)<a name="line.335"></a>
+<span class="sourceLineNo">336</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.336"></a>
+<span class="sourceLineNo">337</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    if (securityEnabled) {<a name="line.338"></a>
+<span class="sourceLineNo">339</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.339"></a>
+<span class="sourceLineNo">340</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.340"></a>
+<span class="sourceLineNo">341</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.341"></a>
+<span class="sourceLineNo">342</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.342"></a>
+<span class="sourceLineNo">343</span>        "hbase.thrift.kerberos.principal", host);<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    }<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.345"></a>
+<span class="sourceLineNo">346</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.349"></a>
+<span class="sourceLineNo">350</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      hbaseHandler, metrics, conf);<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.354"></a>
+<span class="sourceLineNo">355</span>    if (strQop != null) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    }<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    if (doAsEnabled) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.360"></a>
+<span class="sourceLineNo">361</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.361"></a>
+<span class="sourceLineNo">362</span>                "configured ");<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      }<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    }<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    if (qop != null) {<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.369"></a>
+<span class="sourceLineNo">370</span>                              THRIFT_QOP_KEY,<a name="line.370"></a>
+<span class="sourceLineNo">371</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.371"></a>
+<span class="sourceLineNo">372</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.372"></a>
+<span class="sourceLineNo">373</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      }<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      checkHttpSecurity(qop, conf);<a name="line.375"></a>
+<span class="sourceLineNo">376</span>      if (!securityEnabled) {<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        throw new IOException("Thrift server must"<a name="line.377"></a>
+<span class="sourceLineNo">378</span>          + " run in secure mode to support authentication");<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      }<a name="line.379"></a>
 <span class="sourceLineNo">380</span>    }<a name="line.380"></a>
 <span class="sourceLineNo">381</span>  }<a name="line.381"></a>
 <span class="sourceLineNo">382</span><a name="line.382"></a>
-<span class="sourceLineNo">383</span>  /*<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * Runs the Thrift server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
-<span class="sourceLineNo">387</span>  public void run() {<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      @Override<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      public Object run() {<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        try {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>          pauseMonitor.start();<a name="line.392"></a>
-<span class="sourceLineNo">393</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            setupHTTPServer();<a name="line.394"></a>
-<span class="sourceLineNo">395</span>            httpServer.start();<a name="line.395"></a>
-<span class="sourceLineNo">396</span>            httpServer.join();<a name="line.396"></a>
-<span class="sourceLineNo">397</span>          } else {<a name="line.397"></a>
-<span class="sourceLineNo">398</span>            setupServer();<a name="line.398"></a>
-<span class="sourceLineNo">399</span>            tserver.serve();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>          }<a name="line.400"></a>
-<span class="sourceLineNo">401</span>        } catch (Exception e) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>          // Crash the process if the ThriftServer is not running<a name="line.403"></a>
-<span class="sourceLineNo">404</span>          System.exit(-1);<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        }<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        return null;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      }<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    });<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  }<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>  public void shutdown() {<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    if (pauseMonitor != null) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      pauseMonitor.stop();<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    }<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    if (tserver != null) {<a name="line.416"></a>
-<span class="sourceLineNo">417</span>      tserver.stop();<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      tserver = null;<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    if (httpServer != null) {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      try {<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        httpServer.stop();<a name="line.422"></a>
-<span class="sourceLineNo">423</span>        httpServer = null;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      } catch (Exception e) {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      }<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      httpServer = null;<a name="line.427"></a>
+<span class="sourceLineNo">383</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.383"></a>
+<span class="sourceLineNo">384</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.384"></a>
+<span class="sourceLineNo">385</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.385"></a>
+<span class="sourceLineNo">386</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.387"></a>
+<span class="sourceLineNo">388</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  }<a name="line.390"></a>
+<span class="sourceLineNo">391</span><a name="line.391"></a>
+<span class="sourceLineNo">392</span>  /*<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * Runs the Thrift server<a name="line.393"></a>
+<span class="sourceLineNo">394</span>   */<a name="line.394"></a>
+<span class="sourceLineNo">395</span>  @Override<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  public void run() {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      @Override<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      public Object run() {<a name="line.399"></a>
+<span class="sourceLineNo">400</span>        try {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>          pauseMonitor.start();<a name="line.401"></a>
+<span class="sourceLineNo">402</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>            setupHTTPServer();<a name="line.403"></a>
+<span class="sourceLineNo">404</span>            httpServer.start();<a name="line.404"></a>
+<span class="sourceLineNo">405</span>            httpServer.join();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>          } else {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>            setupServer();<a name="line.407"></a>
+<span class="sourceLineNo">408</span>            tserver.serve();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>          }<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        } catch (Exception e) {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>          // Crash the process if the ThriftServer is not running<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          System.exit(-1);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        return null;<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      }<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    });<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public void shutdown() {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    if (pauseMonitor != null) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      pauseMonitor.stop();<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    }<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    if (tserver != null) {<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      tserver.stop();<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      tserver = null;<a name="line.427"></a>
 <span class="sourceLineNo">428</span>    }<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private void setupHTTPServer() throws IOException {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.434"></a>
-<span class="sourceLineNo">435</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.435"></a>
-<span class="sourceLineNo">436</span><a name="line.436"></a>
-<span class="sourceLineNo">437</span>    // Set the default max thread number to 100 to limit<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.439"></a>
-<span class="sourceLineNo">440</span>    //<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.442"></a>
-<span class="sourceLineNo">443</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.443"></a>
-<span class="sourceLineNo">444</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.444"></a>
-<span class="sourceLineNo">445</span>    threadPool.setMinThreads(minThreads);<a name="line.445"></a>
-<span class="sourceLineNo">446</span>    httpServer = new Server(threadPool);<a name="line.446"></a>
-<span class="sourceLineNo">447</span><a name="line.447"></a>
-<span class="sourceLineNo">448</span>    // Context handler<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.449"></a>
-<span class="sourceLineNo">450</span>            ServletContextHandler.SESSIONS);<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>    // set up Jetty and run the embedded server<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    httpConfig.setSecureScheme("https");<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    httpConfig.setSecurePort(listenPort);<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    httpConfig.setSendServerVersion(false);<a name="line.461"></a>
-<span class="sourceLineNo">462</span>    httpConfig.setSendDateHeader(false);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span>    ServerConnector serverConnector;<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.467"></a>
-<span class="sourceLineNo">468</span><a name="line.468"></a>
-<span class="sourceLineNo">469</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.470"></a>
-<span class="sourceLineNo">471</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.471"></a>
-<span class="sourceLineNo">472</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.473"></a>
-<span class="sourceLineNo">474</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.476"></a>
-<span class="sourceLineNo">477</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      String[] excludeCiphers = conf.getStrings(<a name="line.479"></a>
-<span class="sourceLineNo">480</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      if (excludeCiphers.length != 0) {<a name="line.481"></a>
-<span class="sourceLineNo">482</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      }<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      String[] includeCiphers = conf.getStrings(<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>      if (includeCiphers.length != 0) {<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>      }<a name="line.488"></a>
-<span class="sourceLineNo">489</span><a name="line.489"></a>
-<span class="sourceLineNo">490</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.490"></a>
-<span class="sourceLineNo">491</span>      String[] excludeProtocols = conf.getStrings(<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.492"></a>
-<span class="sourceLineNo">493</span>      if (excludeProtocols.length != 0) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      }<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      String[] includeProtocols = conf.getStrings(<a name="line.496"></a>
-<span class="sourceLineNo">497</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      if (includeProtocols.length != 0) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      }<a name="line.500"></a>
-<span class="sourceLineNo">501</span><a name="line.501"></a>
-<span class="sourceLineNo">502</span>      serverConnector = new ServerConnector(httpServer,<a name="line.502"></a>
-<span class="sourceLineNo">503</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.503"></a>
-<span class="sourceLineNo">504</span>          new HttpConnectionFactory(httpsConfig));<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    } else {<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.506"></a>
-<span class="sourceLineNo">507</span>    }<a name="line.507"></a>
-<span class="sourceLineNo">508</span>    serverConnector.setPort(listenPort);<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    serverConnector.setHost(host);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    httpServer.addConnector(serverConnector);<a name="line.511"></a>
-<span class="sourceLineNo">512</span>    httpServer.setStopAtShutdown(true);<a name="line.512"></a>
-<span class="sourceLineNo">513</span><a name="line.513"></a>
-<span class="sourceLineNo">514</span>    if (doAsEnabled) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.515"></a>
+<span class="sourceLineNo">429</span>    if (httpServer != null) {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>      try {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        httpServer.stop();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        httpServer = null;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>      } catch (Exception e) {<a name="line.433"></a>
+<span class="sourceLineNo">434</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      }<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      httpServer = null;<a name="line.436"></a>
+<span class="sourceLineNo">437</span>    }<a name="line.437"></a>
+<span class="sourceLineNo">438</span>  }<a name="line.438"></a>
+<span class="sourceLineNo">439</span><a name="line.439"></a>
+<span class="sourceLineNo">440</span>  private void setupHTTPServer() throws IOException {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.442"></a>
+<span class="sourceLineNo">443</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.444"></a>
+<span class="sourceLineNo">445</span><a name="line.445"></a>
+<span class="sourceLineNo">446</span>    // Set the default max thread number to 100 to limit<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.448"></a>
+<span class="sourceLineNo">449</span>    //<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    threadPool.setMinThreads(minThreads);<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    httpServer = new Server(threadPool);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>    // Context handler<a name="line.457"></a>
+<span class="sourceLineNo">458</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.458"></a>
+<span class="sourceLineNo">459</span>            ServletContextHandler.SESSIONS);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.461"></a>
+<span class="sourceLineNo">462</span><a name="line.462"></a>
+<span class="sourceLineNo">463</span>    // set up Jetty and run the embedded server<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    httpConfig.setSecureScheme("https");<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    httpConfig.setSecurePort(listenPort);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    httpConfig.setSendServerVersion(false);<a name="line.470"></a>
+<span class="sourceLineNo">471</span>    httpConfig.setSendDateHeader(false);<a name="line.471"></a>
+<span class="sourceLineNo">472</span><a name="line.472"></a>
+<span class="sourceLineNo">473</span>    ServerConnector serverConnector;<a name="line.473"></a>
+<span class="sourceLineNo">474</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.476"></a>
+<span class="sourceLineNo">477</span><a name="line.477"></a>
+<span class="sourceLineNo">478</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.479"></a>
+<span class="sourceLineNo">480</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.482"></a>
+<span class="sourceLineNo">483</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.486"></a>
+<span class="sourceLineNo">487</span><a name="line.487"></a>
+<span class="sourceLineNo">488</span>      String[] excludeCiphers = conf.getStrings(<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>      if (excludeCiphers.length != 0) {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>      }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      String[] includeCiphers = conf.getStrings(<a name="line.493"></a>
+<span class="sourceLineNo">494</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      if (includeCiphers.length != 0) {<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      String[] excludeProtocols = conf.getStrings(<a name="line.500"></a>
+<span class="sourceLineNo">501</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      if (excludeProtocols.length != 0) {<a name="line.502"></a>
+<span class="sourceLineNo">503</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      }<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      String[] includeProtocols = conf.getStrings(<a name="line.505"></a>
+<span class="sourceLineNo">506</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.506"></a>
+<span class="sourceLineNo">507</span>      if (includeProtocols.length != 0) {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      }<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span>      serverConnector = new ServerConnector(httpServer,<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          new HttpConnectionFactory(httpsConfig));<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    } else {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.515"></a>
 <span class="sourceLineNo">516</span>    }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
-<span class="sourceLineNo">520</span><a name="line.520"></a>
-<span class="sourceLineNo">521</span>  /**<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * Setting up the thrift TServer<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   */<a name="line.523"></a>
-<span class="sourceLineNo">524</span>  private void setupServer() throws Exception {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>    // Construct correct ProtocolFactory<a name="line.525"></a>
-<span class="sourceLineNo">526</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.526"></a>
-<span class="sourceLineNo">527</span><a name="line.527"></a>
-<span class="sourceLineNo">528</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    TProcessor processor = p;<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>    // Construct correct TransportFactory<a name="line.532"></a>
-<span class="sourceLineNo">533</span>    TTransportFactory transportFactory;<a name="line.533"></a>
-<span class="sourceLineNo">534</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span>      if (qop != null) {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>        throw new RuntimeException("Thrift server authentication"<a name="line.536"></a>
-<span class="sourceLineNo">537</span>          + " doesn't work with framed transport yet");<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      }<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      transportFactory = new TFramedTransport.Factory(<a name="line.539"></a>
-<span class="sourceLineNo">540</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      LOG.debug("Using framed transport");<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    } else if (qop == null) {<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      transportFactory = new TTransportFactory();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>    } else {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      // Extract the name from the principal<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.546"></a>
-<span class="sourceLineNo">547</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        new SaslGssCallbackHandler() {<a name="line.551"></a>
-<span class="sourceLineNo">552</span>          @Override<a name="line.552"></a>
-<span class="sourceLineNo">553</span>          public void handle(Callback[] callbacks)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>              throws UnsupportedCallbackException {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>            AuthorizeCallback ac = null;<a name="line.555"></a>
-<span class="sourceLineNo">556</span>            for (Callback callback : callbacks) {<a name="line.556"></a>
-<span class="sourceLineNo">557</span>              if (callback instanceof AuthorizeCallback) {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>                ac = (AuthorizeCallback) callback;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>              } else {<a name="line.559"></a>
-<span class="sourceLineNo">560</span>                throw new UnsupportedCallbackException(callback,<a name="line.560"></a>
-<span class="sourceLineNo">561</span>                    "Unrecognized SASL GSSAPI Callback");<a name="line.561"></a>
-<span class="sourceLineNo">562</span>              }<a name="line.562"></a>
-<span class="sourceLineNo">563</span>            }<a name="line.563"></a>
-<span class="sourceLineNo">564</span>            if (ac != null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>              String authid = ac.getAuthenticationID();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>              String authzid = ac.getAuthorizationID();<a name="line.566"></a>
-<span class="sourceLineNo">567</span>              if (!authid.equals(authzid)) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>                ac.setAuthorized(false);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>              } else {<a name="line.569"></a>
-<span class="sourceLineNo">570</span>                ac.setAuthorized(true);<a name="line.570"></a>
-<span class="sourceLineNo">571</span>                String userName = SecurityUtil.getUserFromPrincipal(authzid);<a name="line.571"></a>
-<span class="sourceLineNo">572</span>                LOG.info("Effective user: " + userName);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>                ac.setAuthorizedID(userName);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>              }<a name="line.574"></a>
-<span class="sourceLineNo">575</span>            }<a name="line.575"></a>
-<span class="sourceLineNo">576</span>          }<a name="line.576"></a>
-<span class="sourceLineNo">577</span>        });<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      transportFactory = saslFactory;<a name="line.578"></a>
-<span class="sourceLineNo">579</span><a name="line.579"></a>
-<span class="sourceLineNo">580</span>      // Create a processor wrapper, to get the caller<a name="line.580"></a>
-<span class="sourceLineNo">581</span>      processor = new TProcessor() {<a name="line.581"></a>
-<span class="sourceLineNo">582</span>        @Override<a name="line.582"></a>
-<span class="sourceLineNo">583</span>        public boolean process(TProtocol inProt,<a name="line.583"></a>
-<span class="sourceLineNo">584</span>            TProtocol outProt) throws TException {<a name="line.584"></a>
-<span class="sourceLineNo">585</span>          TSaslServerTransport saslServerTransport =<a name="line.585"></a>
-<span class="sourceLineNo">586</span>            (TSaslServerTransport)inProt.getTransport();<a name="line.586"></a>
-<span class="sourceLineNo">587</span>          SaslServer saslServer = saslServerTransport.getSaslServer();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>          String principal = saslServer.getAuthorizationID();<a name="line.588"></a>
-<span class="sourceLineNo">589</span>          hbaseHandler.setEffectiveUser(principal);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>          return p.process(inProt, outProt);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        }<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      };<a name="line.592"></a>
-<span class="sourceLineNo">593</span>    }<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    if (conf.get(BIND_CONF_KEY) != null &amp;&amp; !implType.canSpecifyBindIP) {<a name="line.595"></a>
-<span class="sourceLineNo">596</span>      LOG.error("Server types " + Joiner.on(", ").join(<a name="line.596"></a>
-<span class="sourceLineNo">597</span>          ImplType.serversThatCannotSpecifyBindIP()) + " don't support IP " +<a name="line.597"></a>
-<span class="sourceLineNo">598</span>          "address binding at the moment. See " +<a name="line.598"></a>
-<span class="sourceLineNo">599</span>          "https://issues.apache.org/jira/browse/HBASE-2155 for details.");<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      throw new RuntimeException(<a name="line.600"></a>
-<span class="sourceLineNo">601</span>          "-" + BIND_CONF_KEY + " not supported with " + implType);<a name="line.601"></a>
+<span class="sourceLineNo">517</span>    serverConnector.setPort(listenPort);<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    serverConnector.setHost(host);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>    httpServer.addConnector(serverConnector);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>    httpServer.setStopAtShutdown(true);<a name="line.521"></a>
+<span class="sourceLineNo">522</span><a name="line.522"></a>
+<span class="sourceLineNo">523</span>    if (doAsEnabled) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.524"></a>
+<span class="sourceLineNo">525</span>    }<a name="line.525"></a>
+<span class="sourceLineNo">526</span><a name="line.526"></a>
+<span class="sourceLineNo">527</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.527"></a>
+<span class="sourceLineNo">528</span>  }<a name="line.528"></a>
+<span class="sourceLineNo">529</span><a name="line.529"></a>
+<span class="sourceLineNo">530</span>  /**<a name="line.530"></a>
+<span class="sourceLineNo">531</span>   * Setting up the thrift TServer<a name="line.531"></a>
+<span class="sourceLineNo">532</span>   */<a name="line.532"></a>
+<span class="sourceLineNo">533</span>  private void setupServer() throws Exception {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>    // Construct correct ProtocolFactory<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    TProcessor processor = p;<a name="line.539"></a>
+<span class="sourceLineNo">540</span><a name="line.540"></a>
+<span class="sourceLineNo">541</span>    // Construct correct TransportFactory<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    TTransportFactory transportFactory;<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      if (qop != null) {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>        throw new RuntimeException("Thrift server authentication"<a name="line.545"></a>
+<span class="sourceLineNo">546</span>          + " doesn't work with framed transport yet");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      }<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      transportFactory = new TFramedTransport.Factory(<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      LOG.debug("Using framed transport");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>    } else if (qop == null) {<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      transportFactory = new TTransportFactory();<a name="line.552"></a>
+<span class="sourceLineNo">553</span>    } else {<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Extract the name from the principal<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.555"></a>
+<span class="sourceLineNo">556</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.557"></a>
+<span class="sourceLineNo">558</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.559"></a>
+<span class="sourceLineNo">560</span>        new SaslGssCallbackHandler() {<a name="line.560"></a>
+<span class="sourceLineNo">561</span>          @Override<a name="line.561"></a>
+<span class="sourceLineNo">562</span>          public void handle(Callback[] callbacks)<a name="line.562"></a>
+<span class="sourceLineNo">563</span>              throws UnsupportedCallbackException {<a name="line.563"></a>
+<span class="sourceLineNo">564<

<TRUNCATED>

[10/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html b/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
index 993c1ea..2c6f38a 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
@@ -27,1043 +27,1040 @@
 <span class="sourceLineNo">019</span><a name="line.19"></a>
 <span class="sourceLineNo">020</span>package org.apache.hadoop.hbase.coprocessor;<a name="line.20"></a>
 <span class="sourceLineNo">021</span><a name="line.21"></a>
-<span class="sourceLineNo">022</span>import edu.umd.cs.findbugs.annotations.NonNull;<a name="line.22"></a>
-<span class="sourceLineNo">023</span><a name="line.23"></a>
-<span class="sourceLineNo">024</span>import java.io.IOException;<a name="line.24"></a>
-<span class="sourceLineNo">025</span>import java.util.List;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import java.util.Map;<a name="line.26"></a>
-<span class="sourceLineNo">027</span><a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.Cell;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.CompareOperator;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.client.Append;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.client.Delete;<a name="line.34"></a>
-<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.client.Durability;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.Get;<a name="line.36"></a>
-<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.client.Increment;<a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.38"></a>
-<span class="sourceLineNo">039</span>import org.apache.hadoop.hbase.client.Put;<a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.40"></a>
-<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.client.Result;<a name="line.41"></a>
-<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.client.Scan;<a name="line.42"></a>
-<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.filter.ByteArrayComparable;<a name="line.43"></a>
-<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.io.FSDataInputStreamWrapper;<a name="line.44"></a>
-<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.io.Reference;<a name="line.45"></a>
-<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.io.hfile.CacheConfig;<a name="line.46"></a>
-<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.regionserver.FlushLifeCycleTracker;<a name="line.47"></a>
-<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.regionserver.InternalScanner;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.regionserver.MiniBatchOperationInProgress;<a name="line.49"></a>
-<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.regionserver.OperationStatus;<a name="line.50"></a>
-<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.regionserver.Region;<a name="line.51"></a>
-<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.regionserver.Region.Operation;<a name="line.52"></a>
-<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.regionserver.RegionScanner;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.regionserver.ScanOptions;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.regionserver.ScanType;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.hbase.regionserver.Store;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.hbase.regionserver.StoreFile;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.regionserver.StoreFileReader;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionLifeCycleTracker;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.regionserver.querymatcher.DeleteTracker;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.wal.WALEdit;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.wal.WALKey;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span>/**<a name="line.68"></a>
-<span class="sourceLineNo">069</span> * Coprocessors implement this interface to observe and mediate client actions on the region.<a name="line.69"></a>
-<span class="sourceLineNo">070</span> * &lt;p&gt;<a name="line.70"></a>
-<span class="sourceLineNo">071</span> * Since most implementations will be interested in only a subset of hooks, this class uses<a name="line.71"></a>
-<span class="sourceLineNo">072</span> * 'default' functions to avoid having to add unnecessary overrides. When the functions are<a name="line.72"></a>
-<span class="sourceLineNo">073</span> * non-empty, it's simply to satisfy the compiler by returning value of expected (non-void) type. It<a name="line.73"></a>
-<span class="sourceLineNo">074</span> * is done in a way that these default definitions act as no-op. So our suggestion to implementation<a name="line.74"></a>
-<span class="sourceLineNo">075</span> * would be to not call these 'default' methods from overrides.<a name="line.75"></a>
-<span class="sourceLineNo">076</span> * &lt;p&gt;<a name="line.76"></a>
-<span class="sourceLineNo">077</span> * &lt;h3&gt;Exception Handling&lt;/h3&gt;&lt;br&gt;<a name="line.77"></a>
-<span class="sourceLineNo">078</span> * For all functions, exception handling is done as follows:<a name="line.78"></a>
-<span class="sourceLineNo">079</span> * &lt;ul&gt;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> * &lt;li&gt;Exceptions of type {@link IOException} are reported back to client.&lt;/li&gt;<a name="line.80"></a>
-<span class="sourceLineNo">081</span> * &lt;li&gt;For any other kind of exception:<a name="line.81"></a>
-<span class="sourceLineNo">082</span> * &lt;ul&gt;<a name="line.82"></a>
-<span class="sourceLineNo">083</span> * &lt;li&gt;If the configuration {@link CoprocessorHost#ABORT_ON_ERROR_KEY} is set to true, then the<a name="line.83"></a>
-<span class="sourceLineNo">084</span> * server aborts.&lt;/li&gt;<a name="line.84"></a>
-<span class="sourceLineNo">085</span> * &lt;li&gt;Otherwise, coprocessor is removed from the server and<a name="line.85"></a>
-<span class="sourceLineNo">086</span> * {@link org.apache.hadoop.hbase.DoNotRetryIOException} is returned to the client.&lt;/li&gt;<a name="line.86"></a>
+<span class="sourceLineNo">022</span>import java.io.IOException;<a name="line.22"></a>
+<span class="sourceLineNo">023</span>import java.util.List;<a name="line.23"></a>
+<span class="sourceLineNo">024</span>import java.util.Map;<a name="line.24"></a>
+<span class="sourceLineNo">025</span><a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.Cell;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.CompareOperator;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.client.Append;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.client.Delete;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.client.Durability;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.client.Get;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.client.Increment;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.client.Put;<a name="line.37"></a>
+<span class="sourceLineNo">038</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.apache.hadoop.hbase.client.Result;<a name="line.39"></a>
+<span class="sourceLineNo">040</span>import org.apache.hadoop.hbase.client.Scan;<a name="line.40"></a>
+<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.filter.ByteArrayComparable;<a name="line.41"></a>
+<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.io.FSDataInputStreamWrapper;<a name="line.42"></a>
+<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.io.Reference;<a name="line.43"></a>
+<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.io.hfile.CacheConfig;<a name="line.44"></a>
+<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.regionserver.FlushLifeCycleTracker;<a name="line.45"></a>
+<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.regionserver.InternalScanner;<a name="line.46"></a>
+<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.regionserver.MiniBatchOperationInProgress;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.regionserver.OperationStatus;<a name="line.48"></a>
+<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.regionserver.Region;<a name="line.49"></a>
+<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.regionserver.Region.Operation;<a name="line.50"></a>
+<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.regionserver.RegionScanner;<a name="line.51"></a>
+<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.regionserver.ScanOptions;<a name="line.52"></a>
+<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.regionserver.ScanType;<a name="line.53"></a>
+<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.regionserver.Store;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.regionserver.StoreFile;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.hbase.regionserver.StoreFileReader;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionLifeCycleTracker;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.regionserver.querymatcher.DeleteTracker;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.wal.WALEdit;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.wal.WALKey;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.64"></a>
+<span class="sourceLineNo">065</span><a name="line.65"></a>
+<span class="sourceLineNo">066</span>/**<a name="line.66"></a>
+<span class="sourceLineNo">067</span> * Coprocessors implement this interface to observe and mediate client actions on the region.<a name="line.67"></a>
+<span class="sourceLineNo">068</span> * &lt;p&gt;<a name="line.68"></a>
+<span class="sourceLineNo">069</span> * Since most implementations will be interested in only a subset of hooks, this class uses<a name="line.69"></a>
+<span class="sourceLineNo">070</span> * 'default' functions to avoid having to add unnecessary overrides. When the functions are<a name="line.70"></a>
+<span class="sourceLineNo">071</span> * non-empty, it's simply to satisfy the compiler by returning value of expected (non-void) type. It<a name="line.71"></a>
+<span class="sourceLineNo">072</span> * is done in a way that these default definitions act as no-op. So our suggestion to implementation<a name="line.72"></a>
+<span class="sourceLineNo">073</span> * would be to not call these 'default' methods from overrides.<a name="line.73"></a>
+<span class="sourceLineNo">074</span> * &lt;p&gt;<a name="line.74"></a>
+<span class="sourceLineNo">075</span> * &lt;h3&gt;Exception Handling&lt;/h3&gt;&lt;br&gt;<a name="line.75"></a>
+<span class="sourceLineNo">076</span> * For all functions, exception handling is done as follows:<a name="line.76"></a>
+<span class="sourceLineNo">077</span> * &lt;ul&gt;<a name="line.77"></a>
+<span class="sourceLineNo">078</span> * &lt;li&gt;Exceptions of type {@link IOException} are reported back to client.&lt;/li&gt;<a name="line.78"></a>
+<span class="sourceLineNo">079</span> * &lt;li&gt;For any other kind of exception:<a name="line.79"></a>
+<span class="sourceLineNo">080</span> * &lt;ul&gt;<a name="line.80"></a>
+<span class="sourceLineNo">081</span> * &lt;li&gt;If the configuration {@link CoprocessorHost#ABORT_ON_ERROR_KEY} is set to true, then the<a name="line.81"></a>
+<span class="sourceLineNo">082</span> * server aborts.&lt;/li&gt;<a name="line.82"></a>
+<span class="sourceLineNo">083</span> * &lt;li&gt;Otherwise, coprocessor is removed from the server and<a name="line.83"></a>
+<span class="sourceLineNo">084</span> * {@link org.apache.hadoop.hbase.DoNotRetryIOException} is returned to the client.&lt;/li&gt;<a name="line.84"></a>
+<span class="sourceLineNo">085</span> * &lt;/ul&gt;<a name="line.85"></a>
+<span class="sourceLineNo">086</span> * &lt;/li&gt;<a name="line.86"></a>
 <span class="sourceLineNo">087</span> * &lt;/ul&gt;<a name="line.87"></a>
-<span class="sourceLineNo">088</span> * &lt;/li&gt;<a name="line.88"></a>
-<span class="sourceLineNo">089</span> * &lt;/ul&gt;<a name="line.89"></a>
-<span class="sourceLineNo">090</span> * &lt;p&gt;<a name="line.90"></a>
-<span class="sourceLineNo">091</span> * &lt;h3&gt;For Split Related Hooks&lt;/h3&gt; &lt;br&gt;<a name="line.91"></a>
-<span class="sourceLineNo">092</span> * In hbase2/AMv2, master runs splits, so the split related hooks are moved to<a name="line.92"></a>
-<span class="sourceLineNo">093</span> * {@link MasterObserver}.<a name="line.93"></a>
-<span class="sourceLineNo">094</span> * &lt;p&gt;<a name="line.94"></a>
-<span class="sourceLineNo">095</span> * &lt;h3&gt;Increment Column Value&lt;/h3&gt;&lt;br&gt;<a name="line.95"></a>
-<span class="sourceLineNo">096</span> * We do not call this hook anymore.<a name="line.96"></a>
-<span class="sourceLineNo">097</span> */<a name="line.97"></a>
-<span class="sourceLineNo">098</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.COPROC)<a name="line.98"></a>
-<span class="sourceLineNo">099</span>@InterfaceStability.Evolving<a name="line.99"></a>
-<span class="sourceLineNo">100</span>// TODO as method signatures need to break, update to<a name="line.100"></a>
-<span class="sourceLineNo">101</span>// ObserverContext&lt;? extends RegionCoprocessorEnvironment&gt;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>// so we can use additional environment state that isn't exposed to coprocessors.<a name="line.102"></a>
-<span class="sourceLineNo">103</span>public interface RegionObserver {<a name="line.103"></a>
-<span class="sourceLineNo">104</span>  /** Mutation type for postMutationBeforeWAL hook */<a name="line.104"></a>
-<span class="sourceLineNo">105</span>  enum MutationType {<a name="line.105"></a>
-<span class="sourceLineNo">106</span>    APPEND, INCREMENT<a name="line.106"></a>
-<span class="sourceLineNo">107</span>  }<a name="line.107"></a>
-<span class="sourceLineNo">108</span><a name="line.108"></a>
-<span class="sourceLineNo">109</span>  /**<a name="line.109"></a>
-<span class="sourceLineNo">110</span>   * Called before the region is reported as open to the master.<a name="line.110"></a>
-<span class="sourceLineNo">111</span>   * @param c the environment provided by the region server<a name="line.111"></a>
-<span class="sourceLineNo">112</span>   */<a name="line.112"></a>
-<span class="sourceLineNo">113</span>  default void preOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) throws IOException {}<a name="line.113"></a>
-<span class="sourceLineNo">114</span><a name="line.114"></a>
-<span class="sourceLineNo">115</span>  /**<a name="line.115"></a>
-<span class="sourceLineNo">116</span>   * Called after the region is reported as open to the master.<a name="line.116"></a>
-<span class="sourceLineNo">117</span>   * @param c the environment provided by the region server<a name="line.117"></a>
-<span class="sourceLineNo">118</span>   */<a name="line.118"></a>
-<span class="sourceLineNo">119</span>  default void postOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) {}<a name="line.119"></a>
-<span class="sourceLineNo">120</span><a name="line.120"></a>
-<span class="sourceLineNo">121</span>  /**<a name="line.121"></a>
-<span class="sourceLineNo">122</span>   * Called before the memstore is flushed to disk.<a name="line.122"></a>
-<span class="sourceLineNo">123</span>   * @param c the environment provided by the region server<a name="line.123"></a>
-<span class="sourceLineNo">124</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.124"></a>
-<span class="sourceLineNo">125</span>   */<a name="line.125"></a>
-<span class="sourceLineNo">126</span>  default void preFlush(final ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.126"></a>
-<span class="sourceLineNo">127</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.127"></a>
-<span class="sourceLineNo">128</span><a name="line.128"></a>
-<span class="sourceLineNo">129</span>  /**<a name="line.129"></a>
-<span class="sourceLineNo">130</span>   * Called before we open store scanner for flush. You can use the {@code options} to change max<a name="line.130"></a>
-<span class="sourceLineNo">131</span>   * versions and TTL for the scanner being opened.<a name="line.131"></a>
-<span class="sourceLineNo">132</span>   * @param c the environment provided by the region server<a name="line.132"></a>
-<span class="sourceLineNo">133</span>   * @param store the store where flush is being requested<a name="line.133"></a>
-<span class="sourceLineNo">134</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.134"></a>
-<span class="sourceLineNo">135</span>   */<a name="line.135"></a>
-<span class="sourceLineNo">136</span>  default void preFlushScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.136"></a>
-<span class="sourceLineNo">137</span>      ScanOptions options,FlushLifeCycleTracker tracker) throws IOException {}<a name="line.137"></a>
-<span class="sourceLineNo">138</span><a name="line.138"></a>
-<span class="sourceLineNo">139</span>  /**<a name="line.139"></a>
-<span class="sourceLineNo">140</span>   * Called before a Store's memstore is flushed to disk.<a name="line.140"></a>
-<span class="sourceLineNo">141</span>   * @param c the environment provided by the region server<a name="line.141"></a>
-<span class="sourceLineNo">142</span>   * @param store the store where flush is being requested<a name="line.142"></a>
-<span class="sourceLineNo">143</span>   * @param scanner the scanner over existing data used in the memstore<a name="line.143"></a>
-<span class="sourceLineNo">144</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.144"></a>
-<span class="sourceLineNo">145</span>   * @return the scanner to use during flush. Should not be {@code null} unless the implementation<a name="line.145"></a>
-<span class="sourceLineNo">146</span>   *         is writing new store files on its own.<a name="line.146"></a>
-<span class="sourceLineNo">147</span>   */<a name="line.147"></a>
-<span class="sourceLineNo">148</span>  default InternalScanner preFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.148"></a>
-<span class="sourceLineNo">149</span>      InternalScanner scanner, FlushLifeCycleTracker tracker) throws IOException {<a name="line.149"></a>
-<span class="sourceLineNo">150</span>    return scanner;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>  }<a name="line.151"></a>
-<span class="sourceLineNo">152</span><a name="line.152"></a>
-<span class="sourceLineNo">153</span>  /**<a name="line.153"></a>
-<span class="sourceLineNo">154</span>   * Called after the memstore is flushed to disk.<a name="line.154"></a>
-<span class="sourceLineNo">155</span>   * @param c the environment provided by the region server<a name="line.155"></a>
-<span class="sourceLineNo">156</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.156"></a>
-<span class="sourceLineNo">157</span>   * @throws IOException if an error occurred on the coprocessor<a name="line.157"></a>
-<span class="sourceLineNo">158</span>   */<a name="line.158"></a>
-<span class="sourceLineNo">159</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  /**<a name="line.162"></a>
-<span class="sourceLineNo">163</span>   * Called after a Store's memstore is flushed to disk.<a name="line.163"></a>
-<span class="sourceLineNo">164</span>   * @param c the environment provided by the region server<a name="line.164"></a>
-<span class="sourceLineNo">165</span>   * @param store the store being flushed<a name="line.165"></a>
-<span class="sourceLineNo">166</span>   * @param resultFile the new store file written out during compaction<a name="line.166"></a>
-<span class="sourceLineNo">167</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.167"></a>
-<span class="sourceLineNo">168</span>   */<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.169"></a>
-<span class="sourceLineNo">170</span>      StoreFile resultFile, FlushLifeCycleTracker tracker) throws IOException {}<a name="line.170"></a>
-<span class="sourceLineNo">171</span><a name="line.171"></a>
-<span class="sourceLineNo">172</span>  /**<a name="line.172"></a>
-<span class="sourceLineNo">173</span>   * Called before in memory compaction started.<a name="line.173"></a>
-<span class="sourceLineNo">174</span>   * @param c the environment provided by the region server<a name="line.174"></a>
-<span class="sourceLineNo">175</span>   * @param store the store where in memory compaction is being requested<a name="line.175"></a>
-<span class="sourceLineNo">176</span>   */<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  default void preMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.177"></a>
-<span class="sourceLineNo">178</span>      throws IOException {}<a name="line.178"></a>
-<span class="sourceLineNo">179</span><a name="line.179"></a>
-<span class="sourceLineNo">180</span>  /**<a name="line.180"></a>
-<span class="sourceLineNo">181</span>   * Called before we open store scanner for in memory compaction. You can use the {@code options}<a name="line.181"></a>
-<span class="sourceLineNo">182</span>   * to change max versions and TTL for the scanner being opened. Notice that this method will only<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * be called when you use {@code eager} mode. For {@code basic} mode we will not drop any cells<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * thus we do not open a store scanner.<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * @param c the environment provided by the region server<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   * @param store the store where in memory compaction is being requested<a name="line.186"></a>
-<span class="sourceLineNo">187</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.187"></a>
-<span class="sourceLineNo">188</span>   */<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  default void preMemStoreCompactionCompactScannerOpen(<a name="line.189"></a>
-<span class="sourceLineNo">190</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, ScanOptions options)<a name="line.190"></a>
-<span class="sourceLineNo">191</span>      throws IOException {}<a name="line.191"></a>
-<span class="sourceLineNo">192</span><a name="line.192"></a>
-<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * Called before we do in memory compaction. Notice that this method will only be called when you<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * use {@code eager} mode. For {@code basic} mode we will not drop any cells thus there is no<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * {@link InternalScanner}.<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   * @param c the environment provided by the region server<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * @param store the store where in memory compaction is being executed<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * @param scanner the scanner over existing data used in the memstore segments being compact<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   * @return the scanner to use during in memory compaction. Must be non-null.<a name="line.200"></a>
-<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  @NonNull<a name="line.202"></a>
-<span class="sourceLineNo">203</span>  default InternalScanner preMemStoreCompactionCompact(<a name="line.203"></a>
-<span class="sourceLineNo">204</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, InternalScanner scanner)<a name="line.204"></a>
-<span class="sourceLineNo">205</span>      throws IOException {<a name="line.205"></a>
-<span class="sourceLineNo">206</span>    return scanner;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  }<a name="line.207"></a>
-<span class="sourceLineNo">208</span><a name="line.208"></a>
-<span class="sourceLineNo">209</span>  /**<a name="line.209"></a>
-<span class="sourceLineNo">210</span>   * Called after the in memory compaction is finished.<a name="line.210"></a>
-<span class="sourceLineNo">211</span>   * @param c the environment provided by the region server<a name="line.211"></a>
-<span class="sourceLineNo">212</span>   * @param store the store where in memory compaction is being executed<a name="line.212"></a>
-<span class="sourceLineNo">213</span>   */<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  default void postMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.214"></a>
-<span class="sourceLineNo">215</span>      throws IOException {}<a name="line.215"></a>
-<span class="sourceLineNo">216</span><a name="line.216"></a>
-<span class="sourceLineNo">217</span>  /**<a name="line.217"></a>
-<span class="sourceLineNo">218</span>   * Called prior to selecting the {@link StoreFile StoreFiles} to compact from the list of<a name="line.218"></a>
-<span class="sourceLineNo">219</span>   * available candidates. To alter the files used for compaction, you may mutate the passed in list<a name="line.219"></a>
-<span class="sourceLineNo">220</span>   * of candidates. If you remove all the candidates then the compaction will be canceled.<a name="line.220"></a>
-<span class="sourceLineNo">221</span>   * &lt;p&gt;Supports Coprocessor 'bypass' -- 'bypass' is how this method indicates that it changed<a name="line.221"></a>
-<span class="sourceLineNo">222</span>   * the passed in &lt;code&gt;candidates&lt;/code&gt;.<a name="line.222"></a>
-<span class="sourceLineNo">223</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.223"></a>
-<span class="sourceLineNo">224</span>   * @param c the environment provided by the region server<a name="line.224"></a>
-<span class="sourceLineNo">225</span>   * @param store the store where compaction is being requested<a name="line.225"></a>
-<span class="sourceLineNo">226</span>   * @param candidates the store files currently available for compaction<a name="line.226"></a>
-<span class="sourceLineNo">227</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.227"></a>
-<span class="sourceLineNo">228</span>   */<a name="line.228"></a>
-<span class="sourceLineNo">229</span>  default void preCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.229"></a>
-<span class="sourceLineNo">230</span>      List&lt;? extends StoreFile&gt; candidates, CompactionLifeCycleTracker tracker)<a name="line.230"></a>
-<span class="sourceLineNo">231</span>      throws IOException {}<a name="line.231"></a>
-<span class="sourceLineNo">232</span><a name="line.232"></a>
-<span class="sourceLineNo">233</span>  /**<a name="line.233"></a>
-<span class="sourceLineNo">234</span>   * Called after the {@link StoreFile}s to compact have been selected from the available<a name="line.234"></a>
-<span class="sourceLineNo">235</span>   * candidates.<a name="line.235"></a>
-<span class="sourceLineNo">236</span>   * @param c the environment provided by the region server<a name="line.236"></a>
-<span class="sourceLineNo">237</span>   * @param store the store being compacted<a name="line.237"></a>
-<span class="sourceLineNo">238</span>   * @param selected the store files selected to compact<a name="line.238"></a>
-<span class="sourceLineNo">239</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.239"></a>
-<span class="sourceLineNo">240</span>   * @param request the requested compaction<a name="line.240"></a>
-<span class="sourceLineNo">241</span>   */<a name="line.241"></a>
-<span class="sourceLineNo">242</span>  default void postCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      List&lt;? extends StoreFile&gt; selected, CompactionLifeCycleTracker tracker,<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      CompactionRequest request) {}<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span>  /**<a name="line.246"></a>
-<span class="sourceLineNo">247</span>   * Called before we open store scanner for compaction. You can use the {@code options} to change max<a name="line.247"></a>
-<span class="sourceLineNo">248</span>   * versions and TTL for the scanner being opened.<a name="line.248"></a>
-<span class="sourceLineNo">249</span>   * @param c the environment provided by the region server<a name="line.249"></a>
-<span class="sourceLineNo">250</span>   * @param store the store being compacted<a name="line.250"></a>
-<span class="sourceLineNo">251</span>   * @param scanType type of Scan<a name="line.251"></a>
-<span class="sourceLineNo">252</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.252"></a>
-<span class="sourceLineNo">253</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.253"></a>
-<span class="sourceLineNo">254</span>   * @param request the requested compaction<a name="line.254"></a>
-<span class="sourceLineNo">255</span>   */<a name="line.255"></a>
-<span class="sourceLineNo">256</span>  default void preCompactScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.256"></a>
-<span class="sourceLineNo">257</span>      ScanType scanType, ScanOptions options, CompactionLifeCycleTracker tracker,<a name="line.257"></a>
-<span class="sourceLineNo">258</span>      CompactionRequest request) throws IOException {}<a name="line.258"></a>
-<span class="sourceLineNo">259</span><a name="line.259"></a>
-<span class="sourceLineNo">260</span>  /**<a name="line.260"></a>
-<span class="sourceLineNo">261</span>   * Called prior to writing the {@link StoreFile}s selected for compaction into a new<a name="line.261"></a>
-<span class="sourceLineNo">262</span>   * {@code StoreFile}.<a name="line.262"></a>
-<span class="sourceLineNo">263</span>   * &lt;p&gt;<a name="line.263"></a>
-<span class="sourceLineNo">264</span>   * To override or modify the compaction process, implementing classes can wrap the provided<a name="line.264"></a>
-<span class="sourceLineNo">265</span>   * {@link InternalScanner} with a custom implementation that is returned from this method. The<a name="line.265"></a>
-<span class="sourceLineNo">266</span>   * custom scanner can then inspect {@link org.apache.hadoop.hbase.Cell}s from the wrapped scanner,<a name="line.266"></a>
-<span class="sourceLineNo">267</span>   * applying its own policy to what gets written.<a name="line.267"></a>
-<span class="sourceLineNo">268</span>   * @param c the environment provided by the region server<a name="line.268"></a>
-<span class="sourceLineNo">269</span>   * @param store the store being compacted<a name="line.269"></a>
-<span class="sourceLineNo">270</span>   * @param scanner the scanner over existing data used in the store file rewriting<a name="line.270"></a>
-<span class="sourceLineNo">271</span>   * @param scanType type of Scan<a name="line.271"></a>
-<span class="sourceLineNo">272</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.272"></a>
-<span class="sourceLineNo">273</span>   * @param request the requested compaction<a name="line.273"></a>
-<span class="sourceLineNo">274</span>   * @return the scanner to use during compaction. Should not be {@code null} unless the<a name="line.274"></a>
-<span class="sourceLineNo">275</span>   *         implementation is writing new store files on its own.<a name="line.275"></a>
-<span class="sourceLineNo">276</span>   */<a name="line.276"></a>
-<span class="sourceLineNo">277</span>  default InternalScanner preCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.277"></a>
-<span class="sourceLineNo">278</span>      InternalScanner scanner, ScanType scanType, CompactionLifeCycleTracker tracker,<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      CompactionRequest request) throws IOException {<a name="line.279"></a>
-<span class="sourceLineNo">280</span>    return scanner;<a name="line.280"></a>
-<span class="sourceLineNo">281</span>  }<a name="line.281"></a>
-<span class="sourceLineNo">282</span><a name="line.282"></a>
-<span class="sourceLineNo">283</span>  /**<a name="line.283"></a>
-<span class="sourceLineNo">284</span>   * Called after compaction has completed and the new store file has been moved in to place.<a name="line.284"></a>
-<span class="sourceLineNo">285</span>   * @param c the environment provided by the region server<a name="line.285"></a>
-<span class="sourceLineNo">286</span>   * @param store the store being compacted<a name="line.286"></a>
-<span class="sourceLineNo">287</span>   * @param resultFile the new store file written out during compaction<a name="line.287"></a>
-<span class="sourceLineNo">288</span>   * @param tracker used to track the life cycle of a compaction<a name="line.288"></a>
-<span class="sourceLineNo">289</span>   * @param request the requested compaction<a name="line.289"></a>
-<span class="sourceLineNo">290</span>   */<a name="line.290"></a>
-<span class="sourceLineNo">291</span>  default void postCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.291"></a>
-<span class="sourceLineNo">292</span>      StoreFile resultFile, CompactionLifeCycleTracker tracker, CompactionRequest request)<a name="line.292"></a>
-<span class="sourceLineNo">293</span>      throws IOException {}<a name="line.293"></a>
-<span class="sourceLineNo">294</span><a name="line.294"></a>
-<span class="sourceLineNo">295</span>  /**<a name="line.295"></a>
-<span class="sourceLineNo">296</span>   * Called before the region is reported as closed to the master.<a name="line.296"></a>
-<span class="sourceLineNo">297</span>   * @param c the environment provided by the region server<a name="line.297"></a>
-<span class="sourceLineNo">298</span>   * @param abortRequested true if the region server is aborting<a name="line.298"></a>
-<span class="sourceLineNo">299</span>   */<a name="line.299"></a>
-<span class="sourceLineNo">300</span>  default void preClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested)<a name="line.300"></a>
-<span class="sourceLineNo">301</span>      throws IOException {}<a name="line.301"></a>
-<span class="sourceLineNo">302</span><a name="line.302"></a>
-<span class="sourceLineNo">303</span>  /**<a name="line.303"></a>
-<span class="sourceLineNo">304</span>   * Called after the region is reported as closed to the master.<a name="line.304"></a>
-<span class="sourceLineNo">305</span>   * @param c the environment provided by the region server<a name="line.305"></a>
-<span class="sourceLineNo">306</span>   * @param abortRequested true if the region server is aborting<a name="line.306"></a>
-<span class="sourceLineNo">307</span>   */<a name="line.307"></a>
-<span class="sourceLineNo">308</span>  default void postClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested) {}<a name="line.308"></a>
-<span class="sourceLineNo">309</span><a name="line.309"></a>
-<span class="sourceLineNo">310</span>  /**<a name="line.310"></a>
-<span class="sourceLineNo">311</span>   * Called before the client performs a Get<a name="line.311"></a>
-<span class="sourceLineNo">312</span>   * &lt;p&gt;<a name="line.312"></a>
-<span class="sourceLineNo">313</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.313"></a>
-<span class="sourceLineNo">314</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.314"></a>
-<span class="sourceLineNo">315</span>   * @param c the environment provided by the region server<a name="line.315"></a>
-<span class="sourceLineNo">316</span>   * @param get the Get request<a name="line.316"></a>
-<span class="sourceLineNo">317</span>   * @param result The result to return to the client if default processing<a name="line.317"></a>
-<span class="sourceLineNo">318</span>   * is bypassed. Can be modified. Will not be used if default processing<a name="line.318"></a>
-<span class="sourceLineNo">319</span>   * is not bypassed.<a name="line.319"></a>
-<span class="sourceLineNo">320</span>   */<a name="line.320"></a>
-<span class="sourceLineNo">321</span>  default void preGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get, List&lt;Cell&gt; result)<a name="line.321"></a>
-<span class="sourceLineNo">322</span>      throws IOException {}<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  /**<a name="line.324"></a>
-<span class="sourceLineNo">325</span>   * Called after the client performs a Get<a name="line.325"></a>
-<span class="sourceLineNo">326</span>   * &lt;p&gt;<a name="line.326"></a>
-<span class="sourceLineNo">327</span>   * Note: Do not retain references to any Cells in 'result' beyond the life of this invocation.<a name="line.327"></a>
-<span class="sourceLineNo">328</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.328"></a>
-<span class="sourceLineNo">329</span>   * @param c the environment provided by the region server<a name="line.329"></a>
-<span class="sourceLineNo">330</span>   * @param get the Get request<a name="line.330"></a>
-<span class="sourceLineNo">331</span>   * @param result the result to return to the client, modify as necessary<a name="line.331"></a>
-<span class="sourceLineNo">332</span>   */<a name="line.332"></a>
-<span class="sourceLineNo">333</span>  default void postGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.333"></a>
-<span class="sourceLineNo">334</span>      List&lt;Cell&gt; result) throws IOException {}<a name="line.334"></a>
-<span class="sourceLineNo">335</span><a name="line.335"></a>
-<span class="sourceLineNo">336</span>  /**<a name="line.336"></a>
-<span class="sourceLineNo">337</span>   * Called before the client tests for existence using a Get.<a name="line.337"></a>
-<span class="sourceLineNo">338</span>   * &lt;p&gt;<a name="line.338"></a>
-<span class="sourceLineNo">339</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.339"></a>
-<span class="sourceLineNo">340</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.340"></a>
-<span class="sourceLineNo">341</span>   * @param c the environment provided by the region server<a name="line.341"></a>
-<span class="sourceLineNo">342</span>   * @param get the Get request<a name="line.342"></a>
-<span class="sourceLineNo">343</span>   * @param exists the result returned by the region server<a name="line.343"></a>
-<span class="sourceLineNo">344</span>   * @return the value to return to the client if bypassing default processing<a name="line.344"></a>
-<span class="sourceLineNo">345</span>   */<a name="line.345"></a>
-<span class="sourceLineNo">346</span>  default boolean preExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      boolean exists) throws IOException {<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    return exists;<a name="line.348"></a>
-<span class="sourceLineNo">349</span>  }<a name="line.349"></a>
-<span class="sourceLineNo">350</span><a name="line.350"></a>
-<span class="sourceLineNo">351</span>  /**<a name="line.351"></a>
-<span class="sourceLineNo">352</span>   * Called after the client tests for existence using a Get.<a name="line.352"></a>
-<span class="sourceLineNo">353</span>   * @param c the environment provided by the region server<a name="line.353"></a>
-<span class="sourceLineNo">354</span>   * @param get the Get request<a name="line.354"></a>
-<span class="sourceLineNo">355</span>   * @param exists the result returned by the region server<a name="line.355"></a>
-<span class="sourceLineNo">356</span>   * @return the result to return to the client<a name="line.356"></a>
-<span class="sourceLineNo">357</span>   */<a name="line.357"></a>
-<span class="sourceLineNo">358</span>  default boolean postExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.358"></a>
-<span class="sourceLineNo">359</span>      boolean exists) throws IOException {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>    return exists;<a name="line.360"></a>
-<span class="sourceLineNo">361</span>  }<a name="line.361"></a>
-<span class="sourceLineNo">362</span><a name="line.362"></a>
-<span class="sourceLineNo">363</span>  /**<a name="line.363"></a>
-<span class="sourceLineNo">364</span>   * Called before the client stores a value.<a name="line.364"></a>
+<span class="sourceLineNo">088</span> * &lt;p&gt;<a name="line.88"></a>
+<span class="sourceLineNo">089</span> * &lt;h3&gt;For Split Related Hooks&lt;/h3&gt; &lt;br&gt;<a name="line.89"></a>
+<span class="sourceLineNo">090</span> * In hbase2/AMv2, master runs splits, so the split related hooks are moved to<a name="line.90"></a>
+<span class="sourceLineNo">091</span> * {@link MasterObserver}.<a name="line.91"></a>
+<span class="sourceLineNo">092</span> * &lt;p&gt;<a name="line.92"></a>
+<span class="sourceLineNo">093</span> * &lt;h3&gt;Increment Column Value&lt;/h3&gt;&lt;br&gt;<a name="line.93"></a>
+<span class="sourceLineNo">094</span> * We do not call this hook anymore.<a name="line.94"></a>
+<span class="sourceLineNo">095</span> */<a name="line.95"></a>
+<span class="sourceLineNo">096</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.COPROC)<a name="line.96"></a>
+<span class="sourceLineNo">097</span>@InterfaceStability.Evolving<a name="line.97"></a>
+<span class="sourceLineNo">098</span>// TODO as method signatures need to break, update to<a name="line.98"></a>
+<span class="sourceLineNo">099</span>// ObserverContext&lt;? extends RegionCoprocessorEnvironment&gt;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>// so we can use additional environment state that isn't exposed to coprocessors.<a name="line.100"></a>
+<span class="sourceLineNo">101</span>public interface RegionObserver {<a name="line.101"></a>
+<span class="sourceLineNo">102</span>  /** Mutation type for postMutationBeforeWAL hook */<a name="line.102"></a>
+<span class="sourceLineNo">103</span>  enum MutationType {<a name="line.103"></a>
+<span class="sourceLineNo">104</span>    APPEND, INCREMENT<a name="line.104"></a>
+<span class="sourceLineNo">105</span>  }<a name="line.105"></a>
+<span class="sourceLineNo">106</span><a name="line.106"></a>
+<span class="sourceLineNo">107</span>  /**<a name="line.107"></a>
+<span class="sourceLineNo">108</span>   * Called before the region is reported as open to the master.<a name="line.108"></a>
+<span class="sourceLineNo">109</span>   * @param c the environment provided by the region server<a name="line.109"></a>
+<span class="sourceLineNo">110</span>   */<a name="line.110"></a>
+<span class="sourceLineNo">111</span>  default void preOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) throws IOException {}<a name="line.111"></a>
+<span class="sourceLineNo">112</span><a name="line.112"></a>
+<span class="sourceLineNo">113</span>  /**<a name="line.113"></a>
+<span class="sourceLineNo">114</span>   * Called after the region is reported as open to the master.<a name="line.114"></a>
+<span class="sourceLineNo">115</span>   * @param c the environment provided by the region server<a name="line.115"></a>
+<span class="sourceLineNo">116</span>   */<a name="line.116"></a>
+<span class="sourceLineNo">117</span>  default void postOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) {}<a name="line.117"></a>
+<span class="sourceLineNo">118</span><a name="line.118"></a>
+<span class="sourceLineNo">119</span>  /**<a name="line.119"></a>
+<span class="sourceLineNo">120</span>   * Called before the memstore is flushed to disk.<a name="line.120"></a>
+<span class="sourceLineNo">121</span>   * @param c the environment provided by the region server<a name="line.121"></a>
+<span class="sourceLineNo">122</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.122"></a>
+<span class="sourceLineNo">123</span>   */<a name="line.123"></a>
+<span class="sourceLineNo">124</span>  default void preFlush(final ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.124"></a>
+<span class="sourceLineNo">125</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.125"></a>
+<span class="sourceLineNo">126</span><a name="line.126"></a>
+<span class="sourceLineNo">127</span>  /**<a name="line.127"></a>
+<span class="sourceLineNo">128</span>   * Called before we open store scanner for flush. You can use the {@code options} to change max<a name="line.128"></a>
+<span class="sourceLineNo">129</span>   * versions and TTL for the scanner being opened.<a name="line.129"></a>
+<span class="sourceLineNo">130</span>   * @param c the environment provided by the region server<a name="line.130"></a>
+<span class="sourceLineNo">131</span>   * @param store the store where flush is being requested<a name="line.131"></a>
+<span class="sourceLineNo">132</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.132"></a>
+<span class="sourceLineNo">133</span>   */<a name="line.133"></a>
+<span class="sourceLineNo">134</span>  default void preFlushScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.134"></a>
+<span class="sourceLineNo">135</span>      ScanOptions options,FlushLifeCycleTracker tracker) throws IOException {}<a name="line.135"></a>
+<span class="sourceLineNo">136</span><a name="line.136"></a>
+<span class="sourceLineNo">137</span>  /**<a name="line.137"></a>
+<span class="sourceLineNo">138</span>   * Called before a Store's memstore is flushed to disk.<a name="line.138"></a>
+<span class="sourceLineNo">139</span>   * @param c the environment provided by the region server<a name="line.139"></a>
+<span class="sourceLineNo">140</span>   * @param store the store where flush is being requested<a name="line.140"></a>
+<span class="sourceLineNo">141</span>   * @param scanner the scanner over existing data used in the memstore<a name="line.141"></a>
+<span class="sourceLineNo">142</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.142"></a>
+<span class="sourceLineNo">143</span>   * @return the scanner to use during flush. Should not be {@code null} unless the implementation<a name="line.143"></a>
+<span class="sourceLineNo">144</span>   *         is writing new store files on its own.<a name="line.144"></a>
+<span class="sourceLineNo">145</span>   */<a name="line.145"></a>
+<span class="sourceLineNo">146</span>  default InternalScanner preFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.146"></a>
+<span class="sourceLineNo">147</span>      InternalScanner scanner, FlushLifeCycleTracker tracker) throws IOException {<a name="line.147"></a>
+<span class="sourceLineNo">148</span>    return scanner;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>  }<a name="line.149"></a>
+<span class="sourceLineNo">150</span><a name="line.150"></a>
+<span class="sourceLineNo">151</span>  /**<a name="line.151"></a>
+<span class="sourceLineNo">152</span>   * Called after the memstore is flushed to disk.<a name="line.152"></a>
+<span class="sourceLineNo">153</span>   * @param c the environment provided by the region server<a name="line.153"></a>
+<span class="sourceLineNo">154</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.154"></a>
+<span class="sourceLineNo">155</span>   * @throws IOException if an error occurred on the coprocessor<a name="line.155"></a>
+<span class="sourceLineNo">156</span>   */<a name="line.156"></a>
+<span class="sourceLineNo">157</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.157"></a>
+<span class="sourceLineNo">158</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  /**<a name="line.160"></a>
+<span class="sourceLineNo">161</span>   * Called after a Store's memstore is flushed to disk.<a name="line.161"></a>
+<span class="sourceLineNo">162</span>   * @param c the environment provided by the region server<a name="line.162"></a>
+<span class="sourceLineNo">163</span>   * @param store the store being flushed<a name="line.163"></a>
+<span class="sourceLineNo">164</span>   * @param resultFile the new store file written out during compaction<a name="line.164"></a>
+<span class="sourceLineNo">165</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.165"></a>
+<span class="sourceLineNo">166</span>   */<a name="line.166"></a>
+<span class="sourceLineNo">167</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.167"></a>
+<span class="sourceLineNo">168</span>      StoreFile resultFile, FlushLifeCycleTracker tracker) throws IOException {}<a name="line.168"></a>
+<span class="sourceLineNo">169</span><a name="line.169"></a>
+<span class="sourceLineNo">170</span>  /**<a name="line.170"></a>
+<span class="sourceLineNo">171</span>   * Called before in memory compaction started.<a name="line.171"></a>
+<span class="sourceLineNo">172</span>   * @param c the environment provided by the region server<a name="line.172"></a>
+<span class="sourceLineNo">173</span>   * @param store the store where in memory compaction is being requested<a name="line.173"></a>
+<span class="sourceLineNo">174</span>   */<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  default void preMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.175"></a>
+<span class="sourceLineNo">176</span>      throws IOException {}<a name="line.176"></a>
+<span class="sourceLineNo">177</span><a name="line.177"></a>
+<span class="sourceLineNo">178</span>  /**<a name="line.178"></a>
+<span class="sourceLineNo">179</span>   * Called before we open store scanner for in memory compaction. You can use the {@code options}<a name="line.179"></a>
+<span class="sourceLineNo">180</span>   * to change max versions and TTL for the scanner being opened. Notice that this method will only<a name="line.180"></a>
+<span class="sourceLineNo">181</span>   * be called when you use {@code eager} mode. For {@code basic} mode we will not drop any cells<a name="line.181"></a>
+<span class="sourceLineNo">182</span>   * thus we do not open a store scanner.<a name="line.182"></a>
+<span class="sourceLineNo">183</span>   * @param c the environment provided by the region server<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * @param store the store where in memory compaction is being requested<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
+<span class="sourceLineNo">187</span>  default void preMemStoreCompactionCompactScannerOpen(<a name="line.187"></a>
+<span class="sourceLineNo">188</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, ScanOptions options)<a name="line.188"></a>
+<span class="sourceLineNo">189</span>      throws IOException {}<a name="line.189"></a>
+<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">191</span>  /**<a name="line.191"></a>
+<span class="sourceLineNo">192</span>   * Called before we do in memory compaction. Notice that this method will only be called when you<a name="line.192"></a>
+<span class="sourceLineNo">193</span>   * use {@code eager} mode. For {@code basic} mode we will not drop any cells thus there is no<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * {@link InternalScanner}.<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * @param c the environment provided by the region server<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * @param store the store where in memory compaction is being executed<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * @param scanner the scanner over existing data used in the memstore segments being compact<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   * @return the scanner to use during in memory compaction. Must be non-null.<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   */<a name="line.199"></a>
+<span class="sourceLineNo">200</span>  default InternalScanner preMemStoreCompactionCompact(<a name="line.200"></a>
+<span class="sourceLineNo">201</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, InternalScanner scanner)<a name="line.201"></a>
+<span class="sourceLineNo">202</span>      throws IOException {<a name="line.202"></a>
+<span class="sourceLineNo">203</span>    return scanner;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>  }<a name="line.204"></a>
+<span class="sourceLineNo">205</span><a name="line.205"></a>
+<span class="sourceLineNo">206</span>  /**<a name="line.206"></a>
+<span class="sourceLineNo">207</span>   * Called after the in memory compaction is finished.<a name="line.207"></a>
+<span class="sourceLineNo">208</span>   * @param c the environment provided by the region server<a name="line.208"></a>
+<span class="sourceLineNo">209</span>   * @param store the store where in memory compaction is being executed<a name="line.209"></a>
+<span class="sourceLineNo">210</span>   */<a name="line.210"></a>
+<span class="sourceLineNo">211</span>  default void postMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.211"></a>
+<span class="sourceLineNo">212</span>      throws IOException {}<a name="line.212"></a>
+<span class="sourceLineNo">213</span><a name="line.213"></a>
+<span class="sourceLineNo">214</span>  /**<a name="line.214"></a>
+<span class="sourceLineNo">215</span>   * Called prior to selecting the {@link StoreFile StoreFiles} to compact from the list of<a name="line.215"></a>
+<span class="sourceLineNo">216</span>   * available candidates. To alter the files used for compaction, you may mutate the passed in list<a name="line.216"></a>
+<span class="sourceLineNo">217</span>   * of candidates. If you remove all the candidates then the compaction will be canceled.<a name="line.217"></a>
+<span class="sourceLineNo">218</span>   * &lt;p&gt;Supports Coprocessor 'bypass' -- 'bypass' is how this method indicates that it changed<a name="line.218"></a>
+<span class="sourceLineNo">219</span>   * the passed in &lt;code&gt;candidates&lt;/code&gt;.<a name="line.219"></a>
+<span class="sourceLineNo">220</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.220"></a>
+<span class="sourceLineNo">221</span>   * @param c the environment provided by the region server<a name="line.221"></a>
+<span class="sourceLineNo">222</span>   * @param store the store where compaction is being requested<a name="line.222"></a>
+<span class="sourceLineNo">223</span>   * @param candidates the store files currently available for compaction<a name="line.223"></a>
+<span class="sourceLineNo">224</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.224"></a>
+<span class="sourceLineNo">225</span>   */<a name="line.225"></a>
+<span class="sourceLineNo">226</span>  default void preCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.226"></a>
+<span class="sourceLineNo">227</span>      List&lt;? extends StoreFile&gt; candidates, CompactionLifeCycleTracker tracker)<a name="line.227"></a>
+<span class="sourceLineNo">228</span>      throws IOException {}<a name="line.228"></a>
+<span class="sourceLineNo">229</span><a name="line.229"></a>
+<span class="sourceLineNo">230</span>  /**<a name="line.230"></a>
+<span class="sourceLineNo">231</span>   * Called after the {@link StoreFile}s to compact have been selected from the available<a name="line.231"></a>
+<span class="sourceLineNo">232</span>   * candidates.<a name="line.232"></a>
+<span class="sourceLineNo">233</span>   * @param c the environment provided by the region server<a name="line.233"></a>
+<span class="sourceLineNo">234</span>   * @param store the store being compacted<a name="line.234"></a>
+<span class="sourceLineNo">235</span>   * @param selected the store files selected to compact<a name="line.235"></a>
+<span class="sourceLineNo">236</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.236"></a>
+<span class="sourceLineNo">237</span>   * @param request the requested compaction<a name="line.237"></a>
+<span class="sourceLineNo">238</span>   */<a name="line.238"></a>
+<span class="sourceLineNo">239</span>  default void postCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.239"></a>
+<span class="sourceLineNo">240</span>      List&lt;? extends StoreFile&gt; selected, CompactionLifeCycleTracker tracker,<a name="line.240"></a>
+<span class="sourceLineNo">241</span>      CompactionRequest request) {}<a name="line.241"></a>
+<span class="sourceLineNo">242</span><a name="line.242"></a>
+<span class="sourceLineNo">243</span>  /**<a name="line.243"></a>
+<span class="sourceLineNo">244</span>   * Called before we open store scanner for compaction. You can use the {@code options} to change max<a name="line.244"></a>
+<span class="sourceLineNo">245</span>   * versions and TTL for the scanner being opened.<a name="line.245"></a>
+<span class="sourceLineNo">246</span>   * @param c the environment provided by the region server<a name="line.246"></a>
+<span class="sourceLineNo">247</span>   * @param store the store being compacted<a name="line.247"></a>
+<span class="sourceLineNo">248</span>   * @param scanType type of Scan<a name="line.248"></a>
+<span class="sourceLineNo">249</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.249"></a>
+<span class="sourceLineNo">250</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.250"></a>
+<span class="sourceLineNo">251</span>   * @param request the requested compaction<a name="line.251"></a>
+<span class="sourceLineNo">252</span>   */<a name="line.252"></a>
+<span class="sourceLineNo">253</span>  default void preCompactScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.253"></a>
+<span class="sourceLineNo">254</span>      ScanType scanType, ScanOptions options, CompactionLifeCycleTracker tracker,<a name="line.254"></a>
+<span class="sourceLineNo">255</span>      CompactionRequest request) throws IOException {}<a name="line.255"></a>
+<span class="sourceLineNo">256</span><a name="line.256"></a>
+<span class="sourceLineNo">257</span>  /**<a name="line.257"></a>
+<span class="sourceLineNo">258</span>   * Called prior to writing the {@link StoreFile}s selected for compaction into a new<a name="line.258"></a>
+<span class="sourceLineNo">259</span>   * {@code StoreFile}.<a name="line.259"></a>
+<span class="sourceLineNo">260</span>   * &lt;p&gt;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>   * To override or modify the compaction process, implementing classes can wrap the provided<a name="line.261"></a>
+<span class="sourceLineNo">262</span>   * {@link InternalScanner} with a custom implementation that is returned from this method. The<a name="line.262"></a>
+<span class="sourceLineNo">263</span>   * custom scanner can then inspect {@link org.apache.hadoop.hbase.Cell}s from the wrapped scanner,<a name="line.263"></a>
+<span class="sourceLineNo">264</span>   * applying its own policy to what gets written.<a name="line.264"></a>
+<span class="sourceLineNo">265</span>   * @param c the environment provided by the region server<a name="line.265"></a>
+<span class="sourceLineNo">266</span>   * @param store the store being compacted<a name="line.266"></a>
+<span class="sourceLineNo">267</span>   * @param scanner the scanner over existing data used in the store file rewriting<a name="line.267"></a>
+<span class="sourceLineNo">268</span>   * @param scanType type of Scan<a name="line.268"></a>
+<span class="sourceLineNo">269</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.269"></a>
+<span class="sourceLineNo">270</span>   * @param request the requested compaction<a name="line.270"></a>
+<span class="sourceLineNo">271</span>   * @return the scanner to use during compaction. Should not be {@code null} unless the<a name="line.271"></a>
+<span class="sourceLineNo">272</span>   *         implementation is writing new store files on its own.<a name="line.272"></a>
+<span class="sourceLineNo">273</span>   */<a name="line.273"></a>
+<span class="sourceLineNo">274</span>  default InternalScanner preCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      InternalScanner scanner, ScanType scanType, CompactionLifeCycleTracker tracker,<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      CompactionRequest request) throws IOException {<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    return scanner;<a name="line.277"></a>
+<span class="sourceLineNo">278</span>  }<a name="line.278"></a>
+<span class="sourceLineNo">279</span><a name="line.279"></a>
+<span class="sourceLineNo">280</span>  /**<a name="line.280"></a>
+<span class="sourceLineNo">281</span>   * Called after compaction has completed and the new store file has been moved in to place.<a name="line.281"></a>
+<span class="sourceLineNo">282</span>   * @param c the environment provided by the region server<a name="line.282"></a>
+<span class="sourceLineNo">283</span>   * @param store the store being compacted<a name="line.283"></a>
+<span class="sourceLineNo">284</span>   * @param resultFile the new store file written out during compaction<a name="line.284"></a>
+<span class="sourceLineNo">285</span>   * @param tracker used to track the life cycle of a compaction<a name="line.285"></a>
+<span class="sourceLineNo">286</span>   * @param request the requested compaction<a name="line.286"></a>
+<span class="sourceLineNo">287</span>   */<a name="line.287"></a>
+<span class="sourceLineNo">288</span>  default void postCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      StoreFile resultFile, CompactionLifeCycleTracker tracker, CompactionRequest request)<a name="line.289"></a>
+<span class="sourceLineNo">290</span>      throws IOException {}<a name="line.290"></a>
+<span class="sourceLineNo">291</span><a name="line.291"></a>
+<span class="sourceLineNo">292</span>  /**<a name="line.292"></a>
+<span class="sourceLineNo">293</span>   * Called before the region is reported as closed to the master.<a name="line.293"></a>
+<span class="sourceLineNo">294</span>   * @param c the environment provided by the region server<a name="line.294"></a>
+<span class="sourceLineNo">295</span>   * @param abortRequested true if the region server is aborting<a name="line.295"></a>
+<span class="sourceLineNo">296</span>   */<a name="line.296"></a>
+<span class="sourceLineNo">297</span>  default void preClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested)<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      throws IOException {}<a name="line.298"></a>
+<span class="sourceLineNo">299</span><a name="line.299"></a>
+<span class="sourceLineNo">300</span>  /**<a name="line.300"></a>
+<span class="sourceLineNo">301</span>   * Called after the region is reported as closed to the master.<a name="line.301"></a>
+<span class="sourceLineNo">302</span>   * @param c the environment provided by the region server<a name="line.302"></a>
+<span class="sourceLineNo">303</span>   * @param abortRequested true if the region server is aborting<a name="line.303"></a>
+<span class="sourceLineNo">304</span>   */<a name="line.304"></a>
+<span class="sourceLineNo">305</span>  default void postClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested) {}<a name="line.305"></a>
+<span class="sourceLineNo">306</span><a name="line.306"></a>
+<span class="sourceLineNo">307</span>  /**<a name="line.307"></a>
+<span class="sourceLineNo">308</span>   * Called before the client performs a Get<a name="line.308"></a>
+<span class="sourceLineNo">309</span>   * &lt;p&gt;<a name="line.309"></a>
+<span class="sourceLineNo">310</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.310"></a>
+<span class="sourceLineNo">311</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.311"></a>
+<span class="sourceLineNo">312</span>   * @param c the environment provided by the region server<a name="line.312"></a>
+<span class="sourceLineNo">313</span>   * @param get the Get request<a name="line.313"></a>
+<span class="sourceLineNo">314</span>   * @param result The result to return to the client if default processing<a name="line.314"></a>
+<span class="sourceLineNo">315</span>   * is bypassed. Can be modified. Will not be used if default processing<a name="line.315"></a>
+<span class="sourceLineNo">316</span>   * is not bypassed.<a name="line.316"></a>
+<span class="sourceLineNo">317</span>   */<a name="line.317"></a>
+<span class="sourceLineNo">318</span>  default void preGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get, List&lt;Cell&gt; result)<a name="line.318"></a>
+<span class="sourceLineNo">319</span>      throws IOException {}<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>  /**<a name="line.321"></a>
+<span class="sourceLineNo">322</span>   * Called after the client performs a Get<a name="line.322"></a>
+<span class="sourceLineNo">323</span>   * &lt;p&gt;<a name="line.323"></a>
+<span class="sourceLineNo">324</span>   * Note: Do not retain references to any Cells in 'result' beyond the life of this invocation.<a name="line.324"></a>
+<span class="sourceLineNo">325</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.325"></a>
+<span class="sourceLineNo">326</span>   * @param c the environment provided by the region server<a name="line.326"></a>
+<span class="sourceLineNo">327</span>   * @param get the Get request<a name="line.327"></a>
+<span class="sourceLineNo">328</span>   * @param result the result to return to the client, modify as necessary<a name="line.328"></a>
+<span class="sourceLineNo">329</span>   */<a name="line.329"></a>
+<span class="sourceLineNo">330</span>  default void postGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.330"></a>
+<span class="sourceLineNo">331</span>      List&lt;Cell&gt; result) throws IOException {}<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  /**<a name="line.333"></a>
+<span class="sourceLineNo">334</span>   * Called before the client tests for existence using a Get.<a name="line.334"></a>
+<span class="sourceLineNo">335</span>   * &lt;p&gt;<a name="line.335"></a>
+<span class="sourceLineNo">336</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.336"></a>
+<span class="sourceLineNo">337</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.337"></a>
+<span class="sourceLineNo">338</span>   * @param c the environment provided by the region server<a name="line.338"></a>
+<span class="sourceLineNo">339</span>   * @param get the Get request<a name="line.339"></a>
+<span class="sourceLineNo">340</span>   * @param exists the result returned by the region server<a name="line.340"></a>
+<span class="sourceLineNo">341</span>   * @return the value to return to the client if bypassing default processing<a name="line.341"></a>
+<span class="sourceLineNo">342</span>   */<a name="line.342"></a>
+<span class="sourceLineNo">343</span>  default boolean preExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.343"></a>
+<span class="sourceLineNo">344</span>      boolean exists) throws IOException {<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    return exists;<a name="line.345"></a>
+<span class="sourceLineNo">346</span>  }<a name="line.346"></a>
+<span class="sourceLineNo">347</span><a name="line.347"></a>
+<span class="sourceLineNo">348</span>  /**<a name="line.348"></a>
+<span class="sourceLineNo">349</span>   * Called after the client tests for existence using a Get.<a name="line.349"></a>
+<span class="sourceLineNo">350</span>   * @param c the environment provided by the region server<a name="line.350"></a>
+<span class="sourceLineNo">351</span>   * @param get the Get request<a name="line.351"></a>
+<span class="sourceLineNo">352</span>   * @param exists the result returned by the region server<a name="line.352"></a>
+<span class="sourceLineNo">353</span>   * @return the result to return to the client<a name="line.353"></a>
+<span class="sourceLineNo">354</span>   */<a name="line.354"></a>
+<span class="sourceLineNo">355</span>  default boolean postExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      boolean exists) throws IOException {<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    return exists;<a name="line.357"></a>
+<span class="sourceLineNo">358</span>  }<a name="line.358"></a>
+<span class="sourceLineNo">359</span><a name="line.359"></a>
+<span class="sourceLineNo">360</span>  /**<a name="line.360"></a>
+<span class="sourceLineNo">361</span>   * Called before the client stores a value.<a name="line.361"></a>
+<span class="sourceLineNo">362</span>   * &lt;p&gt;<a name="line.362"></a>
+<span class="sourceLineNo">363</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.363"></a>
+<span class="sourceLineNo">364</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.364"></a>
 <span class="sourceLineNo">365</span>   * &lt;p&gt;<a name="line.365"></a>
-<span class="sourceLineNo">366</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.366"></a>
-<span class="sourceLineNo">367</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.367"></a>
-<span class="sourceLineNo">368</span>   * &lt;p&gt;<a name="line.368"></a>
-<span class="sourceLineNo">369</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.369"></a>
-<span class="sourceLineNo">370</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.370"></a>
-<span class="sourceLineNo">371</span>   * @param c the environment provided by the region server<a name="line.371"></a>
-<span class="sourceLineNo">372</span>   * @param put The Put object<a name="line.372"></a>
-<span class="sourceLineNo">373</span>   * @param edit The WALEdit object that will be written to the wal<a name="line.373"></a>
-<span class="sourceLineNo">374</span>   * @param durability Persistence guarantee for this Put<a name="line.374"></a>
-<span class="sourceLineNo">375</span>   */<a name="line.375"></a>
-<span class="sourceLineNo">376</span>  default void prePut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.376"></a>
-<span class="sourceLineNo">377</span>      Durability durability) throws IOException {}<a name="line.377"></a>
-<span class="sourceLineNo">378</span><a name="line.378"></a>
-<span class="sourceLineNo">379</span>  /**<a name="line.379"></a>
-<span class="sourceLineNo">380</span>   * Called after the client stores a value.<a name="line.380"></a>
-<span class="sourceLineNo">381</span>   * &lt;p&gt;<a name="line.381"></a>
-<span class="sourceLineNo">382</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.382"></a>
-<span class="sourceLineNo">383</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * @param c the environment provided by the region server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   * @param put The Put object<a name="line.385"></a>
-<span class="sourceLineNo">386</span>   * @param edit The WALEdit object for the wal<a name="line.386"></a>
-<span class="sourceLineNo">387</span>   * @param durability Persistence guarantee for this Put<a name="line.387"></a>
-<span class="sourceLineNo">388</span>   */<a name="line.388"></a>
-<span class="sourceLineNo">389</span>  default void postPut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      Durability durability) throws IOException {}<a name="line.390"></a>
-<span class="sourceLineNo">391</span><a name="line.391"></a>
-<span class="sourceLineNo">392</span>  /**<a name="line.392"></a>
-<span class="sourceLineNo">393</span>   * Called before the client deletes a value.<a name="line.393"></a>
+<span class="sourceLineNo">366</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.366"></a>
+<span class="sourceLineNo">367</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.367"></a>
+<span class="sourceLineNo">368</span>   * @param c the environment provided by the region server<a name="line.368"></a>
+<span class="sourceLineNo">369</span>   * @param put The Put object<a name="line.369"></a>
+<span class="sourceLineNo">370</span>   * @param edit The WALEdit object that will be written to the wal<a name="line.370"></a>
+<span class="sourceLineNo">371</span>   * @param durability Persistence guarantee for this Put<a name="line.371"></a>
+<span class="sourceLineNo">372</span>   */<a name="line.372"></a>
+<span class="sourceLineNo">373</span>  default void prePut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      Durability durability) throws IOException {}<a name="line.374"></a>
+<span class="sourceLineNo">375</span><a name="line.375"></a>
+<span class="sourceLineNo">376</span>  /**<a name="line.376"></a>
+<span class="sourceLineNo">377</span>   * Called after the client stores a value.<a name="line.377"></a>
+<span class="sourceLineNo">378</span>   * &lt;p&gt;<a name="line.378"></a>
+<span class="sourceLineNo">379</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.379"></a>
+<span class="sourceLineNo">380</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.380"></a>
+<span class="sourceLineNo">381</span>   * @param c the environment provided by the region server<a name="line.381"></a>
+<span class="sourceLineNo">382</span>   * @param put The Put object<a name="line.382"></a>
+<span class="sourceLineNo">383</span>   * @param edit The WALEdit object for the wal<a name="line.383"></a>
+<span class="sourceLineNo">384</span>   * @param durability Persistence guarantee for this Put<a name="line.384"></a>
+<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
+<span class="sourceLineNo">386</span>  default void postPut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      Durability durability) throws IOException {}<a name="line.387"></a>
+<span class="sourceLineNo">388</span><a name="line.388"></a>
+<span class="sourceLineNo">389</span>  /**<a name="line.389"></a>
+<span class="sourceLineNo">390</span>   * Called before the client deletes a value.<a name="line.390"></a>
+<span class="sourceLineNo">391</span>   * &lt;p&gt;<a name="line.391"></a>
+<span class="sourceLineNo">392</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.393"></a>
 <span class="sourceLineNo">394</span>   * &lt;p&gt;<a name="line.394"></a>
-<span class="sourceLineNo">395</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.395"></a>
-<span class="sourceLineNo">396</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.396"></a>
-<span class="sourceLineNo">397</span>   * &lt;p&gt;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>   * Note: Do not retain references to any Cells in 'delete' beyond the life of this invocation.<a name="line.398"></a>
-<span class="sourceLineNo">399</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.399"></a>
-<span class="sourceLineNo">400</span>   * @param c the environment provided by the region server<a name="line.400"></a>
-<span class="sourceLineNo">401</span>   * @param delete The Delete object<a name="line.401"></a>
-<span class="sourceLineNo">402</span>   * @param edit The WALEdit object for the wal<a name="line.402"></a>
-<span class="sourceLineNo">403</span>   * @param durability Persistence guarantee for this Delete<a name="line.403"></a>
-<span class="sourceLineNo">404</span>   */<a name="line.404"></a>
-<span class="sourceLineNo">405</span>  default void preDelete(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Delete delete,<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      WALEdit edit, Durability durability) throws IOException {}<a name="line.406"></a>
-<span class="sourceLineNo">407</span><a name="line.407"></a>
-<span class="sourceLineNo">408</span>  /**<a name="line.408"></a>
-<span class="sourceLineNo">409</span>   * Called before the server updates the timestamp for version delete with latest timestamp.<a name="line.409"></a>
-<span class="sourceLineNo">410</span>   * &lt;p&gt;<a name="line.410"></a>
-<span class="sourceLineNo">411</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.411"></a>
-<span class="sourceLineNo">412</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.412"></a>
-<span class="sourceLineNo">413</span>   * @param c the environment provided by the region server<a name="line.413"></a>
-<span class="sourceLineNo">414</span>   * @param mutation - the parent mutation associated with this delete cell<a name="line.414"></a>
-<span class="sourceLineNo">415</span>   * @param cell - The deleteColumn with latest version cell<a name="line.415"></a>
-<span class="sourceLineNo">416</span>   * @param byteNow - timestamp bytes<a name="line.416"></a>
-<span class="sourceLineNo">417</span>   * @param get - the get formed using the current cell's row. Note that the get does not specify<a name="line.417"></a>
-<span class="sourceLineNo">418</span>   *          the family and qualifier<a name="line.418"></a>
-<span class="sourceLineNo">419</span>   * @deprecated Since hbase-2.0.0. No replacement. To be removed in hbase-3.0.0 and replaced<a name="line.419"></a>
-<span class="sourceLineNo">420</span>   * with something that doesn't expose IntefaceAudience.Private classes.<a name="line.420"></a>
-<span class="sourceLineNo">421</span>   */<a name="line.421"></a>
-<span class="sourceLineNo">422</span>  @Deprecated<a name="line.422"></a>
-<span class="sourceLineNo">423</span>  default void prePrepareTimeStampForDeleteVersion(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      Mutation mutation, Cell cell, byte[] byteNow, Get get) throws IOException {}<a name="line.424"></a>
-<span class="sourceLineNo">425</span><a name="line.425"></a>
-<span class="sourceLineNo">426</span>  /**<a name="line.426"></a>
-<span class="sourceLineNo">427</span>   * Called after the client deletes a value.<a name="line.427"></a>
-<span class="sourceLineNo">428</span>   * &lt;p&gt;<a name="line.428"></a>
-<span class="sourceLineNo">429</span>   * Note: Do not retain references to any Cells in 'delete' beyond the life of this invocation.<a name="line.429"></a>
-<span class="sourceLineNo">430</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.430"></a>
-<span class="sourceLineNo">431</span>   * @param c the environment provided by the region server<a name="line.431"></a>
-<span class="sourceLineNo">432</span>   * @param delete The Delete object<a name="line.432"></a>
-<span class="sourceLineNo">433</span>   * @param edit The WALEdit object for the wal<a name="line.433"></a>
-<span class="sourceLineNo">434</span>   * @param durability Persistence guarantee for this Delete<a name="line.434"></a>
-<span class="sourceLineNo">435</span>   */<a name="line.435"></a>
-<span class="sourceLineNo">436</span>  default void postDelete(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Delete delete,<a name="line.436"></a>
-<span class="sourceLineNo">437</span>      WALEdit edit, Durability durability) throws IOException {}<a name="line.437"></a>
-<span class="sourceLineNo">438</span><a name="line.438"></a>
-<span class="sourceLineNo">439</span>  /**<a name="line.439"></a>
-<span class="sourceLineNo">440</span>   * This will be called for every batch mutation operation happening at the server. This will be<a name="line.440"></a>
-<span class="sourceLineNo">441</span>   * called after acquiring the locks on the mutating rows and after applying the proper timestamp<a name="line.441"></a>
-<span class="sourceLineNo">442</span>   * for each Mutation at the server. The batch may contain Put/Delete. By setting OperationStatus<a name="line.442"></a>
-<span class="sourceLineNo">443</span>   * of Mutations ({@link MiniBatchOperationInProgress#setOperationStatus(int, OperationStatus)}),<a name="line.443"></a>
-<span class="sourceLineNo">444</span>   * {@link RegionObserver} can make Region to skip these Mutations.<a name="line.444"></a>
-<span class="sourceLineNo">445</span>   * &lt;p&gt;<a name="line.445"></a>
-<span class="sourceLineNo">446</span>   * Note: Do not retain references to any Cells in Mutations beyond the life of this invocation.<a name="line.446"></a>
-<span class="sourceLineNo">447</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.447"></a>
-<span class="sourceLineNo">448</span>   * @param c the environment provided by the region server<a name="line.448"></a>
-<span class="sourceLineNo">449</span>   * @param miniBatchOp batch of Mutations getting applied to region.<a name="line.449"></a>
-<span class="sourceLineNo">450</span>   */<a name="line.450"></a>
-<span class="sourceLineNo">451</span>  default void preBatchMutate(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.451"></a>
-<span class="sourceLineNo">452</span>      MiniBatchOperationInProgress&lt;Mutation&gt; miniBatchOp) throws IOException {}<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>  /**<a name="line.454"></a>
-<span class="sourceLineNo">455</span>   * This will be called after applying a batch of Mutations on a region. The Mutations are added to<a name="line.455"></a>
-<span class="sourceLineNo">456</span>   * memstore and WAL. The difference of this one with<a name="line.456"></a>
-<span class="sourceLineNo">457</span>   * {@link #postPut(ObserverContext, Put, WALEdit, Durability) }<a name="line.457"></a>
-<span class="sourceLineNo">458</span>   * and {@link #postDelete(ObserverContext, Delete, WALEdit, Durability) } is<a name="line.458"></a>
-<span class="sourceLineNo">459</span>   * this hook will be executed before the mvcc transaction completion.<a name="line.459"></a>
-<span class="sourceLineNo">460</span>   * &lt;p&gt;<a name="line.460"></a>
-<span class="sourceLineNo">461</span>   * Note: Do not retain references to any Cells in 

<TRUNCATED>

[11/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/Version.html b/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
index 8cc10a3..7a29186 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
@@ -16,11 +16,11 @@
 <span class="sourceLineNo">008</span>@InterfaceAudience.Private<a name="line.8"></a>
 <span class="sourceLineNo">009</span>public class Version {<a name="line.9"></a>
 <span class="sourceLineNo">010</span>  public static final String version = "3.0.0-SNAPSHOT";<a name="line.10"></a>
-<span class="sourceLineNo">011</span>  public static final String revision = "f4a39043e2fb3da69e378b4e1cbcb4bd7e2a6662";<a name="line.11"></a>
+<span class="sourceLineNo">011</span>  public static final String revision = "e73ba582f23e7ac512665bac2539af53bd3cb47c";<a name="line.11"></a>
 <span class="sourceLineNo">012</span>  public static final String user = "jenkins";<a name="line.12"></a>
-<span class="sourceLineNo">013</span>  public static final String date = "Sun Apr 22 14:39:02 UTC 2018";<a name="line.13"></a>
+<span class="sourceLineNo">013</span>  public static final String date = "Mon Apr 23 14:39:23 UTC 2018";<a name="line.13"></a>
 <span class="sourceLineNo">014</span>  public static final String url = "git://jenkins-websites1.apache.org/home/jenkins/jenkins-slave/workspace/hbase_generate_website/hbase";<a name="line.14"></a>
-<span class="sourceLineNo">015</span>  public static final String srcChecksum = "4c5dd33779be320f0e358eb0c4768d9a";<a name="line.15"></a>
+<span class="sourceLineNo">015</span>  public static final String srcChecksum = "fa71043078ececcd8bf3d37b0362de75";<a name="line.15"></a>
 <span class="sourceLineNo">016</span>}<a name="line.16"></a>
 
 


[09/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html b/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
index 993c1ea..2c6f38a 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
@@ -27,1043 +27,1040 @@
 <span class="sourceLineNo">019</span><a name="line.19"></a>
 <span class="sourceLineNo">020</span>package org.apache.hadoop.hbase.coprocessor;<a name="line.20"></a>
 <span class="sourceLineNo">021</span><a name="line.21"></a>
-<span class="sourceLineNo">022</span>import edu.umd.cs.findbugs.annotations.NonNull;<a name="line.22"></a>
-<span class="sourceLineNo">023</span><a name="line.23"></a>
-<span class="sourceLineNo">024</span>import java.io.IOException;<a name="line.24"></a>
-<span class="sourceLineNo">025</span>import java.util.List;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import java.util.Map;<a name="line.26"></a>
-<span class="sourceLineNo">027</span><a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.fs.FileSystem;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.fs.Path;<a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.Cell;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.CompareOperator;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.client.Append;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.client.Delete;<a name="line.34"></a>
-<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.client.Durability;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.Get;<a name="line.36"></a>
-<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.client.Increment;<a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.38"></a>
-<span class="sourceLineNo">039</span>import org.apache.hadoop.hbase.client.Put;<a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.40"></a>
-<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.client.Result;<a name="line.41"></a>
-<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.client.Scan;<a name="line.42"></a>
-<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.filter.ByteArrayComparable;<a name="line.43"></a>
-<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.io.FSDataInputStreamWrapper;<a name="line.44"></a>
-<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.io.Reference;<a name="line.45"></a>
-<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.io.hfile.CacheConfig;<a name="line.46"></a>
-<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.regionserver.FlushLifeCycleTracker;<a name="line.47"></a>
-<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.regionserver.InternalScanner;<a name="line.48"></a>
-<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.regionserver.MiniBatchOperationInProgress;<a name="line.49"></a>
-<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.regionserver.OperationStatus;<a name="line.50"></a>
-<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.regionserver.Region;<a name="line.51"></a>
-<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.regionserver.Region.Operation;<a name="line.52"></a>
-<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.regionserver.RegionScanner;<a name="line.53"></a>
-<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.regionserver.ScanOptions;<a name="line.54"></a>
-<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.regionserver.ScanType;<a name="line.55"></a>
-<span class="sourceLineNo">056</span>import org.apache.hadoop.hbase.regionserver.Store;<a name="line.56"></a>
-<span class="sourceLineNo">057</span>import org.apache.hadoop.hbase.regionserver.StoreFile;<a name="line.57"></a>
-<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.regionserver.StoreFileReader;<a name="line.58"></a>
-<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionLifeCycleTracker;<a name="line.59"></a>
-<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest;<a name="line.60"></a>
-<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.regionserver.querymatcher.DeleteTracker;<a name="line.61"></a>
-<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.62"></a>
-<span class="sourceLineNo">063</span>import org.apache.hadoop.hbase.wal.WALEdit;<a name="line.63"></a>
-<span class="sourceLineNo">064</span>import org.apache.hadoop.hbase.wal.WALKey;<a name="line.64"></a>
-<span class="sourceLineNo">065</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.65"></a>
-<span class="sourceLineNo">066</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span>/**<a name="line.68"></a>
-<span class="sourceLineNo">069</span> * Coprocessors implement this interface to observe and mediate client actions on the region.<a name="line.69"></a>
-<span class="sourceLineNo">070</span> * &lt;p&gt;<a name="line.70"></a>
-<span class="sourceLineNo">071</span> * Since most implementations will be interested in only a subset of hooks, this class uses<a name="line.71"></a>
-<span class="sourceLineNo">072</span> * 'default' functions to avoid having to add unnecessary overrides. When the functions are<a name="line.72"></a>
-<span class="sourceLineNo">073</span> * non-empty, it's simply to satisfy the compiler by returning value of expected (non-void) type. It<a name="line.73"></a>
-<span class="sourceLineNo">074</span> * is done in a way that these default definitions act as no-op. So our suggestion to implementation<a name="line.74"></a>
-<span class="sourceLineNo">075</span> * would be to not call these 'default' methods from overrides.<a name="line.75"></a>
-<span class="sourceLineNo">076</span> * &lt;p&gt;<a name="line.76"></a>
-<span class="sourceLineNo">077</span> * &lt;h3&gt;Exception Handling&lt;/h3&gt;&lt;br&gt;<a name="line.77"></a>
-<span class="sourceLineNo">078</span> * For all functions, exception handling is done as follows:<a name="line.78"></a>
-<span class="sourceLineNo">079</span> * &lt;ul&gt;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> * &lt;li&gt;Exceptions of type {@link IOException} are reported back to client.&lt;/li&gt;<a name="line.80"></a>
-<span class="sourceLineNo">081</span> * &lt;li&gt;For any other kind of exception:<a name="line.81"></a>
-<span class="sourceLineNo">082</span> * &lt;ul&gt;<a name="line.82"></a>
-<span class="sourceLineNo">083</span> * &lt;li&gt;If the configuration {@link CoprocessorHost#ABORT_ON_ERROR_KEY} is set to true, then the<a name="line.83"></a>
-<span class="sourceLineNo">084</span> * server aborts.&lt;/li&gt;<a name="line.84"></a>
-<span class="sourceLineNo">085</span> * &lt;li&gt;Otherwise, coprocessor is removed from the server and<a name="line.85"></a>
-<span class="sourceLineNo">086</span> * {@link org.apache.hadoop.hbase.DoNotRetryIOException} is returned to the client.&lt;/li&gt;<a name="line.86"></a>
+<span class="sourceLineNo">022</span>import java.io.IOException;<a name="line.22"></a>
+<span class="sourceLineNo">023</span>import java.util.List;<a name="line.23"></a>
+<span class="sourceLineNo">024</span>import java.util.Map;<a name="line.24"></a>
+<span class="sourceLineNo">025</span><a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.hadoop.fs.FileSystem;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.apache.hadoop.fs.Path;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.Cell;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.CompareOperator;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.HBaseInterfaceAudience;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.client.Append;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.client.Delete;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.client.Durability;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.client.Get;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.client.Increment;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.client.Put;<a name="line.37"></a>
+<span class="sourceLineNo">038</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.apache.hadoop.hbase.client.Result;<a name="line.39"></a>
+<span class="sourceLineNo">040</span>import org.apache.hadoop.hbase.client.Scan;<a name="line.40"></a>
+<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.filter.ByteArrayComparable;<a name="line.41"></a>
+<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.io.FSDataInputStreamWrapper;<a name="line.42"></a>
+<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.io.Reference;<a name="line.43"></a>
+<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.io.hfile.CacheConfig;<a name="line.44"></a>
+<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.regionserver.FlushLifeCycleTracker;<a name="line.45"></a>
+<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.regionserver.InternalScanner;<a name="line.46"></a>
+<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.regionserver.MiniBatchOperationInProgress;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.apache.hadoop.hbase.regionserver.OperationStatus;<a name="line.48"></a>
+<span class="sourceLineNo">049</span>import org.apache.hadoop.hbase.regionserver.Region;<a name="line.49"></a>
+<span class="sourceLineNo">050</span>import org.apache.hadoop.hbase.regionserver.Region.Operation;<a name="line.50"></a>
+<span class="sourceLineNo">051</span>import org.apache.hadoop.hbase.regionserver.RegionScanner;<a name="line.51"></a>
+<span class="sourceLineNo">052</span>import org.apache.hadoop.hbase.regionserver.ScanOptions;<a name="line.52"></a>
+<span class="sourceLineNo">053</span>import org.apache.hadoop.hbase.regionserver.ScanType;<a name="line.53"></a>
+<span class="sourceLineNo">054</span>import org.apache.hadoop.hbase.regionserver.Store;<a name="line.54"></a>
+<span class="sourceLineNo">055</span>import org.apache.hadoop.hbase.regionserver.StoreFile;<a name="line.55"></a>
+<span class="sourceLineNo">056</span>import org.apache.hadoop.hbase.regionserver.StoreFileReader;<a name="line.56"></a>
+<span class="sourceLineNo">057</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionLifeCycleTracker;<a name="line.57"></a>
+<span class="sourceLineNo">058</span>import org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest;<a name="line.58"></a>
+<span class="sourceLineNo">059</span>import org.apache.hadoop.hbase.regionserver.querymatcher.DeleteTracker;<a name="line.59"></a>
+<span class="sourceLineNo">060</span>import org.apache.hadoop.hbase.util.Pair;<a name="line.60"></a>
+<span class="sourceLineNo">061</span>import org.apache.hadoop.hbase.wal.WALEdit;<a name="line.61"></a>
+<span class="sourceLineNo">062</span>import org.apache.hadoop.hbase.wal.WALKey;<a name="line.62"></a>
+<span class="sourceLineNo">063</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.63"></a>
+<span class="sourceLineNo">064</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.64"></a>
+<span class="sourceLineNo">065</span><a name="line.65"></a>
+<span class="sourceLineNo">066</span>/**<a name="line.66"></a>
+<span class="sourceLineNo">067</span> * Coprocessors implement this interface to observe and mediate client actions on the region.<a name="line.67"></a>
+<span class="sourceLineNo">068</span> * &lt;p&gt;<a name="line.68"></a>
+<span class="sourceLineNo">069</span> * Since most implementations will be interested in only a subset of hooks, this class uses<a name="line.69"></a>
+<span class="sourceLineNo">070</span> * 'default' functions to avoid having to add unnecessary overrides. When the functions are<a name="line.70"></a>
+<span class="sourceLineNo">071</span> * non-empty, it's simply to satisfy the compiler by returning value of expected (non-void) type. It<a name="line.71"></a>
+<span class="sourceLineNo">072</span> * is done in a way that these default definitions act as no-op. So our suggestion to implementation<a name="line.72"></a>
+<span class="sourceLineNo">073</span> * would be to not call these 'default' methods from overrides.<a name="line.73"></a>
+<span class="sourceLineNo">074</span> * &lt;p&gt;<a name="line.74"></a>
+<span class="sourceLineNo">075</span> * &lt;h3&gt;Exception Handling&lt;/h3&gt;&lt;br&gt;<a name="line.75"></a>
+<span class="sourceLineNo">076</span> * For all functions, exception handling is done as follows:<a name="line.76"></a>
+<span class="sourceLineNo">077</span> * &lt;ul&gt;<a name="line.77"></a>
+<span class="sourceLineNo">078</span> * &lt;li&gt;Exceptions of type {@link IOException} are reported back to client.&lt;/li&gt;<a name="line.78"></a>
+<span class="sourceLineNo">079</span> * &lt;li&gt;For any other kind of exception:<a name="line.79"></a>
+<span class="sourceLineNo">080</span> * &lt;ul&gt;<a name="line.80"></a>
+<span class="sourceLineNo">081</span> * &lt;li&gt;If the configuration {@link CoprocessorHost#ABORT_ON_ERROR_KEY} is set to true, then the<a name="line.81"></a>
+<span class="sourceLineNo">082</span> * server aborts.&lt;/li&gt;<a name="line.82"></a>
+<span class="sourceLineNo">083</span> * &lt;li&gt;Otherwise, coprocessor is removed from the server and<a name="line.83"></a>
+<span class="sourceLineNo">084</span> * {@link org.apache.hadoop.hbase.DoNotRetryIOException} is returned to the client.&lt;/li&gt;<a name="line.84"></a>
+<span class="sourceLineNo">085</span> * &lt;/ul&gt;<a name="line.85"></a>
+<span class="sourceLineNo">086</span> * &lt;/li&gt;<a name="line.86"></a>
 <span class="sourceLineNo">087</span> * &lt;/ul&gt;<a name="line.87"></a>
-<span class="sourceLineNo">088</span> * &lt;/li&gt;<a name="line.88"></a>
-<span class="sourceLineNo">089</span> * &lt;/ul&gt;<a name="line.89"></a>
-<span class="sourceLineNo">090</span> * &lt;p&gt;<a name="line.90"></a>
-<span class="sourceLineNo">091</span> * &lt;h3&gt;For Split Related Hooks&lt;/h3&gt; &lt;br&gt;<a name="line.91"></a>
-<span class="sourceLineNo">092</span> * In hbase2/AMv2, master runs splits, so the split related hooks are moved to<a name="line.92"></a>
-<span class="sourceLineNo">093</span> * {@link MasterObserver}.<a name="line.93"></a>
-<span class="sourceLineNo">094</span> * &lt;p&gt;<a name="line.94"></a>
-<span class="sourceLineNo">095</span> * &lt;h3&gt;Increment Column Value&lt;/h3&gt;&lt;br&gt;<a name="line.95"></a>
-<span class="sourceLineNo">096</span> * We do not call this hook anymore.<a name="line.96"></a>
-<span class="sourceLineNo">097</span> */<a name="line.97"></a>
-<span class="sourceLineNo">098</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.COPROC)<a name="line.98"></a>
-<span class="sourceLineNo">099</span>@InterfaceStability.Evolving<a name="line.99"></a>
-<span class="sourceLineNo">100</span>// TODO as method signatures need to break, update to<a name="line.100"></a>
-<span class="sourceLineNo">101</span>// ObserverContext&lt;? extends RegionCoprocessorEnvironment&gt;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>// so we can use additional environment state that isn't exposed to coprocessors.<a name="line.102"></a>
-<span class="sourceLineNo">103</span>public interface RegionObserver {<a name="line.103"></a>
-<span class="sourceLineNo">104</span>  /** Mutation type for postMutationBeforeWAL hook */<a name="line.104"></a>
-<span class="sourceLineNo">105</span>  enum MutationType {<a name="line.105"></a>
-<span class="sourceLineNo">106</span>    APPEND, INCREMENT<a name="line.106"></a>
-<span class="sourceLineNo">107</span>  }<a name="line.107"></a>
-<span class="sourceLineNo">108</span><a name="line.108"></a>
-<span class="sourceLineNo">109</span>  /**<a name="line.109"></a>
-<span class="sourceLineNo">110</span>   * Called before the region is reported as open to the master.<a name="line.110"></a>
-<span class="sourceLineNo">111</span>   * @param c the environment provided by the region server<a name="line.111"></a>
-<span class="sourceLineNo">112</span>   */<a name="line.112"></a>
-<span class="sourceLineNo">113</span>  default void preOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) throws IOException {}<a name="line.113"></a>
-<span class="sourceLineNo">114</span><a name="line.114"></a>
-<span class="sourceLineNo">115</span>  /**<a name="line.115"></a>
-<span class="sourceLineNo">116</span>   * Called after the region is reported as open to the master.<a name="line.116"></a>
-<span class="sourceLineNo">117</span>   * @param c the environment provided by the region server<a name="line.117"></a>
-<span class="sourceLineNo">118</span>   */<a name="line.118"></a>
-<span class="sourceLineNo">119</span>  default void postOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) {}<a name="line.119"></a>
-<span class="sourceLineNo">120</span><a name="line.120"></a>
-<span class="sourceLineNo">121</span>  /**<a name="line.121"></a>
-<span class="sourceLineNo">122</span>   * Called before the memstore is flushed to disk.<a name="line.122"></a>
-<span class="sourceLineNo">123</span>   * @param c the environment provided by the region server<a name="line.123"></a>
-<span class="sourceLineNo">124</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.124"></a>
-<span class="sourceLineNo">125</span>   */<a name="line.125"></a>
-<span class="sourceLineNo">126</span>  default void preFlush(final ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.126"></a>
-<span class="sourceLineNo">127</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.127"></a>
-<span class="sourceLineNo">128</span><a name="line.128"></a>
-<span class="sourceLineNo">129</span>  /**<a name="line.129"></a>
-<span class="sourceLineNo">130</span>   * Called before we open store scanner for flush. You can use the {@code options} to change max<a name="line.130"></a>
-<span class="sourceLineNo">131</span>   * versions and TTL for the scanner being opened.<a name="line.131"></a>
-<span class="sourceLineNo">132</span>   * @param c the environment provided by the region server<a name="line.132"></a>
-<span class="sourceLineNo">133</span>   * @param store the store where flush is being requested<a name="line.133"></a>
-<span class="sourceLineNo">134</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.134"></a>
-<span class="sourceLineNo">135</span>   */<a name="line.135"></a>
-<span class="sourceLineNo">136</span>  default void preFlushScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.136"></a>
-<span class="sourceLineNo">137</span>      ScanOptions options,FlushLifeCycleTracker tracker) throws IOException {}<a name="line.137"></a>
-<span class="sourceLineNo">138</span><a name="line.138"></a>
-<span class="sourceLineNo">139</span>  /**<a name="line.139"></a>
-<span class="sourceLineNo">140</span>   * Called before a Store's memstore is flushed to disk.<a name="line.140"></a>
-<span class="sourceLineNo">141</span>   * @param c the environment provided by the region server<a name="line.141"></a>
-<span class="sourceLineNo">142</span>   * @param store the store where flush is being requested<a name="line.142"></a>
-<span class="sourceLineNo">143</span>   * @param scanner the scanner over existing data used in the memstore<a name="line.143"></a>
-<span class="sourceLineNo">144</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.144"></a>
-<span class="sourceLineNo">145</span>   * @return the scanner to use during flush. Should not be {@code null} unless the implementation<a name="line.145"></a>
-<span class="sourceLineNo">146</span>   *         is writing new store files on its own.<a name="line.146"></a>
-<span class="sourceLineNo">147</span>   */<a name="line.147"></a>
-<span class="sourceLineNo">148</span>  default InternalScanner preFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.148"></a>
-<span class="sourceLineNo">149</span>      InternalScanner scanner, FlushLifeCycleTracker tracker) throws IOException {<a name="line.149"></a>
-<span class="sourceLineNo">150</span>    return scanner;<a name="line.150"></a>
-<span class="sourceLineNo">151</span>  }<a name="line.151"></a>
-<span class="sourceLineNo">152</span><a name="line.152"></a>
-<span class="sourceLineNo">153</span>  /**<a name="line.153"></a>
-<span class="sourceLineNo">154</span>   * Called after the memstore is flushed to disk.<a name="line.154"></a>
-<span class="sourceLineNo">155</span>   * @param c the environment provided by the region server<a name="line.155"></a>
-<span class="sourceLineNo">156</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.156"></a>
-<span class="sourceLineNo">157</span>   * @throws IOException if an error occurred on the coprocessor<a name="line.157"></a>
-<span class="sourceLineNo">158</span>   */<a name="line.158"></a>
-<span class="sourceLineNo">159</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  /**<a name="line.162"></a>
-<span class="sourceLineNo">163</span>   * Called after a Store's memstore is flushed to disk.<a name="line.163"></a>
-<span class="sourceLineNo">164</span>   * @param c the environment provided by the region server<a name="line.164"></a>
-<span class="sourceLineNo">165</span>   * @param store the store being flushed<a name="line.165"></a>
-<span class="sourceLineNo">166</span>   * @param resultFile the new store file written out during compaction<a name="line.166"></a>
-<span class="sourceLineNo">167</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.167"></a>
-<span class="sourceLineNo">168</span>   */<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.169"></a>
-<span class="sourceLineNo">170</span>      StoreFile resultFile, FlushLifeCycleTracker tracker) throws IOException {}<a name="line.170"></a>
-<span class="sourceLineNo">171</span><a name="line.171"></a>
-<span class="sourceLineNo">172</span>  /**<a name="line.172"></a>
-<span class="sourceLineNo">173</span>   * Called before in memory compaction started.<a name="line.173"></a>
-<span class="sourceLineNo">174</span>   * @param c the environment provided by the region server<a name="line.174"></a>
-<span class="sourceLineNo">175</span>   * @param store the store where in memory compaction is being requested<a name="line.175"></a>
-<span class="sourceLineNo">176</span>   */<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  default void preMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.177"></a>
-<span class="sourceLineNo">178</span>      throws IOException {}<a name="line.178"></a>
-<span class="sourceLineNo">179</span><a name="line.179"></a>
-<span class="sourceLineNo">180</span>  /**<a name="line.180"></a>
-<span class="sourceLineNo">181</span>   * Called before we open store scanner for in memory compaction. You can use the {@code options}<a name="line.181"></a>
-<span class="sourceLineNo">182</span>   * to change max versions and TTL for the scanner being opened. Notice that this method will only<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * be called when you use {@code eager} mode. For {@code basic} mode we will not drop any cells<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * thus we do not open a store scanner.<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * @param c the environment provided by the region server<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   * @param store the store where in memory compaction is being requested<a name="line.186"></a>
-<span class="sourceLineNo">187</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.187"></a>
-<span class="sourceLineNo">188</span>   */<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  default void preMemStoreCompactionCompactScannerOpen(<a name="line.189"></a>
-<span class="sourceLineNo">190</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, ScanOptions options)<a name="line.190"></a>
-<span class="sourceLineNo">191</span>      throws IOException {}<a name="line.191"></a>
-<span class="sourceLineNo">192</span><a name="line.192"></a>
-<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * Called before we do in memory compaction. Notice that this method will only be called when you<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * use {@code eager} mode. For {@code basic} mode we will not drop any cells thus there is no<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * {@link InternalScanner}.<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   * @param c the environment provided by the region server<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * @param store the store where in memory compaction is being executed<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * @param scanner the scanner over existing data used in the memstore segments being compact<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   * @return the scanner to use during in memory compaction. Must be non-null.<a name="line.200"></a>
-<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  @NonNull<a name="line.202"></a>
-<span class="sourceLineNo">203</span>  default InternalScanner preMemStoreCompactionCompact(<a name="line.203"></a>
-<span class="sourceLineNo">204</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, InternalScanner scanner)<a name="line.204"></a>
-<span class="sourceLineNo">205</span>      throws IOException {<a name="line.205"></a>
-<span class="sourceLineNo">206</span>    return scanner;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  }<a name="line.207"></a>
-<span class="sourceLineNo">208</span><a name="line.208"></a>
-<span class="sourceLineNo">209</span>  /**<a name="line.209"></a>
-<span class="sourceLineNo">210</span>   * Called after the in memory compaction is finished.<a name="line.210"></a>
-<span class="sourceLineNo">211</span>   * @param c the environment provided by the region server<a name="line.211"></a>
-<span class="sourceLineNo">212</span>   * @param store the store where in memory compaction is being executed<a name="line.212"></a>
-<span class="sourceLineNo">213</span>   */<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  default void postMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.214"></a>
-<span class="sourceLineNo">215</span>      throws IOException {}<a name="line.215"></a>
-<span class="sourceLineNo">216</span><a name="line.216"></a>
-<span class="sourceLineNo">217</span>  /**<a name="line.217"></a>
-<span class="sourceLineNo">218</span>   * Called prior to selecting the {@link StoreFile StoreFiles} to compact from the list of<a name="line.218"></a>
-<span class="sourceLineNo">219</span>   * available candidates. To alter the files used for compaction, you may mutate the passed in list<a name="line.219"></a>
-<span class="sourceLineNo">220</span>   * of candidates. If you remove all the candidates then the compaction will be canceled.<a name="line.220"></a>
-<span class="sourceLineNo">221</span>   * &lt;p&gt;Supports Coprocessor 'bypass' -- 'bypass' is how this method indicates that it changed<a name="line.221"></a>
-<span class="sourceLineNo">222</span>   * the passed in &lt;code&gt;candidates&lt;/code&gt;.<a name="line.222"></a>
-<span class="sourceLineNo">223</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.223"></a>
-<span class="sourceLineNo">224</span>   * @param c the environment provided by the region server<a name="line.224"></a>
-<span class="sourceLineNo">225</span>   * @param store the store where compaction is being requested<a name="line.225"></a>
-<span class="sourceLineNo">226</span>   * @param candidates the store files currently available for compaction<a name="line.226"></a>
-<span class="sourceLineNo">227</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.227"></a>
-<span class="sourceLineNo">228</span>   */<a name="line.228"></a>
-<span class="sourceLineNo">229</span>  default void preCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.229"></a>
-<span class="sourceLineNo">230</span>      List&lt;? extends StoreFile&gt; candidates, CompactionLifeCycleTracker tracker)<a name="line.230"></a>
-<span class="sourceLineNo">231</span>      throws IOException {}<a name="line.231"></a>
-<span class="sourceLineNo">232</span><a name="line.232"></a>
-<span class="sourceLineNo">233</span>  /**<a name="line.233"></a>
-<span class="sourceLineNo">234</span>   * Called after the {@link StoreFile}s to compact have been selected from the available<a name="line.234"></a>
-<span class="sourceLineNo">235</span>   * candidates.<a name="line.235"></a>
-<span class="sourceLineNo">236</span>   * @param c the environment provided by the region server<a name="line.236"></a>
-<span class="sourceLineNo">237</span>   * @param store the store being compacted<a name="line.237"></a>
-<span class="sourceLineNo">238</span>   * @param selected the store files selected to compact<a name="line.238"></a>
-<span class="sourceLineNo">239</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.239"></a>
-<span class="sourceLineNo">240</span>   * @param request the requested compaction<a name="line.240"></a>
-<span class="sourceLineNo">241</span>   */<a name="line.241"></a>
-<span class="sourceLineNo">242</span>  default void postCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      List&lt;? extends StoreFile&gt; selected, CompactionLifeCycleTracker tracker,<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      CompactionRequest request) {}<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span>  /**<a name="line.246"></a>
-<span class="sourceLineNo">247</span>   * Called before we open store scanner for compaction. You can use the {@code options} to change max<a name="line.247"></a>
-<span class="sourceLineNo">248</span>   * versions and TTL for the scanner being opened.<a name="line.248"></a>
-<span class="sourceLineNo">249</span>   * @param c the environment provided by the region server<a name="line.249"></a>
-<span class="sourceLineNo">250</span>   * @param store the store being compacted<a name="line.250"></a>
-<span class="sourceLineNo">251</span>   * @param scanType type of Scan<a name="line.251"></a>
-<span class="sourceLineNo">252</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.252"></a>
-<span class="sourceLineNo">253</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.253"></a>
-<span class="sourceLineNo">254</span>   * @param request the requested compaction<a name="line.254"></a>
-<span class="sourceLineNo">255</span>   */<a name="line.255"></a>
-<span class="sourceLineNo">256</span>  default void preCompactScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.256"></a>
-<span class="sourceLineNo">257</span>      ScanType scanType, ScanOptions options, CompactionLifeCycleTracker tracker,<a name="line.257"></a>
-<span class="sourceLineNo">258</span>      CompactionRequest request) throws IOException {}<a name="line.258"></a>
-<span class="sourceLineNo">259</span><a name="line.259"></a>
-<span class="sourceLineNo">260</span>  /**<a name="line.260"></a>
-<span class="sourceLineNo">261</span>   * Called prior to writing the {@link StoreFile}s selected for compaction into a new<a name="line.261"></a>
-<span class="sourceLineNo">262</span>   * {@code StoreFile}.<a name="line.262"></a>
-<span class="sourceLineNo">263</span>   * &lt;p&gt;<a name="line.263"></a>
-<span class="sourceLineNo">264</span>   * To override or modify the compaction process, implementing classes can wrap the provided<a name="line.264"></a>
-<span class="sourceLineNo">265</span>   * {@link InternalScanner} with a custom implementation that is returned from this method. The<a name="line.265"></a>
-<span class="sourceLineNo">266</span>   * custom scanner can then inspect {@link org.apache.hadoop.hbase.Cell}s from the wrapped scanner,<a name="line.266"></a>
-<span class="sourceLineNo">267</span>   * applying its own policy to what gets written.<a name="line.267"></a>
-<span class="sourceLineNo">268</span>   * @param c the environment provided by the region server<a name="line.268"></a>
-<span class="sourceLineNo">269</span>   * @param store the store being compacted<a name="line.269"></a>
-<span class="sourceLineNo">270</span>   * @param scanner the scanner over existing data used in the store file rewriting<a name="line.270"></a>
-<span class="sourceLineNo">271</span>   * @param scanType type of Scan<a name="line.271"></a>
-<span class="sourceLineNo">272</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.272"></a>
-<span class="sourceLineNo">273</span>   * @param request the requested compaction<a name="line.273"></a>
-<span class="sourceLineNo">274</span>   * @return the scanner to use during compaction. Should not be {@code null} unless the<a name="line.274"></a>
-<span class="sourceLineNo">275</span>   *         implementation is writing new store files on its own.<a name="line.275"></a>
-<span class="sourceLineNo">276</span>   */<a name="line.276"></a>
-<span class="sourceLineNo">277</span>  default InternalScanner preCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.277"></a>
-<span class="sourceLineNo">278</span>      InternalScanner scanner, ScanType scanType, CompactionLifeCycleTracker tracker,<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      CompactionRequest request) throws IOException {<a name="line.279"></a>
-<span class="sourceLineNo">280</span>    return scanner;<a name="line.280"></a>
-<span class="sourceLineNo">281</span>  }<a name="line.281"></a>
-<span class="sourceLineNo">282</span><a name="line.282"></a>
-<span class="sourceLineNo">283</span>  /**<a name="line.283"></a>
-<span class="sourceLineNo">284</span>   * Called after compaction has completed and the new store file has been moved in to place.<a name="line.284"></a>
-<span class="sourceLineNo">285</span>   * @param c the environment provided by the region server<a name="line.285"></a>
-<span class="sourceLineNo">286</span>   * @param store the store being compacted<a name="line.286"></a>
-<span class="sourceLineNo">287</span>   * @param resultFile the new store file written out during compaction<a name="line.287"></a>
-<span class="sourceLineNo">288</span>   * @param tracker used to track the life cycle of a compaction<a name="line.288"></a>
-<span class="sourceLineNo">289</span>   * @param request the requested compaction<a name="line.289"></a>
-<span class="sourceLineNo">290</span>   */<a name="line.290"></a>
-<span class="sourceLineNo">291</span>  default void postCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.291"></a>
-<span class="sourceLineNo">292</span>      StoreFile resultFile, CompactionLifeCycleTracker tracker, CompactionRequest request)<a name="line.292"></a>
-<span class="sourceLineNo">293</span>      throws IOException {}<a name="line.293"></a>
-<span class="sourceLineNo">294</span><a name="line.294"></a>
-<span class="sourceLineNo">295</span>  /**<a name="line.295"></a>
-<span class="sourceLineNo">296</span>   * Called before the region is reported as closed to the master.<a name="line.296"></a>
-<span class="sourceLineNo">297</span>   * @param c the environment provided by the region server<a name="line.297"></a>
-<span class="sourceLineNo">298</span>   * @param abortRequested true if the region server is aborting<a name="line.298"></a>
-<span class="sourceLineNo">299</span>   */<a name="line.299"></a>
-<span class="sourceLineNo">300</span>  default void preClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested)<a name="line.300"></a>
-<span class="sourceLineNo">301</span>      throws IOException {}<a name="line.301"></a>
-<span class="sourceLineNo">302</span><a name="line.302"></a>
-<span class="sourceLineNo">303</span>  /**<a name="line.303"></a>
-<span class="sourceLineNo">304</span>   * Called after the region is reported as closed to the master.<a name="line.304"></a>
-<span class="sourceLineNo">305</span>   * @param c the environment provided by the region server<a name="line.305"></a>
-<span class="sourceLineNo">306</span>   * @param abortRequested true if the region server is aborting<a name="line.306"></a>
-<span class="sourceLineNo">307</span>   */<a name="line.307"></a>
-<span class="sourceLineNo">308</span>  default void postClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested) {}<a name="line.308"></a>
-<span class="sourceLineNo">309</span><a name="line.309"></a>
-<span class="sourceLineNo">310</span>  /**<a name="line.310"></a>
-<span class="sourceLineNo">311</span>   * Called before the client performs a Get<a name="line.311"></a>
-<span class="sourceLineNo">312</span>   * &lt;p&gt;<a name="line.312"></a>
-<span class="sourceLineNo">313</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.313"></a>
-<span class="sourceLineNo">314</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.314"></a>
-<span class="sourceLineNo">315</span>   * @param c the environment provided by the region server<a name="line.315"></a>
-<span class="sourceLineNo">316</span>   * @param get the Get request<a name="line.316"></a>
-<span class="sourceLineNo">317</span>   * @param result The result to return to the client if default processing<a name="line.317"></a>
-<span class="sourceLineNo">318</span>   * is bypassed. Can be modified. Will not be used if default processing<a name="line.318"></a>
-<span class="sourceLineNo">319</span>   * is not bypassed.<a name="line.319"></a>
-<span class="sourceLineNo">320</span>   */<a name="line.320"></a>
-<span class="sourceLineNo">321</span>  default void preGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get, List&lt;Cell&gt; result)<a name="line.321"></a>
-<span class="sourceLineNo">322</span>      throws IOException {}<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  /**<a name="line.324"></a>
-<span class="sourceLineNo">325</span>   * Called after the client performs a Get<a name="line.325"></a>
-<span class="sourceLineNo">326</span>   * &lt;p&gt;<a name="line.326"></a>
-<span class="sourceLineNo">327</span>   * Note: Do not retain references to any Cells in 'result' beyond the life of this invocation.<a name="line.327"></a>
-<span class="sourceLineNo">328</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.328"></a>
-<span class="sourceLineNo">329</span>   * @param c the environment provided by the region server<a name="line.329"></a>
-<span class="sourceLineNo">330</span>   * @param get the Get request<a name="line.330"></a>
-<span class="sourceLineNo">331</span>   * @param result the result to return to the client, modify as necessary<a name="line.331"></a>
-<span class="sourceLineNo">332</span>   */<a name="line.332"></a>
-<span class="sourceLineNo">333</span>  default void postGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.333"></a>
-<span class="sourceLineNo">334</span>      List&lt;Cell&gt; result) throws IOException {}<a name="line.334"></a>
-<span class="sourceLineNo">335</span><a name="line.335"></a>
-<span class="sourceLineNo">336</span>  /**<a name="line.336"></a>
-<span class="sourceLineNo">337</span>   * Called before the client tests for existence using a Get.<a name="line.337"></a>
-<span class="sourceLineNo">338</span>   * &lt;p&gt;<a name="line.338"></a>
-<span class="sourceLineNo">339</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.339"></a>
-<span class="sourceLineNo">340</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.340"></a>
-<span class="sourceLineNo">341</span>   * @param c the environment provided by the region server<a name="line.341"></a>
-<span class="sourceLineNo">342</span>   * @param get the Get request<a name="line.342"></a>
-<span class="sourceLineNo">343</span>   * @param exists the result returned by the region server<a name="line.343"></a>
-<span class="sourceLineNo">344</span>   * @return the value to return to the client if bypassing default processing<a name="line.344"></a>
-<span class="sourceLineNo">345</span>   */<a name="line.345"></a>
-<span class="sourceLineNo">346</span>  default boolean preExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      boolean exists) throws IOException {<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    return exists;<a name="line.348"></a>
-<span class="sourceLineNo">349</span>  }<a name="line.349"></a>
-<span class="sourceLineNo">350</span><a name="line.350"></a>
-<span class="sourceLineNo">351</span>  /**<a name="line.351"></a>
-<span class="sourceLineNo">352</span>   * Called after the client tests for existence using a Get.<a name="line.352"></a>
-<span class="sourceLineNo">353</span>   * @param c the environment provided by the region server<a name="line.353"></a>
-<span class="sourceLineNo">354</span>   * @param get the Get request<a name="line.354"></a>
-<span class="sourceLineNo">355</span>   * @param exists the result returned by the region server<a name="line.355"></a>
-<span class="sourceLineNo">356</span>   * @return the result to return to the client<a name="line.356"></a>
-<span class="sourceLineNo">357</span>   */<a name="line.357"></a>
-<span class="sourceLineNo">358</span>  default boolean postExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.358"></a>
-<span class="sourceLineNo">359</span>      boolean exists) throws IOException {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>    return exists;<a name="line.360"></a>
-<span class="sourceLineNo">361</span>  }<a name="line.361"></a>
-<span class="sourceLineNo">362</span><a name="line.362"></a>
-<span class="sourceLineNo">363</span>  /**<a name="line.363"></a>
-<span class="sourceLineNo">364</span>   * Called before the client stores a value.<a name="line.364"></a>
+<span class="sourceLineNo">088</span> * &lt;p&gt;<a name="line.88"></a>
+<span class="sourceLineNo">089</span> * &lt;h3&gt;For Split Related Hooks&lt;/h3&gt; &lt;br&gt;<a name="line.89"></a>
+<span class="sourceLineNo">090</span> * In hbase2/AMv2, master runs splits, so the split related hooks are moved to<a name="line.90"></a>
+<span class="sourceLineNo">091</span> * {@link MasterObserver}.<a name="line.91"></a>
+<span class="sourceLineNo">092</span> * &lt;p&gt;<a name="line.92"></a>
+<span class="sourceLineNo">093</span> * &lt;h3&gt;Increment Column Value&lt;/h3&gt;&lt;br&gt;<a name="line.93"></a>
+<span class="sourceLineNo">094</span> * We do not call this hook anymore.<a name="line.94"></a>
+<span class="sourceLineNo">095</span> */<a name="line.95"></a>
+<span class="sourceLineNo">096</span>@InterfaceAudience.LimitedPrivate(HBaseInterfaceAudience.COPROC)<a name="line.96"></a>
+<span class="sourceLineNo">097</span>@InterfaceStability.Evolving<a name="line.97"></a>
+<span class="sourceLineNo">098</span>// TODO as method signatures need to break, update to<a name="line.98"></a>
+<span class="sourceLineNo">099</span>// ObserverContext&lt;? extends RegionCoprocessorEnvironment&gt;<a name="line.99"></a>
+<span class="sourceLineNo">100</span>// so we can use additional environment state that isn't exposed to coprocessors.<a name="line.100"></a>
+<span class="sourceLineNo">101</span>public interface RegionObserver {<a name="line.101"></a>
+<span class="sourceLineNo">102</span>  /** Mutation type for postMutationBeforeWAL hook */<a name="line.102"></a>
+<span class="sourceLineNo">103</span>  enum MutationType {<a name="line.103"></a>
+<span class="sourceLineNo">104</span>    APPEND, INCREMENT<a name="line.104"></a>
+<span class="sourceLineNo">105</span>  }<a name="line.105"></a>
+<span class="sourceLineNo">106</span><a name="line.106"></a>
+<span class="sourceLineNo">107</span>  /**<a name="line.107"></a>
+<span class="sourceLineNo">108</span>   * Called before the region is reported as open to the master.<a name="line.108"></a>
+<span class="sourceLineNo">109</span>   * @param c the environment provided by the region server<a name="line.109"></a>
+<span class="sourceLineNo">110</span>   */<a name="line.110"></a>
+<span class="sourceLineNo">111</span>  default void preOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) throws IOException {}<a name="line.111"></a>
+<span class="sourceLineNo">112</span><a name="line.112"></a>
+<span class="sourceLineNo">113</span>  /**<a name="line.113"></a>
+<span class="sourceLineNo">114</span>   * Called after the region is reported as open to the master.<a name="line.114"></a>
+<span class="sourceLineNo">115</span>   * @param c the environment provided by the region server<a name="line.115"></a>
+<span class="sourceLineNo">116</span>   */<a name="line.116"></a>
+<span class="sourceLineNo">117</span>  default void postOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c) {}<a name="line.117"></a>
+<span class="sourceLineNo">118</span><a name="line.118"></a>
+<span class="sourceLineNo">119</span>  /**<a name="line.119"></a>
+<span class="sourceLineNo">120</span>   * Called before the memstore is flushed to disk.<a name="line.120"></a>
+<span class="sourceLineNo">121</span>   * @param c the environment provided by the region server<a name="line.121"></a>
+<span class="sourceLineNo">122</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.122"></a>
+<span class="sourceLineNo">123</span>   */<a name="line.123"></a>
+<span class="sourceLineNo">124</span>  default void preFlush(final ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.124"></a>
+<span class="sourceLineNo">125</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.125"></a>
+<span class="sourceLineNo">126</span><a name="line.126"></a>
+<span class="sourceLineNo">127</span>  /**<a name="line.127"></a>
+<span class="sourceLineNo">128</span>   * Called before we open store scanner for flush. You can use the {@code options} to change max<a name="line.128"></a>
+<span class="sourceLineNo">129</span>   * versions and TTL for the scanner being opened.<a name="line.129"></a>
+<span class="sourceLineNo">130</span>   * @param c the environment provided by the region server<a name="line.130"></a>
+<span class="sourceLineNo">131</span>   * @param store the store where flush is being requested<a name="line.131"></a>
+<span class="sourceLineNo">132</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.132"></a>
+<span class="sourceLineNo">133</span>   */<a name="line.133"></a>
+<span class="sourceLineNo">134</span>  default void preFlushScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.134"></a>
+<span class="sourceLineNo">135</span>      ScanOptions options,FlushLifeCycleTracker tracker) throws IOException {}<a name="line.135"></a>
+<span class="sourceLineNo">136</span><a name="line.136"></a>
+<span class="sourceLineNo">137</span>  /**<a name="line.137"></a>
+<span class="sourceLineNo">138</span>   * Called before a Store's memstore is flushed to disk.<a name="line.138"></a>
+<span class="sourceLineNo">139</span>   * @param c the environment provided by the region server<a name="line.139"></a>
+<span class="sourceLineNo">140</span>   * @param store the store where flush is being requested<a name="line.140"></a>
+<span class="sourceLineNo">141</span>   * @param scanner the scanner over existing data used in the memstore<a name="line.141"></a>
+<span class="sourceLineNo">142</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.142"></a>
+<span class="sourceLineNo">143</span>   * @return the scanner to use during flush. Should not be {@code null} unless the implementation<a name="line.143"></a>
+<span class="sourceLineNo">144</span>   *         is writing new store files on its own.<a name="line.144"></a>
+<span class="sourceLineNo">145</span>   */<a name="line.145"></a>
+<span class="sourceLineNo">146</span>  default InternalScanner preFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.146"></a>
+<span class="sourceLineNo">147</span>      InternalScanner scanner, FlushLifeCycleTracker tracker) throws IOException {<a name="line.147"></a>
+<span class="sourceLineNo">148</span>    return scanner;<a name="line.148"></a>
+<span class="sourceLineNo">149</span>  }<a name="line.149"></a>
+<span class="sourceLineNo">150</span><a name="line.150"></a>
+<span class="sourceLineNo">151</span>  /**<a name="line.151"></a>
+<span class="sourceLineNo">152</span>   * Called after the memstore is flushed to disk.<a name="line.152"></a>
+<span class="sourceLineNo">153</span>   * @param c the environment provided by the region server<a name="line.153"></a>
+<span class="sourceLineNo">154</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.154"></a>
+<span class="sourceLineNo">155</span>   * @throws IOException if an error occurred on the coprocessor<a name="line.155"></a>
+<span class="sourceLineNo">156</span>   */<a name="line.156"></a>
+<span class="sourceLineNo">157</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.157"></a>
+<span class="sourceLineNo">158</span>      FlushLifeCycleTracker tracker) throws IOException {}<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  /**<a name="line.160"></a>
+<span class="sourceLineNo">161</span>   * Called after a Store's memstore is flushed to disk.<a name="line.161"></a>
+<span class="sourceLineNo">162</span>   * @param c the environment provided by the region server<a name="line.162"></a>
+<span class="sourceLineNo">163</span>   * @param store the store being flushed<a name="line.163"></a>
+<span class="sourceLineNo">164</span>   * @param resultFile the new store file written out during compaction<a name="line.164"></a>
+<span class="sourceLineNo">165</span>   * @param tracker tracker used to track the life cycle of a flush<a name="line.165"></a>
+<span class="sourceLineNo">166</span>   */<a name="line.166"></a>
+<span class="sourceLineNo">167</span>  default void postFlush(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.167"></a>
+<span class="sourceLineNo">168</span>      StoreFile resultFile, FlushLifeCycleTracker tracker) throws IOException {}<a name="line.168"></a>
+<span class="sourceLineNo">169</span><a name="line.169"></a>
+<span class="sourceLineNo">170</span>  /**<a name="line.170"></a>
+<span class="sourceLineNo">171</span>   * Called before in memory compaction started.<a name="line.171"></a>
+<span class="sourceLineNo">172</span>   * @param c the environment provided by the region server<a name="line.172"></a>
+<span class="sourceLineNo">173</span>   * @param store the store where in memory compaction is being requested<a name="line.173"></a>
+<span class="sourceLineNo">174</span>   */<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  default void preMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.175"></a>
+<span class="sourceLineNo">176</span>      throws IOException {}<a name="line.176"></a>
+<span class="sourceLineNo">177</span><a name="line.177"></a>
+<span class="sourceLineNo">178</span>  /**<a name="line.178"></a>
+<span class="sourceLineNo">179</span>   * Called before we open store scanner for in memory compaction. You can use the {@code options}<a name="line.179"></a>
+<span class="sourceLineNo">180</span>   * to change max versions and TTL for the scanner being opened. Notice that this method will only<a name="line.180"></a>
+<span class="sourceLineNo">181</span>   * be called when you use {@code eager} mode. For {@code basic} mode we will not drop any cells<a name="line.181"></a>
+<span class="sourceLineNo">182</span>   * thus we do not open a store scanner.<a name="line.182"></a>
+<span class="sourceLineNo">183</span>   * @param c the environment provided by the region server<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * @param store the store where in memory compaction is being requested<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
+<span class="sourceLineNo">187</span>  default void preMemStoreCompactionCompactScannerOpen(<a name="line.187"></a>
+<span class="sourceLineNo">188</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, ScanOptions options)<a name="line.188"></a>
+<span class="sourceLineNo">189</span>      throws IOException {}<a name="line.189"></a>
+<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">191</span>  /**<a name="line.191"></a>
+<span class="sourceLineNo">192</span>   * Called before we do in memory compaction. Notice that this method will only be called when you<a name="line.192"></a>
+<span class="sourceLineNo">193</span>   * use {@code eager} mode. For {@code basic} mode we will not drop any cells thus there is no<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * {@link InternalScanner}.<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * @param c the environment provided by the region server<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * @param store the store where in memory compaction is being executed<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * @param scanner the scanner over existing data used in the memstore segments being compact<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   * @return the scanner to use during in memory compaction. Must be non-null.<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   */<a name="line.199"></a>
+<span class="sourceLineNo">200</span>  default InternalScanner preMemStoreCompactionCompact(<a name="line.200"></a>
+<span class="sourceLineNo">201</span>      ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store, InternalScanner scanner)<a name="line.201"></a>
+<span class="sourceLineNo">202</span>      throws IOException {<a name="line.202"></a>
+<span class="sourceLineNo">203</span>    return scanner;<a name="line.203"></a>
+<span class="sourceLineNo">204</span>  }<a name="line.204"></a>
+<span class="sourceLineNo">205</span><a name="line.205"></a>
+<span class="sourceLineNo">206</span>  /**<a name="line.206"></a>
+<span class="sourceLineNo">207</span>   * Called after the in memory compaction is finished.<a name="line.207"></a>
+<span class="sourceLineNo">208</span>   * @param c the environment provided by the region server<a name="line.208"></a>
+<span class="sourceLineNo">209</span>   * @param store the store where in memory compaction is being executed<a name="line.209"></a>
+<span class="sourceLineNo">210</span>   */<a name="line.210"></a>
+<span class="sourceLineNo">211</span>  default void postMemStoreCompaction(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store)<a name="line.211"></a>
+<span class="sourceLineNo">212</span>      throws IOException {}<a name="line.212"></a>
+<span class="sourceLineNo">213</span><a name="line.213"></a>
+<span class="sourceLineNo">214</span>  /**<a name="line.214"></a>
+<span class="sourceLineNo">215</span>   * Called prior to selecting the {@link StoreFile StoreFiles} to compact from the list of<a name="line.215"></a>
+<span class="sourceLineNo">216</span>   * available candidates. To alter the files used for compaction, you may mutate the passed in list<a name="line.216"></a>
+<span class="sourceLineNo">217</span>   * of candidates. If you remove all the candidates then the compaction will be canceled.<a name="line.217"></a>
+<span class="sourceLineNo">218</span>   * &lt;p&gt;Supports Coprocessor 'bypass' -- 'bypass' is how this method indicates that it changed<a name="line.218"></a>
+<span class="sourceLineNo">219</span>   * the passed in &lt;code&gt;candidates&lt;/code&gt;.<a name="line.219"></a>
+<span class="sourceLineNo">220</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.220"></a>
+<span class="sourceLineNo">221</span>   * @param c the environment provided by the region server<a name="line.221"></a>
+<span class="sourceLineNo">222</span>   * @param store the store where compaction is being requested<a name="line.222"></a>
+<span class="sourceLineNo">223</span>   * @param candidates the store files currently available for compaction<a name="line.223"></a>
+<span class="sourceLineNo">224</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.224"></a>
+<span class="sourceLineNo">225</span>   */<a name="line.225"></a>
+<span class="sourceLineNo">226</span>  default void preCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.226"></a>
+<span class="sourceLineNo">227</span>      List&lt;? extends StoreFile&gt; candidates, CompactionLifeCycleTracker tracker)<a name="line.227"></a>
+<span class="sourceLineNo">228</span>      throws IOException {}<a name="line.228"></a>
+<span class="sourceLineNo">229</span><a name="line.229"></a>
+<span class="sourceLineNo">230</span>  /**<a name="line.230"></a>
+<span class="sourceLineNo">231</span>   * Called after the {@link StoreFile}s to compact have been selected from the available<a name="line.231"></a>
+<span class="sourceLineNo">232</span>   * candidates.<a name="line.232"></a>
+<span class="sourceLineNo">233</span>   * @param c the environment provided by the region server<a name="line.233"></a>
+<span class="sourceLineNo">234</span>   * @param store the store being compacted<a name="line.234"></a>
+<span class="sourceLineNo">235</span>   * @param selected the store files selected to compact<a name="line.235"></a>
+<span class="sourceLineNo">236</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.236"></a>
+<span class="sourceLineNo">237</span>   * @param request the requested compaction<a name="line.237"></a>
+<span class="sourceLineNo">238</span>   */<a name="line.238"></a>
+<span class="sourceLineNo">239</span>  default void postCompactSelection(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.239"></a>
+<span class="sourceLineNo">240</span>      List&lt;? extends StoreFile&gt; selected, CompactionLifeCycleTracker tracker,<a name="line.240"></a>
+<span class="sourceLineNo">241</span>      CompactionRequest request) {}<a name="line.241"></a>
+<span class="sourceLineNo">242</span><a name="line.242"></a>
+<span class="sourceLineNo">243</span>  /**<a name="line.243"></a>
+<span class="sourceLineNo">244</span>   * Called before we open store scanner for compaction. You can use the {@code options} to change max<a name="line.244"></a>
+<span class="sourceLineNo">245</span>   * versions and TTL for the scanner being opened.<a name="line.245"></a>
+<span class="sourceLineNo">246</span>   * @param c the environment provided by the region server<a name="line.246"></a>
+<span class="sourceLineNo">247</span>   * @param store the store being compacted<a name="line.247"></a>
+<span class="sourceLineNo">248</span>   * @param scanType type of Scan<a name="line.248"></a>
+<span class="sourceLineNo">249</span>   * @param options used to change max versions and TTL for the scanner being opened<a name="line.249"></a>
+<span class="sourceLineNo">250</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.250"></a>
+<span class="sourceLineNo">251</span>   * @param request the requested compaction<a name="line.251"></a>
+<span class="sourceLineNo">252</span>   */<a name="line.252"></a>
+<span class="sourceLineNo">253</span>  default void preCompactScannerOpen(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.253"></a>
+<span class="sourceLineNo">254</span>      ScanType scanType, ScanOptions options, CompactionLifeCycleTracker tracker,<a name="line.254"></a>
+<span class="sourceLineNo">255</span>      CompactionRequest request) throws IOException {}<a name="line.255"></a>
+<span class="sourceLineNo">256</span><a name="line.256"></a>
+<span class="sourceLineNo">257</span>  /**<a name="line.257"></a>
+<span class="sourceLineNo">258</span>   * Called prior to writing the {@link StoreFile}s selected for compaction into a new<a name="line.258"></a>
+<span class="sourceLineNo">259</span>   * {@code StoreFile}.<a name="line.259"></a>
+<span class="sourceLineNo">260</span>   * &lt;p&gt;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>   * To override or modify the compaction process, implementing classes can wrap the provided<a name="line.261"></a>
+<span class="sourceLineNo">262</span>   * {@link InternalScanner} with a custom implementation that is returned from this method. The<a name="line.262"></a>
+<span class="sourceLineNo">263</span>   * custom scanner can then inspect {@link org.apache.hadoop.hbase.Cell}s from the wrapped scanner,<a name="line.263"></a>
+<span class="sourceLineNo">264</span>   * applying its own policy to what gets written.<a name="line.264"></a>
+<span class="sourceLineNo">265</span>   * @param c the environment provided by the region server<a name="line.265"></a>
+<span class="sourceLineNo">266</span>   * @param store the store being compacted<a name="line.266"></a>
+<span class="sourceLineNo">267</span>   * @param scanner the scanner over existing data used in the store file rewriting<a name="line.267"></a>
+<span class="sourceLineNo">268</span>   * @param scanType type of Scan<a name="line.268"></a>
+<span class="sourceLineNo">269</span>   * @param tracker tracker used to track the life cycle of a compaction<a name="line.269"></a>
+<span class="sourceLineNo">270</span>   * @param request the requested compaction<a name="line.270"></a>
+<span class="sourceLineNo">271</span>   * @return the scanner to use during compaction. Should not be {@code null} unless the<a name="line.271"></a>
+<span class="sourceLineNo">272</span>   *         implementation is writing new store files on its own.<a name="line.272"></a>
+<span class="sourceLineNo">273</span>   */<a name="line.273"></a>
+<span class="sourceLineNo">274</span>  default InternalScanner preCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      InternalScanner scanner, ScanType scanType, CompactionLifeCycleTracker tracker,<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      CompactionRequest request) throws IOException {<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    return scanner;<a name="line.277"></a>
+<span class="sourceLineNo">278</span>  }<a name="line.278"></a>
+<span class="sourceLineNo">279</span><a name="line.279"></a>
+<span class="sourceLineNo">280</span>  /**<a name="line.280"></a>
+<span class="sourceLineNo">281</span>   * Called after compaction has completed and the new store file has been moved in to place.<a name="line.281"></a>
+<span class="sourceLineNo">282</span>   * @param c the environment provided by the region server<a name="line.282"></a>
+<span class="sourceLineNo">283</span>   * @param store the store being compacted<a name="line.283"></a>
+<span class="sourceLineNo">284</span>   * @param resultFile the new store file written out during compaction<a name="line.284"></a>
+<span class="sourceLineNo">285</span>   * @param tracker used to track the life cycle of a compaction<a name="line.285"></a>
+<span class="sourceLineNo">286</span>   * @param request the requested compaction<a name="line.286"></a>
+<span class="sourceLineNo">287</span>   */<a name="line.287"></a>
+<span class="sourceLineNo">288</span>  default void postCompact(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Store store,<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      StoreFile resultFile, CompactionLifeCycleTracker tracker, CompactionRequest request)<a name="line.289"></a>
+<span class="sourceLineNo">290</span>      throws IOException {}<a name="line.290"></a>
+<span class="sourceLineNo">291</span><a name="line.291"></a>
+<span class="sourceLineNo">292</span>  /**<a name="line.292"></a>
+<span class="sourceLineNo">293</span>   * Called before the region is reported as closed to the master.<a name="line.293"></a>
+<span class="sourceLineNo">294</span>   * @param c the environment provided by the region server<a name="line.294"></a>
+<span class="sourceLineNo">295</span>   * @param abortRequested true if the region server is aborting<a name="line.295"></a>
+<span class="sourceLineNo">296</span>   */<a name="line.296"></a>
+<span class="sourceLineNo">297</span>  default void preClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested)<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      throws IOException {}<a name="line.298"></a>
+<span class="sourceLineNo">299</span><a name="line.299"></a>
+<span class="sourceLineNo">300</span>  /**<a name="line.300"></a>
+<span class="sourceLineNo">301</span>   * Called after the region is reported as closed to the master.<a name="line.301"></a>
+<span class="sourceLineNo">302</span>   * @param c the environment provided by the region server<a name="line.302"></a>
+<span class="sourceLineNo">303</span>   * @param abortRequested true if the region server is aborting<a name="line.303"></a>
+<span class="sourceLineNo">304</span>   */<a name="line.304"></a>
+<span class="sourceLineNo">305</span>  default void postClose(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, boolean abortRequested) {}<a name="line.305"></a>
+<span class="sourceLineNo">306</span><a name="line.306"></a>
+<span class="sourceLineNo">307</span>  /**<a name="line.307"></a>
+<span class="sourceLineNo">308</span>   * Called before the client performs a Get<a name="line.308"></a>
+<span class="sourceLineNo">309</span>   * &lt;p&gt;<a name="line.309"></a>
+<span class="sourceLineNo">310</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.310"></a>
+<span class="sourceLineNo">311</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.311"></a>
+<span class="sourceLineNo">312</span>   * @param c the environment provided by the region server<a name="line.312"></a>
+<span class="sourceLineNo">313</span>   * @param get the Get request<a name="line.313"></a>
+<span class="sourceLineNo">314</span>   * @param result The result to return to the client if default processing<a name="line.314"></a>
+<span class="sourceLineNo">315</span>   * is bypassed. Can be modified. Will not be used if default processing<a name="line.315"></a>
+<span class="sourceLineNo">316</span>   * is not bypassed.<a name="line.316"></a>
+<span class="sourceLineNo">317</span>   */<a name="line.317"></a>
+<span class="sourceLineNo">318</span>  default void preGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get, List&lt;Cell&gt; result)<a name="line.318"></a>
+<span class="sourceLineNo">319</span>      throws IOException {}<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>  /**<a name="line.321"></a>
+<span class="sourceLineNo">322</span>   * Called after the client performs a Get<a name="line.322"></a>
+<span class="sourceLineNo">323</span>   * &lt;p&gt;<a name="line.323"></a>
+<span class="sourceLineNo">324</span>   * Note: Do not retain references to any Cells in 'result' beyond the life of this invocation.<a name="line.324"></a>
+<span class="sourceLineNo">325</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.325"></a>
+<span class="sourceLineNo">326</span>   * @param c the environment provided by the region server<a name="line.326"></a>
+<span class="sourceLineNo">327</span>   * @param get the Get request<a name="line.327"></a>
+<span class="sourceLineNo">328</span>   * @param result the result to return to the client, modify as necessary<a name="line.328"></a>
+<span class="sourceLineNo">329</span>   */<a name="line.329"></a>
+<span class="sourceLineNo">330</span>  default void postGetOp(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.330"></a>
+<span class="sourceLineNo">331</span>      List&lt;Cell&gt; result) throws IOException {}<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  /**<a name="line.333"></a>
+<span class="sourceLineNo">334</span>   * Called before the client tests for existence using a Get.<a name="line.334"></a>
+<span class="sourceLineNo">335</span>   * &lt;p&gt;<a name="line.335"></a>
+<span class="sourceLineNo">336</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.336"></a>
+<span class="sourceLineNo">337</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.337"></a>
+<span class="sourceLineNo">338</span>   * @param c the environment provided by the region server<a name="line.338"></a>
+<span class="sourceLineNo">339</span>   * @param get the Get request<a name="line.339"></a>
+<span class="sourceLineNo">340</span>   * @param exists the result returned by the region server<a name="line.340"></a>
+<span class="sourceLineNo">341</span>   * @return the value to return to the client if bypassing default processing<a name="line.341"></a>
+<span class="sourceLineNo">342</span>   */<a name="line.342"></a>
+<span class="sourceLineNo">343</span>  default boolean preExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.343"></a>
+<span class="sourceLineNo">344</span>      boolean exists) throws IOException {<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    return exists;<a name="line.345"></a>
+<span class="sourceLineNo">346</span>  }<a name="line.346"></a>
+<span class="sourceLineNo">347</span><a name="line.347"></a>
+<span class="sourceLineNo">348</span>  /**<a name="line.348"></a>
+<span class="sourceLineNo">349</span>   * Called after the client tests for existence using a Get.<a name="line.349"></a>
+<span class="sourceLineNo">350</span>   * @param c the environment provided by the region server<a name="line.350"></a>
+<span class="sourceLineNo">351</span>   * @param get the Get request<a name="line.351"></a>
+<span class="sourceLineNo">352</span>   * @param exists the result returned by the region server<a name="line.352"></a>
+<span class="sourceLineNo">353</span>   * @return the result to return to the client<a name="line.353"></a>
+<span class="sourceLineNo">354</span>   */<a name="line.354"></a>
+<span class="sourceLineNo">355</span>  default boolean postExists(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Get get,<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      boolean exists) throws IOException {<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    return exists;<a name="line.357"></a>
+<span class="sourceLineNo">358</span>  }<a name="line.358"></a>
+<span class="sourceLineNo">359</span><a name="line.359"></a>
+<span class="sourceLineNo">360</span>  /**<a name="line.360"></a>
+<span class="sourceLineNo">361</span>   * Called before the client stores a value.<a name="line.361"></a>
+<span class="sourceLineNo">362</span>   * &lt;p&gt;<a name="line.362"></a>
+<span class="sourceLineNo">363</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.363"></a>
+<span class="sourceLineNo">364</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.364"></a>
 <span class="sourceLineNo">365</span>   * &lt;p&gt;<a name="line.365"></a>
-<span class="sourceLineNo">366</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.366"></a>
-<span class="sourceLineNo">367</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.367"></a>
-<span class="sourceLineNo">368</span>   * &lt;p&gt;<a name="line.368"></a>
-<span class="sourceLineNo">369</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.369"></a>
-<span class="sourceLineNo">370</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.370"></a>
-<span class="sourceLineNo">371</span>   * @param c the environment provided by the region server<a name="line.371"></a>
-<span class="sourceLineNo">372</span>   * @param put The Put object<a name="line.372"></a>
-<span class="sourceLineNo">373</span>   * @param edit The WALEdit object that will be written to the wal<a name="line.373"></a>
-<span class="sourceLineNo">374</span>   * @param durability Persistence guarantee for this Put<a name="line.374"></a>
-<span class="sourceLineNo">375</span>   */<a name="line.375"></a>
-<span class="sourceLineNo">376</span>  default void prePut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.376"></a>
-<span class="sourceLineNo">377</span>      Durability durability) throws IOException {}<a name="line.377"></a>
-<span class="sourceLineNo">378</span><a name="line.378"></a>
-<span class="sourceLineNo">379</span>  /**<a name="line.379"></a>
-<span class="sourceLineNo">380</span>   * Called after the client stores a value.<a name="line.380"></a>
-<span class="sourceLineNo">381</span>   * &lt;p&gt;<a name="line.381"></a>
-<span class="sourceLineNo">382</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.382"></a>
-<span class="sourceLineNo">383</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * @param c the environment provided by the region server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   * @param put The Put object<a name="line.385"></a>
-<span class="sourceLineNo">386</span>   * @param edit The WALEdit object for the wal<a name="line.386"></a>
-<span class="sourceLineNo">387</span>   * @param durability Persistence guarantee for this Put<a name="line.387"></a>
-<span class="sourceLineNo">388</span>   */<a name="line.388"></a>
-<span class="sourceLineNo">389</span>  default void postPut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      Durability durability) throws IOException {}<a name="line.390"></a>
-<span class="sourceLineNo">391</span><a name="line.391"></a>
-<span class="sourceLineNo">392</span>  /**<a name="line.392"></a>
-<span class="sourceLineNo">393</span>   * Called before the client deletes a value.<a name="line.393"></a>
+<span class="sourceLineNo">366</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.366"></a>
+<span class="sourceLineNo">367</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.367"></a>
+<span class="sourceLineNo">368</span>   * @param c the environment provided by the region server<a name="line.368"></a>
+<span class="sourceLineNo">369</span>   * @param put The Put object<a name="line.369"></a>
+<span class="sourceLineNo">370</span>   * @param edit The WALEdit object that will be written to the wal<a name="line.370"></a>
+<span class="sourceLineNo">371</span>   * @param durability Persistence guarantee for this Put<a name="line.371"></a>
+<span class="sourceLineNo">372</span>   */<a name="line.372"></a>
+<span class="sourceLineNo">373</span>  default void prePut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      Durability durability) throws IOException {}<a name="line.374"></a>
+<span class="sourceLineNo">375</span><a name="line.375"></a>
+<span class="sourceLineNo">376</span>  /**<a name="line.376"></a>
+<span class="sourceLineNo">377</span>   * Called after the client stores a value.<a name="line.377"></a>
+<span class="sourceLineNo">378</span>   * &lt;p&gt;<a name="line.378"></a>
+<span class="sourceLineNo">379</span>   * Note: Do not retain references to any Cells in 'put' beyond the life of this invocation.<a name="line.379"></a>
+<span class="sourceLineNo">380</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.380"></a>
+<span class="sourceLineNo">381</span>   * @param c the environment provided by the region server<a name="line.381"></a>
+<span class="sourceLineNo">382</span>   * @param put The Put object<a name="line.382"></a>
+<span class="sourceLineNo">383</span>   * @param edit The WALEdit object for the wal<a name="line.383"></a>
+<span class="sourceLineNo">384</span>   * @param durability Persistence guarantee for this Put<a name="line.384"></a>
+<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
+<span class="sourceLineNo">386</span>  default void postPut(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Put put, WALEdit edit,<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      Durability durability) throws IOException {}<a name="line.387"></a>
+<span class="sourceLineNo">388</span><a name="line.388"></a>
+<span class="sourceLineNo">389</span>  /**<a name="line.389"></a>
+<span class="sourceLineNo">390</span>   * Called before the client deletes a value.<a name="line.390"></a>
+<span class="sourceLineNo">391</span>   * &lt;p&gt;<a name="line.391"></a>
+<span class="sourceLineNo">392</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.393"></a>
 <span class="sourceLineNo">394</span>   * &lt;p&gt;<a name="line.394"></a>
-<span class="sourceLineNo">395</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.395"></a>
-<span class="sourceLineNo">396</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.396"></a>
-<span class="sourceLineNo">397</span>   * &lt;p&gt;<a name="line.397"></a>
-<span class="sourceLineNo">398</span>   * Note: Do not retain references to any Cells in 'delete' beyond the life of this invocation.<a name="line.398"></a>
-<span class="sourceLineNo">399</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.399"></a>
-<span class="sourceLineNo">400</span>   * @param c the environment provided by the region server<a name="line.400"></a>
-<span class="sourceLineNo">401</span>   * @param delete The Delete object<a name="line.401"></a>
-<span class="sourceLineNo">402</span>   * @param edit The WALEdit object for the wal<a name="line.402"></a>
-<span class="sourceLineNo">403</span>   * @param durability Persistence guarantee for this Delete<a name="line.403"></a>
-<span class="sourceLineNo">404</span>   */<a name="line.404"></a>
-<span class="sourceLineNo">405</span>  default void preDelete(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Delete delete,<a name="line.405"></a>
-<span class="sourceLineNo">406</span>      WALEdit edit, Durability durability) throws IOException {}<a name="line.406"></a>
-<span class="sourceLineNo">407</span><a name="line.407"></a>
-<span class="sourceLineNo">408</span>  /**<a name="line.408"></a>
-<span class="sourceLineNo">409</span>   * Called before the server updates the timestamp for version delete with latest timestamp.<a name="line.409"></a>
-<span class="sourceLineNo">410</span>   * &lt;p&gt;<a name="line.410"></a>
-<span class="sourceLineNo">411</span>   * Call CoprocessorEnvironment#bypass to skip default actions.<a name="line.411"></a>
-<span class="sourceLineNo">412</span>   * If 'bypass' is set, we skip out on calling any subsequent chained coprocessors.<a name="line.412"></a>
-<span class="sourceLineNo">413</span>   * @param c the environment provided by the region server<a name="line.413"></a>
-<span class="sourceLineNo">414</span>   * @param mutation - the parent mutation associated with this delete cell<a name="line.414"></a>
-<span class="sourceLineNo">415</span>   * @param cell - The deleteColumn with latest version cell<a name="line.415"></a>
-<span class="sourceLineNo">416</span>   * @param byteNow - timestamp bytes<a name="line.416"></a>
-<span class="sourceLineNo">417</span>   * @param get - the get formed using the current cell's row. Note that the get does not specify<a name="line.417"></a>
-<span class="sourceLineNo">418</span>   *          the family and qualifier<a name="line.418"></a>
-<span class="sourceLineNo">419</span>   * @deprecated Since hbase-2.0.0. No replacement. To be removed in hbase-3.0.0 and replaced<a name="line.419"></a>
-<span class="sourceLineNo">420</span>   * with something that doesn't expose IntefaceAudience.Private classes.<a name="line.420"></a>
-<span class="sourceLineNo">421</span>   */<a name="line.421"></a>
-<span class="sourceLineNo">422</span>  @Deprecated<a name="line.422"></a>
-<span class="sourceLineNo">423</span>  default void prePrepareTimeStampForDeleteVersion(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      Mutation mutation, Cell cell, byte[] byteNow, Get get) throws IOException {}<a name="line.424"></a>
-<span class="sourceLineNo">425</span><a name="line.425"></a>
-<span class="sourceLineNo">426</span>  /**<a name="line.426"></a>
-<span class="sourceLineNo">427</span>   * Called after the client deletes a value.<a name="line.427"></a>
-<span class="sourceLineNo">428</span>   * &lt;p&gt;<a name="line.428"></a>
-<span class="sourceLineNo">429</span>   * Note: Do not retain references to any Cells in 'delete' beyond the life of this invocation.<a name="line.429"></a>
-<span class="sourceLineNo">430</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.430"></a>
-<span class="sourceLineNo">431</span>   * @param c the environment provided by the region server<a name="line.431"></a>
-<span class="sourceLineNo">432</span>   * @param delete The Delete object<a name="line.432"></a>
-<span class="sourceLineNo">433</span>   * @param edit The WALEdit object for the wal<a name="line.433"></a>
-<span class="sourceLineNo">434</span>   * @param durability Persistence guarantee for this Delete<a name="line.434"></a>
-<span class="sourceLineNo">435</span>   */<a name="line.435"></a>
-<span class="sourceLineNo">436</span>  default void postDelete(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c, Delete delete,<a name="line.436"></a>
-<span class="sourceLineNo">437</span>      WALEdit edit, Durability durability) throws IOException {}<a name="line.437"></a>
-<span class="sourceLineNo">438</span><a name="line.438"></a>
-<span class="sourceLineNo">439</span>  /**<a name="line.439"></a>
-<span class="sourceLineNo">440</span>   * This will be called for every batch mutation operation happening at the server. This will be<a name="line.440"></a>
-<span class="sourceLineNo">441</span>   * called after acquiring the locks on the mutating rows and after applying the proper timestamp<a name="line.441"></a>
-<span class="sourceLineNo">442</span>   * for each Mutation at the server. The batch may contain Put/Delete. By setting OperationStatus<a name="line.442"></a>
-<span class="sourceLineNo">443</span>   * of Mutations ({@link MiniBatchOperationInProgress#setOperationStatus(int, OperationStatus)}),<a name="line.443"></a>
-<span class="sourceLineNo">444</span>   * {@link RegionObserver} can make Region to skip these Mutations.<a name="line.444"></a>
-<span class="sourceLineNo">445</span>   * &lt;p&gt;<a name="line.445"></a>
-<span class="sourceLineNo">446</span>   * Note: Do not retain references to any Cells in Mutations beyond the life of this invocation.<a name="line.446"></a>
-<span class="sourceLineNo">447</span>   * If need a Cell reference for later use, copy the cell and use that.<a name="line.447"></a>
-<span class="sourceLineNo">448</span>   * @param c the environment provided by the region server<a name="line.448"></a>
-<span class="sourceLineNo">449</span>   * @param miniBatchOp batch of Mutations getting applied to region.<a name="line.449"></a>
-<span class="sourceLineNo">450</span>   */<a name="line.450"></a>
-<span class="sourceLineNo">451</span>  default void preBatchMutate(ObserverContext&lt;RegionCoprocessorEnvironment&gt; c,<a name="line.451"></a>
-<span class="sourceLineNo">452</span>      MiniBatchOperationInProgress&lt;Mutation&gt; miniBatchOp) throws IOException {}<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>  /**<a name="line.454"></a>
-<span class="sourceLineNo">455</span>   * This will be called after applying a batch of Mutations on a region. The Mutations are added to<a name="line.455"></a>
-<span class="sourceLineNo">456</span>   * memstore and WAL. The difference of this one with<a name="line.456"></a>
-<span class="sourceLineNo">457</span>   * {@link #postPut(ObserverContext, Put, WALEdit, Durability) }<a name="line.457"></a>
-<span class="sourceLineNo">458</span>   * and {@link #postDelete(ObserverContext, Delete, WALEdit, Durability) } is<a name="line.458"></a>
-<span class="sourceLineNo">459</span>   * this hook will be executed before the mvcc transaction completion.<a name="line.459"></a>
-<span class="sourceLineNo">460</span>   * &lt;p&gt;<a name="line.460"></a>
-<span class="sourceLineNo">461</span>   * Note: Do not retain references to any Cells in Mutations beyond the life of this invocation.<a name="line.461"><

<TRUNCATED>

[15/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.html b/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
index 4d5f94f..90452b8 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.html
@@ -107,7 +107,7 @@ var activeTableTab = "activeTableTab";
 <br>
 <pre>@InterfaceAudience.LimitedPrivate(value="Coprocesssor")
  @InterfaceStability.Evolving
-public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.103">RegionObserver</a></pre>
+public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.101">RegionObserver</a></pre>
 <div class="block">Coprocessors implement this interface to observe and mediate client actions on the region.
  <p>
  Since most implementations will be interested in only a subset of hooks, this class uses
@@ -773,7 +773,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.113">preOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c)
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.111">preOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c)
               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">Called before the region is reported as open to the master.</div>
 <dl>
@@ -790,7 +790,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>postOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.119">postOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c)</pre>
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.117">postOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c)</pre>
 <div class="block">Called after the region is reported as open to the master.</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -804,7 +804,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preFlush</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.126">preFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.124">preFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                       <a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a>&nbsp;tracker)
                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">Called before the memstore is flushed to disk.</div>
@@ -823,7 +823,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preFlushScannerOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.136">preFlushScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.134">preFlushScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a>&nbsp;options,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a>&nbsp;tracker)
@@ -846,7 +846,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preFlush</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.148">preFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.146">preFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;scanner,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a>&nbsp;tracker)
@@ -872,7 +872,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>postFlush</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.159">postFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.157">postFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                        <a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a>&nbsp;tracker)
                 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">Called after the memstore is flushed to disk.</div>
@@ -891,7 +891,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>postFlush</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.169">postFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.167">postFlush</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                        <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                        <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>&nbsp;resultFile,
                        <a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a>&nbsp;tracker)
@@ -914,7 +914,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preMemStoreCompaction</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.177">preMemStoreCompaction</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.175">preMemStoreCompaction</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store)
                             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">Called before in memory compaction started.</div>
@@ -933,7 +933,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preMemStoreCompactionCompactScannerOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.189">preMemStoreCompactionCompactScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.187">preMemStoreCompactionCompactScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                                      <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                                      <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a>&nbsp;options)
                                               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>
@@ -957,11 +957,10 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/coproc
 <ul class="blockList">
 <li class="blockList">
 <h4>preMemStoreCompactionCompact</h4>
-<pre>@NonNull
-default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.203">preMemStoreCompactionCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
-                                                              <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
-                                                              <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;scanner)
-                                                       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>
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.200">preMemStoreCompactionCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+                                                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
+                                                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;scanner)
+                                              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">Called before we do in memory compaction. Notice that this method will only be called when you
  use <code>eager</code> mode. For <code>basic</code> mode we will not drop any cells thus there is no
  <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver"><code>InternalScanner</code></a>.</div>
@@ -983,7 +982,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postMemStoreCompaction</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.214">postMemStoreCompaction</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.211">postMemStoreCompaction</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                     <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store)
                              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">Called after the in memory compaction is finished.</div>
@@ -1002,7 +1001,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preCompactSelection</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.229">preCompactSelection</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.226">preCompactSelection</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                  <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;? extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>&gt;&nbsp;candidates,
                                  <a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a>&nbsp;tracker)
@@ -1030,7 +1029,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postCompactSelection</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.242">postCompactSelection</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.239">postCompactSelection</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                   <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                   <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;? extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>&gt;&nbsp;selected,
                                   <a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a>&nbsp;tracker,
@@ -1053,7 +1052,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preCompactScannerOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.256">preCompactScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.253">preCompactScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver">ScanType</a>&nbsp;scanType,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a>&nbsp;options,
@@ -1081,7 +1080,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preCompact</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.277">preCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.274">preCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;scanner,
                                    <a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver">ScanType</a>&nbsp;scanType,
@@ -1117,7 +1116,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postCompact</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.291">postCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.288">postCompact</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                          <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a>&nbsp;store,
                          <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>&nbsp;resultFile,
                          <a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a>&nbsp;tracker,
@@ -1142,7 +1141,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preClose</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.300">preClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.297">preClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                       boolean&nbsp;abortRequested)
                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">Called before the region is reported as closed to the master.</div>
@@ -1161,7 +1160,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postClose</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.308">postClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.305">postClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                        boolean&nbsp;abortRequested)</pre>
 <div class="block">Called after the region is reported as closed to the master.</div>
 <dl>
@@ -1177,7 +1176,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preGetOp</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.321">preGetOp</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.318">preGetOp</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                       <a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>&nbsp;get,
                       <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/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&gt;&nbsp;result)
                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>
@@ -1203,7 +1202,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postGetOp</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.333">postGetOp</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.330">postGetOp</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                        <a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>&nbsp;get,
                        <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/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&gt;&nbsp;result)
                 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>
@@ -1227,7 +1226,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preExists</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.346">preExists</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.343">preExists</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                           <a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>&nbsp;get,
                           boolean&nbsp;exists)
                    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>
@@ -1253,7 +1252,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postExists</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.358">postExists</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.355">postExists</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                            <a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>&nbsp;get,
                            boolean&nbsp;exists)
                     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>
@@ -1276,7 +1275,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>prePut</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.376">prePut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.373">prePut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                     <a href="../../../../../org/apache/hadoop/hbase/client/Put.html" title="class in org.apache.hadoop.hbase.client">Put</a>&nbsp;put,
                     <a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a>&nbsp;edit,
                     <a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a>&nbsp;durability)
@@ -1305,7 +1304,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>postPut</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.389">postPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.386">postPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                      <a href="../../../../../org/apache/hadoop/hbase/client/Put.html" title="class in org.apache.hadoop.hbase.client">Put</a>&nbsp;put,
                      <a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a>&nbsp;edit,
                      <a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a>&nbsp;durability)
@@ -1331,7 +1330,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <ul class="blockList">
 <li class="blockList">
 <h4>preDelete</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.405">preDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.402">preDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                        <a href="../../../../../org/apache/hadoop/hbase/client/Delete.html" title="class in org.apache.hadoop.hbase.client">Delete</a>&nbsp;delete,
                        <a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a>&nbsp;edit,
                        <a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a>&nbsp;durability)
@@ -1361,7 +1360,7 @@ default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
 <li class="blockList">
 <h4>prePrepareTimeStampForDeleteVersion</h4>
 <pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Deprecated.html?is-external=true" title="class or interface in java.lang">@Deprecated</a>
-default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.423">prePrepareTimeStampForDeleteVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.420">prePrepareTimeStampForDeleteVersion</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                                              <a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>&nbsp;mutation,
                                                              <a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&nbsp;cell,
                                                              byte[]&nbsp;byteNow,
@@ -1392,7 +1391,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postDelete</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.436">postDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.433">postDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                         <a href="../../../../../org/apache/hadoop/hbase/client/Delete.html" title="class in org.apache.hadoop.hbase.client">Delete</a>&nbsp;delete,
                         <a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a>&nbsp;edit,
                         <a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a>&nbsp;durability)
@@ -1418,7 +1417,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preBatchMutate</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.451">preBatchMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.448">preBatchMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                             <a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>&gt;&nbsp;miniBatchOp)
                      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">This will be called for every batch mutation operation happening at the server. This will be
@@ -1444,7 +1443,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postBatchMutate</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.468">postBatchMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.465">postBatchMutate</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                              <a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>&gt;&nbsp;miniBatchOp)
                       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">This will be called after applying a batch of Mutations on a region. The Mutations are added to
@@ -1471,7 +1470,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postStartRegionOperation</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.477">postStartRegionOperation</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.474">postStartRegionOperation</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
                                       <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>&nbsp;operation)
                                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">This will be called for region operations where read lock is acquired in
@@ -1491,7 +1490,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postCloseRegionOperation</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.485">postCloseRegionOperation</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.482">postCloseRegionOperation</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
                                       <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>&nbsp;operation)
                                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">Called after releasing read lock in <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html#closeRegionOperation--"><code>Region.closeRegionOperation()</code></a>.</div>
@@ -1510,7 +1509,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postBatchMutateIndispensably</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.498">postBatchMutateIndispensably</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.495">postBatchMutateIndispensably</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
                                           <a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>&gt;&nbsp;miniBatchOp,
                                           boolean&nbsp;success)
                                    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>
@@ -1535,7 +1534,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckAndPut</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.520">preCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.517">preCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                byte[]&nbsp;row,
                                byte[]&nbsp;family,
                                byte[]&nbsp;qualifier,
@@ -1575,7 +1574,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckAndPutAfterRowLock</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.549">preCheckAndPutAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.546">preCheckAndPutAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                            byte[]&nbsp;row,
                                            byte[]&nbsp;family,
                                            byte[]&nbsp;qualifier,
@@ -1619,7 +1618,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postCheckAndPut</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.570">postCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.567">postCheckAndPut</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                 byte[]&nbsp;row,
                                 byte[]&nbsp;family,
                                 byte[]&nbsp;qualifier,
@@ -1655,7 +1654,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckAndDelete</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.594">preCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.591">preCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                   byte[]&nbsp;row,
                                   byte[]&nbsp;family,
                                   byte[]&nbsp;qualifier,
@@ -1694,7 +1693,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preCheckAndDeleteAfterRowLock</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.622">preCheckAndDeleteAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.619">preCheckAndDeleteAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                               byte[]&nbsp;row,
                                               byte[]&nbsp;family,
                                               byte[]&nbsp;qualifier,
@@ -1737,7 +1736,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postCheckAndDelete</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.643">postCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.640">postCheckAndDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                    byte[]&nbsp;row,
                                    byte[]&nbsp;family,
                                    byte[]&nbsp;qualifier,
@@ -1773,7 +1772,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preAppend</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.661">preAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.658">preAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                          <a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a>&nbsp;append)
                   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">Called before Append.
@@ -1800,7 +1799,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preAppendAfterRowLock</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.682">preAppendAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.679">preAppendAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                      <a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a>&nbsp;append)
                               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">Called before Append but after acquiring rowlock.
@@ -1831,7 +1830,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postAppend</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.697">postAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.694">postAppend</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                           <a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a>&nbsp;append,
                           <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;result)
                    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>
@@ -1857,7 +1856,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preIncrement</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.714">preIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.711">preIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                             <a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a>&nbsp;increment)
                      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">Called before Increment.
@@ -1884,7 +1883,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preIncrementAfterRowLock</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.739">preIncrementAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.736">preIncrementAfterRowLock</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                         <a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a>&nbsp;increment)
                                  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">Called before Increment but after acquiring rowlock.
@@ -1916,7 +1915,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postIncrement</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.754">postIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.751">postIncrement</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                              <a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a>&nbsp;increment,
                              <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;result)
                       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>
@@ -1942,7 +1941,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preScannerOpen</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.767">preScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.764">preScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                             <a href="../../../../../org/apache/hadoop/hbase/client/Scan.html" title="class in org.apache.hadoop.hbase.client">Scan</a>&nbsp;scan)
                      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">Called before the client opens a new scanner.
@@ -1964,7 +1963,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postScannerOpen</h4>
-<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.781">postScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.778">postScannerOpen</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                       <a href="../../../../../org/apache/hadoop/hbase/client/Scan.html" title="class in org.apache.hadoop.hbase.client">Scan</a>&nbsp;scan,
                                       <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a>&nbsp;s)
                                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>
@@ -1990,7 +1989,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preScannerNext</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.803">preScannerNext</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.800">preScannerNext</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;s,
                                <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/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt;&nbsp;result,
                                int&nbsp;limit,
@@ -2025,7 +2024,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postScannerNext</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.820">postScannerNext</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.817">postScannerNext</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                 <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;s,
                                 <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/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&gt;&nbsp;result,
                                 int&nbsp;limit,
@@ -2055,7 +2054,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postScannerFilterRow</h4>
-<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.846">postScannerFilterRow</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.843">postScannerFilterRow</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                                      <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;s,
                                      <a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>&nbsp;curRowCell,
                                      boolean&nbsp;hasMore)
@@ -2093,7 +2092,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>preScannerClose</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.859">preScannerClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.856">preScannerClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;c,
                              <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a>&nbsp;s)
                       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">Called before the client closes a scanner.
@@ -2115,7 +2114,7 @@ default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/
 <ul class="blockList">
 <li class="blockList">
 <h4>postScannerClose</h4>
-<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.867">postScannerClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>&gt;&nbsp;ctx,
+<pre>default&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.864">postScannerClose</a>(<a href="../../../../../org/apache/hadoop/hbase/coprocessor/ObserverContext.html" title="interface in org.apache.hadoop.hbase.coprocessor">ObserverContext</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCo

<TRUNCATED>

[05/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
index fd7ab7a..021207f 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
@@ -147,1891 +147,1901 @@
 <span class="sourceLineNo">139</span>import org.slf4j.Logger;<a name="line.139"></a>
 <span class="sourceLineNo">140</span>import org.slf4j.LoggerFactory;<a name="line.140"></a>
 <span class="sourceLineNo">141</span>import org.apache.hbase.thirdparty.com.google.common.base.Joiner;<a name="line.141"></a>
-<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.142"></a>
-<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.143"></a>
-<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.144"></a>
-<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.145"></a>
-<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span>/**<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.149"></a>
-<span class="sourceLineNo">150</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.150"></a>
-<span class="sourceLineNo">151</span> */<a name="line.151"></a>
-<span class="sourceLineNo">152</span>@InterfaceAudience.Private<a name="line.152"></a>
-<span class="sourceLineNo">153</span>public class ThriftServerRunner implements Runnable {<a name="line.153"></a>
-<span class="sourceLineNo">154</span><a name="line.154"></a>
-<span class="sourceLineNo">155</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.155"></a>
-<span class="sourceLineNo">156</span><a name="line.156"></a>
-<span class="sourceLineNo">157</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.157"></a>
-<span class="sourceLineNo">158</span><a name="line.158"></a>
-<span class="sourceLineNo">159</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.159"></a>
-<span class="sourceLineNo">160</span>      "hbase.regionserver.thrift.server.type";<a name="line.160"></a>
-<span class="sourceLineNo">161</span><a name="line.161"></a>
-<span class="sourceLineNo">162</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.162"></a>
-<span class="sourceLineNo">163</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.163"></a>
-<span class="sourceLineNo">164</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.164"></a>
-<span class="sourceLineNo">165</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.165"></a>
-<span class="sourceLineNo">166</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.166"></a>
-<span class="sourceLineNo">167</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.167"></a>
-<span class="sourceLineNo">168</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.168"></a>
-<span class="sourceLineNo">169</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.169"></a>
-<span class="sourceLineNo">170</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.170"></a>
-<span class="sourceLineNo">171</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.171"></a>
-<span class="sourceLineNo">172</span><a name="line.172"></a>
-<span class="sourceLineNo">173</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.173"></a>
-<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.174"></a>
-<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.175"></a>
-<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.176"></a>
-<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.177"></a>
-<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.178"></a>
-<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.179"></a>
-<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span>  /**<a name="line.182"></a>
-<span class="sourceLineNo">183</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.183"></a>
-<span class="sourceLineNo">184</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.184"></a>
-<span class="sourceLineNo">185</span>   * applies only to TBoundedThreadPoolServer<a name="line.185"></a>
-<span class="sourceLineNo">186</span>   */<a name="line.186"></a>
-<span class="sourceLineNo">187</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.187"></a>
-<span class="sourceLineNo">188</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.188"></a>
-<span class="sourceLineNo">189</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.189"></a>
-<span class="sourceLineNo">190</span><a name="line.190"></a>
+<span class="sourceLineNo">142</span>import org.apache.hbase.thirdparty.com.google.common.base.Splitter;<a name="line.142"></a>
+<span class="sourceLineNo">143</span>import org.apache.hbase.thirdparty.com.google.common.base.Throwables;<a name="line.143"></a>
+<span class="sourceLineNo">144</span>import org.apache.hbase.thirdparty.com.google.common.util.concurrent.ThreadFactoryBuilder;<a name="line.144"></a>
+<span class="sourceLineNo">145</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine;<a name="line.145"></a>
+<span class="sourceLineNo">146</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.Option;<a name="line.146"></a>
+<span class="sourceLineNo">147</span>import org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup;<a name="line.147"></a>
+<span class="sourceLineNo">148</span><a name="line.148"></a>
+<span class="sourceLineNo">149</span>/**<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * ThriftServerRunner - this class starts up a Thrift server which implements<a name="line.150"></a>
+<span class="sourceLineNo">151</span> * the Hbase API specified in the Hbase.thrift IDL file.<a name="line.151"></a>
+<span class="sourceLineNo">152</span> */<a name="line.152"></a>
+<span class="sourceLineNo">153</span>@InterfaceAudience.Private<a name="line.153"></a>
+<span class="sourceLineNo">154</span>public class ThriftServerRunner implements Runnable {<a name="line.154"></a>
+<span class="sourceLineNo">155</span><a name="line.155"></a>
+<span class="sourceLineNo">156</span>  private static final Logger LOG = LoggerFactory.getLogger(ThriftServerRunner.class);<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span>  private static final int DEFAULT_HTTP_MAX_HEADER_SIZE = 64 * 1024; // 64k<a name="line.158"></a>
+<span class="sourceLineNo">159</span><a name="line.159"></a>
+<span class="sourceLineNo">160</span>  static final String SERVER_TYPE_CONF_KEY =<a name="line.160"></a>
+<span class="sourceLineNo">161</span>      "hbase.regionserver.thrift.server.type";<a name="line.161"></a>
+<span class="sourceLineNo">162</span><a name="line.162"></a>
+<span class="sourceLineNo">163</span>  static final String BIND_CONF_KEY = "hbase.regionserver.thrift.ipaddress";<a name="line.163"></a>
+<span class="sourceLineNo">164</span>  static final String COMPACT_CONF_KEY = "hbase.regionserver.thrift.compact";<a name="line.164"></a>
+<span class="sourceLineNo">165</span>  static final String FRAMED_CONF_KEY = "hbase.regionserver.thrift.framed";<a name="line.165"></a>
+<span class="sourceLineNo">166</span>  static final String MAX_FRAME_SIZE_CONF_KEY =<a name="line.166"></a>
+<span class="sourceLineNo">167</span>          "hbase.regionserver.thrift.framed.max_frame_size_in_mb";<a name="line.167"></a>
+<span class="sourceLineNo">168</span>  static final String PORT_CONF_KEY = "hbase.regionserver.thrift.port";<a name="line.168"></a>
+<span class="sourceLineNo">169</span>  static final String COALESCE_INC_KEY = "hbase.regionserver.thrift.coalesceIncrement";<a name="line.169"></a>
+<span class="sourceLineNo">170</span>  static final String USE_HTTP_CONF_KEY = "hbase.regionserver.thrift.http";<a name="line.170"></a>
+<span class="sourceLineNo">171</span>  static final String HTTP_MIN_THREADS = "hbase.thrift.http_threads.min";<a name="line.171"></a>
+<span class="sourceLineNo">172</span>  static final String HTTP_MAX_THREADS = "hbase.thrift.http_threads.max";<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span>  static final String THRIFT_SSL_ENABLED = "hbase.thrift.ssl.enabled";<a name="line.174"></a>
+<span class="sourceLineNo">175</span>  static final String THRIFT_SSL_KEYSTORE_STORE = "hbase.thrift.ssl.keystore.store";<a name="line.175"></a>
+<span class="sourceLineNo">176</span>  static final String THRIFT_SSL_KEYSTORE_PASSWORD = "hbase.thrift.ssl.keystore.password";<a name="line.176"></a>
+<span class="sourceLineNo">177</span>  static final String THRIFT_SSL_KEYSTORE_KEYPASSWORD = "hbase.thrift.ssl.keystore.keypassword";<a name="line.177"></a>
+<span class="sourceLineNo">178</span>  static final String THRIFT_SSL_EXCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.exclude.cipher.suites";<a name="line.178"></a>
+<span class="sourceLineNo">179</span>  static final String THRIFT_SSL_INCLUDE_CIPHER_SUITES = "hbase.thrift.ssl.include.cipher.suites";<a name="line.179"></a>
+<span class="sourceLineNo">180</span>  static final String THRIFT_SSL_EXCLUDE_PROTOCOLS = "hbase.thrift.ssl.exclude.protocols";<a name="line.180"></a>
+<span class="sourceLineNo">181</span>  static final String THRIFT_SSL_INCLUDE_PROTOCOLS = "hbase.thrift.ssl.include.protocols";<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span>  /**<a name="line.183"></a>
+<span class="sourceLineNo">184</span>   * Amount of time in milliseconds before a server thread will timeout<a name="line.184"></a>
+<span class="sourceLineNo">185</span>   * waiting for client to send data on a connected socket. Currently,<a name="line.185"></a>
+<span class="sourceLineNo">186</span>   * applies only to TBoundedThreadPoolServer<a name="line.186"></a>
+<span class="sourceLineNo">187</span>   */<a name="line.187"></a>
+<span class="sourceLineNo">188</span>  public static final String THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY =<a name="line.188"></a>
+<span class="sourceLineNo">189</span>    "hbase.thrift.server.socket.read.timeout";<a name="line.189"></a>
+<span class="sourceLineNo">190</span>  public static final int THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT = 60000;<a name="line.190"></a>
 <span class="sourceLineNo">191</span><a name="line.191"></a>
-<span class="sourceLineNo">192</span>  /**<a name="line.192"></a>
-<span class="sourceLineNo">193</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.193"></a>
-<span class="sourceLineNo">194</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.194"></a>
-<span class="sourceLineNo">195</span>   * auth-int: authentication and integrity checking<a name="line.195"></a>
-<span class="sourceLineNo">196</span>   * auth: authentication only<a name="line.196"></a>
-<span class="sourceLineNo">197</span>   *<a name="line.197"></a>
-<span class="sourceLineNo">198</span>   * This is used to authenticate the callers and support impersonation.<a name="line.198"></a>
-<span class="sourceLineNo">199</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.199"></a>
-<span class="sourceLineNo">200</span>   */<a name="line.200"></a>
-<span class="sourceLineNo">201</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.201"></a>
-<span class="sourceLineNo">202</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.204"></a>
-<span class="sourceLineNo">205</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.205"></a>
-<span class="sourceLineNo">206</span>  public static final int HREGION_VERSION = 1;<a name="line.206"></a>
-<span class="sourceLineNo">207</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.207"></a>
-<span class="sourceLineNo">208</span>  private final int listenPort;<a name="line.208"></a>
-<span class="sourceLineNo">209</span><a name="line.209"></a>
-<span class="sourceLineNo">210</span>  private Configuration conf;<a name="line.210"></a>
-<span class="sourceLineNo">211</span>  volatile TServer tserver;<a name="line.211"></a>
-<span class="sourceLineNo">212</span>  volatile Server httpServer;<a name="line.212"></a>
-<span class="sourceLineNo">213</span>  private final Hbase.Iface handler;<a name="line.213"></a>
-<span class="sourceLineNo">214</span>  private final ThriftMetrics metrics;<a name="line.214"></a>
-<span class="sourceLineNo">215</span>  private final HBaseHandler hbaseHandler;<a name="line.215"></a>
-<span class="sourceLineNo">216</span>  private final UserGroupInformation realUser;<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span>  private SaslUtil.QualityOfProtection qop;<a name="line.218"></a>
-<span class="sourceLineNo">219</span>  private String host;<a name="line.219"></a>
-<span class="sourceLineNo">220</span><a name="line.220"></a>
-<span class="sourceLineNo">221</span>  private final boolean securityEnabled;<a name="line.221"></a>
-<span class="sourceLineNo">222</span>  private final boolean doAsEnabled;<a name="line.222"></a>
-<span class="sourceLineNo">223</span><a name="line.223"></a>
-<span class="sourceLineNo">224</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.224"></a>
-<span class="sourceLineNo">225</span><a name="line.225"></a>
-<span class="sourceLineNo">226</span>  /** An enum of server implementation selections */<a name="line.226"></a>
-<span class="sourceLineNo">227</span>  enum ImplType {<a name="line.227"></a>
-<span class="sourceLineNo">228</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.228"></a>
-<span class="sourceLineNo">229</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.229"></a>
-<span class="sourceLineNo">230</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.230"></a>
-<span class="sourceLineNo">231</span>    THREADED_SELECTOR(<a name="line.231"></a>
-<span class="sourceLineNo">232</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.232"></a>
-<span class="sourceLineNo">233</span><a name="line.233"></a>
-<span class="sourceLineNo">234</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.234"></a>
-<span class="sourceLineNo">235</span><a name="line.235"></a>
-<span class="sourceLineNo">236</span>    final String option;<a name="line.236"></a>
-<span class="sourceLineNo">237</span>    final boolean isAlwaysFramed;<a name="line.237"></a>
-<span class="sourceLineNo">238</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.238"></a>
-<span class="sourceLineNo">239</span>    final boolean canSpecifyBindIP;<a name="line.239"></a>
-<span class="sourceLineNo">240</span><a name="line.240"></a>
-<span class="sourceLineNo">241</span>    ImplType(String option, boolean isAlwaysFramed,<a name="line.241"></a>
-<span class="sourceLineNo">242</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.242"></a>
-<span class="sourceLineNo">243</span>      this.option = option;<a name="line.243"></a>
-<span class="sourceLineNo">244</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.244"></a>
-<span class="sourceLineNo">245</span>      this.serverClass = serverClass;<a name="line.245"></a>
-<span class="sourceLineNo">246</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.246"></a>
-<span class="sourceLineNo">247</span>    }<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span>    /**<a name="line.249"></a>
-<span class="sourceLineNo">250</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.250"></a>
-<span class="sourceLineNo">251</span>     *         {@link #values()}<a name="line.251"></a>
-<span class="sourceLineNo">252</span>     */<a name="line.252"></a>
-<span class="sourceLineNo">253</span>    @Override<a name="line.253"></a>
-<span class="sourceLineNo">254</span>    public String toString() {<a name="line.254"></a>
-<span class="sourceLineNo">255</span>      return "-" + option;<a name="line.255"></a>
-<span class="sourceLineNo">256</span>    }<a name="line.256"></a>
-<span class="sourceLineNo">257</span><a name="line.257"></a>
-<span class="sourceLineNo">258</span>    String getDescription() {<a name="line.258"></a>
-<span class="sourceLineNo">259</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.259"></a>
-<span class="sourceLineNo">260</span>          serverClass.getSimpleName());<a name="line.260"></a>
-<span class="sourceLineNo">261</span>      if (isAlwaysFramed) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span>        sb.append(" This implies the framed transport.");<a name="line.262"></a>
-<span class="sourceLineNo">263</span>      }<a name="line.263"></a>
-<span class="sourceLineNo">264</span>      if (this == DEFAULT) {<a name="line.264"></a>
-<span class="sourceLineNo">265</span>        sb.append("This is the default.");<a name="line.265"></a>
-<span class="sourceLineNo">266</span>      }<a name="line.266"></a>
-<span class="sourceLineNo">267</span>      return sb.toString();<a name="line.267"></a>
-<span class="sourceLineNo">268</span>    }<a name="line.268"></a>
-<span class="sourceLineNo">269</span><a name="line.269"></a>
-<span class="sourceLineNo">270</span>    static OptionGroup createOptionGroup() {<a name="line.270"></a>
-<span class="sourceLineNo">271</span>      OptionGroup group = new OptionGroup();<a name="line.271"></a>
-<span class="sourceLineNo">272</span>      for (ImplType t : values()) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.273"></a>
-<span class="sourceLineNo">274</span>      }<a name="line.274"></a>
-<span class="sourceLineNo">275</span>      return group;<a name="line.275"></a>
-<span class="sourceLineNo">276</span>    }<a name="line.276"></a>
-<span class="sourceLineNo">277</span><a name="line.277"></a>
-<span class="sourceLineNo">278</span>    static ImplType getServerImpl(Configuration conf) {<a name="line.278"></a>
-<span class="sourceLineNo">279</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.279"></a>
-<span class="sourceLineNo">280</span>      for (ImplType t : values()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span>        if (confType.equals(t.option)) {<a name="line.281"></a>
-<span class="sourceLineNo">282</span>          return t;<a name="line.282"></a>
-<span class="sourceLineNo">283</span>        }<a name="line.283"></a>
-<span class="sourceLineNo">284</span>      }<a name="line.284"></a>
-<span class="sourceLineNo">285</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.285"></a>
-<span class="sourceLineNo">286</span>    }<a name="line.286"></a>
-<span class="sourceLineNo">287</span><a name="line.287"></a>
-<span class="sourceLineNo">288</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.288"></a>
-<span class="sourceLineNo">289</span>      ImplType chosenType = null;<a name="line.289"></a>
-<span class="sourceLineNo">290</span>      int numChosen = 0;<a name="line.290"></a>
-<span class="sourceLineNo">291</span>      for (ImplType t : values()) {<a name="line.291"></a>
-<span class="sourceLineNo">292</span>        if (cmd.hasOption(t.option)) {<a name="line.292"></a>
-<span class="sourceLineNo">293</span>          chosenType = t;<a name="line.293"></a>
-<span class="sourceLineNo">294</span>          ++numChosen;<a name="line.294"></a>
-<span class="sourceLineNo">295</span>        }<a name="line.295"></a>
-<span class="sourceLineNo">296</span>      }<a name="line.296"></a>
-<span class="sourceLineNo">297</span>      if (numChosen &lt; 1) {<a name="line.297"></a>
-<span class="sourceLineNo">298</span>        LOG.info("Using default thrift server type");<a name="line.298"></a>
-<span class="sourceLineNo">299</span>        chosenType = DEFAULT;<a name="line.299"></a>
-<span class="sourceLineNo">300</span>      } else if (numChosen &gt; 1) {<a name="line.300"></a>
-<span class="sourceLineNo">301</span>        throw new AssertionError("Exactly one option out of " +<a name="line.301"></a>
-<span class="sourceLineNo">302</span>          Arrays.toString(values()) + " has to be specified");<a name="line.302"></a>
-<span class="sourceLineNo">303</span>      }<a name="line.303"></a>
-<span class="sourceLineNo">304</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.304"></a>
-<span class="sourceLineNo">305</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.305"></a>
-<span class="sourceLineNo">306</span>    }<a name="line.306"></a>
-<span class="sourceLineNo">307</span><a name="line.307"></a>
-<span class="sourceLineNo">308</span>    public String simpleClassName() {<a name="line.308"></a>
-<span class="sourceLineNo">309</span>      return serverClass.getSimpleName();<a name="line.309"></a>
-<span class="sourceLineNo">310</span>    }<a name="line.310"></a>
-<span class="sourceLineNo">311</span><a name="line.311"></a>
-<span class="sourceLineNo">312</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.313"></a>
-<span class="sourceLineNo">314</span>      for (ImplType t : values()) {<a name="line.314"></a>
-<span class="sourceLineNo">315</span>        if (!t.canSpecifyBindIP) {<a name="line.315"></a>
-<span class="sourceLineNo">316</span>          l.add(t.simpleClassName());<a name="line.316"></a>
-<span class="sourceLineNo">317</span>        }<a name="line.317"></a>
-<span class="sourceLineNo">318</span>      }<a name="line.318"></a>
-<span class="sourceLineNo">319</span>      return l;<a name="line.319"></a>
-<span class="sourceLineNo">320</span>    }<a name="line.320"></a>
-<span class="sourceLineNo">321</span><a name="line.321"></a>
-<span class="sourceLineNo">322</span>  }<a name="line.322"></a>
-<span class="sourceLineNo">323</span><a name="line.323"></a>
-<span class="sourceLineNo">324</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.324"></a>
-<span class="sourceLineNo">325</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.325"></a>
-<span class="sourceLineNo">326</span>    // login the server principal (if using secure Hadoop)<a name="line.326"></a>
-<span class="sourceLineNo">327</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.327"></a>
-<span class="sourceLineNo">328</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.328"></a>
-<span class="sourceLineNo">329</span>    if (securityEnabled) {<a name="line.329"></a>
-<span class="sourceLineNo">330</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.330"></a>
-<span class="sourceLineNo">331</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.331"></a>
-<span class="sourceLineNo">332</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.332"></a>
-<span class="sourceLineNo">333</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.333"></a>
-<span class="sourceLineNo">334</span>        "hbase.thrift.kerberos.principal", host);<a name="line.334"></a>
-<span class="sourceLineNo">335</span>    }<a name="line.335"></a>
-<span class="sourceLineNo">336</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.336"></a>
-<span class="sourceLineNo">337</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.337"></a>
-<span class="sourceLineNo">338</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.338"></a>
-<span class="sourceLineNo">339</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.339"></a>
-<span class="sourceLineNo">340</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.340"></a>
-<span class="sourceLineNo">341</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.341"></a>
-<span class="sourceLineNo">342</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.342"></a>
-<span class="sourceLineNo">343</span>      hbaseHandler, metrics, conf);<a name="line.343"></a>
-<span class="sourceLineNo">344</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.344"></a>
-<span class="sourceLineNo">345</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.345"></a>
-<span class="sourceLineNo">346</span>    if (strQop != null) {<a name="line.346"></a>
-<span class="sourceLineNo">347</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.347"></a>
-<span class="sourceLineNo">348</span>    }<a name="line.348"></a>
-<span class="sourceLineNo">349</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.349"></a>
-<span class="sourceLineNo">350</span>    if (doAsEnabled) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.351"></a>
-<span class="sourceLineNo">352</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.352"></a>
-<span class="sourceLineNo">353</span>                "configured ");<a name="line.353"></a>
-<span class="sourceLineNo">354</span>      }<a name="line.354"></a>
-<span class="sourceLineNo">355</span>    }<a name="line.355"></a>
-<span class="sourceLineNo">356</span>    if (qop != null) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.357"></a>
-<span class="sourceLineNo">358</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.358"></a>
-<span class="sourceLineNo">359</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.359"></a>
-<span class="sourceLineNo">360</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.360"></a>
-<span class="sourceLineNo">361</span>                              THRIFT_QOP_KEY,<a name="line.361"></a>
-<span class="sourceLineNo">362</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.362"></a>
-<span class="sourceLineNo">363</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.363"></a>
-<span class="sourceLineNo">364</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.364"></a>
-<span class="sourceLineNo">365</span>      }<a name="line.365"></a>
-<span class="sourceLineNo">366</span>      checkHttpSecurity(qop, conf);<a name="line.366"></a>
-<span class="sourceLineNo">367</span>      if (!securityEnabled) {<a name="line.367"></a>
-<span class="sourceLineNo">368</span>        throw new IOException("Thrift server must"<a name="line.368"></a>
-<span class="sourceLineNo">369</span>          + " run in secure mode to support authentication");<a name="line.369"></a>
-<span class="sourceLineNo">370</span>      }<a name="line.370"></a>
-<span class="sourceLineNo">371</span>    }<a name="line.371"></a>
-<span class="sourceLineNo">372</span>  }<a name="line.372"></a>
-<span class="sourceLineNo">373</span><a name="line.373"></a>
-<span class="sourceLineNo">374</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.375"></a>
-<span class="sourceLineNo">376</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.376"></a>
-<span class="sourceLineNo">377</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.378"></a>
-<span class="sourceLineNo">379</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.379"></a>
+<span class="sourceLineNo">192</span><a name="line.192"></a>
+<span class="sourceLineNo">193</span>  /**<a name="line.193"></a>
+<span class="sourceLineNo">194</span>   * Thrift quality of protection configuration key. Valid values can be:<a name="line.194"></a>
+<span class="sourceLineNo">195</span>   * auth-conf: authentication, integrity and confidentiality checking<a name="line.195"></a>
+<span class="sourceLineNo">196</span>   * auth-int: authentication and integrity checking<a name="line.196"></a>
+<span class="sourceLineNo">197</span>   * auth: authentication only<a name="line.197"></a>
+<span class="sourceLineNo">198</span>   *<a name="line.198"></a>
+<span class="sourceLineNo">199</span>   * This is used to authenticate the callers and support impersonation.<a name="line.199"></a>
+<span class="sourceLineNo">200</span>   * The thrift server and the HBase cluster must run in secure mode.<a name="line.200"></a>
+<span class="sourceLineNo">201</span>   */<a name="line.201"></a>
+<span class="sourceLineNo">202</span>  static final String THRIFT_QOP_KEY = "hbase.thrift.security.qop";<a name="line.202"></a>
+<span class="sourceLineNo">203</span>  static final String BACKLOG_CONF_KEY = "hbase.regionserver.thrift.backlog";<a name="line.203"></a>
+<span class="sourceLineNo">204</span><a name="line.204"></a>
+<span class="sourceLineNo">205</span>  private static final String DEFAULT_BIND_ADDR = "0.0.0.0";<a name="line.205"></a>
+<span class="sourceLineNo">206</span>  public static final int DEFAULT_LISTEN_PORT = 9090;<a name="line.206"></a>
+<span class="sourceLineNo">207</span>  public static final int HREGION_VERSION = 1;<a name="line.207"></a>
+<span class="sourceLineNo">208</span>  static final String THRIFT_SUPPORT_PROXYUSER = "hbase.thrift.support.proxyuser";<a name="line.208"></a>
+<span class="sourceLineNo">209</span>  private final int listenPort;<a name="line.209"></a>
+<span class="sourceLineNo">210</span><a name="line.210"></a>
+<span class="sourceLineNo">211</span>  private Configuration conf;<a name="line.211"></a>
+<span class="sourceLineNo">212</span>  volatile TServer tserver;<a name="line.212"></a>
+<span class="sourceLineNo">213</span>  volatile Server httpServer;<a name="line.213"></a>
+<span class="sourceLineNo">214</span>  private final Hbase.Iface handler;<a name="line.214"></a>
+<span class="sourceLineNo">215</span>  private final ThriftMetrics metrics;<a name="line.215"></a>
+<span class="sourceLineNo">216</span>  private final HBaseHandler hbaseHandler;<a name="line.216"></a>
+<span class="sourceLineNo">217</span>  private final UserGroupInformation realUser;<a name="line.217"></a>
+<span class="sourceLineNo">218</span><a name="line.218"></a>
+<span class="sourceLineNo">219</span>  private SaslUtil.QualityOfProtection qop;<a name="line.219"></a>
+<span class="sourceLineNo">220</span>  private String host;<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span>  private final boolean securityEnabled;<a name="line.222"></a>
+<span class="sourceLineNo">223</span>  private final boolean doAsEnabled;<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span>  private final JvmPauseMonitor pauseMonitor;<a name="line.225"></a>
+<span class="sourceLineNo">226</span><a name="line.226"></a>
+<span class="sourceLineNo">227</span>  /** An enum of server implementation selections */<a name="line.227"></a>
+<span class="sourceLineNo">228</span>  public enum ImplType {<a name="line.228"></a>
+<span class="sourceLineNo">229</span>    HS_HA("hsha", true, THsHaServer.class, true),<a name="line.229"></a>
+<span class="sourceLineNo">230</span>    NONBLOCKING("nonblocking", true, TNonblockingServer.class, true),<a name="line.230"></a>
+<span class="sourceLineNo">231</span>    THREAD_POOL("threadpool", false, TBoundedThreadPoolServer.class, true),<a name="line.231"></a>
+<span class="sourceLineNo">232</span>    THREADED_SELECTOR(<a name="line.232"></a>
+<span class="sourceLineNo">233</span>        "threadedselector", true, TThreadedSelectorServer.class, true);<a name="line.233"></a>
+<span class="sourceLineNo">234</span><a name="line.234"></a>
+<span class="sourceLineNo">235</span>    public static final ImplType DEFAULT = THREAD_POOL;<a name="line.235"></a>
+<span class="sourceLineNo">236</span><a name="line.236"></a>
+<span class="sourceLineNo">237</span>    final String option;<a name="line.237"></a>
+<span class="sourceLineNo">238</span>    final boolean isAlwaysFramed;<a name="line.238"></a>
+<span class="sourceLineNo">239</span>    final Class&lt;? extends TServer&gt; serverClass;<a name="line.239"></a>
+<span class="sourceLineNo">240</span>    final boolean canSpecifyBindIP;<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span>    private ImplType(String option, boolean isAlwaysFramed,<a name="line.242"></a>
+<span class="sourceLineNo">243</span>        Class&lt;? extends TServer&gt; serverClass, boolean canSpecifyBindIP) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span>      this.option = option;<a name="line.244"></a>
+<span class="sourceLineNo">245</span>      this.isAlwaysFramed = isAlwaysFramed;<a name="line.245"></a>
+<span class="sourceLineNo">246</span>      this.serverClass = serverClass;<a name="line.246"></a>
+<span class="sourceLineNo">247</span>      this.canSpecifyBindIP = canSpecifyBindIP;<a name="line.247"></a>
+<span class="sourceLineNo">248</span>    }<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span>    /**<a name="line.250"></a>
+<span class="sourceLineNo">251</span>     * @return &lt;code&gt;-option&lt;/code&gt; so we can get the list of options from<a name="line.251"></a>
+<span class="sourceLineNo">252</span>     *         {@link #values()}<a name="line.252"></a>
+<span class="sourceLineNo">253</span>     */<a name="line.253"></a>
+<span class="sourceLineNo">254</span>    @Override<a name="line.254"></a>
+<span class="sourceLineNo">255</span>    public String toString() {<a name="line.255"></a>
+<span class="sourceLineNo">256</span>      return "-" + option;<a name="line.256"></a>
+<span class="sourceLineNo">257</span>    }<a name="line.257"></a>
+<span class="sourceLineNo">258</span><a name="line.258"></a>
+<span class="sourceLineNo">259</span>    public String getOption() {<a name="line.259"></a>
+<span class="sourceLineNo">260</span>      return option;<a name="line.260"></a>
+<span class="sourceLineNo">261</span>    }<a name="line.261"></a>
+<span class="sourceLineNo">262</span><a name="line.262"></a>
+<span class="sourceLineNo">263</span>    public boolean isAlwaysFramed() {<a name="line.263"></a>
+<span class="sourceLineNo">264</span>      return isAlwaysFramed;<a name="line.264"></a>
+<span class="sourceLineNo">265</span>    }<a name="line.265"></a>
+<span class="sourceLineNo">266</span><a name="line.266"></a>
+<span class="sourceLineNo">267</span>    public String getDescription() {<a name="line.267"></a>
+<span class="sourceLineNo">268</span>      StringBuilder sb = new StringBuilder("Use the " +<a name="line.268"></a>
+<span class="sourceLineNo">269</span>          serverClass.getSimpleName());<a name="line.269"></a>
+<span class="sourceLineNo">270</span>      if (isAlwaysFramed) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span>        sb.append(" This implies the framed transport.");<a name="line.271"></a>
+<span class="sourceLineNo">272</span>      }<a name="line.272"></a>
+<span class="sourceLineNo">273</span>      if (this == DEFAULT) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span>        sb.append("This is the default.");<a name="line.274"></a>
+<span class="sourceLineNo">275</span>      }<a name="line.275"></a>
+<span class="sourceLineNo">276</span>      return sb.toString();<a name="line.276"></a>
+<span class="sourceLineNo">277</span>    }<a name="line.277"></a>
+<span class="sourceLineNo">278</span><a name="line.278"></a>
+<span class="sourceLineNo">279</span>    static OptionGroup createOptionGroup() {<a name="line.279"></a>
+<span class="sourceLineNo">280</span>      OptionGroup group = new OptionGroup();<a name="line.280"></a>
+<span class="sourceLineNo">281</span>      for (ImplType t : values()) {<a name="line.281"></a>
+<span class="sourceLineNo">282</span>        group.addOption(new Option(t.option, t.getDescription()));<a name="line.282"></a>
+<span class="sourceLineNo">283</span>      }<a name="line.283"></a>
+<span class="sourceLineNo">284</span>      return group;<a name="line.284"></a>
+<span class="sourceLineNo">285</span>    }<a name="line.285"></a>
+<span class="sourceLineNo">286</span><a name="line.286"></a>
+<span class="sourceLineNo">287</span>    public static ImplType getServerImpl(Configuration conf) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span>      String confType = conf.get(SERVER_TYPE_CONF_KEY, THREAD_POOL.option);<a name="line.288"></a>
+<span class="sourceLineNo">289</span>      for (ImplType t : values()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span>        if (confType.equals(t.option)) {<a name="line.290"></a>
+<span class="sourceLineNo">291</span>          return t;<a name="line.291"></a>
+<span class="sourceLineNo">292</span>        }<a name="line.292"></a>
+<span class="sourceLineNo">293</span>      }<a name="line.293"></a>
+<span class="sourceLineNo">294</span>      throw new AssertionError("Unknown server ImplType.option:" + confType);<a name="line.294"></a>
+<span class="sourceLineNo">295</span>    }<a name="line.295"></a>
+<span class="sourceLineNo">296</span><a name="line.296"></a>
+<span class="sourceLineNo">297</span>    static void setServerImpl(CommandLine cmd, Configuration conf) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span>      ImplType chosenType = null;<a name="line.298"></a>
+<span class="sourceLineNo">299</span>      int numChosen = 0;<a name="line.299"></a>
+<span class="sourceLineNo">300</span>      for (ImplType t : values()) {<a name="line.300"></a>
+<span class="sourceLineNo">301</span>        if (cmd.hasOption(t.option)) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span>          chosenType = t;<a name="line.302"></a>
+<span class="sourceLineNo">303</span>          ++numChosen;<a name="line.303"></a>
+<span class="sourceLineNo">304</span>        }<a name="line.304"></a>
+<span class="sourceLineNo">305</span>      }<a name="line.305"></a>
+<span class="sourceLineNo">306</span>      if (numChosen &lt; 1) {<a name="line.306"></a>
+<span class="sourceLineNo">307</span>        LOG.info("Using default thrift server type");<a name="line.307"></a>
+<span class="sourceLineNo">308</span>        chosenType = DEFAULT;<a name="line.308"></a>
+<span class="sourceLineNo">309</span>      } else if (numChosen &gt; 1) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span>        throw new AssertionError("Exactly one option out of " +<a name="line.310"></a>
+<span class="sourceLineNo">311</span>          Arrays.toString(values()) + " has to be specified");<a name="line.311"></a>
+<span class="sourceLineNo">312</span>      }<a name="line.312"></a>
+<span class="sourceLineNo">313</span>      LOG.info("Using thrift server type " + chosenType.option);<a name="line.313"></a>
+<span class="sourceLineNo">314</span>      conf.set(SERVER_TYPE_CONF_KEY, chosenType.option);<a name="line.314"></a>
+<span class="sourceLineNo">315</span>    }<a name="line.315"></a>
+<span class="sourceLineNo">316</span><a name="line.316"></a>
+<span class="sourceLineNo">317</span>    public String simpleClassName() {<a name="line.317"></a>
+<span class="sourceLineNo">318</span>      return serverClass.getSimpleName();<a name="line.318"></a>
+<span class="sourceLineNo">319</span>    }<a name="line.319"></a>
+<span class="sourceLineNo">320</span><a name="line.320"></a>
+<span class="sourceLineNo">321</span>    public static List&lt;String&gt; serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span>      List&lt;String&gt; l = new ArrayList&lt;&gt;();<a name="line.322"></a>
+<span class="sourceLineNo">323</span>      for (ImplType t : values()) {<a name="line.323"></a>
+<span class="sourceLineNo">324</span>        if (!t.canSpecifyBindIP) {<a name="line.324"></a>
+<span class="sourceLineNo">325</span>          l.add(t.simpleClassName());<a name="line.325"></a>
+<span class="sourceLineNo">326</span>        }<a name="line.326"></a>
+<span class="sourceLineNo">327</span>      }<a name="line.327"></a>
+<span class="sourceLineNo">328</span>      return l;<a name="line.328"></a>
+<span class="sourceLineNo">329</span>    }<a name="line.329"></a>
+<span class="sourceLineNo">330</span><a name="line.330"></a>
+<span class="sourceLineNo">331</span>  }<a name="line.331"></a>
+<span class="sourceLineNo">332</span><a name="line.332"></a>
+<span class="sourceLineNo">333</span>  public ThriftServerRunner(Configuration conf) throws IOException {<a name="line.333"></a>
+<span class="sourceLineNo">334</span>    UserProvider userProvider = UserProvider.instantiate(conf);<a name="line.334"></a>
+<span class="sourceLineNo">335</span>    // login the server principal (if using secure Hadoop)<a name="line.335"></a>
+<span class="sourceLineNo">336</span>    securityEnabled = userProvider.isHadoopSecurityEnabled()<a name="line.336"></a>
+<span class="sourceLineNo">337</span>      &amp;&amp; userProvider.isHBaseSecurityEnabled();<a name="line.337"></a>
+<span class="sourceLineNo">338</span>    if (securityEnabled) {<a name="line.338"></a>
+<span class="sourceLineNo">339</span>      host = Strings.domainNamePointerToHostName(DNS.getDefaultHost(<a name="line.339"></a>
+<span class="sourceLineNo">340</span>        conf.get("hbase.thrift.dns.interface", "default"),<a name="line.340"></a>
+<span class="sourceLineNo">341</span>        conf.get("hbase.thrift.dns.nameserver", "default")));<a name="line.341"></a>
+<span class="sourceLineNo">342</span>      userProvider.login("hbase.thrift.keytab.file",<a name="line.342"></a>
+<span class="sourceLineNo">343</span>        "hbase.thrift.kerberos.principal", host);<a name="line.343"></a>
+<span class="sourceLineNo">344</span>    }<a name="line.344"></a>
+<span class="sourceLineNo">345</span>    this.conf = HBaseConfiguration.create(conf);<a name="line.345"></a>
+<span class="sourceLineNo">346</span>    this.listenPort = conf.getInt(PORT_CONF_KEY, DEFAULT_LISTEN_PORT);<a name="line.346"></a>
+<span class="sourceLineNo">347</span>    this.metrics = new ThriftMetrics(conf, ThriftMetrics.ThriftServerType.ONE);<a name="line.347"></a>
+<span class="sourceLineNo">348</span>    this.pauseMonitor = new JvmPauseMonitor(conf, this.metrics.getSource());<a name="line.348"></a>
+<span class="sourceLineNo">349</span>    this.hbaseHandler = new HBaseHandler(conf, userProvider);<a name="line.349"></a>
+<span class="sourceLineNo">350</span>    this.hbaseHandler.initMetrics(metrics);<a name="line.350"></a>
+<span class="sourceLineNo">351</span>    this.handler = HbaseHandlerMetricsProxy.newInstance(<a name="line.351"></a>
+<span class="sourceLineNo">352</span>      hbaseHandler, metrics, conf);<a name="line.352"></a>
+<span class="sourceLineNo">353</span>    this.realUser = userProvider.getCurrent().getUGI();<a name="line.353"></a>
+<span class="sourceLineNo">354</span>    String strQop = conf.get(THRIFT_QOP_KEY);<a name="line.354"></a>
+<span class="sourceLineNo">355</span>    if (strQop != null) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span>      this.qop = SaslUtil.getQop(strQop);<a name="line.356"></a>
+<span class="sourceLineNo">357</span>    }<a name="line.357"></a>
+<span class="sourceLineNo">358</span>    doAsEnabled = conf.getBoolean(THRIFT_SUPPORT_PROXYUSER, false);<a name="line.358"></a>
+<span class="sourceLineNo">359</span>    if (doAsEnabled) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span>      if (!conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.360"></a>
+<span class="sourceLineNo">361</span>        LOG.warn("Fail to enable the doAs feature. hbase.regionserver.thrift.http is not " +<a name="line.361"></a>
+<span class="sourceLineNo">362</span>                "configured ");<a name="line.362"></a>
+<span class="sourceLineNo">363</span>      }<a name="line.363"></a>
+<span class="sourceLineNo">364</span>    }<a name="line.364"></a>
+<span class="sourceLineNo">365</span>    if (qop != null) {<a name="line.365"></a>
+<span class="sourceLineNo">366</span>      if (qop != QualityOfProtection.AUTHENTICATION &amp;&amp;<a name="line.366"></a>
+<span class="sourceLineNo">367</span>          qop != QualityOfProtection.INTEGRITY &amp;&amp;<a name="line.367"></a>
+<span class="sourceLineNo">368</span>          qop != QualityOfProtection.PRIVACY) {<a name="line.368"></a>
+<span class="sourceLineNo">369</span>        throw new IOException(String.format("Invalide %s: It must be one of %s, %s, or %s.",<a name="line.369"></a>
+<span class="sourceLineNo">370</span>                              THRIFT_QOP_KEY,<a name="line.370"></a>
+<span class="sourceLineNo">371</span>                              QualityOfProtection.AUTHENTICATION.name(),<a name="line.371"></a>
+<span class="sourceLineNo">372</span>                              QualityOfProtection.INTEGRITY.name(),<a name="line.372"></a>
+<span class="sourceLineNo">373</span>                              QualityOfProtection.PRIVACY.name()));<a name="line.373"></a>
+<span class="sourceLineNo">374</span>      }<a name="line.374"></a>
+<span class="sourceLineNo">375</span>      checkHttpSecurity(qop, conf);<a name="line.375"></a>
+<span class="sourceLineNo">376</span>      if (!securityEnabled) {<a name="line.376"></a>
+<span class="sourceLineNo">377</span>        throw new IOException("Thrift server must"<a name="line.377"></a>
+<span class="sourceLineNo">378</span>          + " run in secure mode to support authentication");<a name="line.378"></a>
+<span class="sourceLineNo">379</span>      }<a name="line.379"></a>
 <span class="sourceLineNo">380</span>    }<a name="line.380"></a>
 <span class="sourceLineNo">381</span>  }<a name="line.381"></a>
 <span class="sourceLineNo">382</span><a name="line.382"></a>
-<span class="sourceLineNo">383</span>  /*<a name="line.383"></a>
-<span class="sourceLineNo">384</span>   * Runs the Thrift server<a name="line.384"></a>
-<span class="sourceLineNo">385</span>   */<a name="line.385"></a>
-<span class="sourceLineNo">386</span>  @Override<a name="line.386"></a>
-<span class="sourceLineNo">387</span>  public void run() {<a name="line.387"></a>
-<span class="sourceLineNo">388</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.388"></a>
-<span class="sourceLineNo">389</span>      @Override<a name="line.389"></a>
-<span class="sourceLineNo">390</span>      public Object run() {<a name="line.390"></a>
-<span class="sourceLineNo">391</span>        try {<a name="line.391"></a>
-<span class="sourceLineNo">392</span>          pauseMonitor.start();<a name="line.392"></a>
-<span class="sourceLineNo">393</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.393"></a>
-<span class="sourceLineNo">394</span>            setupHTTPServer();<a name="line.394"></a>
-<span class="sourceLineNo">395</span>            httpServer.start();<a name="line.395"></a>
-<span class="sourceLineNo">396</span>            httpServer.join();<a name="line.396"></a>
-<span class="sourceLineNo">397</span>          } else {<a name="line.397"></a>
-<span class="sourceLineNo">398</span>            setupServer();<a name="line.398"></a>
-<span class="sourceLineNo">399</span>            tserver.serve();<a name="line.399"></a>
-<span class="sourceLineNo">400</span>          }<a name="line.400"></a>
-<span class="sourceLineNo">401</span>        } catch (Exception e) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.402"></a>
-<span class="sourceLineNo">403</span>          // Crash the process if the ThriftServer is not running<a name="line.403"></a>
-<span class="sourceLineNo">404</span>          System.exit(-1);<a name="line.404"></a>
-<span class="sourceLineNo">405</span>        }<a name="line.405"></a>
-<span class="sourceLineNo">406</span>        return null;<a name="line.406"></a>
-<span class="sourceLineNo">407</span>      }<a name="line.407"></a>
-<span class="sourceLineNo">408</span>    });<a name="line.408"></a>
-<span class="sourceLineNo">409</span><a name="line.409"></a>
-<span class="sourceLineNo">410</span>  }<a name="line.410"></a>
-<span class="sourceLineNo">411</span><a name="line.411"></a>
-<span class="sourceLineNo">412</span>  public void shutdown() {<a name="line.412"></a>
-<span class="sourceLineNo">413</span>    if (pauseMonitor != null) {<a name="line.413"></a>
-<span class="sourceLineNo">414</span>      pauseMonitor.stop();<a name="line.414"></a>
-<span class="sourceLineNo">415</span>    }<a name="line.415"></a>
-<span class="sourceLineNo">416</span>    if (tserver != null) {<a name="line.416"></a>
-<span class="sourceLineNo">417</span>      tserver.stop();<a name="line.417"></a>
-<span class="sourceLineNo">418</span>      tserver = null;<a name="line.418"></a>
-<span class="sourceLineNo">419</span>    }<a name="line.419"></a>
-<span class="sourceLineNo">420</span>    if (httpServer != null) {<a name="line.420"></a>
-<span class="sourceLineNo">421</span>      try {<a name="line.421"></a>
-<span class="sourceLineNo">422</span>        httpServer.stop();<a name="line.422"></a>
-<span class="sourceLineNo">423</span>        httpServer = null;<a name="line.423"></a>
-<span class="sourceLineNo">424</span>      } catch (Exception e) {<a name="line.424"></a>
-<span class="sourceLineNo">425</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.425"></a>
-<span class="sourceLineNo">426</span>      }<a name="line.426"></a>
-<span class="sourceLineNo">427</span>      httpServer = null;<a name="line.427"></a>
+<span class="sourceLineNo">383</span>  private void checkHttpSecurity(QualityOfProtection qop, Configuration conf) {<a name="line.383"></a>
+<span class="sourceLineNo">384</span>    if (qop == QualityOfProtection.PRIVACY &amp;&amp;<a name="line.384"></a>
+<span class="sourceLineNo">385</span>        conf.getBoolean(USE_HTTP_CONF_KEY, false) &amp;&amp;<a name="line.385"></a>
+<span class="sourceLineNo">386</span>        !conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.386"></a>
+<span class="sourceLineNo">387</span>      throw new IllegalArgumentException("Thrift HTTP Server's QoP is privacy, but " +<a name="line.387"></a>
+<span class="sourceLineNo">388</span>          THRIFT_SSL_ENABLED + " is false");<a name="line.388"></a>
+<span class="sourceLineNo">389</span>    }<a name="line.389"></a>
+<span class="sourceLineNo">390</span>  }<a name="line.390"></a>
+<span class="sourceLineNo">391</span><a name="line.391"></a>
+<span class="sourceLineNo">392</span>  /*<a name="line.392"></a>
+<span class="sourceLineNo">393</span>   * Runs the Thrift server<a name="line.393"></a>
+<span class="sourceLineNo">394</span>   */<a name="line.394"></a>
+<span class="sourceLineNo">395</span>  @Override<a name="line.395"></a>
+<span class="sourceLineNo">396</span>  public void run() {<a name="line.396"></a>
+<span class="sourceLineNo">397</span>    realUser.doAs(new PrivilegedAction&lt;Object&gt;() {<a name="line.397"></a>
+<span class="sourceLineNo">398</span>      @Override<a name="line.398"></a>
+<span class="sourceLineNo">399</span>      public Object run() {<a name="line.399"></a>
+<span class="sourceLineNo">400</span>        try {<a name="line.400"></a>
+<span class="sourceLineNo">401</span>          pauseMonitor.start();<a name="line.401"></a>
+<span class="sourceLineNo">402</span>          if (conf.getBoolean(USE_HTTP_CONF_KEY, false)) {<a name="line.402"></a>
+<span class="sourceLineNo">403</span>            setupHTTPServer();<a name="line.403"></a>
+<span class="sourceLineNo">404</span>            httpServer.start();<a name="line.404"></a>
+<span class="sourceLineNo">405</span>            httpServer.join();<a name="line.405"></a>
+<span class="sourceLineNo">406</span>          } else {<a name="line.406"></a>
+<span class="sourceLineNo">407</span>            setupServer();<a name="line.407"></a>
+<span class="sourceLineNo">408</span>            tserver.serve();<a name="line.408"></a>
+<span class="sourceLineNo">409</span>          }<a name="line.409"></a>
+<span class="sourceLineNo">410</span>        } catch (Exception e) {<a name="line.410"></a>
+<span class="sourceLineNo">411</span>          LOG.error(HBaseMarkers.FATAL, "Cannot run ThriftServer", e);<a name="line.411"></a>
+<span class="sourceLineNo">412</span>          // Crash the process if the ThriftServer is not running<a name="line.412"></a>
+<span class="sourceLineNo">413</span>          System.exit(-1);<a name="line.413"></a>
+<span class="sourceLineNo">414</span>        }<a name="line.414"></a>
+<span class="sourceLineNo">415</span>        return null;<a name="line.415"></a>
+<span class="sourceLineNo">416</span>      }<a name="line.416"></a>
+<span class="sourceLineNo">417</span>    });<a name="line.417"></a>
+<span class="sourceLineNo">418</span><a name="line.418"></a>
+<span class="sourceLineNo">419</span>  }<a name="line.419"></a>
+<span class="sourceLineNo">420</span><a name="line.420"></a>
+<span class="sourceLineNo">421</span>  public void shutdown() {<a name="line.421"></a>
+<span class="sourceLineNo">422</span>    if (pauseMonitor != null) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span>      pauseMonitor.stop();<a name="line.423"></a>
+<span class="sourceLineNo">424</span>    }<a name="line.424"></a>
+<span class="sourceLineNo">425</span>    if (tserver != null) {<a name="line.425"></a>
+<span class="sourceLineNo">426</span>      tserver.stop();<a name="line.426"></a>
+<span class="sourceLineNo">427</span>      tserver = null;<a name="line.427"></a>
 <span class="sourceLineNo">428</span>    }<a name="line.428"></a>
-<span class="sourceLineNo">429</span>  }<a name="line.429"></a>
-<span class="sourceLineNo">430</span><a name="line.430"></a>
-<span class="sourceLineNo">431</span>  private void setupHTTPServer() throws IOException {<a name="line.431"></a>
-<span class="sourceLineNo">432</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.432"></a>
-<span class="sourceLineNo">433</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.433"></a>
-<span class="sourceLineNo">434</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.434"></a>
-<span class="sourceLineNo">435</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.435"></a>
-<span class="sourceLineNo">436</span><a name="line.436"></a>
-<span class="sourceLineNo">437</span>    // Set the default max thread number to 100 to limit<a name="line.437"></a>
-<span class="sourceLineNo">438</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.438"></a>
-<span class="sourceLineNo">439</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.439"></a>
-<span class="sourceLineNo">440</span>    //<a name="line.440"></a>
-<span class="sourceLineNo">441</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.441"></a>
-<span class="sourceLineNo">442</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.442"></a>
-<span class="sourceLineNo">443</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.443"></a>
-<span class="sourceLineNo">444</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.444"></a>
-<span class="sourceLineNo">445</span>    threadPool.setMinThreads(minThreads);<a name="line.445"></a>
-<span class="sourceLineNo">446</span>    httpServer = new Server(threadPool);<a name="line.446"></a>
-<span class="sourceLineNo">447</span><a name="line.447"></a>
-<span class="sourceLineNo">448</span>    // Context handler<a name="line.448"></a>
-<span class="sourceLineNo">449</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.449"></a>
-<span class="sourceLineNo">450</span>            ServletContextHandler.SESSIONS);<a name="line.450"></a>
-<span class="sourceLineNo">451</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.451"></a>
-<span class="sourceLineNo">452</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.452"></a>
-<span class="sourceLineNo">453</span><a name="line.453"></a>
-<span class="sourceLineNo">454</span>    // set up Jetty and run the embedded server<a name="line.454"></a>
-<span class="sourceLineNo">455</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.455"></a>
-<span class="sourceLineNo">456</span>    httpConfig.setSecureScheme("https");<a name="line.456"></a>
-<span class="sourceLineNo">457</span>    httpConfig.setSecurePort(listenPort);<a name="line.457"></a>
-<span class="sourceLineNo">458</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.458"></a>
-<span class="sourceLineNo">459</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.459"></a>
-<span class="sourceLineNo">460</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.460"></a>
-<span class="sourceLineNo">461</span>    httpConfig.setSendServerVersion(false);<a name="line.461"></a>
-<span class="sourceLineNo">462</span>    httpConfig.setSendDateHeader(false);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span>    ServerConnector serverConnector;<a name="line.464"></a>
-<span class="sourceLineNo">465</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.466"></a>
-<span class="sourceLineNo">467</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.467"></a>
-<span class="sourceLineNo">468</span><a name="line.468"></a>
-<span class="sourceLineNo">469</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.469"></a>
-<span class="sourceLineNo">470</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.470"></a>
-<span class="sourceLineNo">471</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.471"></a>
-<span class="sourceLineNo">472</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.472"></a>
-<span class="sourceLineNo">473</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.473"></a>
-<span class="sourceLineNo">474</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.474"></a>
-<span class="sourceLineNo">475</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.475"></a>
-<span class="sourceLineNo">476</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.476"></a>
-<span class="sourceLineNo">477</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.477"></a>
-<span class="sourceLineNo">478</span><a name="line.478"></a>
-<span class="sourceLineNo">479</span>      String[] excludeCiphers = conf.getStrings(<a name="line.479"></a>
-<span class="sourceLineNo">480</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.480"></a>
-<span class="sourceLineNo">481</span>      if (excludeCiphers.length != 0) {<a name="line.481"></a>
-<span class="sourceLineNo">482</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.482"></a>
-<span class="sourceLineNo">483</span>      }<a name="line.483"></a>
-<span class="sourceLineNo">484</span>      String[] includeCiphers = conf.getStrings(<a name="line.484"></a>
-<span class="sourceLineNo">485</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.485"></a>
-<span class="sourceLineNo">486</span>      if (includeCiphers.length != 0) {<a name="line.486"></a>
-<span class="sourceLineNo">487</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.487"></a>
-<span class="sourceLineNo">488</span>      }<a name="line.488"></a>
-<span class="sourceLineNo">489</span><a name="line.489"></a>
-<span class="sourceLineNo">490</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.490"></a>
-<span class="sourceLineNo">491</span>      String[] excludeProtocols = conf.getStrings(<a name="line.491"></a>
-<span class="sourceLineNo">492</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.492"></a>
-<span class="sourceLineNo">493</span>      if (excludeProtocols.length != 0) {<a name="line.493"></a>
-<span class="sourceLineNo">494</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.494"></a>
-<span class="sourceLineNo">495</span>      }<a name="line.495"></a>
-<span class="sourceLineNo">496</span>      String[] includeProtocols = conf.getStrings(<a name="line.496"></a>
-<span class="sourceLineNo">497</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.497"></a>
-<span class="sourceLineNo">498</span>      if (includeProtocols.length != 0) {<a name="line.498"></a>
-<span class="sourceLineNo">499</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.499"></a>
-<span class="sourceLineNo">500</span>      }<a name="line.500"></a>
-<span class="sourceLineNo">501</span><a name="line.501"></a>
-<span class="sourceLineNo">502</span>      serverConnector = new ServerConnector(httpServer,<a name="line.502"></a>
-<span class="sourceLineNo">503</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.503"></a>
-<span class="sourceLineNo">504</span>          new HttpConnectionFactory(httpsConfig));<a name="line.504"></a>
-<span class="sourceLineNo">505</span>    } else {<a name="line.505"></a>
-<span class="sourceLineNo">506</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.506"></a>
-<span class="sourceLineNo">507</span>    }<a name="line.507"></a>
-<span class="sourceLineNo">508</span>    serverConnector.setPort(listenPort);<a name="line.508"></a>
-<span class="sourceLineNo">509</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.509"></a>
-<span class="sourceLineNo">510</span>    serverConnector.setHost(host);<a name="line.510"></a>
-<span class="sourceLineNo">511</span>    httpServer.addConnector(serverConnector);<a name="line.511"></a>
-<span class="sourceLineNo">512</span>    httpServer.setStopAtShutdown(true);<a name="line.512"></a>
-<span class="sourceLineNo">513</span><a name="line.513"></a>
-<span class="sourceLineNo">514</span>    if (doAsEnabled) {<a name="line.514"></a>
-<span class="sourceLineNo">515</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.515"></a>
+<span class="sourceLineNo">429</span>    if (httpServer != null) {<a name="line.429"></a>
+<span class="sourceLineNo">430</span>      try {<a name="line.430"></a>
+<span class="sourceLineNo">431</span>        httpServer.stop();<a name="line.431"></a>
+<span class="sourceLineNo">432</span>        httpServer = null;<a name="line.432"></a>
+<span class="sourceLineNo">433</span>      } catch (Exception e) {<a name="line.433"></a>
+<span class="sourceLineNo">434</span>        LOG.error("Problem encountered in shutting down HTTP server " + e.getCause());<a name="line.434"></a>
+<span class="sourceLineNo">435</span>      }<a name="line.435"></a>
+<span class="sourceLineNo">436</span>      httpServer = null;<a name="line.436"></a>
+<span class="sourceLineNo">437</span>    }<a name="line.437"></a>
+<span class="sourceLineNo">438</span>  }<a name="line.438"></a>
+<span class="sourceLineNo">439</span><a name="line.439"></a>
+<span class="sourceLineNo">440</span>  private void setupHTTPServer() throws IOException {<a name="line.440"></a>
+<span class="sourceLineNo">441</span>    TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();<a name="line.441"></a>
+<span class="sourceLineNo">442</span>    TProcessor processor = new Hbase.Processor&lt;&gt;(handler);<a name="line.442"></a>
+<span class="sourceLineNo">443</span>    TServlet thriftHttpServlet = new ThriftHttpServlet(processor, protocolFactory, realUser,<a name="line.443"></a>
+<span class="sourceLineNo">444</span>        conf, hbaseHandler, securityEnabled, doAsEnabled);<a name="line.444"></a>
+<span class="sourceLineNo">445</span><a name="line.445"></a>
+<span class="sourceLineNo">446</span>    // Set the default max thread number to 100 to limit<a name="line.446"></a>
+<span class="sourceLineNo">447</span>    // the number of concurrent requests so that Thrfit HTTP server doesn't OOM easily.<a name="line.447"></a>
+<span class="sourceLineNo">448</span>    // Jetty set the default max thread number to 250, if we don't set it.<a name="line.448"></a>
+<span class="sourceLineNo">449</span>    //<a name="line.449"></a>
+<span class="sourceLineNo">450</span>    // Our default min thread number 2 is the same as that used by Jetty.<a name="line.450"></a>
+<span class="sourceLineNo">451</span>    int minThreads = conf.getInt(HTTP_MIN_THREADS, 2);<a name="line.451"></a>
+<span class="sourceLineNo">452</span>    int maxThreads = conf.getInt(HTTP_MAX_THREADS, 100);<a name="line.452"></a>
+<span class="sourceLineNo">453</span>    QueuedThreadPool threadPool = new QueuedThreadPool(maxThreads);<a name="line.453"></a>
+<span class="sourceLineNo">454</span>    threadPool.setMinThreads(minThreads);<a name="line.454"></a>
+<span class="sourceLineNo">455</span>    httpServer = new Server(threadPool);<a name="line.455"></a>
+<span class="sourceLineNo">456</span><a name="line.456"></a>
+<span class="sourceLineNo">457</span>    // Context handler<a name="line.457"></a>
+<span class="sourceLineNo">458</span>    ServletContextHandler ctxHandler = new ServletContextHandler(httpServer, "/",<a name="line.458"></a>
+<span class="sourceLineNo">459</span>            ServletContextHandler.SESSIONS);<a name="line.459"></a>
+<span class="sourceLineNo">460</span>    ctxHandler.addServlet(new ServletHolder(thriftHttpServlet), "/*");<a name="line.460"></a>
+<span class="sourceLineNo">461</span>    HttpServerUtil.constrainHttpMethods(ctxHandler);<a name="line.461"></a>
+<span class="sourceLineNo">462</span><a name="line.462"></a>
+<span class="sourceLineNo">463</span>    // set up Jetty and run the embedded server<a name="line.463"></a>
+<span class="sourceLineNo">464</span>    HttpConfiguration httpConfig = new HttpConfiguration();<a name="line.464"></a>
+<span class="sourceLineNo">465</span>    httpConfig.setSecureScheme("https");<a name="line.465"></a>
+<span class="sourceLineNo">466</span>    httpConfig.setSecurePort(listenPort);<a name="line.466"></a>
+<span class="sourceLineNo">467</span>    httpConfig.setHeaderCacheSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.467"></a>
+<span class="sourceLineNo">468</span>    httpConfig.setRequestHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.468"></a>
+<span class="sourceLineNo">469</span>    httpConfig.setResponseHeaderSize(DEFAULT_HTTP_MAX_HEADER_SIZE);<a name="line.469"></a>
+<span class="sourceLineNo">470</span>    httpConfig.setSendServerVersion(false);<a name="line.470"></a>
+<span class="sourceLineNo">471</span>    httpConfig.setSendDateHeader(false);<a name="line.471"></a>
+<span class="sourceLineNo">472</span><a name="line.472"></a>
+<span class="sourceLineNo">473</span>    ServerConnector serverConnector;<a name="line.473"></a>
+<span class="sourceLineNo">474</span>    if(conf.getBoolean(THRIFT_SSL_ENABLED, false)) {<a name="line.474"></a>
+<span class="sourceLineNo">475</span>      HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);<a name="line.475"></a>
+<span class="sourceLineNo">476</span>      httpsConfig.addCustomizer(new SecureRequestCustomizer());<a name="line.476"></a>
+<span class="sourceLineNo">477</span><a name="line.477"></a>
+<span class="sourceLineNo">478</span>      SslContextFactory sslCtxFactory = new SslContextFactory();<a name="line.478"></a>
+<span class="sourceLineNo">479</span>      String keystore = conf.get(THRIFT_SSL_KEYSTORE_STORE);<a name="line.479"></a>
+<span class="sourceLineNo">480</span>      String password = HBaseConfiguration.getPassword(conf,<a name="line.480"></a>
+<span class="sourceLineNo">481</span>          THRIFT_SSL_KEYSTORE_PASSWORD, null);<a name="line.481"></a>
+<span class="sourceLineNo">482</span>      String keyPassword = HBaseConfiguration.getPassword(conf,<a name="line.482"></a>
+<span class="sourceLineNo">483</span>          THRIFT_SSL_KEYSTORE_KEYPASSWORD, password);<a name="line.483"></a>
+<span class="sourceLineNo">484</span>      sslCtxFactory.setKeyStorePath(keystore);<a name="line.484"></a>
+<span class="sourceLineNo">485</span>      sslCtxFactory.setKeyStorePassword(password);<a name="line.485"></a>
+<span class="sourceLineNo">486</span>      sslCtxFactory.setKeyManagerPassword(keyPassword);<a name="line.486"></a>
+<span class="sourceLineNo">487</span><a name="line.487"></a>
+<span class="sourceLineNo">488</span>      String[] excludeCiphers = conf.getStrings(<a name="line.488"></a>
+<span class="sourceLineNo">489</span>          THRIFT_SSL_EXCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.489"></a>
+<span class="sourceLineNo">490</span>      if (excludeCiphers.length != 0) {<a name="line.490"></a>
+<span class="sourceLineNo">491</span>        sslCtxFactory.setExcludeCipherSuites(excludeCiphers);<a name="line.491"></a>
+<span class="sourceLineNo">492</span>      }<a name="line.492"></a>
+<span class="sourceLineNo">493</span>      String[] includeCiphers = conf.getStrings(<a name="line.493"></a>
+<span class="sourceLineNo">494</span>          THRIFT_SSL_INCLUDE_CIPHER_SUITES, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.494"></a>
+<span class="sourceLineNo">495</span>      if (includeCiphers.length != 0) {<a name="line.495"></a>
+<span class="sourceLineNo">496</span>        sslCtxFactory.setIncludeCipherSuites(includeCiphers);<a name="line.496"></a>
+<span class="sourceLineNo">497</span>      }<a name="line.497"></a>
+<span class="sourceLineNo">498</span><a name="line.498"></a>
+<span class="sourceLineNo">499</span>      // Disable SSLv3 by default due to "Poodle" Vulnerability - CVE-2014-3566<a name="line.499"></a>
+<span class="sourceLineNo">500</span>      String[] excludeProtocols = conf.getStrings(<a name="line.500"></a>
+<span class="sourceLineNo">501</span>          THRIFT_SSL_EXCLUDE_PROTOCOLS, "SSLv3");<a name="line.501"></a>
+<span class="sourceLineNo">502</span>      if (excludeProtocols.length != 0) {<a name="line.502"></a>
+<span class="sourceLineNo">503</span>        sslCtxFactory.setExcludeProtocols(excludeProtocols);<a name="line.503"></a>
+<span class="sourceLineNo">504</span>      }<a name="line.504"></a>
+<span class="sourceLineNo">505</span>      String[] includeProtocols = conf.getStrings(<a name="line.505"></a>
+<span class="sourceLineNo">506</span>          THRIFT_SSL_INCLUDE_PROTOCOLS, ArrayUtils.EMPTY_STRING_ARRAY);<a name="line.506"></a>
+<span class="sourceLineNo">507</span>      if (includeProtocols.length != 0) {<a name="line.507"></a>
+<span class="sourceLineNo">508</span>        sslCtxFactory.setIncludeProtocols(includeProtocols);<a name="line.508"></a>
+<span class="sourceLineNo">509</span>      }<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span>      serverConnector = new ServerConnector(httpServer,<a name="line.511"></a>
+<span class="sourceLineNo">512</span>          new SslConnectionFactory(sslCtxFactory, HttpVersion.HTTP_1_1.toString()),<a name="line.512"></a>
+<span class="sourceLineNo">513</span>          new HttpConnectionFactory(httpsConfig));<a name="line.513"></a>
+<span class="sourceLineNo">514</span>    } else {<a name="line.514"></a>
+<span class="sourceLineNo">515</span>      serverConnector = new ServerConnector(httpServer, new HttpConnectionFactory(httpConfig));<a name="line.515"></a>
 <span class="sourceLineNo">516</span>    }<a name="line.516"></a>
-<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.518"></a>
-<span class="sourceLineNo">519</span>  }<a name="line.519"></a>
-<span class="sourceLineNo">520</span><a name="line.520"></a>
-<span class="sourceLineNo">521</span>  /**<a name="line.521"></a>
-<span class="sourceLineNo">522</span>   * Setting up the thrift TServer<a name="line.522"></a>
-<span class="sourceLineNo">523</span>   */<a name="line.523"></a>
-<span class="sourceLineNo">524</span>  private void setupServer() throws Exception {<a name="line.524"></a>
-<span class="sourceLineNo">525</span>    // Construct correct ProtocolFactory<a name="line.525"></a>
-<span class="sourceLineNo">526</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.526"></a>
-<span class="sourceLineNo">527</span><a name="line.527"></a>
-<span class="sourceLineNo">528</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.528"></a>
-<span class="sourceLineNo">529</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.529"></a>
-<span class="sourceLineNo">530</span>    TProcessor processor = p;<a name="line.530"></a>
-<span class="sourceLineNo">531</span><a name="line.531"></a>
-<span class="sourceLineNo">532</span>    // Construct correct TransportFactory<a name="line.532"></a>
-<span class="sourceLineNo">533</span>    TTransportFactory transportFactory;<a name="line.533"></a>
-<span class="sourceLineNo">534</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span>      if (qop != null) {<a name="line.535"></a>
-<span class="sourceLineNo">536</span>        throw new RuntimeException("Thrift server authentication"<a name="line.536"></a>
-<span class="sourceLineNo">537</span>          + " doesn't work with framed transport yet");<a name="line.537"></a>
-<span class="sourceLineNo">538</span>      }<a name="line.538"></a>
-<span class="sourceLineNo">539</span>      transportFactory = new TFramedTransport.Factory(<a name="line.539"></a>
-<span class="sourceLineNo">540</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.540"></a>
-<span class="sourceLineNo">541</span>      LOG.debug("Using framed transport");<a name="line.541"></a>
-<span class="sourceLineNo">542</span>    } else if (qop == null) {<a name="line.542"></a>
-<span class="sourceLineNo">543</span>      transportFactory = new TTransportFactory();<a name="line.543"></a>
-<span class="sourceLineNo">544</span>    } else {<a name="line.544"></a>
-<span class="sourceLineNo">545</span>      // Extract the name from the principal<a name="line.545"></a>
-<span class="sourceLineNo">546</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.546"></a>
-<span class="sourceLineNo">547</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.547"></a>
-<span class="sourceLineNo">548</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.548"></a>
-<span class="sourceLineNo">549</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.549"></a>
-<span class="sourceLineNo">550</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.550"></a>
-<span class="sourceLineNo">551</span>        new SaslGssCallbackHandler() {<a name="line.551"></a>
-<span class="sourceLineNo">552</span>          @Override<a name="line.552"></a>
-<span class="sourceLineNo">553</span>          public void handle(Callback[] callbacks)<a name="line.553"></a>
-<span class="sourceLineNo">554</span>              throws UnsupportedCallbackException {<a name="line.554"></a>
-<span class="sourceLineNo">555</span>            AuthorizeCallback ac = null;<a name="line.555"></a>
-<span class="sourceLineNo">556</span>            for (Callback callback : callbacks) {<a name="line.556"></a>
-<span class="sourceLineNo">557</span>              if (callback instanceof AuthorizeCallback) {<a name="line.557"></a>
-<span class="sourceLineNo">558</span>                ac = (AuthorizeCallback) callback;<a name="line.558"></a>
-<span class="sourceLineNo">559</span>              } else {<a name="line.559"></a>
-<span class="sourceLineNo">560</span>                throw new UnsupportedCallbackException(callback,<a name="line.560"></a>
-<span class="sourceLineNo">561</span>                    "Unrecognized SASL GSSAPI Callback");<a name="line.561"></a>
-<span class="sourceLineNo">562</span>              }<a name="line.562"></a>
-<span class="sourceLineNo">563</span>            }<a name="line.563"></a>
-<span class="sourceLineNo">564</span>            if (ac != null) {<a name="line.564"></a>
-<span class="sourceLineNo">565</span>              String authid = ac.getAuthenticationID();<a name="line.565"></a>
-<span class="sourceLineNo">566</span>              String authzid = ac.getAuthorizationID();<a name="line.566"></a>
-<span class="sourceLineNo">567</span>              if (!authid.equals(authzid)) {<a name="line.567"></a>
-<span class="sourceLineNo">568</span>                ac.setAuthorized(false);<a name="line.568"></a>
-<span class="sourceLineNo">569</span>              } else {<a name="line.569"></a>
-<span class="sourceLineNo">570</span>                ac.setAuthorized(true);<a name="line.570"></a>
-<span class="sourceLineNo">571</span>                String userName = SecurityUtil.getUserFromPrincipal(authzid);<a name="line.571"></a>
-<span class="sourceLineNo">572</span>                LOG.info("Effective user: " + userName);<a name="line.572"></a>
-<span class="sourceLineNo">573</span>                ac.setAuthorizedID(userName);<a name="line.573"></a>
-<span class="sourceLineNo">574</span>              }<a name="line.574"></a>
-<span class="sourceLineNo">575</span>            }<a name="line.575"></a>
-<span class="sourceLineNo">576</span>          }<a name="line.576"></a>
-<span class="sourceLineNo">577</span>        });<a name="line.577"></a>
-<span class="sourceLineNo">578</span>      transportFactory = saslFactory;<a name="line.578"></a>
-<span class="sourceLineNo">579</span><a name="line.579"></a>
-<span class="sourceLineNo">580</span>      // Create a processor wrapper, to get the caller<a name="line.580"></a>
-<span class="sourceLineNo">581</span>      processor = new TProcessor() {<a name="line.581"></a>
-<span class="sourceLineNo">582</span>        @Override<a name="line.582"></a>
-<span class="sourceLineNo">583</span>        public boolean process(TProtocol inProt,<a name="line.583"></a>
-<span class="sourceLineNo">584</span>            TProtocol outProt) throws TException {<a name="line.584"></a>
-<span class="sourceLineNo">585</span>          TSaslServerTransport saslServerTransport =<a name="line.585"></a>
-<span class="sourceLineNo">586</span>            (TSaslServerTransport)inProt.getTransport();<a name="line.586"></a>
-<span class="sourceLineNo">587</span>          SaslServer saslServer = saslServerTransport.getSaslServer();<a name="line.587"></a>
-<span class="sourceLineNo">588</span>          String principal = saslServer.getAuthorizationID();<a name="line.588"></a>
-<span class="sourceLineNo">589</span>          hbaseHandler.setEffectiveUser(principal);<a name="line.589"></a>
-<span class="sourceLineNo">590</span>          return p.process(inProt, outProt);<a name="line.590"></a>
-<span class="sourceLineNo">591</span>        }<a name="line.591"></a>
-<span class="sourceLineNo">592</span>      };<a name="line.592"></a>
-<span class="sourceLineNo">593</span>    }<a name="line.593"></a>
-<span class="sourceLineNo">594</span><a name="line.594"></a>
-<span class="sourceLineNo">595</span>    if (conf.get(BIND_CONF_KEY) != null &amp;&amp; !implType.canSpecifyBindIP) {<a name="line.595"></a>
-<span class="sourceLineNo">596</span>      LOG.error("Server types " + Joiner.on(", ").join(<a name="line.596"></a>
-<span class="sourceLineNo">597</span>          ImplType.serversThatCannotSpecifyBindIP()) + " don't support IP " +<a name="line.597"></a>
-<span class="sourceLineNo">598</span>          "address binding at the moment. See " +<a name="line.598"></a>
-<span class="sourceLineNo">599</span>          "https://issues.apache.org/jira/browse/HBASE-2155 for details.");<a name="line.599"></a>
-<span class="sourceLineNo">600</span>      throw new RuntimeException(<a name="line.600"></a>
-<span class="sourceLineNo">601</span>          "-" + BIND_CONF_KEY + " not supported with " + implType);<a name="line.601"></a>
+<span class="sourceLineNo">517</span>    serverConnector.setPort(listenPort);<a name="line.517"></a>
+<span class="sourceLineNo">518</span>    String host = getBindAddress(conf).getHostAddress();<a name="line.518"></a>
+<span class="sourceLineNo">519</span>    serverConnector.setHost(host);<a name="line.519"></a>
+<span class="sourceLineNo">520</span>    httpServer.addConnector(serverConnector);<a name="line.520"></a>
+<span class="sourceLineNo">521</span>    httpServer.setStopAtShutdown(true);<a name="line.521"></a>
+<span class="sourceLineNo">522</span><a name="line.522"></a>
+<span class="sourceLineNo">523</span>    if (doAsEnabled) {<a name="line.523"></a>
+<span class="sourceLineNo">524</span>      ProxyUsers.refreshSuperUserGroupsConfiguration(conf);<a name="line.524"></a>
+<span class="sourceLineNo">525</span>    }<a name="line.525"></a>
+<span class="sourceLineNo">526</span><a name="line.526"></a>
+<span class="sourceLineNo">527</span>    LOG.info("Starting Thrift HTTP Server on " + Integer.toString(listenPort));<a name="line.527"></a>
+<span class="sourceLineNo">528</span>  }<a name="line.528"></a>
+<span class="sourceLineNo">529</span><a name="line.529"></a>
+<span class="sourceLineNo">530</span>  /**<a name="line.530"></a>
+<span class="sourceLineNo">531</span>   * Setting up the thrift TServer<a name="line.531"></a>
+<span class="sourceLineNo">532</span>   */<a name="line.532"></a>
+<span class="sourceLineNo">533</span>  private void setupServer() throws Exception {<a name="line.533"></a>
+<span class="sourceLineNo">534</span>    // Construct correct ProtocolFactory<a name="line.534"></a>
+<span class="sourceLineNo">535</span>    TProtocolFactory protocolFactory = getProtocolFactory();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span>    final TProcessor p = new Hbase.Processor&lt;&gt;(handler);<a name="line.537"></a>
+<span class="sourceLineNo">538</span>    ImplType implType = ImplType.getServerImpl(conf);<a name="line.538"></a>
+<span class="sourceLineNo">539</span>    TProcessor processor = p;<a name="line.539"></a>
+<span class="sourceLineNo">540</span><a name="line.540"></a>
+<span class="sourceLineNo">541</span>    // Construct correct TransportFactory<a name="line.541"></a>
+<span class="sourceLineNo">542</span>    TTransportFactory transportFactory;<a name="line.542"></a>
+<span class="sourceLineNo">543</span>    if (conf.getBoolean(FRAMED_CONF_KEY, false) || implType.isAlwaysFramed) {<a name="line.543"></a>
+<span class="sourceLineNo">544</span>      if (qop != null) {<a name="line.544"></a>
+<span class="sourceLineNo">545</span>        throw new RuntimeException("Thrift server authentication"<a name="line.545"></a>
+<span class="sourceLineNo">546</span>          + " doesn't work with framed transport yet");<a name="line.546"></a>
+<span class="sourceLineNo">547</span>      }<a name="line.547"></a>
+<span class="sourceLineNo">548</span>      transportFactory = new TFramedTransport.Factory(<a name="line.548"></a>
+<span class="sourceLineNo">549</span>          conf.getInt(MAX_FRAME_SIZE_CONF_KEY, 2)  * 1024 * 1024);<a name="line.549"></a>
+<span class="sourceLineNo">550</span>      LOG.debug("Using framed transport");<a name="line.550"></a>
+<span class="sourceLineNo">551</span>    } else if (qop == null) {<a name="line.551"></a>
+<span class="sourceLineNo">552</span>      transportFactory = new TTransportFactory();<a name="line.552"></a>
+<span class="sourceLineNo">553</span>    } else {<a name="line.553"></a>
+<span class="sourceLineNo">554</span>      // Extract the name from the principal<a name="line.554"></a>
+<span class="sourceLineNo">555</span>      String name = SecurityUtil.getUserFromPrincipal(<a name="line.555"></a>
+<span class="sourceLineNo">556</span>        conf.get("hbase.thrift.kerberos.principal"));<a name="line.556"></a>
+<span class="sourceLineNo">557</span>      Map&lt;String, String&gt; saslProperties = SaslUtil.initSaslProperties(qop.name());<a name="line.557"></a>
+<span class="sourceLineNo">558</span>      TSaslServerTransport.Factory saslFactory = new TSaslServerTransport.Factory();<a name="line.558"></a>
+<span class="sourceLineNo">559</span>      saslFactory.addServerDefinition("GSSAPI", name, host, saslProperties,<a name="line.559"></a>
+<span class="sourceLineNo">560</span>        new SaslGssCallbackHandler() {<a name="line.560"></a>
+<span class="sourceLineNo">561</span>          @Override<a name="line.561"></a>
+<span class="sourceLineNo">562</span>          public void handle(Callback[] callbacks)<a name="line.562"></a>
+<span class="sourceLineNo">563</span>              throws UnsupportedCallbackException {<a name="line.563"></a>
+<span class="sourceLineNo">564</span>            AuthorizeCallback ac = null;<a name="line.

<TRUNCATED>

[13/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
index f338c1a..d82c3a7 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html
@@ -117,7 +117,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.729">ThriftServerRunner.HBaseHandler</a>
+<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.738">ThriftServerRunner.HBaseHandler</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <div class="block">The HBaseHandler is a glue object that connects Thrift RPC calls to the
@@ -721,7 +721,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>conf</h4>
-<pre>protected&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.730">conf</a></pre>
+<pre>protected&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.739">conf</a></pre>
 </li>
 </ul>
 <a name="LOG">
@@ -730,7 +730,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>LOG</h4>
-<pre>protected static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.731">LOG</a></pre>
+<pre>protected static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.740">LOG</a></pre>
 </li>
 </ul>
 <a name="nextScannerId">
@@ -739,7 +739,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>nextScannerId</h4>
-<pre>protected&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.734">nextScannerId</a></pre>
+<pre>protected&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.743">nextScannerId</a></pre>
 </li>
 </ul>
 <a name="scannerMap">
@@ -748,7 +748,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerMap</h4>
-<pre>protected&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/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.735">scannerMap</a></pre>
+<pre>protected&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/Integer.html?is-external=true" title="class or interface in java.lang">Integer</a>,<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.744">scannerMap</a></pre>
 </li>
 </ul>
 <a name="metrics">
@@ -757,7 +757,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>metrics</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.736">metrics</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.745">metrics</a></pre>
 </li>
 </ul>
 <a name="connectionCache">
@@ -766,7 +766,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>connectionCache</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/ConnectionCache.html" title="class in org.apache.hadoop.hbase.util">ConnectionCache</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.738">connectionCache</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/ConnectionCache.html" title="class in org.apache.hadoop.hbase.util">ConnectionCache</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.747">connectionCache</a></pre>
 </li>
 </ul>
 <a name="coalescer">
@@ -775,7 +775,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>coalescer</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/thrift/IncrementCoalescer.html" title="class in org.apache.hadoop.hbase.thrift">IncrementCoalescer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.739">coalescer</a></pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/thrift/IncrementCoalescer.html" title="class in org.apache.hadoop.hbase.thrift">IncrementCoalescer</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.748">coalescer</a></pre>
 </li>
 </ul>
 <a name="CLEANUP_INTERVAL">
@@ -784,7 +784,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>CLEANUP_INTERVAL</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.741">CLEANUP_INTERVAL</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.750">CLEANUP_INTERVAL</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.HBaseHandler.CLEANUP_INTERVAL">Constant Field Values</a></dd>
@@ -797,7 +797,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>MAX_IDLETIME</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.742">MAX_IDLETIME</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.751">MAX_IDLETIME</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.HBaseHandler.MAX_IDLETIME">Constant Field Values</a></dd>
@@ -818,7 +818,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>HBaseHandler</h4>
-<pre>protected&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.812">HBaseHandler</a>(org.apache.hadoop.conf.Configuration&nbsp;c,
+<pre>protected&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.821">HBaseHandler</a>(org.apache.hadoop.conf.Configuration&nbsp;c,
                        <a href="../../../../../org/apache/hadoop/hbase/security/UserProvider.html" title="class in org.apache.hadoop.hbase.security">UserProvider</a>&nbsp;userProvider)
                 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>
@@ -841,7 +841,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getAllColumns</h4>
-<pre>byte[][]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.750">getAllColumns</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;table)
+<pre>byte[][]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.759">getAllColumns</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</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>
 <div class="block">Returns a list of all the column families for a given Table.</div>
 <dl>
@@ -858,7 +858,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getTable</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.768">getTable</a>(byte[]&nbsp;tableName)
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.777">getTable</a>(byte[]&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>
 <div class="block">Creates and returns a Table instance from a given table name.</div>
 <dl>
@@ -877,7 +877,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getTable</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.773">getTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.782">getTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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>
@@ -891,7 +891,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>addScanner</h4>
-<pre>protected&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.784">addScanner</a>(<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;scanner,
+<pre>protected&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.793">addScanner</a>(<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;scanner,
                          boolean&nbsp;sortColumns)</pre>
 <div class="block">Assigns a unique ID to the scanner and adds the mapping to an internal
  hash-map.</div>
@@ -909,7 +909,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getScanner</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.797">getScanner</a>(int&nbsp;id)</pre>
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.806">getScanner</a>(int&nbsp;id)</pre>
 <div class="block">Returns the scanner associated with the specified ID.</div>
 <dl>
 <dt><span class="paramLabel">Parameters:</span></dt>
@@ -925,7 +925,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>removeScanner</h4>
-<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.808">removeScanner</a>(int&nbsp;id)</pre>
+<pre>protected&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.817">removeScanner</a>(int&nbsp;id)</pre>
 <div class="block">Removes the scanner associated with the specified ID from the internal
  id-&gt;scanner hash-map.</div>
 <dl>
@@ -942,7 +942,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getAdmin</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.827">getAdmin</a>()
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.836">getAdmin</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">Obtain HBaseAdmin. Creates the instance if it is not already created.</div>
 <dl>
@@ -957,7 +957,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>setEffectiveUser</h4>
-<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.831">setEffectiveUser</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;effectiveUser)</pre>
+<pre>void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.840">setEffectiveUser</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;effectiveUser)</pre>
 </li>
 </ul>
 <a name="enableTable-java.nio.ByteBuffer-">
@@ -966,7 +966,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>enableTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.836">enableTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.845">enableTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
                  throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">Brings a table on-line (enables it)</div>
@@ -986,7 +986,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>disableTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.846">disableTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.855">disableTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
                   throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">Disables a table (takes it off-line) If it is being served, the master
@@ -1007,7 +1007,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>isTableEnabled</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.856">isTableEnabled</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.865">isTableEnabled</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
                        throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1027,7 +1027,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>compact</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.868">compact</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableNameOrRegionName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.877">compact</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableNameOrRegionName)
              throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1043,7 +1043,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>majorCompact</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.885">majorCompact</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableNameOrRegionName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.894">majorCompact</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableNameOrRegionName)
                   throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -1059,7 +1059,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableNames</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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.900">getTableNames</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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.909">getTableNames</a>()
                                throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">List all the userspace tables.</div>
@@ -1079,7 +1079,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableRegions</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;org.apache.hadoop.hbase.thrift.generated.TRegionInfo&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.918">getTableRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<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;org.apache.hadoop.hbase.thrift.generated.TRegionInfo&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.927">getTableRegions</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
                                                                            throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">List the regions associated with a table.</div>
@@ -1101,7 +1101,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>get</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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.948">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.957">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                 <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                 <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                                                                 <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1130,7 +1130,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>get</h4>
-<pre>protected&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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.969">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>protected&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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.978">get</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                    byte[]&nbsp;family,
                                                                    byte[]&nbsp;qualifier,
@@ -1153,7 +1153,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getVer</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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.995">getVer</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1004">getVer</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                                                                    int&nbsp;numVersions,
@@ -1184,7 +1184,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getVer</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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1016">getVer</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1025">getVer</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                    byte[]&nbsp;family,
                                                                    byte[]&nbsp;qualifier,
@@ -1209,7 +1209,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getVerTs</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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1041">getVerTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1050">getVerTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                      <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                      <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                                                                      long&nbsp;timestamp,
@@ -1243,7 +1243,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getVerTs</h4>
-<pre>protected&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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1061">getVerTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>protected&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;org.apache.hadoop.hbase.thrift.generated.TCell&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1070">getVerTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                         <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                         byte[]&nbsp;family,
                                                                         byte[]&nbsp;qualifier,
@@ -1268,7 +1268,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRow</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1088">getRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1097">getRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                         <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                         <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
                                                                  throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
@@ -1295,7 +1295,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowWithColumns</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1096">getRowWithColumns</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1105">getRowWithColumns</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                                    <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                                    <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                                                                                    <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1324,7 +1324,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowTs</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1106">getRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1115">getRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                           <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                           long&nbsp;timestamp,
                                                                           <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1353,7 +1353,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowWithColumnsTs</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1113">getRowWithColumnsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1122">getRowWithColumnsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                                                                      <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                                                                      <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                                                                                      long&nbsp;timestamp,
@@ -1383,7 +1383,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRows</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1149">getRows</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1158">getRows</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;rows,
                                                                          <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
                                                                   throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
@@ -1410,7 +1410,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowsWithColumns</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1159">getRowsWithColumns</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1168">getRowsWithColumns</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;rows,
                                                                                     <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                                                                                     <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1439,7 +1439,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowsTs</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1169">getRowsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1178">getRowsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;rows,
                                                                            long&nbsp;timestamp,
                                                                            <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1468,7 +1468,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRowsWithColumnsTs</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1178">getRowsWithColumnsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1187">getRowsWithColumnsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;rows,
                                                                                       <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                                                                                       long&nbsp;timestamp,
@@ -1498,7 +1498,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteAll</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1218">deleteAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1227">deleteAll</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                       <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1524,7 +1524,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteAllTs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1227">deleteAllTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1236">deleteAllTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                         long&nbsp;timestamp,
@@ -1553,7 +1553,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteAllRow</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1253">deleteAllRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1262">deleteAllRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                          <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                          <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
                   throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
@@ -1577,7 +1577,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteAllRowTs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1260">deleteAllRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1269">deleteAllRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                            <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                            long&nbsp;timestamp,
                            <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1604,7 +1604,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>createTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1278">createTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;in_tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1287">createTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;in_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;org.apache.hadoop.hbase.thrift.generated.ColumnDescriptor&gt;&nbsp;columnFamilies)
                  throws org.apache.hadoop.hbase.thrift.generated.IOError,
                         org.apache.hadoop.hbase.thrift.generated.IllegalArgument,
@@ -1633,7 +1633,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getTableName</h4>
-<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1301">getTableName</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;buffer)</pre>
+<pre>private static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1310">getTableName</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;buffer)</pre>
 </li>
 </ul>
 <a name="deleteTable-java.nio.ByteBuffer-">
@@ -1642,7 +1642,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>deleteTable</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1306">deleteTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;in_tableName)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1315">deleteTable</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;in_tableName)
                  throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">Deletes a table</div>
@@ -1663,7 +1663,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>mutateRow</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1323">mutateRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1332">mutateRow</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                       <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                       <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;org.apache.hadoop.hbase.thrift.generated.Mutation&gt;&nbsp;mutations,
                       <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1694,7 +1694,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>mutateRowTs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1331">mutateRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1340">mutateRowTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                         <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                         <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;org.apache.hadoop.hbase.thrift.generated.Mutation&gt;&nbsp;mutations,
                         long&nbsp;timestamp,
@@ -1727,7 +1727,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>mutateRows</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1395">mutateRows</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1404">mutateRows</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;org.apache.hadoop.hbase.thrift.generated.BatchMutation&gt;&nbsp;rowBatches,
                        <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
                 throws org.apache.hadoop.hbase.thrift.generated.IOError,
@@ -1758,7 +1758,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>mutateRowsTs</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1402">mutateRowsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1411">mutateRowsTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</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;org.apache.hadoop.hbase.thrift.generated.BatchMutation&gt;&nbsp;rowBatches,
                          long&nbsp;timestamp,
                          <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1791,7 +1791,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>atomicIncrement</h4>
-<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1482">atomicIncrement</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1491">atomicIncrement</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                             <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                             <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;column,
                             long&nbsp;amount)
@@ -1821,7 +1821,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>atomicIncrement</h4>
-<pre>protected&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1492">atomicIncrement</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>protected&nbsp;long&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1501">atomicIncrement</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;row,
                                byte[]&nbsp;family,
                                byte[]&nbsp;qualifier,
@@ -1843,7 +1843,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerClose</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1509">scannerClose</a>(int&nbsp;id)
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1518">scannerClose</a>(int&nbsp;id)
                   throws org.apache.hadoop.hbase.thrift.generated.IOError,
                          org.apache.hadoop.hbase.thrift.generated.IllegalArgument</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
@@ -1865,7 +1865,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerGetList</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1522">scannerGetList</a>(int&nbsp;id,
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1531">scannerGetList</a>(int&nbsp;id,
                                                                                 int&nbsp;nbRows)
                                                                          throws org.apache.hadoop.hbase.thrift.generated.IllegalArgument,
                                                                                 org.apache.hadoop.hbase.thrift.generated.IOError</pre>
@@ -1894,7 +1894,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerGet</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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1546">scannerGet</a>(int&nbsp;id)
+<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;org.apache.hadoop.hbase.thrift.generated.TRowResult&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1555">scannerGet</a>(int&nbsp;id)
                                                                      throws org.apache.hadoop.hbase.thrift.generated.IllegalArgument,
                                                                             org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
@@ -1921,7 +1921,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpenWithScan</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1551">scannerOpenWithScan</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1560">scannerOpenWithScan</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                org.apache.hadoop.hbase.thrift.generated.TScan&nbsp;tScan,
                                <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
                         throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
@@ -1946,7 +1946,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpen</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1606">scannerOpen</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1615">scannerOpen</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                        <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;startRow,
                        <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                        <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -1978,7 +1978,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpenWithStop</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1635">scannerOpenWithStop</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1644">scannerOpenWithStop</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;startRow,
                                <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;stopRow,
                                <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
@@ -2016,7 +2016,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpenWithPrefix</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1665">scannerOpenWithPrefix</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1674">scannerOpenWithPrefix</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;startAndPrefix,
                                  <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                                  <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)
@@ -2047,7 +2047,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpenTs</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1699">scannerOpenTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1708">scannerOpenTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                          <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;startRow,
                          <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
                          long&nbsp;timestamp,
@@ -2084,7 +2084,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>scannerOpenWithStopTs</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1729">scannerOpenWithStopTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1738">scannerOpenWithStopTs</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;startRow,
                                  <a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;stopRow,
                                  <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;columns,
@@ -2125,7 +2125,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getColumnDescriptors</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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,org.apache.hadoop.hbase.thrift.generated.ColumnDescriptor&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1761">getColumnDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
+<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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,org.apache.hadoop.hbase.thrift.generated.ColumnDescriptor&gt;&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1770">getColumnDescriptors</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;tableName)
                                                                                                throws org.apache.hadoop.hbase.thrift.generated.IOError,
                                                                                                       org.apache.thrift.TException</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
@@ -2149,7 +2149,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>closeTable</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1784">closeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;table)
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1793">closeTable</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a>&nbsp;table)
                  throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -2163,7 +2163,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getRegionInfo</h4>
-<pre>public&nbsp;org.apache.hadoop.hbase.thrift.generated.TRegionInfo&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1796">getRegionInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;searchRow)
+<pre>public&nbsp;org.apache.hadoop.hbase.thrift.generated.TRegionInfo&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1805">getRegionInfo</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&nbsp;searchRow)
                                                                    throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <div class="block"><span class="descfrmTypeLabel">Description copied from interface:&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</code></span></div>
 <div class="block">Get the regininfo for the specified row. It scans
@@ -2186,7 +2186,7 @@ implements org.apache.hadoop.hbase.thrift.generated.Hbase.Iface</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getReverseScanResult</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1834">getReverseScanResult</a>(byte[]&nbsp;tableName,
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1843">getReverseScanResult</a>(byte[

<TRUNCATED>

[16/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.


Project: http://git-wip-us.apache.org/repos/asf/hbase-site/repo
Commit: http://git-wip-us.apache.org/repos/asf/hbase-site/commit/952146b4
Tree: http://git-wip-us.apache.org/repos/asf/hbase-site/tree/952146b4
Diff: http://git-wip-us.apache.org/repos/asf/hbase-site/diff/952146b4

Branch: refs/heads/asf-site
Commit: 952146b40f01d00db3276f5e84eb200bf1f78a44
Parents: 9021c03
Author: jenkins <bu...@apache.org>
Authored: Mon Apr 23 14:48:14 2018 +0000
Committer: jenkins <bu...@apache.org>
Committed: Mon Apr 23 14:48:14 2018 +0000

----------------------------------------------------------------------
 acid-semantics.html                             |    4 +-
 apache_hbase_reference_guide.pdf                |    4 +-
 book.html                                       |    2 +-
 bulk-loads.html                                 |    4 +-
 checkstyle-aggregate.html                       |   56 +-
 coc.html                                        |    4 +-
 dependencies.html                               |    4 +-
 dependency-convergence.html                     |    4 +-
 dependency-info.html                            |    4 +-
 dependency-management.html                      |    4 +-
 devapidocs/constant-values.html                 |    6 +-
 devapidocs/index-all.html                       |    4 +
 .../hadoop/hbase/backup/package-tree.html       |    2 +-
 .../hadoop/hbase/client/package-tree.html       |   20 +-
 .../RegionObserver.MutationType.html            |   10 +-
 .../hbase/coprocessor/RegionObserver.html       |  137 +-
 .../hadoop/hbase/filter/package-tree.html       |    6 +-
 .../hadoop/hbase/io/hfile/package-tree.html     |    6 +-
 .../apache/hadoop/hbase/ipc/package-tree.html   |    4 +-
 .../hadoop/hbase/mapreduce/package-tree.html    |    4 +-
 .../hadoop/hbase/master/package-tree.html       |    4 +-
 .../hbase/master/procedure/package-tree.html    |    2 +-
 .../hadoop/hbase/monitoring/package-tree.html   |    2 +-
 .../org/apache/hadoop/hbase/package-tree.html   |   16 +-
 .../hadoop/hbase/procedure2/package-tree.html   |    4 +-
 .../hadoop/hbase/quotas/package-tree.html       |    6 +-
 .../hadoop/hbase/regionserver/MemStoreSize.html |    4 +-
 .../hbase/regionserver/Region.Operation.html    |    4 +-
 .../hadoop/hbase/regionserver/package-tree.html |   18 +-
 .../regionserver/querymatcher/package-tree.html |    2 +-
 .../hadoop/hbase/rest/model/package-tree.html   |    2 +-
 .../hadoop/hbase/security/package-tree.html     |    2 +-
 .../thrift/ThriftServerRunner.HBaseHandler.html |  142 +-
 .../ThriftServerRunner.IOErrorWithCause.html    |   12 +-
 .../thrift/ThriftServerRunner.ImplType.html     |   82 +-
 ...ThriftServerRunner.ResultScannerWrapper.html |   12 +-
 .../hadoop/hbase/thrift/ThriftServerRunner.html |  110 +-
 .../class-use/ThriftServerRunner.ImplType.html  |    2 +-
 .../apache/hadoop/hbase/util/package-tree.html  |    8 +-
 .../apache/hadoop/hbase/wal/package-tree.html   |    2 +-
 .../org/apache/hadoop/hbase/Version.html        |    6 +-
 .../RegionObserver.MutationType.html            | 2045 +++++-----
 .../hbase/coprocessor/RegionObserver.html       | 2045 +++++-----
 .../hadoop/hbase/regionserver/MemStoreSize.html |   47 +-
 .../thrift/ThriftServerRunner.HBaseHandler.html | 3718 +++++++++---------
 .../ThriftServerRunner.IOErrorWithCause.html    | 3718 +++++++++---------
 .../thrift/ThriftServerRunner.ImplType.html     | 3718 +++++++++---------
 ...ThriftServerRunner.ResultScannerWrapper.html | 3718 +++++++++---------
 .../hadoop/hbase/thrift/ThriftServerRunner.html | 3718 +++++++++---------
 export_control.html                             |    4 +-
 index.html                                      |    4 +-
 integration.html                                |    4 +-
 issue-tracking.html                             |    4 +-
 license.html                                    |    4 +-
 mail-lists.html                                 |    4 +-
 metrics.html                                    |    4 +-
 old_news.html                                   |    4 +-
 plugin-management.html                          |    4 +-
 plugins.html                                    |    4 +-
 poweredbyhbase.html                             |    4 +-
 project-info.html                               |    4 +-
 project-reports.html                            |    4 +-
 project-summary.html                            |    4 +-
 pseudo-distributed.html                         |    4 +-
 replication.html                                |    4 +-
 resources.html                                  |    4 +-
 source-repository.html                          |    4 +-
 sponsors.html                                   |    4 +-
 supportingprojects.html                         |    4 +-
 team-list.html                                  |    4 +-
 .../regionserver/TestPerColumnFamilyFlush.html  |   14 +-
 .../regionserver/TestPerColumnFamilyFlush.html  |  597 +--
 .../hadoop/hbase/rsgroup/TestEnableRSGroup.html |   53 +-
 73 files changed, 12143 insertions(+), 12063 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/acid-semantics.html
----------------------------------------------------------------------
diff --git a/acid-semantics.html b/acid-semantics.html
index 63da65d..fa40b85 100644
--- a/acid-semantics.html
+++ b/acid-semantics.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013;  
       Apache HBase (TM) ACID Properties
@@ -601,7 +601,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/apache_hbase_reference_guide.pdf
----------------------------------------------------------------------
diff --git a/apache_hbase_reference_guide.pdf b/apache_hbase_reference_guide.pdf
index 859e5f0..57773f7 100644
--- a/apache_hbase_reference_guide.pdf
+++ b/apache_hbase_reference_guide.pdf
@@ -5,8 +5,8 @@
 /Author (Apache HBase Team)
 /Creator (Asciidoctor PDF 1.5.0.alpha.15, based on Prawn 2.2.2)
 /Producer (Apache HBase Team)
-/ModDate (D:20180422142950+00'00')
-/CreationDate (D:20180422144429+00'00')
+/ModDate (D:20180423142952+00'00')
+/CreationDate (D:20180423144512+00'00')
 >>
 endobj
 2 0 obj

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/book.html
----------------------------------------------------------------------
diff --git a/book.html b/book.html
index 837f39c..b9711f4 100644
--- a/book.html
+++ b/book.html
@@ -37824,7 +37824,7 @@ The server will return cellblocks compressed using this same compressor as long
 <div id="footer">
 <div id="footer-text">
 Version 3.0.0-SNAPSHOT<br>
-Last updated 2018-04-22 14:29:50 UTC
+Last updated 2018-04-23 14:29:52 UTC
 </div>
 </div>
 </body>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/bulk-loads.html
----------------------------------------------------------------------
diff --git a/bulk-loads.html b/bulk-loads.html
index 8cd7dd7..306bb1b 100644
--- a/bulk-loads.html
+++ b/bulk-loads.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013;  
       Bulk Loads in Apache HBase (TM)
@@ -306,7 +306,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/checkstyle-aggregate.html
----------------------------------------------------------------------
diff --git a/checkstyle-aggregate.html b/checkstyle-aggregate.html
index 9cc28de..541782c 100644
--- a/checkstyle-aggregate.html
+++ b/checkstyle-aggregate.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Checkstyle Results</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -35885,133 +35885,133 @@
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 102).</td>
-<td>247</td></tr>
+<td>244</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>318</td></tr>
+<td>315</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>319</td></tr>
+<td>316</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>420</td></tr>
+<td>417</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>474</td></tr>
+<td>471</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>482</td></tr>
+<td>479</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>483</td></tr>
+<td>480</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>494</td></tr>
+<td>491</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>495</td></tr>
+<td>492</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>516</td></tr>
+<td>513</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>518</td></tr>
+<td>515</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>545</td></tr>
+<td>542</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>547</td></tr>
+<td>544</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>591</td></tr>
+<td>588</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>619</td></tr>
+<td>616</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>797</td></tr>
+<td>794</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>798</td></tr>
+<td>795</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>934</td></tr>
+<td>931</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>945</td></tr>
+<td>942</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>985</td></tr>
+<td>982</td></tr>
 <tr class="b">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>JavadocTagContinuationIndentation</td>
 <td>Line continuation have incorrect indentation level, expected level should be 2.</td>
-<td>989</td></tr>
+<td>986</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>1009</td></tr></table></div>
+<td>1006</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.coprocessor.RegionServerCoprocessor.java">org/apache/hadoop/hbase/coprocessor/RegionServerCoprocessor.java</h3>
 <table border="0" class="table table-striped">
@@ -89369,25 +89369,25 @@
 <td>javadoc</td>
 <td>NonEmptyAtclauseDescription</td>
 <td>At-clause should have a non-empty description.</td>
-<td>443</td></tr>
+<td>446</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 106).</td>
-<td>496</td></tr>
+<td>499</td></tr>
 <tr class="a">
 <td><img src="images/icon_error_sml.gif" alt="" />&#160;Error</td>
 <td>sizes</td>
 <td>LineLength</td>
 <td>Line is longer than 100 characters (found 106).</td>
-<td>497</td></tr>
+<td>500</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 106).</td>
-<td>498</td></tr></table></div>
+<td>501</td></tr></table></div>
 <div class="section">
 <h3 id="org.apache.hadoop.hbase.regionserver.TestPriorityRpc.java">org/apache/hadoop/hbase/regionserver/TestPriorityRpc.java</h3>
 <table border="0" class="table table-striped">
@@ -123387,7 +123387,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/coc.html
----------------------------------------------------------------------
diff --git a/coc.html b/coc.html
index d4b3432..813f3ab 100644
--- a/coc.html
+++ b/coc.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; 
       Code of Conduct Policy
@@ -375,7 +375,7 @@ email to <a class="externalLink" href="mailto:private@hbase.apache.org">the priv
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/dependencies.html
----------------------------------------------------------------------
diff --git a/dependencies.html b/dependencies.html
index d4db779..1ddfefa 100644
--- a/dependencies.html
+++ b/dependencies.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Dependencies</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -440,7 +440,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/dependency-convergence.html
----------------------------------------------------------------------
diff --git a/dependency-convergence.html b/dependency-convergence.html
index ea0c214..9aab71f 100644
--- a/dependency-convergence.html
+++ b/dependency-convergence.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Reactor Dependency Convergence</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -1105,7 +1105,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/dependency-info.html
----------------------------------------------------------------------
diff --git a/dependency-info.html b/dependency-info.html
index f9aa516..0115cf9 100644
--- a/dependency-info.html
+++ b/dependency-info.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Dependency Information</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -313,7 +313,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/dependency-management.html
----------------------------------------------------------------------
diff --git a/dependency-management.html b/dependency-management.html
index 58678e7..37d7600 100644
--- a/dependency-management.html
+++ b/dependency-management.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Dependency Management</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -969,7 +969,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/constant-values.html
----------------------------------------------------------------------
diff --git a/devapidocs/constant-values.html b/devapidocs/constant-values.html
index 1cd8167..5f934f0 100644
--- a/devapidocs/constant-values.html
+++ b/devapidocs/constant-values.html
@@ -3768,21 +3768,21 @@
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td><code><a href="org/apache/hadoop/hbase/Version.html#date">date</a></code></td>
-<td class="colLast"><code>"Sun Apr 22 14:39:02 UTC 2018"</code></td>
+<td class="colLast"><code>"Mon Apr 23 14:39:23 UTC 2018"</code></td>
 </tr>
 <tr class="rowColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.Version.revision">
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td><code><a href="org/apache/hadoop/hbase/Version.html#revision">revision</a></code></td>
-<td class="colLast"><code>"f4a39043e2fb3da69e378b4e1cbcb4bd7e2a6662"</code></td>
+<td class="colLast"><code>"e73ba582f23e7ac512665bac2539af53bd3cb47c"</code></td>
 </tr>
 <tr class="altColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.Version.srcChecksum">
 <!--   -->
 </a><code>public&nbsp;static&nbsp;final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td><code><a href="org/apache/hadoop/hbase/Version.html#srcChecksum">srcChecksum</a></code></td>
-<td class="colLast"><code>"4c5dd33779be320f0e358eb0c4768d9a"</code></td>
+<td class="colLast"><code>"fa71043078ececcd8bf3d37b0362de75"</code></td>
 </tr>
 <tr class="rowColor">
 <td class="colFirst"><a name="org.apache.hadoop.hbase.Version.url">

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/index-all.html
----------------------------------------------------------------------
diff --git a/devapidocs/index-all.html b/devapidocs/index-all.html
index 57ff987..61c831a 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -44014,6 +44014,8 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/security/visibility/ExpressionParser.html#getOperator-byte-">getOperator(byte)</a></span> - Static method in class org.apache.hadoop.hbase.security.visibility.<a href="org/apache/hadoop/hbase/security/visibility/ExpressionParser.html" title="class in org.apache.hadoop.hbase.security.visibility">ExpressionParser</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getOption--">getOption()</a></span> - Method in enum org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/util/AbstractHBaseTool.html#getOptionAsDouble-org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine-java.lang.String-double-">getOptionAsDouble(CommandLine, String, double)</a></span> - Method in class org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/AbstractHBaseTool.html" title="class in org.apache.hadoop.hbase.util">AbstractHBaseTool</a></dt>
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/util/AbstractHBaseTool.html#getOptionAsInt-org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine-java.lang.String-int-">getOptionAsInt(CommandLine, String, int)</a></span> - Method in class org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/AbstractHBaseTool.html" title="class in org.apache.hadoop.hbase.util">AbstractHBaseTool</a></dt>
@@ -60776,6 +60778,8 @@
 <dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#isAlwaysFramed">isAlwaysFramed</a></span> - Variable in enum org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></dt>
 <dd>&nbsp;</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#isAlwaysFramed--">isAlwaysFramed()</a></span> - Method in enum org.apache.hadoop.hbase.thrift.<a href="org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></dt>
+<dd>&nbsp;</dd>
 <dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/util/JVM.html#isAmd64--">isAmd64()</a></span> - Static method in class org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/JVM.html" title="class in org.apache.hadoop.hbase.util">JVM</a></dt>
 <dd>
 <div class="block">Check if the arch is amd64;</div>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
index c31871d..52c7f71 100644
--- a/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/backup/package-tree.html
@@ -167,10 +167,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupState.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupState</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupPhase.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupPhase</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupRestoreConstants.BackupCommand.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupRestoreConstants.BackupCommand</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupInfo.BackupState.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupState</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
index 0d6fb14..5979c8e 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -550,24 +550,24 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Scan.ReadType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Scan.ReadType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Consistency.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Consistency</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactionState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncRequestFutureImpl.Retry.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncRequestFutureImpl.Retry</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MobCompactPartitionPolicy.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MobCompactPartitionPolicy</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncProcessTask.SubmittedRows.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncProcessTask.SubmittedRows</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/IsolationLevel.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">IsolationLevel</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Scan.ReadType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Scan.ReadType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncProcessTask.SubmittedRows.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncProcessTask.SubmittedRows</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanResumerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Consistency.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Consistency</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/MasterSwitchType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MasterSwitchType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AbstractResponse.ResponseType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AbstractResponse.ResponseType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/ScannerCallable.MoreResults.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">ScannerCallable.MoreResults</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncRequestFutureImpl.Retry.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncRequestFutureImpl.Retry</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/TableState.State.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">TableState.State</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html b/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
index 18ce0b2..86cf8c3 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>public static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.105">RegionObserver.MutationType</a>
+<pre>public static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.html#line.103">RegionObserver.MutationType</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang">Enum</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>&gt;</pre>
 <div class="block">Mutation type for postMutationBeforeWAL hook</div>
 </li>
@@ -211,7 +211,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>APPEND</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.106">APPEND</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.104">APPEND</a></pre>
 </li>
 </ul>
 <a name="INCREMENT">
@@ -220,7 +220,7 @@ the order they are declared.</div>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>INCREMENT</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.106">INCREMENT</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.104">INCREMENT</a></pre>
 </li>
 </ul>
 </li>
@@ -237,7 +237,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.148">values</a>()</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.146">values</a>()</pre>
 <div class="block">Returns an array containing the constants of this enum type, in
 the order they are declared.  This method may be used to iterate
 over the constants as follows:
@@ -257,7 +257,7 @@ for (RegionObserver.MutationType c : RegionObserver.MutationType.values())
 <ul class="blockListLast">
 <li class="blockList">
 <h4>valueOf</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.148">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html#line.146">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block">Returns the enum constant of this type with the specified name.
 The string must match <i>exactly</i> an identifier used to declare an
 enum constant in this type.  (Extraneous whitespace characters are 


[14/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
index e96b77e..6c817bc 100644
--- a/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/filter/package-tree.html
@@ -183,14 +183,14 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.Order.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.Order</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/RegexStringComparator.EngineType.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">RegexStringComparator.EngineType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/CompareFilter.CompareOp.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">CompareFilter.CompareOp</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/Filter.ReturnCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">Filter.ReturnCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.Order.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.Order</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/BitComparator.BitwiseOp.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">BitComparator.BitwiseOp</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
index 1a0ab0b..40422cf 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
@@ -273,12 +273,12 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/CacheConfig.ExternalBlockCaches.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">CacheConfig.ExternalBlockCaches</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/Cacheable.MemoryType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">Cacheable.MemoryType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/CacheConfig.ExternalBlockCaches.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">CacheConfig.ExternalBlockCaches</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/HFileBlock.Writer.State.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">HFileBlock.Writer.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
index 928ae20..1f90dde 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -349,9 +349,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/MetricsHBaseServerSourceFactoryImpl.SourceStorage.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">MetricsHBaseServerSourceFactoryImpl.SourceStorage</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/CallEvent.Type.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">CallEvent.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/MetricsHBaseServerSourceFactoryImpl.SourceStorage.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">MetricsHBaseServerSourceFactoryImpl.SourceStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
index a77bff8..730b7cf 100644
--- a/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/mapreduce/package-tree.html
@@ -293,10 +293,10 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/TableSplit.Version.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">TableSplit.Version</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/SyncTable.SyncMapper.Counter.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">SyncTable.SyncMapper.Counter</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/CellCounter.CellCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">CellCounter.CellCounterMapper.Counters</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/TableSplit.Version.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">TableSplit.Version</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.mapreduce.<a href="../../../../../org/apache/hadoop/hbase/mapreduce/RowCounter.RowCounterMapper.Counters.html" title="enum in org.apache.hadoop.hbase.mapreduce"><span class="typeNameLink">RowCounter.RowCounterMapper.Counters</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
index daea993..ad13ea2 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -346,11 +346,11 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMasterSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetricsMasterSourceFactoryImpl.FactoryStorage</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMasterSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetricsMasterSourceFactoryImpl.FactoryStorage</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
index 7b8e220..550d779 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
@@ -208,9 +208,9 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">PeerProcedureInterface.PeerOperationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/ServerProcedureInterface.ServerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">ServerProcedureInterface.ServerOperationType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/TableProcedureInterface.TableOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">TableProcedureInterface.TableOperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">PeerProcedureInterface.PeerOperationType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html b/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
index 3e1ea7f..9eb46aa 100644
--- a/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
@@ -125,8 +125,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/TaskMonitor.TaskFilter.TaskType.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">TaskMonitor.TaskFilter.TaskType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/MonitoredTask.State.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">MonitoredTask.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.monitoring.<a href="../../../../../org/apache/hadoop/hbase/monitoring/TaskMonitor.TaskFilter.TaskType.html" title="enum in org.apache.hadoop.hbase.monitoring"><span class="typeNameLink">TaskMonitor.TaskFilter.TaskType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/package-tree.html b/devapidocs/org/apache/hadoop/hbase/package-tree.html
index 41cda7e..9410ae3 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -441,19 +441,19 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompatibilitySingletonFactory.SingletonStorage.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompatibilitySingletonFactory.SingletonStorage</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Coprocessor.State.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Coprocessor.State</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompatibilitySingletonFactory.SingletonStorage.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompatibilitySingletonFactory.SingletonStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaTableAccessor.QueryType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Size.Unit.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Size.Unit</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeyValue.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeyValue.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeepDeletedCells.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeepDeletedCells</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MemoryCompactionPolicy.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MemoryCompactionPolicy</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Coprocessor.State.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Coprocessor.State</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HConstants.OperationStatusCode.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HConstants.OperationStatusCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterMetrics.Option.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterMetrics.Option</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/KeyValue.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">KeyValue.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/MetaTableAccessor.QueryType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">MetaTableAccessor.QueryType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
index 4b7734b..12c2675 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -212,11 +212,11 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/Procedure.LockState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">Procedure.LockState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">StateMachineProcedure.Flow</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/LockedResourceType.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">LockedResourceType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/RootProcedureState.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">RootProcedureState.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/StateMachineProcedure.Flow.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">StateMachineProcedure.Flow</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
index 152e2b7..9c12e62 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
@@ -230,12 +230,12 @@
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottlingException.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">OperationQuota.OperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">SpaceViolationPolicy</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottlingException.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottleType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/MemStoreSize.html b/devapidocs/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
index 9d6e29a..a40bb14 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
@@ -387,7 +387,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>hashCode</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.108">hashCode</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.111">hashCode</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#hashCode--" title="class or interface in java.lang">hashCode</a></code>&nbsp;in class&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>
@@ -400,7 +400,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>toString</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.116">toString</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.119">toString</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#toString--" title="class or interface in java.lang">toString</a></code>&nbsp;in class&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/regionserver/Region.Operation.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/Region.Operation.html b/devapidocs/org/apache/hadoop/hbase/regionserver/Region.Operation.html
index 30f64de..b7b761f 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/Region.Operation.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/Region.Operation.html
@@ -382,7 +382,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/Region.Operation.html#line.126">values</a>()</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/Region.Operation.html#line.125">values</a>()</pre>
 <div class="block">Returns an array containing the constants of this enum type, in
 the order they are declared.  This method may be used to iterate
 over the constants as follows:
@@ -402,7 +402,7 @@ for (Region.Operation c : Region.Operation.values())
 <ul class="blockListLast">
 <li class="blockList">
 <h4>valueOf</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/Region.Operation.html#line.126">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/Region.Operation.html#line.125">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block">Returns the enum constant of this type with the specified name.
 The string must match <i>exactly</i> an identifier used to declare an
 enum constant in this type.  (Extraneous whitespace characters are 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
index 96a082f..c9a863c 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -704,20 +704,20 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">FlushType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TimeRangeTracker.Type.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TimeRangeTracker.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/HRegion.FlushResult.Result.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">HRegion.FlushResult.Result</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.LimitScope.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.LimitScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MetricsRegionServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MetricsRegionServerSourceFactoryImpl.FactoryStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MemStoreCompactionStrategy.Action.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MemStoreCompactionStrategy.Action</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TimeRangeTracker.Type.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TimeRangeTracker.Type</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">FlushType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScannerContext.NextState.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScannerContext.NextState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/MemStoreCompactionStrategy.Action.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MemStoreCompactionStrategy.Action</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.StepDirection.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DefaultHeapMemoryTuner.StepDirection</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
index 2731576..6851ee1 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
@@ -130,8 +130,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.MatchCode.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">ScanQueryMatcher.MatchCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/DeleteTracker.DeleteResult.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">DeleteTracker.DeleteResult</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.MatchCode.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">ScanQueryMatcher.MatchCode</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
 </ul>
 </li>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html b/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
index c20ff47..034077c 100644
--- a/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/rest/model/package-tree.html
@@ -110,8 +110,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.FilterType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.FilterType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.ByteArrayComparableModel.ComparatorType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.rest.model.<a href="../../../../../../org/apache/hadoop/hbase/rest/model/ScannerModel.FilterModel.FilterType.html" title="enum in org.apache.hadoop.hbase.rest.model"><span class="typeNameLink">ScannerModel.FilterModel.FilterType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
index 29d7634..6ef281d 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/package-tree.html
@@ -191,8 +191,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslStatus.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslUtil.QualityOfProtection</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/SaslStatus.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">SaslStatus</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.security.<a href="../../../../../org/apache/hadoop/hbase/security/AuthMethod.html" title="enum in org.apache.hadoop.hbase.security"><span class="typeNameLink">AuthMethod</span></a></li>
 </ul>
 </li>


[12/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
index c2d61b1..aaef58f 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html
@@ -137,7 +137,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1994">ThriftServerRunner.IOErrorWithCause</a>
+<pre>public static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.2004">ThriftServerRunner.IOErrorWithCause</a>
 extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
@@ -273,7 +273,7 @@ extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>cause</h4>
-<pre>private&nbsp;<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> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.1995">cause</a></pre>
+<pre>private&nbsp;<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> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2005">cause</a></pre>
 </li>
 </ul>
 </li>
@@ -290,7 +290,7 @@ extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>IOErrorWithCause</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.1996">IOErrorWithCause</a>(<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>
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2006">IOErrorWithCause</a>(<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>
 </li>
@@ -307,7 +307,7 @@ extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>getCause</h4>
-<pre>public&nbsp;<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;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2001">getCause</a>()</pre>
+<pre>public&nbsp;<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;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2011">getCause</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html?is-external=true#getCause--" title="class or interface in java.lang">getCause</a></code>&nbsp;in class&nbsp;<code><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></code></dd>
@@ -320,7 +320,7 @@ extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <ul class="blockList">
 <li class="blockList">
 <h4>equals</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2006">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;other)</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2016">equals</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>&nbsp;other)</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code>equals</code>&nbsp;in class&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.IOError</code></dd>
@@ -333,7 +333,7 @@ extends org.apache.hadoop.hbase.thrift.generated.IOError</pre>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>hashCode</h4>
-<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2020">hashCode</a>()</pre>
+<pre>public&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2030">hashCode</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code>hashCode</code>&nbsp;in class&nbsp;<code>org.apache.hadoop.hbase.thrift.generated.IOError</code></dd>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
index 0392c62..3aa763c 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html
@@ -18,7 +18,7 @@
     catch(err) {
     }
 //-->
-var methods = {"i0":9,"i1":10,"i2":9,"i3":9,"i4":9,"i5":10,"i6":10,"i7":9,"i8":9};
+var methods = {"i0":9,"i1":10,"i2":10,"i3":9,"i4":10,"i5":9,"i6":9,"i7":10,"i8":10,"i9":9,"i10":9};
 var tabs = {65535:["t0","All Methods"],1:["t1","Static Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
 var altColor = "altColor";
 var rowColor = "rowColor";
@@ -122,7 +122,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.227">ThriftServerRunner.ImplType</a>
+<pre>public static enum <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.228">ThriftServerRunner.ImplType</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang">Enum</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&gt;</pre>
 <div class="block">An enum of server implementation selections</div>
 </li>
@@ -209,37 +209,45 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?i
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#createOptionGroup--">createOptionGroup</a></span>()</code>&nbsp;</td>
 </tr>
 <tr id="i1" class="rowColor">
-<td class="colFirst"><code>(package private) <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colFirst"><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getDescription--">getDescription</a></span>()</code>&nbsp;</td>
 </tr>
 <tr id="i2" class="altColor">
-<td class="colFirst"><code>(package private) static <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getServerImpl-org.apache.hadoop.conf.Configuration-">getServerImpl</a></span>(org.apache.hadoop.conf.Configuration&nbsp;conf)</code>&nbsp;</td>
+<td class="colFirst"><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getOption--">getOption</a></span>()</code>&nbsp;</td>
 </tr>
 <tr id="i3" class="rowColor">
+<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getServerImpl-org.apache.hadoop.conf.Configuration-">getServerImpl</a></span>(org.apache.hadoop.conf.Configuration&nbsp;conf)</code>&nbsp;</td>
+</tr>
+<tr id="i4" class="altColor">
+<td class="colFirst"><code>boolean</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#isAlwaysFramed--">isAlwaysFramed</a></span>()</code>&nbsp;</td>
+</tr>
+<tr id="i5" class="rowColor">
 <td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&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;</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#serversThatCannotSpecifyBindIP--">serversThatCannotSpecifyBindIP</a></span>()</code>&nbsp;</td>
 </tr>
-<tr id="i4" class="altColor">
+<tr id="i6" class="altColor">
 <td class="colFirst"><code>(package private) static void</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#setServerImpl-org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine-org.apache.hadoop.conf.Configuration-">setServerImpl</a></span>(org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine&nbsp;cmd,
              org.apache.hadoop.conf.Configuration&nbsp;conf)</code>&nbsp;</td>
 </tr>
-<tr id="i5" class="rowColor">
+<tr id="i7" class="rowColor">
 <td class="colFirst"><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#simpleClassName--">simpleClassName</a></span>()</code>&nbsp;</td>
 </tr>
-<tr id="i6" class="altColor">
+<tr id="i8" class="altColor">
 <td class="colFirst"><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#toString--">toString</a></span>()</code>&nbsp;</td>
 </tr>
-<tr id="i7" class="rowColor">
+<tr id="i9" class="rowColor">
 <td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#valueOf-java.lang.String-">valueOf</a></span>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</code>
 <div class="block">Returns the enum constant of this type with the specified name.</div>
 </td>
 </tr>
-<tr id="i8" class="altColor">
+<tr id="i10" class="altColor">
 <td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>[]</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#values--">values</a></span>()</code>
 <div class="block">Returns an array containing the constants of this enum type, in
@@ -281,7 +289,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>HS_HA</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.228">HS_HA</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.229">HS_HA</a></pre>
 </li>
 </ul>
 <a name="NONBLOCKING">
@@ -290,7 +298,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>NONBLOCKING</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.229">NONBLOCKING</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.230">NONBLOCKING</a></pre>
 </li>
 </ul>
 <a name="THREAD_POOL">
@@ -299,7 +307,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>THREAD_POOL</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.230">THREAD_POOL</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.231">THREAD_POOL</a></pre>
 </li>
 </ul>
 <a name="THREADED_SELECTOR">
@@ -308,7 +316,7 @@ the order they are declared.</div>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>THREADED_SELECTOR</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.231">THREADED_SELECTOR</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.232">THREADED_SELECTOR</a></pre>
 </li>
 </ul>
 </li>
@@ -325,7 +333,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT</h4>
-<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.234">DEFAULT</a></pre>
+<pre>public static final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.235">DEFAULT</a></pre>
 </li>
 </ul>
 <a name="option">
@@ -334,7 +342,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>option</h4>
-<pre>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/thrift/ThriftServerRunner.ImplType.html#line.236">option</a></pre>
+<pre>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/thrift/ThriftServerRunner.ImplType.html#line.237">option</a></pre>
 </li>
 </ul>
 <a name="isAlwaysFramed">
@@ -343,7 +351,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>isAlwaysFramed</h4>
-<pre>final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.237">isAlwaysFramed</a></pre>
+<pre>final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.238">isAlwaysFramed</a></pre>
 </li>
 </ul>
 <a name="serverClass">
@@ -352,7 +360,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>serverClass</h4>
-<pre>final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends org.apache.thrift.server.TServer&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.238">serverClass</a></pre>
+<pre>final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Class.html?is-external=true" title="class or interface in java.lang">Class</a>&lt;? extends org.apache.thrift.server.TServer&gt; <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.239">serverClass</a></pre>
 </li>
 </ul>
 <a name="canSpecifyBindIP">
@@ -361,7 +369,7 @@ the order they are declared.</div>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>canSpecifyBindIP</h4>
-<pre>final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.239">canSpecifyBindIP</a></pre>
+<pre>final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.240">canSpecifyBindIP</a></pre>
 </li>
 </ul>
 </li>
@@ -378,7 +386,7 @@ the order they are declared.</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>values</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.227">values</a>()</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>[]&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.228">values</a>()</pre>
 <div class="block">Returns an array containing the constants of this enum type, in
 the order they are declared.  This method may be used to iterate
 over the constants as follows:
@@ -398,7 +406,7 @@ for (ThriftServerRunner.ImplType c : ThriftServerRunner.ImplType.values())
 <ul class="blockList">
 <li class="blockList">
 <h4>valueOf</h4>
-<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.227">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.228">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;name)</pre>
 <div class="block">Returns the enum constant of this type with the specified name.
 The string must match <i>exactly</i> an identifier used to declare an
 enum constant in this type.  (Extraneous whitespace characters are 
@@ -420,7 +428,7 @@ not permitted.)</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>toString</h4>
-<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.254">toString</a>()</pre>
+<pre>public&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.255">toString</a>()</pre>
 <dl>
 <dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
 <dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true#toString--" title="class or interface in java.lang">toString</a></code>&nbsp;in class&nbsp;<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang">Enum</a>&lt;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&gt;</code></dd>
@@ -430,13 +438,31 @@ not permitted.)</div>
 </dl>
 </li>
 </ul>
+<a name="getOption--">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>getOption</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/thrift/ThriftServerRunner.ImplType.html#line.259">getOption</a>()</pre>
+</li>
+</ul>
+<a name="isAlwaysFramed--">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>isAlwaysFramed</h4>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.263">isAlwaysFramed</a>()</pre>
+</li>
+</ul>
 <a name="getDescription--">
 <!--   -->
 </a>
 <ul class="blockList">
 <li class="blockList">
 <h4>getDescription</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.258">getDescription</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/thrift/ThriftServerRunner.ImplType.html#line.267">getDescription</a>()</pre>
 </li>
 </ul>
 <a name="createOptionGroup--">
@@ -445,7 +471,7 @@ not permitted.)</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>createOptionGroup</h4>
-<pre>static&nbsp;org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.270">createOptionGroup</a>()</pre>
+<pre>static&nbsp;org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.279">createOptionGroup</a>()</pre>
 </li>
 </ul>
 <a name="getServerImpl-org.apache.hadoop.conf.Configuration-">
@@ -454,7 +480,7 @@ not permitted.)</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>getServerImpl</h4>
-<pre>static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.278">getServerImpl</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public static&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.287">getServerImpl</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 </li>
 </ul>
 <a name="setServerImpl-org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine-org.apache.hadoop.conf.Configuration-">
@@ -463,7 +489,7 @@ not permitted.)</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>setServerImpl</h4>
-<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.288">setServerImpl</a>(org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine&nbsp;cmd,
+<pre>static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.297">setServerImpl</a>(org.apache.hbase.thirdparty.org.apache.commons.cli.CommandLine&nbsp;cmd,
                           org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 </li>
 </ul>
@@ -473,7 +499,7 @@ not permitted.)</div>
 <ul class="blockList">
 <li class="blockList">
 <h4>simpleClassName</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/thrift/ThriftServerRunner.ImplType.html#line.308">simpleClassName</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/thrift/ThriftServerRunner.ImplType.html#line.317">simpleClassName</a>()</pre>
 </li>
 </ul>
 <a name="serversThatCannotSpecifyBindIP--">
@@ -482,7 +508,7 @@ not permitted.)</div>
 <ul class="blockListLast">
 <li class="blockList">
 <h4>serversThatCannotSpecifyBindIP</h4>
-<pre>public static&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/thrift/ThriftServerRunner.ImplType.html#line.312">serversThatCannotSpecifyBindIP</a>()</pre>
+<pre>public static&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/thrift/ThriftServerRunner.ImplType.html#line.321">serversThatCannotSpecifyBindIP</a>()</pre>
 </li>
 </ul>
 </li>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
index 384244d..4215cd5 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html
@@ -113,7 +113,7 @@ var activeTableTab = "activeTableTab";
 </dl>
 <hr>
 <br>
-<pre>protected static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.706">ThriftServerRunner.ResultScannerWrapper</a>
+<pre>protected static class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.715">ThriftServerRunner.ResultScannerWrapper</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
 </li>
 </ul>
@@ -210,7 +210,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>scanner</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.708">scanner</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.717">scanner</a></pre>
 </li>
 </ul>
 <a name="sortColumns">
@@ -219,7 +219,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>sortColumns</h4>
-<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.709">sortColumns</a></pre>
+<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.718">sortColumns</a></pre>
 </li>
 </ul>
 </li>
@@ -236,7 +236,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>ResultScannerWrapper</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.710">ResultScannerWrapper</a>(<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;resultScanner,
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.719">ResultScannerWrapper</a>(<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;resultScanner,
                             boolean&nbsp;sortResultColumns)</pre>
 </li>
 </ul>
@@ -254,7 +254,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getScanner</h4>
-<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.716">getScanner</a>()</pre>
+<pre>public&nbsp;<a href="../../../../../org/apache/hadoop/hbase/client/ResultScanner.html" title="interface in org.apache.hadoop.hbase.client">ResultScanner</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.725">getScanner</a>()</pre>
 </li>
 </ul>
 <a name="isColumnSorted--">
@@ -263,7 +263,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>isColumnSorted</h4>
-<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.720">isColumnSorted</a>()</pre>
+<pre>public&nbsp;boolean&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.729">isColumnSorted</a>()</pre>
 </li>
 </ul>
 </li>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
index 6f2abe0..afabfdf 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html
@@ -114,7 +114,7 @@ var activeTableTab = "activeTableTab";
 <hr>
 <br>
 <pre>@InterfaceAudience.Private
-public class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.153">ThriftServerRunner</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.154">ThriftServerRunner</a>
 extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
 implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable.html?is-external=true" title="class or interface in java.lang">Runnable</a></pre>
 <div class="block">ThriftServerRunner - this class starts up a Thrift server which implements
@@ -145,7 +145,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 </td>
 </tr>
 <tr class="rowColor">
-<td class="colFirst"><code>(package private) static class&nbsp;</code></td>
+<td class="colFirst"><code>static class&nbsp;</code></td>
 <td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></span></code>
 <div class="block">An enum of server implementation selections</div>
 </td>
@@ -454,7 +454,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <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/thrift/ThriftServerRunner.html#line.155">LOG</a></pre>
+<pre>private static final&nbsp;org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.156">LOG</a></pre>
 </li>
 </ul>
 <a name="DEFAULT_HTTP_MAX_HEADER_SIZE">
@@ -463,7 +463,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_HTTP_MAX_HEADER_SIZE</h4>
-<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.157">DEFAULT_HTTP_MAX_HEADER_SIZE</a></pre>
+<pre>private static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.158">DEFAULT_HTTP_MAX_HEADER_SIZE</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.DEFAULT_HTTP_MAX_HEADER_SIZE">Constant Field Values</a></dd>
@@ -476,7 +476,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>SERVER_TYPE_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.159">SERVER_TYPE_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.160">SERVER_TYPE_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.SERVER_TYPE_CONF_KEY">Constant Field Values</a></dd>
@@ -489,7 +489,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>BIND_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.162">BIND_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.163">BIND_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.BIND_CONF_KEY">Constant Field Values</a></dd>
@@ -502,7 +502,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>COMPACT_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.163">COMPACT_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.164">COMPACT_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.COMPACT_CONF_KEY">Constant Field Values</a></dd>
@@ -515,7 +515,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>FRAMED_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.164">FRAMED_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.165">FRAMED_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.FRAMED_CONF_KEY">Constant Field Values</a></dd>
@@ -528,7 +528,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>MAX_FRAME_SIZE_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.165">MAX_FRAME_SIZE_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.166">MAX_FRAME_SIZE_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.MAX_FRAME_SIZE_CONF_KEY">Constant Field Values</a></dd>
@@ -541,7 +541,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>PORT_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.167">PORT_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.168">PORT_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.PORT_CONF_KEY">Constant Field Values</a></dd>
@@ -554,7 +554,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>COALESCE_INC_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.168">COALESCE_INC_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.169">COALESCE_INC_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.COALESCE_INC_KEY">Constant Field Values</a></dd>
@@ -567,7 +567,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>USE_HTTP_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.169">USE_HTTP_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.170">USE_HTTP_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.USE_HTTP_CONF_KEY">Constant Field Values</a></dd>
@@ -580,7 +580,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>HTTP_MIN_THREADS</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.170">HTTP_MIN_THREADS</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.171">HTTP_MIN_THREADS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.HTTP_MIN_THREADS">Constant Field Values</a></dd>
@@ -593,7 +593,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>HTTP_MAX_THREADS</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.171">HTTP_MAX_THREADS</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.172">HTTP_MAX_THREADS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.HTTP_MAX_THREADS">Constant Field Values</a></dd>
@@ -606,7 +606,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_ENABLED</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.173">THRIFT_SSL_ENABLED</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.174">THRIFT_SSL_ENABLED</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_ENABLED">Constant Field Values</a></dd>
@@ -619,7 +619,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_KEYSTORE_STORE</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.174">THRIFT_SSL_KEYSTORE_STORE</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.175">THRIFT_SSL_KEYSTORE_STORE</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_KEYSTORE_STORE">Constant Field Values</a></dd>
@@ -632,7 +632,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_KEYSTORE_PASSWORD</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.175">THRIFT_SSL_KEYSTORE_PASSWORD</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.176">THRIFT_SSL_KEYSTORE_PASSWORD</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_KEYSTORE_PASSWORD">Constant Field Values</a></dd>
@@ -645,7 +645,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_KEYSTORE_KEYPASSWORD</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.176">THRIFT_SSL_KEYSTORE_KEYPASSWORD</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.177">THRIFT_SSL_KEYSTORE_KEYPASSWORD</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_KEYSTORE_KEYPASSWORD">Constant Field Values</a></dd>
@@ -658,7 +658,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_EXCLUDE_CIPHER_SUITES</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.177">THRIFT_SSL_EXCLUDE_CIPHER_SUITES</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.178">THRIFT_SSL_EXCLUDE_CIPHER_SUITES</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_EXCLUDE_CIPHER_SUITES">Constant Field Values</a></dd>
@@ -671,7 +671,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_INCLUDE_CIPHER_SUITES</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.178">THRIFT_SSL_INCLUDE_CIPHER_SUITES</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.179">THRIFT_SSL_INCLUDE_CIPHER_SUITES</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_INCLUDE_CIPHER_SUITES">Constant Field Values</a></dd>
@@ -684,7 +684,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_EXCLUDE_PROTOCOLS</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.179">THRIFT_SSL_EXCLUDE_PROTOCOLS</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.180">THRIFT_SSL_EXCLUDE_PROTOCOLS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_EXCLUDE_PROTOCOLS">Constant Field Values</a></dd>
@@ -697,7 +697,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SSL_INCLUDE_PROTOCOLS</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.180">THRIFT_SSL_INCLUDE_PROTOCOLS</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.181">THRIFT_SSL_INCLUDE_PROTOCOLS</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SSL_INCLUDE_PROTOCOLS">Constant Field Values</a></dd>
@@ -710,7 +710,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY</h4>
-<pre>public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.187">THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY</a></pre>
+<pre>public static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.188">THRIFT_SERVER_SOCKET_READ_TIMEOUT_KEY</a></pre>
 <div class="block">Amount of time in milliseconds before a server thread will timeout
  waiting for client to send data on a connected socket. Currently,
  applies only to TBoundedThreadPoolServer</div>
@@ -726,7 +726,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT</h4>
-<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.189">THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT</a></pre>
+<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.190">THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SERVER_SOCKET_READ_TIMEOUT_DEFAULT">Constant Field Values</a></dd>
@@ -739,7 +739,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_QOP_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.201">THRIFT_QOP_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.202">THRIFT_QOP_KEY</a></pre>
 <div class="block">Thrift quality of protection configuration key. Valid values can be:
  auth-conf: authentication, integrity and confidentiality checking
  auth-int: authentication and integrity checking
@@ -759,7 +759,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>BACKLOG_CONF_KEY</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.202">BACKLOG_CONF_KEY</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.203">BACKLOG_CONF_KEY</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.BACKLOG_CONF_KEY">Constant Field Values</a></dd>
@@ -772,7 +772,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_BIND_ADDR</h4>
-<pre>private 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/thrift/ThriftServerRunner.html#line.204">DEFAULT_BIND_ADDR</a></pre>
+<pre>private 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/thrift/ThriftServerRunner.html#line.205">DEFAULT_BIND_ADDR</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.DEFAULT_BIND_ADDR">Constant Field Values</a></dd>
@@ -785,7 +785,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>DEFAULT_LISTEN_PORT</h4>
-<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.205">DEFAULT_LISTEN_PORT</a></pre>
+<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.206">DEFAULT_LISTEN_PORT</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.DEFAULT_LISTEN_PORT">Constant Field Values</a></dd>
@@ -798,7 +798,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>HREGION_VERSION</h4>
-<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.206">HREGION_VERSION</a></pre>
+<pre>public static final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.207">HREGION_VERSION</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.HREGION_VERSION">Constant Field Values</a></dd>
@@ -811,7 +811,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>THRIFT_SUPPORT_PROXYUSER</h4>
-<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.207">THRIFT_SUPPORT_PROXYUSER</a></pre>
+<pre>static final&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.208">THRIFT_SUPPORT_PROXYUSER</a></pre>
 <dl>
 <dt><span class="seeLabel">See Also:</span></dt>
 <dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.thrift.ThriftServerRunner.THRIFT_SUPPORT_PROXYUSER">Constant Field Values</a></dd>
@@ -824,7 +824,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>listenPort</h4>
-<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.208">listenPort</a></pre>
+<pre>private final&nbsp;int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.209">listenPort</a></pre>
 </li>
 </ul>
 <a name="conf">
@@ -833,7 +833,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>conf</h4>
-<pre>private&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.210">conf</a></pre>
+<pre>private&nbsp;org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.211">conf</a></pre>
 </li>
 </ul>
 <a name="tserver">
@@ -842,7 +842,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>tserver</h4>
-<pre>volatile&nbsp;org.apache.thrift.server.TServer <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.211">tserver</a></pre>
+<pre>volatile&nbsp;org.apache.thrift.server.TServer <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.212">tserver</a></pre>
 </li>
 </ul>
 <a name="httpServer">
@@ -851,7 +851,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>httpServer</h4>
-<pre>volatile&nbsp;org.eclipse.jetty.server.Server <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.212">httpServer</a></pre>
+<pre>volatile&nbsp;org.eclipse.jetty.server.Server <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.213">httpServer</a></pre>
 </li>
 </ul>
 <a name="handler">
@@ -860,7 +860,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>handler</h4>
-<pre>private final&nbsp;org.apache.hadoop.hbase.thrift.generated.Hbase.Iface <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.213">handler</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.hbase.thrift.generated.Hbase.Iface <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.214">handler</a></pre>
 </li>
 </ul>
 <a name="metrics">
@@ -869,7 +869,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>metrics</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.214">metrics</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftMetrics.html" title="class in org.apache.hadoop.hbase.thrift">ThriftMetrics</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.215">metrics</a></pre>
 </li>
 </ul>
 <a name="hbaseHandler">
@@ -878,7 +878,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>hbaseHandler</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.HBaseHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.215">hbaseHandler</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.HBaseHandler</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.216">hbaseHandler</a></pre>
 </li>
 </ul>
 <a name="realUser">
@@ -887,7 +887,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>realUser</h4>
-<pre>private final&nbsp;org.apache.hadoop.security.UserGroupInformation <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.216">realUser</a></pre>
+<pre>private final&nbsp;org.apache.hadoop.security.UserGroupInformation <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.217">realUser</a></pre>
 </li>
 </ul>
 <a name="qop">
@@ -896,7 +896,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>qop</h4>
-<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security">SaslUtil.QualityOfProtection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.218">qop</a></pre>
+<pre>private&nbsp;<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security">SaslUtil.QualityOfProtection</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.219">qop</a></pre>
 </li>
 </ul>
 <a name="host">
@@ -905,7 +905,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>host</h4>
-<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.219">host</a></pre>
+<pre>private&nbsp;<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.220">host</a></pre>
 </li>
 </ul>
 <a name="securityEnabled">
@@ -914,7 +914,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>securityEnabled</h4>
-<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.221">securityEnabled</a></pre>
+<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.222">securityEnabled</a></pre>
 </li>
 </ul>
 <a name="doAsEnabled">
@@ -923,7 +923,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>doAsEnabled</h4>
-<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.222">doAsEnabled</a></pre>
+<pre>private final&nbsp;boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.223">doAsEnabled</a></pre>
 </li>
 </ul>
 <a name="pauseMonitor">
@@ -932,7 +932,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockListLast">
 <li class="blockList">
 <h4>pauseMonitor</h4>
-<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/JvmPauseMonitor.html" title="class in org.apache.hadoop.hbase.util">JvmPauseMonitor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.224">pauseMonitor</a></pre>
+<pre>private final&nbsp;<a href="../../../../../org/apache/hadoop/hbase/util/JvmPauseMonitor.html" title="class in org.apache.hadoop.hbase.util">JvmPauseMonitor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.225">pauseMonitor</a></pre>
 </li>
 </ul>
 </li>
@@ -949,7 +949,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockListLast">
 <li class="blockList">
 <h4>ThriftServerRunner</h4>
-<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.324">ThriftServerRunner</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>public&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.333">ThriftServerRunner</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
                    throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -971,7 +971,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>checkHttpSecurity</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.374">checkHttpSecurity</a>(<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security">SaslUtil.QualityOfProtection</a>&nbsp;qop,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.383">checkHttpSecurity</a>(<a href="../../../../../org/apache/hadoop/hbase/security/SaslUtil.QualityOfProtection.html" title="enum in org.apache.hadoop.hbase.security">SaslUtil.QualityOfProtection</a>&nbsp;qop,
                                org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 </li>
 </ul>
@@ -981,7 +981,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>run</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.387">run</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.396">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>
@@ -994,7 +994,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>shutdown</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.412">shutdown</a>()</pre>
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.421">shutdown</a>()</pre>
 </li>
 </ul>
 <a name="setupHTTPServer--">
@@ -1003,7 +1003,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>setupHTTPServer</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.431">setupHTTPServer</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.440">setupHTTPServer</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>
@@ -1017,7 +1017,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>setupServer</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.524">setupServer</a>()
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.533">setupServer</a>()
                   throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <div class="block">Setting up the thrift TServer</div>
 <dl>
@@ -1032,7 +1032,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>getProtocolFactory</h4>
-<pre>private&nbsp;org.apache.thrift.protocol.TProtocolFactory&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.675">getProtocolFactory</a>()</pre>
+<pre>private&nbsp;org.apache.thrift.protocol.TProtocolFactory&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.684">getProtocolFactory</a>()</pre>
 </li>
 </ul>
 <a name="createExecutor-java.util.concurrent.BlockingQueue-int-int-">
@@ -1041,7 +1041,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>createExecutor</h4>
-<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.689">createExecutor</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/BlockingQueue.html?is-external=true" title="class or interface in java.util.concurrent">BlockingQueue</a>&lt;<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>&gt;&nbsp;callQueue,
+<pre><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutorService.html?is-external=true" title="class or interface in java.util.concurrent">ExecutorService</a>&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.698">createExecutor</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/BlockingQueue.html?is-external=true" title="class or interface in java.util.concurrent">BlockingQueue</a>&lt;<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>&gt;&nbsp;callQueue,
                                int&nbsp;minWorkers,
                                int&nbsp;maxWorkers)</pre>
 </li>
@@ -1052,7 +1052,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>getBindAddress</h4>
-<pre>private&nbsp;<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/thrift/ThriftServerRunner.html#line.700">getBindAddress</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
+<pre>private&nbsp;<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/thrift/ThriftServerRunner.html#line.709">getBindAddress</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)
                             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>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -1066,7 +1066,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>getIOError</h4>
-<pre>private static&nbsp;org.apache.hadoop.hbase.thrift.generated.IOError&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1959">getIOError</a>(<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;throwable)</pre>
+<pre>private static&nbsp;org.apache.hadoop.hbase.thrift.generated.IOError&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1968">getIOError</a>(<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;throwable)</pre>
 </li>
 </ul>
 <a name="addAttributes-org.apache.hadoop.hbase.client.OperationWithAttributes-java.util.Map-">
@@ -1075,7 +1075,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockList">
 <li class="blockList">
 <h4>addAttributes</h4>
-<pre>private static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1968">addAttributes</a>(<a href="../../../../../org/apache/hadoop/hbase/client/OperationWithAttributes.html" title="class in org.apache.hadoop.hbase.client">OperationWithAttributes</a>&nbsp;op,
+<pre>private static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1977">addAttributes</a>(<a href="../../../../../org/apache/hadoop/hbase/client/OperationWithAttributes.html" title="class in org.apache.hadoop.hbase.client">OperationWithAttributes</a>&nbsp;op,
                                   <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/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>,<a href="https://docs.oracle.com/javase/8/docs/api/java/nio/ByteBuffer.html?is-external=true" title="class or interface in java.nio">ByteBuffer</a>&gt;&nbsp;attributes)</pre>
 <div class="block">Adds all the attributes into the Operation object</div>
 </li>
@@ -1086,7 +1086,7 @@ implements <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable
 <ul class="blockListLast">
 <li class="blockList">
 <h4>registerFilters</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1980">registerFilters</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1989">registerFilters</a>(org.apache.hadoop.conf.Configuration&nbsp;conf)</pre>
 </li>
 </ul>
 </li>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/thrift/class-use/ThriftServerRunner.ImplType.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/thrift/class-use/ThriftServerRunner.ImplType.html b/devapidocs/org/apache/hadoop/hbase/thrift/class-use/ThriftServerRunner.ImplType.html
index 29521d0..130905b 100644
--- a/devapidocs/org/apache/hadoop/hbase/thrift/class-use/ThriftServerRunner.ImplType.html
+++ b/devapidocs/org/apache/hadoop/hbase/thrift/class-use/ThriftServerRunner.ImplType.html
@@ -119,7 +119,7 @@ service.</div>
 </tr>
 <tbody>
 <tr class="altColor">
-<td class="colFirst"><code>(package private) static <a href="../../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></code></td>
+<td class="colFirst"><code>static <a href="../../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a></code></td>
 <td class="colLast"><span class="typeNameLabel">ThriftServerRunner.ImplType.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#getServerImpl-org.apache.hadoop.conf.Configuration-">getServerImpl</a></span>(org.apache.hadoop.conf.Configuration&nbsp;conf)</code>&nbsp;</td>
 </tr>
 <tr class="rowColor">

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
index cdcb489..75493ca 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -533,13 +533,13 @@
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.UnsafeComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.UnsafeComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLock.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLock.ReferenceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PrettyPrinter.Unit.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PrettyPrinter.Unit</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/ChecksumType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">ChecksumType</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Order.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Order</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/HBaseFsck.ErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HBaseFsck.ErrorReporter.ERROR_CODE</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/IdReadWriteLock.ReferenceType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">IdReadWriteLock.ReferenceType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.LexicographicalComparerHolder.PureJavaComparer.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">Bytes.LexicographicalComparerHolder.PureJavaComparer</span></a> (implements org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/Bytes.Comparer.html" title="interface in org.apache.hadoop.hbase.util">Bytes.Comparer</a>&lt;T&gt;)</li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PrettyPrinter.Unit.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PrettyPrinter.Unit</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/PoolMap.PoolType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">PoolMap.PoolType</span></a></li>
 </ul>
 </li>
 </ul>

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
index 9ec5b35..c0e28b4 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/package-tree.html
@@ -189,8 +189,8 @@
 <ul>
 <li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a>&lt;E&gt; (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a>&lt;T&gt;, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" title="class or interface in java.io">Serializable</a>)
 <ul>
-<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.Providers.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">WALFactory.Providers</span></a></li>
 <li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/RegionGroupingProvider.Strategies.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">RegionGroupingProvider.Strategies</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.Providers.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">WALFactory.Providers</span></a></li>
 </ul>
 </li>
 </ul>


[08/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
index 01edd36..cdc0ca3 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html
@@ -103,30 +103,33 @@
 <span class="sourceLineNo">095</span><a name="line.95"></a>
 <span class="sourceLineNo">096</span>  @Override<a name="line.96"></a>
 <span class="sourceLineNo">097</span>  public boolean equals(Object obj) {<a name="line.97"></a>
-<span class="sourceLineNo">098</span>    if (obj == null || getClass() != obj.getClass()) {<a name="line.98"></a>
+<span class="sourceLineNo">098</span>    if (obj == null) {<a name="line.98"></a>
 <span class="sourceLineNo">099</span>      return false;<a name="line.99"></a>
 <span class="sourceLineNo">100</span>    }<a name="line.100"></a>
-<span class="sourceLineNo">101</span>    MemStoreSize other = (MemStoreSize) obj;<a name="line.101"></a>
-<span class="sourceLineNo">102</span>    return this.dataSize == other.dataSize<a name="line.102"></a>
-<span class="sourceLineNo">103</span>        &amp;&amp; this.heapSize == other.heapSize<a name="line.103"></a>
-<span class="sourceLineNo">104</span>        &amp;&amp; this.offHeapSize == other.offHeapSize;<a name="line.104"></a>
-<span class="sourceLineNo">105</span>  }<a name="line.105"></a>
-<span class="sourceLineNo">106</span><a name="line.106"></a>
-<span class="sourceLineNo">107</span>  @Override<a name="line.107"></a>
-<span class="sourceLineNo">108</span>  public int hashCode() {<a name="line.108"></a>
-<span class="sourceLineNo">109</span>    long h = 13 * this.dataSize;<a name="line.109"></a>
-<span class="sourceLineNo">110</span>    h = h + 14 * this.heapSize;<a name="line.110"></a>
-<span class="sourceLineNo">111</span>    h = h + 15 * this.offHeapSize;<a name="line.111"></a>
-<span class="sourceLineNo">112</span>    return (int) h;<a name="line.112"></a>
-<span class="sourceLineNo">113</span>  }<a name="line.113"></a>
-<span class="sourceLineNo">114</span><a name="line.114"></a>
-<span class="sourceLineNo">115</span>  @Override<a name="line.115"></a>
-<span class="sourceLineNo">116</span>  public String toString() {<a name="line.116"></a>
-<span class="sourceLineNo">117</span>    return "dataSize=" + this.dataSize<a name="line.117"></a>
-<span class="sourceLineNo">118</span>        + " , heapSize=" + this.heapSize<a name="line.118"></a>
-<span class="sourceLineNo">119</span>        + " , offHeapSize=" + this.offHeapSize;<a name="line.119"></a>
-<span class="sourceLineNo">120</span>  }<a name="line.120"></a>
-<span class="sourceLineNo">121</span>}<a name="line.121"></a>
+<span class="sourceLineNo">101</span>    if (!(obj instanceof MemStoreSize)) {<a name="line.101"></a>
+<span class="sourceLineNo">102</span>      return false;<a name="line.102"></a>
+<span class="sourceLineNo">103</span>    }<a name="line.103"></a>
+<span class="sourceLineNo">104</span>    MemStoreSize other = (MemStoreSize) obj;<a name="line.104"></a>
+<span class="sourceLineNo">105</span>    return this.dataSize == other.dataSize<a name="line.105"></a>
+<span class="sourceLineNo">106</span>        &amp;&amp; this.heapSize == other.heapSize<a name="line.106"></a>
+<span class="sourceLineNo">107</span>        &amp;&amp; this.offHeapSize == other.offHeapSize;<a name="line.107"></a>
+<span class="sourceLineNo">108</span>  }<a name="line.108"></a>
+<span class="sourceLineNo">109</span><a name="line.109"></a>
+<span class="sourceLineNo">110</span>  @Override<a name="line.110"></a>
+<span class="sourceLineNo">111</span>  public int hashCode() {<a name="line.111"></a>
+<span class="sourceLineNo">112</span>    long h = 13 * this.dataSize;<a name="line.112"></a>
+<span class="sourceLineNo">113</span>    h = h + 14 * this.heapSize;<a name="line.113"></a>
+<span class="sourceLineNo">114</span>    h = h + 15 * this.offHeapSize;<a name="line.114"></a>
+<span class="sourceLineNo">115</span>    return (int) h;<a name="line.115"></a>
+<span class="sourceLineNo">116</span>  }<a name="line.116"></a>
+<span class="sourceLineNo">117</span><a name="line.117"></a>
+<span class="sourceLineNo">118</span>  @Override<a name="line.118"></a>
+<span class="sourceLineNo">119</span>  public String toString() {<a name="line.119"></a>
+<span class="sourceLineNo">120</span>    return "dataSize=" + this.dataSize<a name="line.120"></a>
+<span class="sourceLineNo">121</span>        + " , heapSize=" + this.heapSize<a name="line.121"></a>
+<span class="sourceLineNo">122</span>        + " , offHeapSize=" + this.offHeapSize;<a name="line.122"></a>
+<span class="sourceLineNo">123</span>  }<a name="line.123"></a>
+<span class="sourceLineNo">124</span>}<a name="line.124"></a>
 
 
 


[02/16] hbase-site git commit: Published site at e73ba582f23e7ac512665bac2539af53bd3cb47c.

Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/export_control.html
----------------------------------------------------------------------
diff --git a/export_control.html b/export_control.html
index 9cd43ef..437879d 100644
--- a/export_control.html
+++ b/export_control.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; 
       Export Control
@@ -331,7 +331,7 @@ for more details.</p>
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/index.html
----------------------------------------------------------------------
diff --git a/index.html b/index.html
index a18e713..c039284 100644
--- a/index.html
+++ b/index.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Apache HBase™ Home</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -409,7 +409,7 @@ Apache HBase is an open-source, distributed, versioned, non-relational database
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/integration.html
----------------------------------------------------------------------
diff --git a/integration.html b/integration.html
index 2a063f8..230a717 100644
--- a/integration.html
+++ b/integration.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; CI Management</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -291,7 +291,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/issue-tracking.html
----------------------------------------------------------------------
diff --git a/issue-tracking.html b/issue-tracking.html
index a2537a6..2b8edc6 100644
--- a/issue-tracking.html
+++ b/issue-tracking.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Issue Management</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -288,7 +288,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/license.html
----------------------------------------------------------------------
diff --git a/license.html b/license.html
index 4b85e78..2347553 100644
--- a/license.html
+++ b/license.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Licenses</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -491,7 +491,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/mail-lists.html
----------------------------------------------------------------------
diff --git a/mail-lists.html b/mail-lists.html
index 4f42628..df436c7 100644
--- a/mail-lists.html
+++ b/mail-lists.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Mailing Lists</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -341,7 +341,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/metrics.html
----------------------------------------------------------------------
diff --git a/metrics.html b/metrics.html
index f3fd5ff..41770b3 100644
--- a/metrics.html
+++ b/metrics.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013;  
       Apache HBase (TM) Metrics
@@ -459,7 +459,7 @@ export HBASE_REGIONSERVER_OPTS=&quot;$HBASE_JMX_OPTS -Dcom.sun.management.jmxrem
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/old_news.html
----------------------------------------------------------------------
diff --git a/old_news.html b/old_news.html
index 5ed3699..eaca3fb 100644
--- a/old_news.html
+++ b/old_news.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; 
       Old Apache HBase (TM) News
@@ -440,7 +440,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/plugin-management.html
----------------------------------------------------------------------
diff --git a/plugin-management.html b/plugin-management.html
index f7d9df7..7cf41ea 100644
--- a/plugin-management.html
+++ b/plugin-management.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Plugin Management</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -440,7 +440,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/plugins.html
----------------------------------------------------------------------
diff --git a/plugins.html b/plugins.html
index 89793a4..75292d9 100644
--- a/plugins.html
+++ b/plugins.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Plugins</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -375,7 +375,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/poweredbyhbase.html
----------------------------------------------------------------------
diff --git a/poweredbyhbase.html b/poweredbyhbase.html
index 3f1bdd9..e5da82d 100644
--- a/poweredbyhbase.html
+++ b/poweredbyhbase.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Powered By Apache HBase™</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -769,7 +769,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/project-info.html
----------------------------------------------------------------------
diff --git a/project-info.html b/project-info.html
index 2a3959a..aa1dd9f 100644
--- a/project-info.html
+++ b/project-info.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Information</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -335,7 +335,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/project-reports.html
----------------------------------------------------------------------
diff --git a/project-reports.html b/project-reports.html
index caad0f6..3d158c8 100644
--- a/project-reports.html
+++ b/project-reports.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Generated Reports</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -305,7 +305,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/project-summary.html
----------------------------------------------------------------------
diff --git a/project-summary.html b/project-summary.html
index d65e14a..3325af0 100644
--- a/project-summary.html
+++ b/project-summary.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Summary</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -331,7 +331,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/pseudo-distributed.html
----------------------------------------------------------------------
diff --git a/pseudo-distributed.html b/pseudo-distributed.html
index 0307905..3d9cb48 100644
--- a/pseudo-distributed.html
+++ b/pseudo-distributed.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013;  
 Running Apache HBase (TM) in pseudo-distributed mode
@@ -308,7 +308,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/replication.html
----------------------------------------------------------------------
diff --git a/replication.html b/replication.html
index ce6fc23..25bcda5 100644
--- a/replication.html
+++ b/replication.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; 
       Apache HBase (TM) Replication
@@ -303,7 +303,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/resources.html
----------------------------------------------------------------------
diff --git a/resources.html b/resources.html
index 0bc6175..adfbda4 100644
--- a/resources.html
+++ b/resources.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Other Apache HBase (TM) Resources</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -331,7 +331,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/source-repository.html
----------------------------------------------------------------------
diff --git a/source-repository.html b/source-repository.html
index 292c58d..cfb2485 100644
--- a/source-repository.html
+++ b/source-repository.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Source Code Management</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -299,7 +299,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/sponsors.html
----------------------------------------------------------------------
diff --git a/sponsors.html b/sponsors.html
index 3831cc0..83d1afd 100644
--- a/sponsors.html
+++ b/sponsors.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Apache HBase™ Sponsors</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -333,7 +333,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/supportingprojects.html
----------------------------------------------------------------------
diff --git a/supportingprojects.html b/supportingprojects.html
index e5d6edf..fabff4c 100644
--- a/supportingprojects.html
+++ b/supportingprojects.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Supporting Projects</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -520,7 +520,7 @@ under the License. -->
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/team-list.html
----------------------------------------------------------------------
diff --git a/team-list.html b/team-list.html
index 01d047f..be414ba 100644
--- a/team-list.html
+++ b/team-list.html
@@ -7,7 +7,7 @@
   <head>
     <meta charset="UTF-8" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <meta name="Date-Revision-yyyymmdd" content="20180422" />
+    <meta name="Date-Revision-yyyymmdd" content="20180423" />
     <meta http-equiv="Content-Language" content="en" />
     <title>Apache HBase &#x2013; Project Team</title>
     <link rel="stylesheet" href="./css/apache-maven-fluido-1.5-HBASE.min.css" />
@@ -730,7 +730,7 @@
                         <a href="https://www.apache.org/">The Apache Software Foundation</a>.
             All rights reserved.      
                     
-                  <li id="publishDate" class="pull-right">Last Published: 2018-04-22</li>
+                  <li id="publishDate" class="pull-right">Last Published: 2018-04-23</li>
             </p>
                 </div>
 

http://git-wip-us.apache.org/repos/asf/hbase-site/blob/952146b4/testdevapidocs/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html b/testdevapidocs/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
index 00ac625..ca9acd3 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html
@@ -503,7 +503,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>testLogReplayWithDistributedLogSplit</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.427">testLogReplayWithDistributedLogSplit</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.430">testLogReplayWithDistributedLogSplit</a>()
                                           throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -517,7 +517,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getWAL</h4>
-<pre>private&nbsp;org.apache.hadoop.hbase.wal.WAL&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.431">getWAL</a>(org.apache.hadoop.hbase.regionserver.Region&nbsp;region)</pre>
+<pre>private&nbsp;org.apache.hadoop.hbase.wal.WAL&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.434">getWAL</a>(org.apache.hadoop.hbase.regionserver.Region&nbsp;region)</pre>
 </li>
 </ul>
 <a name="getNumRolledLogFiles-org.apache.hadoop.hbase.regionserver.Region-">
@@ -526,7 +526,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>getNumRolledLogFiles</h4>
-<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.435">getNumRolledLogFiles</a>(org.apache.hadoop.hbase.regionserver.Region&nbsp;region)</pre>
+<pre>private&nbsp;int&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.438">getNumRolledLogFiles</a>(org.apache.hadoop.hbase.regionserver.Region&nbsp;region)</pre>
 </li>
 </ul>
 <a name="testFlushingWhenLogRolling--">
@@ -535,7 +535,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>testFlushingWhenLogRolling</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.446">testFlushingWhenLogRolling</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.449">testFlushingWhenLogRolling</a>()
                                 throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <div class="block">When a log roll is about to happen, we do a flush of the regions who will be affected by the
  log roll. These flushes cannot be a selective flushes, otherwise we cannot roll the logs. This
@@ -553,7 +553,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>doPut</h4>
-<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.535">doPut</a>(org.apache.hadoop.hbase.client.Table&nbsp;table,
+<pre>private&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.538">doPut</a>(org.apache.hadoop.hbase.client.Table&nbsp;table,
                    long&nbsp;memstoreFlushSize)
             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>
@@ -570,7 +570,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockList">
 <li class="blockList">
 <h4>testCompareStoreFileCount</h4>
-<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.563">testCompareStoreFileCount</a>()
+<pre>public&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.566">testCompareStoreFileCount</a>()
                                throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>
@@ -584,7 +584,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
 <ul class="blockListLast">
 <li class="blockList">
 <h4>main</h4>
-<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.639">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
+<pre>public static&nbsp;void&nbsp;<a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.642">main</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>[]&nbsp;args)
                  throws <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
 <dl>
 <dt><span class="throwsLabel">Throws:</span></dt>