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 > 0);<a name="line.394"></a>
-<span class="sourceLineNo">395</span> assertTrue(cf3MemstoreSize > 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 <= 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 <= 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<HRegion, HRegionServer> 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 <= 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 < maxLogs; i++) {<a name="line.484"></a>
-<span class="sourceLineNo">485</span> for (int j = 0; j < 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) <= 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() > cfFlushSizeLowerBound);<a name="line.496"></a>
-<span class="sourceLineNo">497</span> assertTrue(desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize() < cfFlushSizeLowerBound);<a name="line.497"></a>
-<span class="sourceLineNo">498</span> assertTrue(desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize() < 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<Exception>() {<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 > 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) < 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 < 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() > 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) + "=>" + cf1StoreFileCount<a name="line.628"></a>
-<span class="sourceLineNo">629</span> + ", " + Bytes.toString(FAMILY2) + "=>" + cf2StoreFileCount + ", "<a name="line.629"></a>
-<span class="sourceLineNo">630</span> + Bytes.toString(FAMILY3) + "=>" + cf3StoreFileCount);<a name="line.630"></a>
-<span class="sourceLineNo">631</span> LOG.info("enable selective flush: " + Bytes.toString(FAMILY1) + "=>" + cf1StoreFileCount1<a name="line.631"></a>
-<span class="sourceLineNo">632</span> + ", " + Bytes.toString(FAMILY2) + "=>" + cf2StoreFileCount1 + ", "<a name="line.632"></a>
-<span class="sourceLineNo">633</span> + Bytes.toString(FAMILY3) + "=>" + 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 < cf1StoreFileCount);<a name="line.635"></a>
-<span class="sourceLineNo">636</span> assertTrue(cf2StoreFileCount1 < 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 >= 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 < 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 >= 0);<a name="line.397"></a>
+<span class="sourceLineNo">398</span> assertTrue(cf3MemstoreSize >= 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 <= 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 <= 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<HRegion, HRegionServer> 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 <= 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 < maxLogs; i++) {<a name="line.487"></a>
+<span class="sourceLineNo">488</span> for (int j = 0; j < 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) <= 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() > cfFlushSizeLowerBound);<a name="line.499"></a>
+<span class="sourceLineNo">500</span> assertTrue(desiredRegion.getStore(FAMILY2).getMemStoreSize().getHeapSize() < cfFlushSizeLowerBound);<a name="line.500"></a>
+<span class="sourceLineNo">501</span> assertTrue(desiredRegion.getStore(FAMILY3).getMemStoreSize().getHeapSize() < 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<Exception>() {<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 > 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) < 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 < 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() > 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) + "=>" + cf1StoreFileCount<a name="line.631"></a>
+<span class="sourceLineNo">632</span> + ", " + Bytes.toString(FAMILY2) + "=>" + cf2StoreFileCount + ", "<a name="line.632"></a>
+<span class="sourceLineNo">633</span> + Bytes.toString(FAMILY3) + "=>" + cf3StoreFileCount);<a name="line.633"></a>
+<span class="sourceLineNo">634</span> LOG.info("enable selective flush: " + Bytes.toString(FAMILY1) + "=>" + cf1StoreFileCount1<a name="line.634"></a>
+<span class="sourceLineNo">635</span> + ", " + Bytes.toString(FAMILY2) + "=>" + cf2StoreFileCount1 + ", "<a name="line.635"></a>
+<span class="sourceLineNo">636</span> + Bytes.toString(FAMILY3) + "=>" + 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 < cf1StoreFileCount);<a name="line.638"></a>
+<span class="sourceLineNo">639</span> assertTrue(cf2StoreFileCount1 < 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 >= 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 < 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 <= 60000 && !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 <= 60000 && !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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.357"></a>
-<span class="sourceLineNo">358</span> qop != QualityOfProtection.INTEGRITY &&<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 &&<a name="line.375"></a>
-<span class="sourceLineNo">376</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.366"></a>
+<span class="sourceLineNo">367</span> qop != QualityOfProtection.INTEGRITY &&<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<Object>() {<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 &&<a name="line.384"></a>
+<span class="sourceLineNo">385</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<Object>() {<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<>(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<>(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<>(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<String, String> 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 && !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<>(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<String, String> 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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.357"></a>
-<span class="sourceLineNo">358</span> qop != QualityOfProtection.INTEGRITY &&<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 &&<a name="line.375"></a>
-<span class="sourceLineNo">376</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.366"></a>
+<span class="sourceLineNo">367</span> qop != QualityOfProtection.INTEGRITY &&<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<Object>() {<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 &&<a name="line.384"></a>
+<span class="sourceLineNo">385</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<Object>() {<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<>(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<>(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<>(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<String, String> 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 && !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<>(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<String, String> 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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.357"></a>
-<span class="sourceLineNo">358</span> qop != QualityOfProtection.INTEGRITY &&<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 &&<a name="line.375"></a>
-<span class="sourceLineNo">376</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.366"></a>
+<span class="sourceLineNo">367</span> qop != QualityOfProtection.INTEGRITY &&<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<Object>() {<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 &&<a name="line.384"></a>
+<span class="sourceLineNo">385</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<Object>() {<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<>(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<>(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<>(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<String, String> 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 && !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<>(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<String, String> 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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.357"></a>
-<span class="sourceLineNo">358</span> qop != QualityOfProtection.INTEGRITY &&<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 &&<a name="line.375"></a>
-<span class="sourceLineNo">376</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.366"></a>
+<span class="sourceLineNo">367</span> qop != QualityOfProtection.INTEGRITY &&<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<Object>() {<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 &&<a name="line.384"></a>
+<span class="sourceLineNo">385</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<Object>() {<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<>(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<>(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<>(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<String, String> 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 && !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<>(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<String, String> 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> * <p><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> * <p><a name="line.76"></a>
-<span class="sourceLineNo">077</span> * <h3>Exception Handling</h3><br><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> * <ul><a name="line.79"></a>
-<span class="sourceLineNo">080</span> * <li>Exceptions of type {@link IOException} are reported back to client.</li><a name="line.80"></a>
-<span class="sourceLineNo">081</span> * <li>For any other kind of exception:<a name="line.81"></a>
-<span class="sourceLineNo">082</span> * <ul><a name="line.82"></a>
-<span class="sourceLineNo">083</span> * <li>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.</li><a name="line.84"></a>
-<span class="sourceLineNo">085</span> * <li>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.</li><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> * <p><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> * <p><a name="line.74"></a>
+<span class="sourceLineNo">075</span> * <h3>Exception Handling</h3><br><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> * <ul><a name="line.77"></a>
+<span class="sourceLineNo">078</span> * <li>Exceptions of type {@link IOException} are reported back to client.</li><a name="line.78"></a>
+<span class="sourceLineNo">079</span> * <li>For any other kind of exception:<a name="line.79"></a>
+<span class="sourceLineNo">080</span> * <ul><a name="line.80"></a>
+<span class="sourceLineNo">081</span> * <li>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.</li><a name="line.82"></a>
+<span class="sourceLineNo">083</span> * <li>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.</li><a name="line.84"></a>
+<span class="sourceLineNo">085</span> * </ul><a name="line.85"></a>
+<span class="sourceLineNo">086</span> * </li><a name="line.86"></a>
<span class="sourceLineNo">087</span> * </ul><a name="line.87"></a>
-<span class="sourceLineNo">088</span> * </li><a name="line.88"></a>
-<span class="sourceLineNo">089</span> * </ul><a name="line.89"></a>
-<span class="sourceLineNo">090</span> * <p><a name="line.90"></a>
-<span class="sourceLineNo">091</span> * <h3>For Split Related Hooks</h3> <br><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> * <p><a name="line.94"></a>
-<span class="sourceLineNo">095</span> * <h3>Increment Column Value</h3><br><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<? extends RegionCoprocessorEnvironment><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p>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 <code>candidates</code>.<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<RegionCoprocessorEnvironment> c, Store store,<a name="line.229"></a>
-<span class="sourceLineNo">230</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> c, Store store,<a name="line.242"></a>
-<span class="sourceLineNo">243</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get, List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get,<a name="line.333"></a>
-<span class="sourceLineNo">334</span> List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><a name="line.88"></a>
+<span class="sourceLineNo">089</span> * <h3>For Split Related Hooks</h3> <br><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> * <p><a name="line.92"></a>
+<span class="sourceLineNo">093</span> * <h3>Increment Column Value</h3><br><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<? extends RegionCoprocessorEnvironment><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p>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 <code>candidates</code>.<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<RegionCoprocessorEnvironment> c, Store store,<a name="line.226"></a>
+<span class="sourceLineNo">227</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> c, Store store,<a name="line.239"></a>
+<span class="sourceLineNo">240</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get, List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get,<a name="line.330"></a>
+<span class="sourceLineNo">331</span> List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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> * <p><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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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> * <p><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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c,<a name="line.451"></a>
-<span class="sourceLineNo">452</span> MiniBatchOperationInProgress<Mutation> 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> * <p><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> * <p><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> * <p><a name="line.76"></a>
-<span class="sourceLineNo">077</span> * <h3>Exception Handling</h3><br><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> * <ul><a name="line.79"></a>
-<span class="sourceLineNo">080</span> * <li>Exceptions of type {@link IOException} are reported back to client.</li><a name="line.80"></a>
-<span class="sourceLineNo">081</span> * <li>For any other kind of exception:<a name="line.81"></a>
-<span class="sourceLineNo">082</span> * <ul><a name="line.82"></a>
-<span class="sourceLineNo">083</span> * <li>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.</li><a name="line.84"></a>
-<span class="sourceLineNo">085</span> * <li>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.</li><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> * <p><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> * <p><a name="line.74"></a>
+<span class="sourceLineNo">075</span> * <h3>Exception Handling</h3><br><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> * <ul><a name="line.77"></a>
+<span class="sourceLineNo">078</span> * <li>Exceptions of type {@link IOException} are reported back to client.</li><a name="line.78"></a>
+<span class="sourceLineNo">079</span> * <li>For any other kind of exception:<a name="line.79"></a>
+<span class="sourceLineNo">080</span> * <ul><a name="line.80"></a>
+<span class="sourceLineNo">081</span> * <li>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.</li><a name="line.82"></a>
+<span class="sourceLineNo">083</span> * <li>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.</li><a name="line.84"></a>
+<span class="sourceLineNo">085</span> * </ul><a name="line.85"></a>
+<span class="sourceLineNo">086</span> * </li><a name="line.86"></a>
<span class="sourceLineNo">087</span> * </ul><a name="line.87"></a>
-<span class="sourceLineNo">088</span> * </li><a name="line.88"></a>
-<span class="sourceLineNo">089</span> * </ul><a name="line.89"></a>
-<span class="sourceLineNo">090</span> * <p><a name="line.90"></a>
-<span class="sourceLineNo">091</span> * <h3>For Split Related Hooks</h3> <br><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> * <p><a name="line.94"></a>
-<span class="sourceLineNo">095</span> * <h3>Increment Column Value</h3><br><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<? extends RegionCoprocessorEnvironment><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p>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 <code>candidates</code>.<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<RegionCoprocessorEnvironment> c, Store store,<a name="line.229"></a>
-<span class="sourceLineNo">230</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> c, Store store,<a name="line.242"></a>
-<span class="sourceLineNo">243</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get, List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get,<a name="line.333"></a>
-<span class="sourceLineNo">334</span> List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><a name="line.88"></a>
+<span class="sourceLineNo">089</span> * <h3>For Split Related Hooks</h3> <br><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> * <p><a name="line.92"></a>
+<span class="sourceLineNo">093</span> * <h3>Increment Column Value</h3><br><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<? extends RegionCoprocessorEnvironment><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p>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 <code>candidates</code>.<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<RegionCoprocessorEnvironment> c, Store store,<a name="line.226"></a>
+<span class="sourceLineNo">227</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> c, Store store,<a name="line.239"></a>
+<span class="sourceLineNo">240</span> List<? extends StoreFile> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get, List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> c, Get get,<a name="line.330"></a>
+<span class="sourceLineNo">331</span> List<Cell> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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> * <p><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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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> * <p><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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> 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> * <p><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<RegionCoprocessorEnvironment> c,<a name="line.451"></a>
-<span class="sourceLineNo">452</span> MiniBatchOperationInProgress<Mutation> 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> * <p><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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c)
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c)</pre>
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a> options,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> scanner,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a> resultFile,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/FlushLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver">FlushLifeCycleTracker</a> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> 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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
- <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
- <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+ <a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
+ <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postMemStoreCompaction</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preCompactSelection</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> 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><? extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>> candidates,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a> tracker)
@@ -1030,7 +1029,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postCompactSelection</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> 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><? extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a>> selected,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a> tracker,
@@ -1053,7 +1052,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preCompactScannerOpen</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver">ScanType</a> scanType,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanOptions.html" title="interface in org.apache.hadoop.hbase.regionserver">ScanOptions</a> options,
@@ -1081,7 +1080,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preCompact</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> scanner,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver">ScanType</a> scanType,
@@ -1117,7 +1116,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postCompact</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Store.html" title="interface in org.apache.hadoop.hbase.regionserver">Store</a> store,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/StoreFile.html" title="interface in org.apache.hadoop.hbase.regionserver">StoreFile</a> resultFile,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/compactions/CompactionLifeCycleTracker.html" title="interface in org.apache.hadoop.hbase.regionserver.compactions">CompactionLifeCycleTracker</a> tracker,
@@ -1142,7 +1141,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preClose</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
boolean 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postClose</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
boolean abortRequested)</pre>
<div class="block">Called after the region is reported as closed to the master.</div>
<dl>
@@ -1177,7 +1176,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preGetOp</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a> 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><<a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postGetOp</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a> 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><<a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a>> 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preExists</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a> get,
boolean 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postExists</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a> get,
boolean 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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>prePut</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Put.html" title="class in org.apache.hadoop.hbase.client">Put</a> put,
<a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a> edit,
<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a> durability)
@@ -1305,7 +1304,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>postPut</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Put.html" title="class in org.apache.hadoop.hbase.client">Put</a> put,
<a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a> edit,
<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a> durability)
@@ -1331,7 +1330,7 @@ default <a href="../../../../../org/apache/hadoop/hbase/regionserver/Intern
<ul class="blockList">
<li class="blockList">
<h4>preDelete</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Delete.html" title="class in org.apache.hadoop.hbase.client">Delete</a> delete,
<a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a> edit,
<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a> durability)
@@ -1361,7 +1360,7 @@ default <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 void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a> mutation,
<a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> cell,
byte[] byteNow,
@@ -1392,7 +1391,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postDelete</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Delete.html" title="class in org.apache.hadoop.hbase.client">Delete</a> delete,
<a href="../../../../../org/apache/hadoop/hbase/wal/WALEdit.html" title="class in org.apache.hadoop.hbase.wal">WALEdit</a> edit,
<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client">Durability</a> durability)
@@ -1418,7 +1417,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preBatchMutate</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a><<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postBatchMutate</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a><<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postStartRegionOperation</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postCloseRegionOperation</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postBatchMutateIndispensably</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.html" title="class in org.apache.hadoop.hbase.regionserver">MiniBatchOperationInProgress</a><<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a>> miniBatchOp,
boolean 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preCheckAndPut</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1575,7 +1574,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preCheckAndPutAfterRowLock</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1619,7 +1618,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postCheckAndPut</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1655,7 +1654,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preCheckAndDelete</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1694,7 +1693,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preCheckAndDeleteAfterRowLock</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1737,7 +1736,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postCheckAndDelete</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
byte[] row,
byte[] family,
byte[] qualifier,
@@ -1773,7 +1772,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preAppend</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preAppendAfterRowLock</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postAppend</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Append.html" title="class in org.apache.hadoop.hbase.client">Append</a> append,
<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preIncrement</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preIncrementAfterRowLock</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postIncrement</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Increment.html" title="class in org.apache.hadoop.hbase.client">Increment</a> increment,
<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preScannerOpen</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Scan.html" title="class in org.apache.hadoop.hbase.client">Scan</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postScannerOpen</h4>
-<pre>default <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default <a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a> <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/client/Scan.html" title="class in org.apache.hadoop.hbase.client">Scan</a> scan,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/RegionScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">RegionScanner</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preScannerNext</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> 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><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> result,
int limit,
@@ -2025,7 +2024,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postScannerNext</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> 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><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> result,
int limit,
@@ -2055,7 +2054,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postScannerFilterRow</h4>
-<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default boolean <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> s,
<a href="../../../../../org/apache/hadoop/hbase/Cell.html" title="interface in org.apache.hadoop.hbase">Cell</a> curRowCell,
boolean hasMore)
@@ -2093,7 +2092,7 @@ default void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>preScannerClose</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
+<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> c,
<a href="../../../../../org/apache/hadoop/hbase/regionserver/InternalScanner.html" title="interface in org.apache.hadoop.hbase.regionserver">InternalScanner</a> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/
<ul class="blockList">
<li class="blockList">
<h4>postScannerClose</h4>
-<pre>default void <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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionCoprocessorEnvironment.html" title="interface in org.apache.hadoop.hbase.coprocessor">RegionCoprocessorEnvironment</a>> ctx,
+<pre>default void <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><<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.312"></a>
-<span class="sourceLineNo">313</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.357"></a>
-<span class="sourceLineNo">358</span> qop != QualityOfProtection.INTEGRITY &&<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 &&<a name="line.375"></a>
-<span class="sourceLineNo">376</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<? extends TServer> 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<? extends TServer> 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 <code>-option</code> 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 < 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 > 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<String> serversThatCannotSpecifyBindIP() {<a name="line.321"></a>
+<span class="sourceLineNo">322</span> List<String> l = new ArrayList<>();<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> && 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 &&<a name="line.366"></a>
+<span class="sourceLineNo">367</span> qop != QualityOfProtection.INTEGRITY &&<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<Object>() {<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 &&<a name="line.384"></a>
+<span class="sourceLineNo">385</span> conf.getBoolean(USE_HTTP_CONF_KEY, false) &&<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<Object>() {<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<>(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<>(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<>(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<String, String> 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 && !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<>(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<String, String> 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 org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.730">conf</a></pre>
+<pre>protected 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 org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.731">LOG</a></pre>
+<pre>protected static final 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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.734">nextScannerId</a></pre>
+<pre>protected 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 <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><<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>> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.735">scannerMap</a></pre>
+<pre>protected <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><<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>> <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 <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 <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 <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 <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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.812">HBaseHandler</a>(org.apache.hadoop.conf.Configuration c,
+<pre>protected <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.821">HBaseHandler</a>(org.apache.hadoop.conf.Configuration c,
<a href="../../../../../org/apache/hadoop/hbase/security/UserProvider.html" title="class in org.apache.hadoop.hbase.security">UserProvider</a> 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[][] <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> table)
+<pre>byte[][] <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> 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 <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.768">getTable</a>(byte[] tableName)
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.777">getTable</a>(byte[] 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 <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> tableName)
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/client/Table.html" title="interface in org.apache.hadoop.hbase.client">Table</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> 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 int <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> scanner,
+<pre>protected int <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> scanner,
boolean 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 <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.797">getScanner</a>(int id)</pre>
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.806">getScanner</a>(int 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 <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.808">removeScanner</a>(int id)</pre>
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html" title="class in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ResultScannerWrapper</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.817">removeScanner</a>(int id)</pre>
<div class="block">Removes the scanner associated with the specified ID from the internal
id->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 <a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.827">getAdmin</a>()
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Admin.html" title="interface in org.apache.hadoop.hbase.client">Admin</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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 <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> effectiveUser)</pre>
+<pre>void <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> 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 void <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> tableName)
+<pre>public void <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> tableName)
throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 void <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> tableName)
+<pre>public void <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> tableName)
throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 boolean <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> tableName)
+<pre>public boolean <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> 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 void <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> tableNameOrRegionName)
+<pre>public void <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> 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 void <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> tableNameOrRegionName)
+<pre>public void <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> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="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="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.900">getTableNames</a>()
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="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="../../../../../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: <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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRegionInfo> <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> tableName)
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRegionInfo> <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> tableName)
throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> 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> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> row,
byte[] family,
byte[] 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> 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> column,
int 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> row,
byte[] family,
byte[] 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> 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> column,
long 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> tableName,
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TCell> <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> 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> row,
byte[] family,
byte[] 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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> 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><<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>> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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> row,
long 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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> 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><<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>> columns,
long 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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><<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>> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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><<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>> 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><<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>> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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><<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>> rows,
long 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> tableName,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <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> 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><<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>> 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><<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>> columns,
long 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 void <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> tableName,
+<pre>public void <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> 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> 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> 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><<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>> 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 void <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> tableName,
+<pre>public void <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> 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> 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> column,
long 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 void <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> tableName,
+<pre>public void <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> 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> 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><<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>> 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 void <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> tableName,
+<pre>public void <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> 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> row,
long 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><<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>> 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 void <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> in_tableName,
+<pre>public void <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> 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><org.apache.hadoop.hbase.thrift.generated.ColumnDescriptor> 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 <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> buffer)</pre>
+<pre>private static <a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> 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 void <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> in_tableName)
+<pre>public void <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> in_tableName)
throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 void <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> tableName,
+<pre>public void <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> 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> 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><org.apache.hadoop.hbase.thrift.generated.Mutation> 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><<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>> 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 void <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> tableName,
+<pre>public void <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> 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> 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><org.apache.hadoop.hbase.thrift.generated.Mutation> mutations,
long 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 void <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> tableName,
+<pre>public void <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> 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><org.apache.hadoop.hbase.thrift.generated.BatchMutation> 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><<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>> 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 void <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> tableName,
+<pre>public void <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> 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><org.apache.hadoop.hbase.thrift.generated.BatchMutation> rowBatches,
long 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><<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>> 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 long <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> tableName,
+<pre>public long <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> 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> 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> column,
long 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 long <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> tableName,
+<pre>protected long <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> 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> row,
byte[] family,
byte[] 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1509">scannerClose</a>(int id)
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1518">scannerClose</a>(int 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: <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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1522">scannerGetList</a>(int id,
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1531">scannerGetList</a>(int id,
int 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1546">scannerGet</a>(int id)
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.thrift.generated.TRowResult> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1555">scannerGet</a>(int 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: <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 int <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> tableName,
+<pre>public int <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> tableName,
org.apache.hadoop.hbase.thrift.generated.TScan 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><<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>> 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 int <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> tableName,
+<pre>public int <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> 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> 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><<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>> 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><<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>> 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 int <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> tableName,
+<pre>public int <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> 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> 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> 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><<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>> 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 int <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> tableName,
+<pre>public int <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> 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> 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><<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>> 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><<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>> 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 int <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> tableName,
+<pre>public int <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> 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> 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><<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>> columns,
long 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 int <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> tableName,
+<pre>public int <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> 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> 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> 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><<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>> 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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="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> <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> tableName)
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="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> <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> tableName)
throws org.apache.hadoop.hbase.thrift.generated.IOError,
org.apache.thrift.TException</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 void <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> table)
+<pre>private void <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> 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 org.apache.hadoop.hbase.thrift.generated.TRegionInfo <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> searchRow)
+<pre>public org.apache.hadoop.hbase.thrift.generated.TRegionInfo <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> searchRow)
throws org.apache.hadoop.hbase.thrift.generated.IOError</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <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 <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.HBaseHandler.html#line.1834">getReverseScanResult</a>(byte[] tableName,
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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 –
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 –
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 – 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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="" /> 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 –
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 – 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 – 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 – 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 – 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 static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td><code><a href="org/apache/hadoop/hbase/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 static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td><code><a href="org/apache/hadoop/hbase/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 static final <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
<td><code><a href="org/apache/hadoop/hbase/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> </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> </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> </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> </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> </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> </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> </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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor">RegionObserver.MutationType</a>></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 <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 <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 <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 <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 <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.148">values</a>()</pre>
+<pre>public static <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.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 <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.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> name)</pre>
+<pre>public static <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.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> 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.108">hashCode</a>()</pre>
+<pre>public int <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> in class <code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>
@@ -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 <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/MemStoreSize.html#line.116">toString</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> in class <code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></code></dd>
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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>[] <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/Region.Operation.html#line.126">values</a>()</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a>[] <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 <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a> <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> name)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver">Region.Operation</a> <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> 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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 <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 <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 <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> cause)</pre>
+<pre>public <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> 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 <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.2001">getCause</a>()</pre>
+<pre>public <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.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> in class <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 boolean <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> other)</pre>
+<pre>public boolean <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> other)</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Overrides:</span></dt>
<dd><code>equals</code> in class <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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.IOErrorWithCause.html#line.2020">hashCode</a>()</pre>
+<pre>public int <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> in class <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><<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>></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> </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> </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 conf)</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#getOption--">getOption</a></span>()</code> </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 conf)</code> </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> </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><<a href="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#serversThatCannotSpecifyBindIP--">serversThatCannotSpecifyBindIP</a></span>()</code> </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 cmd,
org.apache.hadoop.conf.Configuration conf)</code> </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> </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> </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> 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 <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 <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 <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 <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 <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 <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 <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 <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 <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 <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 <a href="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 <a href="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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.237">isAlwaysFramed</a></pre>
+<pre>final 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 <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><? extends org.apache.thrift.server.TServer> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.238">serverClass</a></pre>
+<pre>final <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><? extends org.apache.thrift.server.TServer> <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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.239">canSpecifyBindIP</a></pre>
+<pre>final 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 <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.227">values</a>()</pre>
+<pre>public static <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">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 <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.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> name)</pre>
+<pre>public static <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">valueOf</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> name)</pre>
<div class="block">Returns the enum constant of this type with the specified name.
The string must match <i>exactly</i> an identifier used to declare an
enum constant in this type. (Extraneous whitespace characters are
@@ -420,7 +428,7 @@ not permitted.)</div>
<ul class="blockList">
<li class="blockList">
<h4>toString</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.254">toString</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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> in class <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><<a href="../../../../../org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html" title="enum in org.apache.hadoop.hbase.thrift">ThriftServerRunner.ImplType</a>></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 <a href="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.259">getOption</a>()</pre>
+</li>
+</ul>
+<a name="isAlwaysFramed--">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>isAlwaysFramed</h4>
+<pre>public boolean <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> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.258">getDescription</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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 org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.270">createOptionGroup</a>()</pre>
+<pre>static org.apache.hbase.thirdparty.org.apache.commons.cli.OptionGroup <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 <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.278">getServerImpl</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>public static <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.287">getServerImpl</a>(org.apache.hadoop.conf.Configuration 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 void <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 cmd,
+<pre>static void <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 cmd,
org.apache.hadoop.conf.Configuration conf)</pre>
</li>
</ul>
@@ -473,7 +499,7 @@ not permitted.)</div>
<ul class="blockList">
<li class="blockList">
<h4>simpleClassName</h4>
-<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ImplType.html#line.308">simpleClassName</a>()</pre>
+<pre>public <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/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 <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="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.312">serversThatCannotSpecifyBindIP</a>()</pre>
+<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="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.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 <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 <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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.709">sortColumns</a></pre>
+<pre>private final 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 <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> resultScanner,
+<pre>public <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> resultScanner,
boolean 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 <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.716">getScanner</a>()</pre>
+<pre>public <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.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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.ResultScannerWrapper.html#line.720">isColumnSorted</a>()</pre>
+<pre>public boolean <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 </code></td>
+<td class="colFirst"><code>static class </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 org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.155">LOG</a></pre>
+<pre>private static final 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 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 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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 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 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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 <a href="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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.205">DEFAULT_LISTEN_PORT</a></pre>
+<pre>public static final 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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.206">HREGION_VERSION</a></pre>
+<pre>public static final 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 <a href="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 <a href="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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.208">listenPort</a></pre>
+<pre>private final 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 org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.210">conf</a></pre>
+<pre>private 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 org.apache.thrift.server.TServer <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.211">tserver</a></pre>
+<pre>volatile 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 org.eclipse.jetty.server.Server <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.212">httpServer</a></pre>
+<pre>volatile 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 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 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 <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 <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 <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 <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 org.apache.hadoop.security.UserGroupInformation <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.216">realUser</a></pre>
+<pre>private final 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 <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 <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 <a href="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 <a href="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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.221">securityEnabled</a></pre>
+<pre>private final 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 boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.222">doAsEnabled</a></pre>
+<pre>private final 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 <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 <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 <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.324">ThriftServerRunner</a>(org.apache.hadoop.conf.Configuration conf)
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.333">ThriftServerRunner</a>(org.apache.hadoop.conf.Configuration conf)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<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 void <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> qop,
+<pre>private void <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> qop,
org.apache.hadoop.conf.Configuration 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.387">run</a>()</pre>
+<pre>public void <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> in interface <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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.412">shutdown</a>()</pre>
+<pre>public void <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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.431">setupHTTPServer</a>()
+<pre>private void <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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.524">setupServer</a>()
+<pre>private void <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 org.apache.thrift.protocol.TProtocolFactory <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.675">getProtocolFactory</a>()</pre>
+<pre>private org.apache.thrift.protocol.TProtocolFactory <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> <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><<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>> 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> <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><<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>> callQueue,
int minWorkers,
int 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 <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> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.700">getBindAddress</a>(org.apache.hadoop.conf.Configuration conf)
+<pre>private <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> <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.709">getBindAddress</a>(org.apache.hadoop.conf.Configuration 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 org.apache.hadoop.hbase.thrift.generated.IOError <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> throwable)</pre>
+<pre>private static org.apache.hadoop.hbase.thrift.generated.IOError <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> 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 void <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> op,
+<pre>private static void <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> 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><<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>> 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1980">registerFilters</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/thrift/ThriftServerRunner.html#line.1989">registerFilters</a>(org.apache.hadoop.conf.Configuration 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 conf)</code> </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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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><T>)</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><T>)</li>
<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/ChecksumType.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">ChecksumType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.util.<a href="../../../../../org/apache/hadoop/hbase/util/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><T>)</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><E> (implements java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Comparable.html?is-external=true" title="class or interface in java.lang">Comparable</a><T>, java.io.<a href="https://docs.oracle.com/javase/8/docs/api/java/io/Serializable.html?is-external=true" 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> && this.heapSize == other.heapSize<a name="line.103"></a>
-<span class="sourceLineNo">104</span> && 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> && this.heapSize == other.heapSize<a name="line.106"></a>
+<span class="sourceLineNo">107</span> && 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 –
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 – 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 – 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 – 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 – 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 – 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 –
Apache HBase (TM) Metrics
@@ -459,7 +459,7 @@ export HBASE_REGIONSERVER_OPTS="$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 –
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 – 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 – 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 – 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 – 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 – 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 – 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 –
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 –
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 – 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 – 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 – 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 – 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 – 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.427">testLogReplayWithDistributedLogSplit</a>()
+<pre>public void <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 org.apache.hadoop.hbase.wal.WAL <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.431">getWAL</a>(org.apache.hadoop.hbase.regionserver.Region region)</pre>
+<pre>private org.apache.hadoop.hbase.wal.WAL <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.434">getWAL</a>(org.apache.hadoop.hbase.regionserver.Region 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 int <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.435">getNumRolledLogFiles</a>(org.apache.hadoop.hbase.regionserver.Region region)</pre>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.438">getNumRolledLogFiles</a>(org.apache.hadoop.hbase.regionserver.Region 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.446">testFlushingWhenLogRolling</a>()
+<pre>public void <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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.535">doPut</a>(org.apache.hadoop.hbase.client.Table table,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.538">doPut</a>(org.apache.hadoop.hbase.client.Table table,
long 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 void <a href="../../../../../src-html/org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.html#line.563">testCompareStoreFileCount</a>()
+<pre>public void <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 void <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>[] args)
+<pre>public static void <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>[] 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>