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/11/21 14:53:21 UTC
[01/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Repository: hbase-site
Updated Branches:
refs/heads/asf-site af942ccb6 -> de8c44eb3
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
index 53719b2..f878875 100644
--- a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
@@ -463,186 +463,204 @@
<span class="sourceLineNo">455</span><a name="line.455"></a>
<span class="sourceLineNo">456</span> @Test<a name="line.456"></a>
<span class="sourceLineNo">457</span> public void testSetGetRemoveRPCQuota() throws Exception {<a name="line.457"></a>
-<span class="sourceLineNo">458</span> Admin admin = TEST_UTIL.getAdmin();<a name="line.458"></a>
-<span class="sourceLineNo">459</span> final TableName tn = TableName.valueOf("sq_table1");<a name="line.459"></a>
-<span class="sourceLineNo">460</span> QuotaSettings settings =<a name="line.460"></a>
-<span class="sourceLineNo">461</span> QuotaSettingsFactory.throttleTable(tn, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.461"></a>
-<span class="sourceLineNo">462</span> admin.setQuota(settings);<a name="line.462"></a>
-<span class="sourceLineNo">463</span><a name="line.463"></a>
-<span class="sourceLineNo">464</span> // Verify the Quota in the table<a name="line.464"></a>
-<span class="sourceLineNo">465</span> verifyRecordPresentInQuotaTable(ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.465"></a>
-<span class="sourceLineNo">466</span><a name="line.466"></a>
-<span class="sourceLineNo">467</span> // Verify we can retrieve it via the QuotaRetriever API<a name="line.467"></a>
-<span class="sourceLineNo">468</span> verifyFetchableViaAPI(admin, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.468"></a>
-<span class="sourceLineNo">469</span><a name="line.469"></a>
-<span class="sourceLineNo">470</span> // Now, remove the quota<a name="line.470"></a>
-<span class="sourceLineNo">471</span> QuotaSettings removeQuota = QuotaSettingsFactory.unthrottleTable(tn);<a name="line.471"></a>
-<span class="sourceLineNo">472</span> admin.setQuota(removeQuota);<a name="line.472"></a>
-<span class="sourceLineNo">473</span><a name="line.473"></a>
-<span class="sourceLineNo">474</span> // Verify that the record doesn't exist in the table<a name="line.474"></a>
-<span class="sourceLineNo">475</span> verifyRecordNotPresentInQuotaTable();<a name="line.475"></a>
-<span class="sourceLineNo">476</span><a name="line.476"></a>
-<span class="sourceLineNo">477</span> // Verify that we can also not fetch it via the API<a name="line.477"></a>
-<span class="sourceLineNo">478</span> verifyNotFetchableViaAPI(admin);<a name="line.478"></a>
-<span class="sourceLineNo">479</span> }<a name="line.479"></a>
-<span class="sourceLineNo">480</span><a name="line.480"></a>
-<span class="sourceLineNo">481</span> @Test<a name="line.481"></a>
-<span class="sourceLineNo">482</span> public void testSetModifyRemoveRPCQuota() throws Exception {<a name="line.482"></a>
-<span class="sourceLineNo">483</span> Admin admin = TEST_UTIL.getAdmin();<a name="line.483"></a>
-<span class="sourceLineNo">484</span> final TableName tn = TableName.valueOf("sq_table1");<a name="line.484"></a>
-<span class="sourceLineNo">485</span> QuotaSettings settings =<a name="line.485"></a>
-<span class="sourceLineNo">486</span> QuotaSettingsFactory.throttleTable(tn, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.486"></a>
-<span class="sourceLineNo">487</span> admin.setQuota(settings);<a name="line.487"></a>
-<span class="sourceLineNo">488</span><a name="line.488"></a>
-<span class="sourceLineNo">489</span> // Verify the Quota in the table<a name="line.489"></a>
-<span class="sourceLineNo">490</span> verifyRecordPresentInQuotaTable(ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.490"></a>
-<span class="sourceLineNo">491</span><a name="line.491"></a>
-<span class="sourceLineNo">492</span> // Verify we can retrieve it via the QuotaRetriever API<a name="line.492"></a>
-<span class="sourceLineNo">493</span> verifyFetchableViaAPI(admin, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.493"></a>
-<span class="sourceLineNo">494</span><a name="line.494"></a>
-<span class="sourceLineNo">495</span> // Setting a limit and time unit should be reflected<a name="line.495"></a>
-<span class="sourceLineNo">496</span> QuotaSettings newSettings =<a name="line.496"></a>
-<span class="sourceLineNo">497</span> QuotaSettingsFactory.throttleTable(tn, ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.497"></a>
-<span class="sourceLineNo">498</span> admin.setQuota(newSettings);<a name="line.498"></a>
+<span class="sourceLineNo">458</span> testSetGetRemoveRPCQuota(ThrottleType.REQUEST_SIZE);<a name="line.458"></a>
+<span class="sourceLineNo">459</span> testSetGetRemoveRPCQuota(ThrottleType.REQUEST_CAPACITY_UNIT);<a name="line.459"></a>
+<span class="sourceLineNo">460</span> }<a name="line.460"></a>
+<span class="sourceLineNo">461</span><a name="line.461"></a>
+<span class="sourceLineNo">462</span> private void testSetGetRemoveRPCQuota(ThrottleType throttleType) throws Exception {<a name="line.462"></a>
+<span class="sourceLineNo">463</span> Admin admin = TEST_UTIL.getAdmin();<a name="line.463"></a>
+<span class="sourceLineNo">464</span> final TableName tn = TableName.valueOf("sq_table1");<a name="line.464"></a>
+<span class="sourceLineNo">465</span> QuotaSettings settings =<a name="line.465"></a>
+<span class="sourceLineNo">466</span> QuotaSettingsFactory.throttleTable(tn, throttleType, 2L, TimeUnit.HOURS);<a name="line.466"></a>
+<span class="sourceLineNo">467</span> admin.setQuota(settings);<a name="line.467"></a>
+<span class="sourceLineNo">468</span><a name="line.468"></a>
+<span class="sourceLineNo">469</span> // Verify the Quota in the table<a name="line.469"></a>
+<span class="sourceLineNo">470</span> verifyRecordPresentInQuotaTable(throttleType, 2L, TimeUnit.HOURS);<a name="line.470"></a>
+<span class="sourceLineNo">471</span><a name="line.471"></a>
+<span class="sourceLineNo">472</span> // Verify we can retrieve it via the QuotaRetriever API<a name="line.472"></a>
+<span class="sourceLineNo">473</span> verifyFetchableViaAPI(admin, throttleType, 2L, TimeUnit.HOURS);<a name="line.473"></a>
+<span class="sourceLineNo">474</span><a name="line.474"></a>
+<span class="sourceLineNo">475</span> // Now, remove the quota<a name="line.475"></a>
+<span class="sourceLineNo">476</span> QuotaSettings removeQuota = QuotaSettingsFactory.unthrottleTable(tn);<a name="line.476"></a>
+<span class="sourceLineNo">477</span> admin.setQuota(removeQuota);<a name="line.477"></a>
+<span class="sourceLineNo">478</span><a name="line.478"></a>
+<span class="sourceLineNo">479</span> // Verify that the record doesn't exist in the table<a name="line.479"></a>
+<span class="sourceLineNo">480</span> verifyRecordNotPresentInQuotaTable();<a name="line.480"></a>
+<span class="sourceLineNo">481</span><a name="line.481"></a>
+<span class="sourceLineNo">482</span> // Verify that we can also not fetch it via the API<a name="line.482"></a>
+<span class="sourceLineNo">483</span> verifyNotFetchableViaAPI(admin);<a name="line.483"></a>
+<span class="sourceLineNo">484</span> }<a name="line.484"></a>
+<span class="sourceLineNo">485</span><a name="line.485"></a>
+<span class="sourceLineNo">486</span> @Test<a name="line.486"></a>
+<span class="sourceLineNo">487</span> public void testSetModifyRemoveRPCQuota() throws Exception {<a name="line.487"></a>
+<span class="sourceLineNo">488</span> Admin admin = TEST_UTIL.getAdmin();<a name="line.488"></a>
+<span class="sourceLineNo">489</span> final TableName tn = TableName.valueOf("sq_table1");<a name="line.489"></a>
+<span class="sourceLineNo">490</span> QuotaSettings settings =<a name="line.490"></a>
+<span class="sourceLineNo">491</span> QuotaSettingsFactory.throttleTable(tn, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.491"></a>
+<span class="sourceLineNo">492</span> admin.setQuota(settings);<a name="line.492"></a>
+<span class="sourceLineNo">493</span><a name="line.493"></a>
+<span class="sourceLineNo">494</span> // Verify the Quota in the table<a name="line.494"></a>
+<span class="sourceLineNo">495</span> verifyRecordPresentInQuotaTable(ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.495"></a>
+<span class="sourceLineNo">496</span><a name="line.496"></a>
+<span class="sourceLineNo">497</span> // Verify we can retrieve it via the QuotaRetriever API<a name="line.497"></a>
+<span class="sourceLineNo">498</span> verifyFetchableViaAPI(admin, ThrottleType.REQUEST_SIZE, 2L, TimeUnit.HOURS);<a name="line.498"></a>
<span class="sourceLineNo">499</span><a name="line.499"></a>
-<span class="sourceLineNo">500</span> // Verify the new Quota in the table<a name="line.500"></a>
-<span class="sourceLineNo">501</span> verifyRecordPresentInQuotaTable(ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.501"></a>
-<span class="sourceLineNo">502</span><a name="line.502"></a>
-<span class="sourceLineNo">503</span> // Verify we can retrieve the new quota via the QuotaRetriever API<a name="line.503"></a>
-<span class="sourceLineNo">504</span> verifyFetchableViaAPI(admin, ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.504"></a>
-<span class="sourceLineNo">505</span><a name="line.505"></a>
-<span class="sourceLineNo">506</span> // Now, remove the quota<a name="line.506"></a>
-<span class="sourceLineNo">507</span> QuotaSettings removeQuota = QuotaSettingsFactory.unthrottleTable(tn);<a name="line.507"></a>
-<span class="sourceLineNo">508</span> admin.setQuota(removeQuota);<a name="line.508"></a>
-<span class="sourceLineNo">509</span><a name="line.509"></a>
-<span class="sourceLineNo">510</span> // Verify that the record doesn't exist in the table<a name="line.510"></a>
-<span class="sourceLineNo">511</span> verifyRecordNotPresentInQuotaTable();<a name="line.511"></a>
-<span class="sourceLineNo">512</span><a name="line.512"></a>
-<span class="sourceLineNo">513</span> // Verify that we can also not fetch it via the API<a name="line.513"></a>
-<span class="sourceLineNo">514</span> verifyNotFetchableViaAPI(admin);<a name="line.514"></a>
-<span class="sourceLineNo">515</span><a name="line.515"></a>
-<span class="sourceLineNo">516</span> }<a name="line.516"></a>
+<span class="sourceLineNo">500</span> // Setting a limit and time unit should be reflected<a name="line.500"></a>
+<span class="sourceLineNo">501</span> QuotaSettings newSettings =<a name="line.501"></a>
+<span class="sourceLineNo">502</span> QuotaSettingsFactory.throttleTable(tn, ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.502"></a>
+<span class="sourceLineNo">503</span> admin.setQuota(newSettings);<a name="line.503"></a>
+<span class="sourceLineNo">504</span><a name="line.504"></a>
+<span class="sourceLineNo">505</span> // Verify the new Quota in the table<a name="line.505"></a>
+<span class="sourceLineNo">506</span> verifyRecordPresentInQuotaTable(ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.506"></a>
+<span class="sourceLineNo">507</span><a name="line.507"></a>
+<span class="sourceLineNo">508</span> // Verify we can retrieve the new quota via the QuotaRetriever API<a name="line.508"></a>
+<span class="sourceLineNo">509</span> verifyFetchableViaAPI(admin, ThrottleType.REQUEST_SIZE, 3L, TimeUnit.DAYS);<a name="line.509"></a>
+<span class="sourceLineNo">510</span><a name="line.510"></a>
+<span class="sourceLineNo">511</span> // Now, remove the quota<a name="line.511"></a>
+<span class="sourceLineNo">512</span> QuotaSettings removeQuota = QuotaSettingsFactory.unthrottleTable(tn);<a name="line.512"></a>
+<span class="sourceLineNo">513</span> admin.setQuota(removeQuota);<a name="line.513"></a>
+<span class="sourceLineNo">514</span><a name="line.514"></a>
+<span class="sourceLineNo">515</span> // Verify that the record doesn't exist in the table<a name="line.515"></a>
+<span class="sourceLineNo">516</span> verifyRecordNotPresentInQuotaTable();<a name="line.516"></a>
<span class="sourceLineNo">517</span><a name="line.517"></a>
-<span class="sourceLineNo">518</span> private void verifyRecordPresentInQuotaTable(ThrottleType type, long limit, TimeUnit tu)<a name="line.518"></a>
-<span class="sourceLineNo">519</span> throws Exception {<a name="line.519"></a>
-<span class="sourceLineNo">520</span> // Verify the RPC Quotas in the table<a name="line.520"></a>
-<span class="sourceLineNo">521</span> try (Table quotaTable = TEST_UTIL.getConnection().getTable(QuotaTableUtil.QUOTA_TABLE_NAME);<a name="line.521"></a>
-<span class="sourceLineNo">522</span> ResultScanner scanner = quotaTable.getScanner(new Scan())) {<a name="line.522"></a>
-<span class="sourceLineNo">523</span> Result r = Iterables.getOnlyElement(scanner);<a name="line.523"></a>
-<span class="sourceLineNo">524</span> CellScanner cells = r.cellScanner();<a name="line.524"></a>
-<span class="sourceLineNo">525</span> assertTrue("Expected to find a cell", cells.advance());<a name="line.525"></a>
-<span class="sourceLineNo">526</span> assertRPCQuota(type, limit, tu, cells.current());<a name="line.526"></a>
-<span class="sourceLineNo">527</span> }<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> private void verifyRecordNotPresentInQuotaTable() throws Exception {<a name="line.530"></a>
-<span class="sourceLineNo">531</span> // Verify that the record doesn't exist in the QuotaTableUtil.QUOTA_TABLE_NAME<a name="line.531"></a>
-<span class="sourceLineNo">532</span> try (Table quotaTable = TEST_UTIL.getConnection().getTable(QuotaTableUtil.QUOTA_TABLE_NAME);<a name="line.532"></a>
-<span class="sourceLineNo">533</span> ResultScanner scanner = quotaTable.getScanner(new Scan())) {<a name="line.533"></a>
-<span class="sourceLineNo">534</span> assertNull("Did not expect to find a quota entry", scanner.next());<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 verifyFetchableViaAPI(Admin admin, ThrottleType type, long limit, TimeUnit tu)<a name="line.538"></a>
-<span class="sourceLineNo">539</span> throws Exception {<a name="line.539"></a>
-<span class="sourceLineNo">540</span> // Verify we can retrieve the new quota via the QuotaRetriever API<a name="line.540"></a>
-<span class="sourceLineNo">541</span> try (QuotaRetriever quotaScanner = QuotaRetriever.open(admin.getConfiguration())) {<a name="line.541"></a>
-<span class="sourceLineNo">542</span> assertRPCQuota(type, limit, tu, Iterables.getOnlyElement(quotaScanner));<a name="line.542"></a>
-<span class="sourceLineNo">543</span> }<a name="line.543"></a>
-<span class="sourceLineNo">544</span> }<a name="line.544"></a>
-<span class="sourceLineNo">545</span><a name="line.545"></a>
-<span class="sourceLineNo">546</span> private void verifyNotFetchableViaAPI(Admin admin) throws Exception {<a name="line.546"></a>
-<span class="sourceLineNo">547</span> // Verify that we can also not fetch it via the API<a name="line.547"></a>
-<span class="sourceLineNo">548</span> try (QuotaRetriever quotaScanner = QuotaRetriever.open(admin.getConfiguration())) {<a name="line.548"></a>
-<span class="sourceLineNo">549</span> assertNull("Did not expect to find a quota entry", quotaScanner.next());<a name="line.549"></a>
-<span class="sourceLineNo">550</span> }<a name="line.550"></a>
-<span class="sourceLineNo">551</span> }<a name="line.551"></a>
-<span class="sourceLineNo">552</span><a name="line.552"></a>
-<span class="sourceLineNo">553</span> private void assertRPCQuota(ThrottleType type, long limit, TimeUnit tu, Cell cell)<a name="line.553"></a>
-<span class="sourceLineNo">554</span> throws Exception {<a name="line.554"></a>
-<span class="sourceLineNo">555</span> Quotas q = QuotaTableUtil<a name="line.555"></a>
-<span class="sourceLineNo">556</span> .quotasFromData(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength());<a name="line.556"></a>
-<span class="sourceLineNo">557</span> assertTrue("Quota should have rpc quota defined", q.hasThrottle());<a name="line.557"></a>
-<span class="sourceLineNo">558</span><a name="line.558"></a>
-<span class="sourceLineNo">559</span> QuotaProtos.Throttle rpcQuota = q.getThrottle();<a name="line.559"></a>
-<span class="sourceLineNo">560</span> QuotaProtos.TimedQuota t = null;<a name="line.560"></a>
-<span class="sourceLineNo">561</span><a name="line.561"></a>
-<span class="sourceLineNo">562</span> switch (type) {<a name="line.562"></a>
-<span class="sourceLineNo">563</span> case REQUEST_SIZE:<a name="line.563"></a>
-<span class="sourceLineNo">564</span> assertTrue(rpcQuota.hasReqSize());<a name="line.564"></a>
-<span class="sourceLineNo">565</span> t = rpcQuota.getReqSize();<a name="line.565"></a>
-<span class="sourceLineNo">566</span> break;<a name="line.566"></a>
-<span class="sourceLineNo">567</span> case READ_NUMBER:<a name="line.567"></a>
-<span class="sourceLineNo">568</span> assertTrue(rpcQuota.hasReadNum());<a name="line.568"></a>
-<span class="sourceLineNo">569</span> t = rpcQuota.getReadNum();<a name="line.569"></a>
-<span class="sourceLineNo">570</span> break;<a name="line.570"></a>
-<span class="sourceLineNo">571</span> case READ_SIZE:<a name="line.571"></a>
-<span class="sourceLineNo">572</span> assertTrue(rpcQuota.hasReadSize());<a name="line.572"></a>
-<span class="sourceLineNo">573</span> t = rpcQuota.getReadSize();<a name="line.573"></a>
-<span class="sourceLineNo">574</span> break;<a name="line.574"></a>
-<span class="sourceLineNo">575</span> case REQUEST_NUMBER:<a name="line.575"></a>
-<span class="sourceLineNo">576</span> assertTrue(rpcQuota.hasReqNum());<a name="line.576"></a>
-<span class="sourceLineNo">577</span> t = rpcQuota.getReqNum();<a name="line.577"></a>
-<span class="sourceLineNo">578</span> break;<a name="line.578"></a>
-<span class="sourceLineNo">579</span> case WRITE_NUMBER:<a name="line.579"></a>
-<span class="sourceLineNo">580</span> assertTrue(rpcQuota.hasWriteNum());<a name="line.580"></a>
-<span class="sourceLineNo">581</span> t = rpcQuota.getWriteNum();<a name="line.581"></a>
-<span class="sourceLineNo">582</span> break;<a name="line.582"></a>
-<span class="sourceLineNo">583</span> case WRITE_SIZE:<a name="line.583"></a>
-<span class="sourceLineNo">584</span> assertTrue(rpcQuota.hasWriteSize());<a name="line.584"></a>
-<span class="sourceLineNo">585</span> t = rpcQuota.getWriteSize();<a name="line.585"></a>
-<span class="sourceLineNo">586</span> break;<a name="line.586"></a>
-<span class="sourceLineNo">587</span> }<a name="line.587"></a>
-<span class="sourceLineNo">588</span><a name="line.588"></a>
-<span class="sourceLineNo">589</span> assertEquals(t.getSoftLimit(), limit);<a name="line.589"></a>
-<span class="sourceLineNo">590</span> assertEquals(t.getTimeUnit(), ProtobufUtil.toProtoTimeUnit(tu));<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> private void assertRPCQuota(ThrottleType type, long limit, TimeUnit tu,<a name="line.593"></a>
-<span class="sourceLineNo">594</span> QuotaSettings actualSettings) throws Exception {<a name="line.594"></a>
-<span class="sourceLineNo">595</span> assertTrue(<a name="line.595"></a>
-<span class="sourceLineNo">596</span> "The actual QuotaSettings was not an instance of " + ThrottleSettings.class + " but of "<a name="line.596"></a>
-<span class="sourceLineNo">597</span> + actualSettings.getClass(), actualSettings instanceof ThrottleSettings);<a name="line.597"></a>
-<span class="sourceLineNo">598</span> QuotaProtos.ThrottleRequest throttleRequest = ((ThrottleSettings) actualSettings).getProto();<a name="line.598"></a>
-<span class="sourceLineNo">599</span> assertEquals(limit, throttleRequest.getTimedQuota().getSoftLimit());<a name="line.599"></a>
-<span class="sourceLineNo">600</span> assertEquals(ProtobufUtil.toProtoTimeUnit(tu), throttleRequest.getTimedQuota().getTimeUnit());<a name="line.600"></a>
-<span class="sourceLineNo">601</span> assertEquals(ProtobufUtil.toProtoThrottleType(type), throttleRequest.getType());<a name="line.601"></a>
-<span class="sourceLineNo">602</span> }<a name="line.602"></a>
-<span class="sourceLineNo">603</span><a name="line.603"></a>
-<span class="sourceLineNo">604</span> private void assertSpaceQuota(<a name="line.604"></a>
-<span class="sourceLineNo">605</span> long sizeLimit, SpaceViolationPolicy violationPolicy, Cell cell) throws Exception {<a name="line.605"></a>
-<span class="sourceLineNo">606</span> Quotas q = QuotaTableUtil.quotasFromData(<a name="line.606"></a>
-<span class="sourceLineNo">607</span> cell.getValueArray(), cell.getValueOffset(), cell.getValueLength());<a name="line.607"></a>
-<span class="sourceLineNo">608</span> assertTrue("Quota should have space quota defined", q.hasSpace());<a name="line.608"></a>
-<span class="sourceLineNo">609</span> QuotaProtos.SpaceQuota spaceQuota = q.getSpace();<a name="line.609"></a>
-<span class="sourceLineNo">610</span> assertEquals(sizeLimit, spaceQuota.getSoftLimit());<a name="line.610"></a>
-<span class="sourceLineNo">611</span> assertEquals(violationPolicy, ProtobufUtil.toViolationPolicy(spaceQuota.getViolationPolicy()));<a name="line.611"></a>
-<span class="sourceLineNo">612</span> }<a name="line.612"></a>
-<span class="sourceLineNo">613</span><a name="line.613"></a>
-<span class="sourceLineNo">614</span> private void assertSpaceQuota(<a name="line.614"></a>
-<span class="sourceLineNo">615</span> long sizeLimit, SpaceViolationPolicy violationPolicy, QuotaSettings actualSettings) {<a name="line.615"></a>
-<span class="sourceLineNo">616</span> assertTrue("The actual QuotaSettings was not an instance of " + SpaceLimitSettings.class<a name="line.616"></a>
-<span class="sourceLineNo">617</span> + " but of " + actualSettings.getClass(), actualSettings instanceof SpaceLimitSettings);<a name="line.617"></a>
-<span class="sourceLineNo">618</span> SpaceLimitRequest spaceLimitRequest = ((SpaceLimitSettings) actualSettings).getProto();<a name="line.618"></a>
-<span class="sourceLineNo">619</span> assertEquals(sizeLimit, spaceLimitRequest.getQuota().getSoftLimit());<a name="line.619"></a>
-<span class="sourceLineNo">620</span> assertEquals(violationPolicy,<a name="line.620"></a>
-<span class="sourceLineNo">621</span> ProtobufUtil.toViolationPolicy(spaceLimitRequest.getQuota().getViolationPolicy()));<a name="line.621"></a>
-<span class="sourceLineNo">622</span> }<a name="line.622"></a>
-<span class="sourceLineNo">623</span><a name="line.623"></a>
-<span class="sourceLineNo">624</span> private int countResults(final QuotaFilter filter) throws Exception {<a name="line.624"></a>
-<span class="sourceLineNo">625</span> QuotaRetriever scanner = QuotaRetriever.open(TEST_UTIL.getConfiguration(), filter);<a name="line.625"></a>
-<span class="sourceLineNo">626</span> try {<a name="line.626"></a>
-<span class="sourceLineNo">627</span> int count = 0;<a name="line.627"></a>
-<span class="sourceLineNo">628</span> for (QuotaSettings settings: scanner) {<a name="line.628"></a>
-<span class="sourceLineNo">629</span> LOG.debug(Objects.toString(settings));<a name="line.629"></a>
-<span class="sourceLineNo">630</span> count++;<a name="line.630"></a>
-<span class="sourceLineNo">631</span> }<a name="line.631"></a>
-<span class="sourceLineNo">632</span> return count;<a name="line.632"></a>
-<span class="sourceLineNo">633</span> } finally {<a name="line.633"></a>
-<span class="sourceLineNo">634</span> scanner.close();<a name="line.634"></a>
-<span class="sourceLineNo">635</span> }<a name="line.635"></a>
-<span class="sourceLineNo">636</span> }<a name="line.636"></a>
-<span class="sourceLineNo">637</span>}<a name="line.637"></a>
+<span class="sourceLineNo">518</span> // Verify that we can also not fetch it via the API<a name="line.518"></a>
+<span class="sourceLineNo">519</span> verifyNotFetchableViaAPI(admin);<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><a name="line.522"></a>
+<span class="sourceLineNo">523</span> private void verifyRecordPresentInQuotaTable(ThrottleType type, long limit, TimeUnit tu)<a name="line.523"></a>
+<span class="sourceLineNo">524</span> throws Exception {<a name="line.524"></a>
+<span class="sourceLineNo">525</span> // Verify the RPC Quotas in the table<a name="line.525"></a>
+<span class="sourceLineNo">526</span> try (Table quotaTable = TEST_UTIL.getConnection().getTable(QuotaTableUtil.QUOTA_TABLE_NAME);<a name="line.526"></a>
+<span class="sourceLineNo">527</span> ResultScanner scanner = quotaTable.getScanner(new Scan())) {<a name="line.527"></a>
+<span class="sourceLineNo">528</span> Result r = Iterables.getOnlyElement(scanner);<a name="line.528"></a>
+<span class="sourceLineNo">529</span> CellScanner cells = r.cellScanner();<a name="line.529"></a>
+<span class="sourceLineNo">530</span> assertTrue("Expected to find a cell", cells.advance());<a name="line.530"></a>
+<span class="sourceLineNo">531</span> assertRPCQuota(type, limit, tu, cells.current());<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 verifyRecordNotPresentInQuotaTable() throws Exception {<a name="line.535"></a>
+<span class="sourceLineNo">536</span> // Verify that the record doesn't exist in the QuotaTableUtil.QUOTA_TABLE_NAME<a name="line.536"></a>
+<span class="sourceLineNo">537</span> try (Table quotaTable = TEST_UTIL.getConnection().getTable(QuotaTableUtil.QUOTA_TABLE_NAME);<a name="line.537"></a>
+<span class="sourceLineNo">538</span> ResultScanner scanner = quotaTable.getScanner(new Scan())) {<a name="line.538"></a>
+<span class="sourceLineNo">539</span> assertNull("Did not expect to find a quota entry", scanner.next());<a name="line.539"></a>
+<span class="sourceLineNo">540</span> }<a name="line.540"></a>
+<span class="sourceLineNo">541</span> }<a name="line.541"></a>
+<span class="sourceLineNo">542</span><a name="line.542"></a>
+<span class="sourceLineNo">543</span> private void verifyFetchableViaAPI(Admin admin, ThrottleType type, long limit, TimeUnit tu)<a name="line.543"></a>
+<span class="sourceLineNo">544</span> throws Exception {<a name="line.544"></a>
+<span class="sourceLineNo">545</span> // Verify we can retrieve the new quota via the QuotaRetriever API<a name="line.545"></a>
+<span class="sourceLineNo">546</span> try (QuotaRetriever quotaScanner = QuotaRetriever.open(admin.getConfiguration())) {<a name="line.546"></a>
+<span class="sourceLineNo">547</span> assertRPCQuota(type, limit, tu, Iterables.getOnlyElement(quotaScanner));<a name="line.547"></a>
+<span class="sourceLineNo">548</span> }<a name="line.548"></a>
+<span class="sourceLineNo">549</span> }<a name="line.549"></a>
+<span class="sourceLineNo">550</span><a name="line.550"></a>
+<span class="sourceLineNo">551</span> private void verifyNotFetchableViaAPI(Admin admin) throws Exception {<a name="line.551"></a>
+<span class="sourceLineNo">552</span> // Verify that we can also not fetch it via the API<a name="line.552"></a>
+<span class="sourceLineNo">553</span> try (QuotaRetriever quotaScanner = QuotaRetriever.open(admin.getConfiguration())) {<a name="line.553"></a>
+<span class="sourceLineNo">554</span> assertNull("Did not expect to find a quota entry", quotaScanner.next());<a name="line.554"></a>
+<span class="sourceLineNo">555</span> }<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> private void assertRPCQuota(ThrottleType type, long limit, TimeUnit tu, Cell cell)<a name="line.558"></a>
+<span class="sourceLineNo">559</span> throws Exception {<a name="line.559"></a>
+<span class="sourceLineNo">560</span> Quotas q = QuotaTableUtil<a name="line.560"></a>
+<span class="sourceLineNo">561</span> .quotasFromData(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength());<a name="line.561"></a>
+<span class="sourceLineNo">562</span> assertTrue("Quota should have rpc quota defined", q.hasThrottle());<a name="line.562"></a>
+<span class="sourceLineNo">563</span><a name="line.563"></a>
+<span class="sourceLineNo">564</span> QuotaProtos.Throttle rpcQuota = q.getThrottle();<a name="line.564"></a>
+<span class="sourceLineNo">565</span> QuotaProtos.TimedQuota t = null;<a name="line.565"></a>
+<span class="sourceLineNo">566</span><a name="line.566"></a>
+<span class="sourceLineNo">567</span> switch (type) {<a name="line.567"></a>
+<span class="sourceLineNo">568</span> case REQUEST_SIZE:<a name="line.568"></a>
+<span class="sourceLineNo">569</span> assertTrue(rpcQuota.hasReqSize());<a name="line.569"></a>
+<span class="sourceLineNo">570</span> t = rpcQuota.getReqSize();<a name="line.570"></a>
+<span class="sourceLineNo">571</span> break;<a name="line.571"></a>
+<span class="sourceLineNo">572</span> case READ_NUMBER:<a name="line.572"></a>
+<span class="sourceLineNo">573</span> assertTrue(rpcQuota.hasReadNum());<a name="line.573"></a>
+<span class="sourceLineNo">574</span> t = rpcQuota.getReadNum();<a name="line.574"></a>
+<span class="sourceLineNo">575</span> break;<a name="line.575"></a>
+<span class="sourceLineNo">576</span> case READ_SIZE:<a name="line.576"></a>
+<span class="sourceLineNo">577</span> assertTrue(rpcQuota.hasReadSize());<a name="line.577"></a>
+<span class="sourceLineNo">578</span> t = rpcQuota.getReadSize();<a name="line.578"></a>
+<span class="sourceLineNo">579</span> break;<a name="line.579"></a>
+<span class="sourceLineNo">580</span> case REQUEST_NUMBER:<a name="line.580"></a>
+<span class="sourceLineNo">581</span> assertTrue(rpcQuota.hasReqNum());<a name="line.581"></a>
+<span class="sourceLineNo">582</span> t = rpcQuota.getReqNum();<a name="line.582"></a>
+<span class="sourceLineNo">583</span> break;<a name="line.583"></a>
+<span class="sourceLineNo">584</span> case WRITE_NUMBER:<a name="line.584"></a>
+<span class="sourceLineNo">585</span> assertTrue(rpcQuota.hasWriteNum());<a name="line.585"></a>
+<span class="sourceLineNo">586</span> t = rpcQuota.getWriteNum();<a name="line.586"></a>
+<span class="sourceLineNo">587</span> break;<a name="line.587"></a>
+<span class="sourceLineNo">588</span> case WRITE_SIZE:<a name="line.588"></a>
+<span class="sourceLineNo">589</span> assertTrue(rpcQuota.hasWriteSize());<a name="line.589"></a>
+<span class="sourceLineNo">590</span> t = rpcQuota.getWriteSize();<a name="line.590"></a>
+<span class="sourceLineNo">591</span> break;<a name="line.591"></a>
+<span class="sourceLineNo">592</span> case REQUEST_CAPACITY_UNIT:<a name="line.592"></a>
+<span class="sourceLineNo">593</span> assertTrue(rpcQuota.hasReqCapacityUnit());<a name="line.593"></a>
+<span class="sourceLineNo">594</span> t = rpcQuota.getReqCapacityUnit();<a name="line.594"></a>
+<span class="sourceLineNo">595</span> break;<a name="line.595"></a>
+<span class="sourceLineNo">596</span> case READ_CAPACITY_UNIT:<a name="line.596"></a>
+<span class="sourceLineNo">597</span> assertTrue(rpcQuota.hasReadCapacityUnit());<a name="line.597"></a>
+<span class="sourceLineNo">598</span> t = rpcQuota.getReadCapacityUnit();<a name="line.598"></a>
+<span class="sourceLineNo">599</span> break;<a name="line.599"></a>
+<span class="sourceLineNo">600</span> case WRITE_CAPACITY_UNIT:<a name="line.600"></a>
+<span class="sourceLineNo">601</span> assertTrue(rpcQuota.hasWriteCapacityUnit());<a name="line.601"></a>
+<span class="sourceLineNo">602</span> t = rpcQuota.getWriteCapacityUnit();<a name="line.602"></a>
+<span class="sourceLineNo">603</span> break;<a name="line.603"></a>
+<span class="sourceLineNo">604</span> default:<a name="line.604"></a>
+<span class="sourceLineNo">605</span> }<a name="line.605"></a>
+<span class="sourceLineNo">606</span><a name="line.606"></a>
+<span class="sourceLineNo">607</span> assertEquals(t.getSoftLimit(), limit);<a name="line.607"></a>
+<span class="sourceLineNo">608</span> assertEquals(t.getTimeUnit(), ProtobufUtil.toProtoTimeUnit(tu));<a name="line.608"></a>
+<span class="sourceLineNo">609</span> }<a name="line.609"></a>
+<span class="sourceLineNo">610</span><a name="line.610"></a>
+<span class="sourceLineNo">611</span> private void assertRPCQuota(ThrottleType type, long limit, TimeUnit tu,<a name="line.611"></a>
+<span class="sourceLineNo">612</span> QuotaSettings actualSettings) throws Exception {<a name="line.612"></a>
+<span class="sourceLineNo">613</span> assertTrue(<a name="line.613"></a>
+<span class="sourceLineNo">614</span> "The actual QuotaSettings was not an instance of " + ThrottleSettings.class + " but of "<a name="line.614"></a>
+<span class="sourceLineNo">615</span> + actualSettings.getClass(), actualSettings instanceof ThrottleSettings);<a name="line.615"></a>
+<span class="sourceLineNo">616</span> QuotaProtos.ThrottleRequest throttleRequest = ((ThrottleSettings) actualSettings).getProto();<a name="line.616"></a>
+<span class="sourceLineNo">617</span> assertEquals(limit, throttleRequest.getTimedQuota().getSoftLimit());<a name="line.617"></a>
+<span class="sourceLineNo">618</span> assertEquals(ProtobufUtil.toProtoTimeUnit(tu), throttleRequest.getTimedQuota().getTimeUnit());<a name="line.618"></a>
+<span class="sourceLineNo">619</span> assertEquals(ProtobufUtil.toProtoThrottleType(type), throttleRequest.getType());<a name="line.619"></a>
+<span class="sourceLineNo">620</span> }<a name="line.620"></a>
+<span class="sourceLineNo">621</span><a name="line.621"></a>
+<span class="sourceLineNo">622</span> private void assertSpaceQuota(<a name="line.622"></a>
+<span class="sourceLineNo">623</span> long sizeLimit, SpaceViolationPolicy violationPolicy, Cell cell) throws Exception {<a name="line.623"></a>
+<span class="sourceLineNo">624</span> Quotas q = QuotaTableUtil.quotasFromData(<a name="line.624"></a>
+<span class="sourceLineNo">625</span> cell.getValueArray(), cell.getValueOffset(), cell.getValueLength());<a name="line.625"></a>
+<span class="sourceLineNo">626</span> assertTrue("Quota should have space quota defined", q.hasSpace());<a name="line.626"></a>
+<span class="sourceLineNo">627</span> QuotaProtos.SpaceQuota spaceQuota = q.getSpace();<a name="line.627"></a>
+<span class="sourceLineNo">628</span> assertEquals(sizeLimit, spaceQuota.getSoftLimit());<a name="line.628"></a>
+<span class="sourceLineNo">629</span> assertEquals(violationPolicy, ProtobufUtil.toViolationPolicy(spaceQuota.getViolationPolicy()));<a name="line.629"></a>
+<span class="sourceLineNo">630</span> }<a name="line.630"></a>
+<span class="sourceLineNo">631</span><a name="line.631"></a>
+<span class="sourceLineNo">632</span> private void assertSpaceQuota(<a name="line.632"></a>
+<span class="sourceLineNo">633</span> long sizeLimit, SpaceViolationPolicy violationPolicy, QuotaSettings actualSettings) {<a name="line.633"></a>
+<span class="sourceLineNo">634</span> assertTrue("The actual QuotaSettings was not an instance of " + SpaceLimitSettings.class<a name="line.634"></a>
+<span class="sourceLineNo">635</span> + " but of " + actualSettings.getClass(), actualSettings instanceof SpaceLimitSettings);<a name="line.635"></a>
+<span class="sourceLineNo">636</span> SpaceLimitRequest spaceLimitRequest = ((SpaceLimitSettings) actualSettings).getProto();<a name="line.636"></a>
+<span class="sourceLineNo">637</span> assertEquals(sizeLimit, spaceLimitRequest.getQuota().getSoftLimit());<a name="line.637"></a>
+<span class="sourceLineNo">638</span> assertEquals(violationPolicy,<a name="line.638"></a>
+<span class="sourceLineNo">639</span> ProtobufUtil.toViolationPolicy(spaceLimitRequest.getQuota().getViolationPolicy()));<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> private int countResults(final QuotaFilter filter) throws Exception {<a name="line.642"></a>
+<span class="sourceLineNo">643</span> QuotaRetriever scanner = QuotaRetriever.open(TEST_UTIL.getConfiguration(), filter);<a name="line.643"></a>
+<span class="sourceLineNo">644</span> try {<a name="line.644"></a>
+<span class="sourceLineNo">645</span> int count = 0;<a name="line.645"></a>
+<span class="sourceLineNo">646</span> for (QuotaSettings settings: scanner) {<a name="line.646"></a>
+<span class="sourceLineNo">647</span> LOG.debug(Objects.toString(settings));<a name="line.647"></a>
+<span class="sourceLineNo">648</span> count++;<a name="line.648"></a>
+<span class="sourceLineNo">649</span> }<a name="line.649"></a>
+<span class="sourceLineNo">650</span> return count;<a name="line.650"></a>
+<span class="sourceLineNo">651</span> } finally {<a name="line.651"></a>
+<span class="sourceLineNo">652</span> scanner.close();<a name="line.652"></a>
+<span class="sourceLineNo">653</span> }<a name="line.653"></a>
+<span class="sourceLineNo">654</span> }<a name="line.654"></a>
+<span class="sourceLineNo">655</span>}<a name="line.655"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaState.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaState.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaState.html
index efc9af0..a57d5a9 100644
--- a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaState.html
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaState.html
@@ -232,7 +232,7 @@
<span class="sourceLineNo">224</span> assertFalse(quotaInfo.isBypass());<a name="line.224"></a>
<span class="sourceLineNo">225</span> QuotaLimiter limiter = quotaInfo.getTableLimiter(TABLE_A);<a name="line.225"></a>
<span class="sourceLineNo">226</span> try {<a name="line.226"></a>
-<span class="sourceLineNo">227</span> limiter.checkQuota(TABLE_A_THROTTLE_1 + 1, TABLE_A_THROTTLE_1 + 1, 0, 0);<a name="line.227"></a>
+<span class="sourceLineNo">227</span> limiter.checkQuota(TABLE_A_THROTTLE_1 + 1, TABLE_A_THROTTLE_1 + 1, 0, 0, 1, 0);<a name="line.227"></a>
<span class="sourceLineNo">228</span> fail("Should have thrown RpcThrottlingException");<a name="line.228"></a>
<span class="sourceLineNo">229</span> } catch (RpcThrottlingException e) {<a name="line.229"></a>
<span class="sourceLineNo">230</span> // expected<a name="line.230"></a>
@@ -250,7 +250,7 @@
<span class="sourceLineNo">242</span> private void assertThrottleException(final QuotaLimiter limiter, final int availReqs) {<a name="line.242"></a>
<span class="sourceLineNo">243</span> assertNoThrottleException(limiter, availReqs);<a name="line.243"></a>
<span class="sourceLineNo">244</span> try {<a name="line.244"></a>
-<span class="sourceLineNo">245</span> limiter.checkQuota(1, 1, 0, 0);<a name="line.245"></a>
+<span class="sourceLineNo">245</span> limiter.checkQuota(1, 1, 0, 0, 1, 0);<a name="line.245"></a>
<span class="sourceLineNo">246</span> fail("Should have thrown RpcThrottlingException");<a name="line.246"></a>
<span class="sourceLineNo">247</span> } catch (RpcThrottlingException e) {<a name="line.247"></a>
<span class="sourceLineNo">248</span> // expected<a name="line.248"></a>
@@ -260,11 +260,11 @@
<span class="sourceLineNo">252</span> private void assertNoThrottleException(final QuotaLimiter limiter, final int availReqs) {<a name="line.252"></a>
<span class="sourceLineNo">253</span> for (int i = 0; i < availReqs; ++i) {<a name="line.253"></a>
<span class="sourceLineNo">254</span> try {<a name="line.254"></a>
-<span class="sourceLineNo">255</span> limiter.checkQuota(1, 1, 0, 0);<a name="line.255"></a>
+<span class="sourceLineNo">255</span> limiter.checkQuota(1, 1, 0, 0, 1, 0);<a name="line.255"></a>
<span class="sourceLineNo">256</span> } catch (RpcThrottlingException e) {<a name="line.256"></a>
<span class="sourceLineNo">257</span> fail("Unexpected RpcThrottlingException after " + i + " requests. limit=" + availReqs);<a name="line.257"></a>
<span class="sourceLineNo">258</span> }<a name="line.258"></a>
-<span class="sourceLineNo">259</span> limiter.grabQuota(1, 1, 0, 0);<a name="line.259"></a>
+<span class="sourceLineNo">259</span> limiter.grabQuota(1, 1, 0, 0, 1, 0);<a name="line.259"></a>
<span class="sourceLineNo">260</span> }<a name="line.260"></a>
<span class="sourceLineNo">261</span> }<a name="line.261"></a>
<span class="sourceLineNo">262</span><a name="line.262"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
index 28d5840..5cc1086 100644
--- a/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
@@ -517,100 +517,162 @@
<span class="sourceLineNo">509</span> assertEquals(30, doGets(30, tables[1]));<a name="line.509"></a>
<span class="sourceLineNo">510</span> }<a name="line.510"></a>
<span class="sourceLineNo">511</span><a name="line.511"></a>
-<span class="sourceLineNo">512</span> private int doPuts(int maxOps, final Table... tables) throws Exception {<a name="line.512"></a>
-<span class="sourceLineNo">513</span> int count = 0;<a name="line.513"></a>
-<span class="sourceLineNo">514</span> try {<a name="line.514"></a>
-<span class="sourceLineNo">515</span> while (count < maxOps) {<a name="line.515"></a>
-<span class="sourceLineNo">516</span> Put put = new Put(Bytes.toBytes("row-" + count));<a name="line.516"></a>
-<span class="sourceLineNo">517</span> put.addColumn(FAMILY, QUALIFIER, Bytes.toBytes("data-" + count));<a name="line.517"></a>
-<span class="sourceLineNo">518</span> for (final Table table: tables) {<a name="line.518"></a>
-<span class="sourceLineNo">519</span> table.put(put);<a name="line.519"></a>
-<span class="sourceLineNo">520</span> }<a name="line.520"></a>
-<span class="sourceLineNo">521</span> count += tables.length;<a name="line.521"></a>
-<span class="sourceLineNo">522</span> }<a name="line.522"></a>
-<span class="sourceLineNo">523</span> } catch (RpcThrottlingException e) {<a name="line.523"></a>
-<span class="sourceLineNo">524</span> LOG.error("put failed after nRetries=" + count, e);<a name="line.524"></a>
-<span class="sourceLineNo">525</span> }<a name="line.525"></a>
-<span class="sourceLineNo">526</span> return count;<a name="line.526"></a>
-<span class="sourceLineNo">527</span> }<a name="line.527"></a>
+<span class="sourceLineNo">512</span> @Test<a name="line.512"></a>
+<span class="sourceLineNo">513</span> public void testTableWriteCapacityUnitThrottle() throws Exception {<a name="line.513"></a>
+<span class="sourceLineNo">514</span> final Admin admin = TEST_UTIL.getAdmin();<a name="line.514"></a>
+<span class="sourceLineNo">515</span><a name="line.515"></a>
+<span class="sourceLineNo">516</span> // Add 6CU/min limit<a name="line.516"></a>
+<span class="sourceLineNo">517</span> admin.setQuota(QuotaSettingsFactory.throttleTable(TABLE_NAMES[0],<a name="line.517"></a>
+<span class="sourceLineNo">518</span> ThrottleType.WRITE_CAPACITY_UNIT, 6, TimeUnit.MINUTES));<a name="line.518"></a>
+<span class="sourceLineNo">519</span> triggerTableCacheRefresh(false, TABLE_NAMES[0]);<a name="line.519"></a>
+<span class="sourceLineNo">520</span><a name="line.520"></a>
+<span class="sourceLineNo">521</span> // should execute at max 6 capacity units because each put size is 1 capacity unit<a name="line.521"></a>
+<span class="sourceLineNo">522</span> assertEquals(6, doPuts(20, 10, tables[0]));<a name="line.522"></a>
+<span class="sourceLineNo">523</span><a name="line.523"></a>
+<span class="sourceLineNo">524</span> // wait a minute and you should execute at max 3 capacity units because each put size is 2<a name="line.524"></a>
+<span class="sourceLineNo">525</span> // capacity unit<a name="line.525"></a>
+<span class="sourceLineNo">526</span> waitMinuteQuota();<a name="line.526"></a>
+<span class="sourceLineNo">527</span> assertEquals(3, doPuts(20, 1025, tables[0]));<a name="line.527"></a>
<span class="sourceLineNo">528</span><a name="line.528"></a>
-<span class="sourceLineNo">529</span> private long doGets(int maxOps, final Table... tables) throws Exception {<a name="line.529"></a>
-<span class="sourceLineNo">530</span> int count = 0;<a name="line.530"></a>
-<span class="sourceLineNo">531</span> try {<a name="line.531"></a>
-<span class="sourceLineNo">532</span> while (count < maxOps) {<a name="line.532"></a>
-<span class="sourceLineNo">533</span> Get get = new Get(Bytes.toBytes("row-" + count));<a name="line.533"></a>
-<span class="sourceLineNo">534</span> for (final Table table: tables) {<a name="line.534"></a>
-<span class="sourceLineNo">535</span> table.get(get);<a name="line.535"></a>
-<span class="sourceLineNo">536</span> }<a name="line.536"></a>
-<span class="sourceLineNo">537</span> count += tables.length;<a name="line.537"></a>
-<span class="sourceLineNo">538</span> }<a name="line.538"></a>
-<span class="sourceLineNo">539</span> } catch (RpcThrottlingException e) {<a name="line.539"></a>
-<span class="sourceLineNo">540</span> LOG.error("get failed after nRetries=" + count, e);<a name="line.540"></a>
-<span class="sourceLineNo">541</span> }<a name="line.541"></a>
-<span class="sourceLineNo">542</span> return count;<a name="line.542"></a>
-<span class="sourceLineNo">543</span> }<a name="line.543"></a>
-<span class="sourceLineNo">544</span><a name="line.544"></a>
-<span class="sourceLineNo">545</span> private void triggerUserCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.545"></a>
-<span class="sourceLineNo">546</span> triggerCacheRefresh(bypass, true, false, false, tables);<a name="line.546"></a>
-<span class="sourceLineNo">547</span> }<a name="line.547"></a>
-<span class="sourceLineNo">548</span><a name="line.548"></a>
-<span class="sourceLineNo">549</span> private void triggerTableCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.549"></a>
-<span class="sourceLineNo">550</span> triggerCacheRefresh(bypass, false, true, false, tables);<a name="line.550"></a>
-<span class="sourceLineNo">551</span> }<a name="line.551"></a>
-<span class="sourceLineNo">552</span><a name="line.552"></a>
-<span class="sourceLineNo">553</span> private void triggerNamespaceCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.553"></a>
-<span class="sourceLineNo">554</span> triggerCacheRefresh(bypass, false, false, true, tables);<a name="line.554"></a>
-<span class="sourceLineNo">555</span> }<a name="line.555"></a>
-<span class="sourceLineNo">556</span><a name="line.556"></a>
-<span class="sourceLineNo">557</span> private void triggerCacheRefresh(boolean bypass, boolean userLimiter, boolean tableLimiter,<a name="line.557"></a>
-<span class="sourceLineNo">558</span> boolean nsLimiter, final TableName... tables) throws Exception {<a name="line.558"></a>
-<span class="sourceLineNo">559</span> envEdge.incValue(2 * REFRESH_TIME);<a name="line.559"></a>
-<span class="sourceLineNo">560</span> for (RegionServerThread rst: TEST_UTIL.getMiniHBaseCluster().getRegionServerThreads()) {<a name="line.560"></a>
-<span class="sourceLineNo">561</span> RegionServerRpcQuotaManager quotaManager = rst.getRegionServer().getRegionServerRpcQuotaManager();<a name="line.561"></a>
-<span class="sourceLineNo">562</span> QuotaCache quotaCache = quotaManager.getQuotaCache();<a name="line.562"></a>
-<span class="sourceLineNo">563</span><a name="line.563"></a>
-<span class="sourceLineNo">564</span> quotaCache.triggerCacheRefresh();<a name="line.564"></a>
-<span class="sourceLineNo">565</span> // sleep for cache update<a name="line.565"></a>
-<span class="sourceLineNo">566</span> Thread.sleep(250);<a name="line.566"></a>
-<span class="sourceLineNo">567</span><a name="line.567"></a>
-<span class="sourceLineNo">568</span> for (TableName table: tables) {<a name="line.568"></a>
-<span class="sourceLineNo">569</span> quotaCache.getTableLimiter(table);<a name="line.569"></a>
-<span class="sourceLineNo">570</span> }<a name="line.570"></a>
-<span class="sourceLineNo">571</span><a name="line.571"></a>
-<span class="sourceLineNo">572</span> boolean isUpdated = false;<a name="line.572"></a>
-<span class="sourceLineNo">573</span> while (!isUpdated) {<a name="line.573"></a>
-<span class="sourceLineNo">574</span> quotaCache.triggerCacheRefresh();<a name="line.574"></a>
-<span class="sourceLineNo">575</span> isUpdated = true;<a name="line.575"></a>
-<span class="sourceLineNo">576</span> for (TableName table: tables) {<a name="line.576"></a>
-<span class="sourceLineNo">577</span> boolean isBypass = true;<a name="line.577"></a>
-<span class="sourceLineNo">578</span> if (userLimiter) {<a name="line.578"></a>
-<span class="sourceLineNo">579</span> isBypass &= quotaCache.getUserLimiter(User.getCurrent().getUGI(), table).isBypass();<a name="line.579"></a>
-<span class="sourceLineNo">580</span> }<a name="line.580"></a>
-<span class="sourceLineNo">581</span> if (tableLimiter) {<a name="line.581"></a>
-<span class="sourceLineNo">582</span> isBypass &= quotaCache.getTableLimiter(table).isBypass();<a name="line.582"></a>
-<span class="sourceLineNo">583</span> }<a name="line.583"></a>
-<span class="sourceLineNo">584</span> if (nsLimiter) {<a name="line.584"></a>
-<span class="sourceLineNo">585</span> isBypass &= quotaCache.getNamespaceLimiter(table.getNamespaceAsString()).isBypass();<a name="line.585"></a>
-<span class="sourceLineNo">586</span> }<a name="line.586"></a>
-<span class="sourceLineNo">587</span> if (isBypass != bypass) {<a name="line.587"></a>
-<span class="sourceLineNo">588</span> envEdge.incValue(100);<a name="line.588"></a>
-<span class="sourceLineNo">589</span> isUpdated = false;<a name="line.589"></a>
-<span class="sourceLineNo">590</span> break;<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> LOG.debug("QuotaCache");<a name="line.595"></a>
-<span class="sourceLineNo">596</span> LOG.debug(Objects.toString(quotaCache.getNamespaceQuotaCache()));<a name="line.596"></a>
-<span class="sourceLineNo">597</span> LOG.debug(Objects.toString(quotaCache.getTableQuotaCache()));<a name="line.597"></a>
-<span class="sourceLineNo">598</span> LOG.debug(Objects.toString(quotaCache.getUserQuotaCache()));<a name="line.598"></a>
-<span class="sourceLineNo">599</span> }<a name="line.599"></a>
-<span class="sourceLineNo">600</span> }<a name="line.600"></a>
-<span class="sourceLineNo">601</span><a name="line.601"></a>
-<span class="sourceLineNo">602</span> private void waitMinuteQuota() {<a name="line.602"></a>
-<span class="sourceLineNo">603</span> envEdge.incValue(70000);<a name="line.603"></a>
-<span class="sourceLineNo">604</span> }<a name="line.604"></a>
-<span class="sourceLineNo">605</span>}<a name="line.605"></a>
+<span class="sourceLineNo">529</span> admin.setQuota(QuotaSettingsFactory.unthrottleTable(TABLE_NAMES[0]));<a name="line.529"></a>
+<span class="sourceLineNo">530</span> triggerTableCacheRefresh(true, TABLE_NAMES[0]);<a name="line.530"></a>
+<span class="sourceLineNo">531</span> }<a name="line.531"></a>
+<span class="sourceLineNo">532</span><a name="line.532"></a>
+<span class="sourceLineNo">533</span> @Test<a name="line.533"></a>
+<span class="sourceLineNo">534</span> public void testTableReadCapacityUnitThrottle() throws Exception {<a name="line.534"></a>
+<span class="sourceLineNo">535</span> final Admin admin = TEST_UTIL.getAdmin();<a name="line.535"></a>
+<span class="sourceLineNo">536</span><a name="line.536"></a>
+<span class="sourceLineNo">537</span> // Add 6CU/min limit<a name="line.537"></a>
+<span class="sourceLineNo">538</span> admin.setQuota(QuotaSettingsFactory.throttleTable(TABLE_NAMES[0],<a name="line.538"></a>
+<span class="sourceLineNo">539</span> ThrottleType.READ_CAPACITY_UNIT, 6, TimeUnit.MINUTES));<a name="line.539"></a>
+<span class="sourceLineNo">540</span> triggerTableCacheRefresh(false, TABLE_NAMES[0]);<a name="line.540"></a>
+<span class="sourceLineNo">541</span><a name="line.541"></a>
+<span class="sourceLineNo">542</span> assertEquals(20, doPuts(20, 10, tables[0]));<a name="line.542"></a>
+<span class="sourceLineNo">543</span> // should execute at max 6 capacity units because each get size is 1 capacity unit<a name="line.543"></a>
+<span class="sourceLineNo">544</span> assertEquals(6, doGets(20, tables[0]));<a name="line.544"></a>
+<span class="sourceLineNo">545</span><a name="line.545"></a>
+<span class="sourceLineNo">546</span> assertEquals(20, doPuts(20, 2015, tables[0]));<a name="line.546"></a>
+<span class="sourceLineNo">547</span> // wait a minute and you should execute at max 3 capacity units because each get size is 2<a name="line.547"></a>
+<span class="sourceLineNo">548</span> // capacity unit on tables[0]<a name="line.548"></a>
+<span class="sourceLineNo">549</span> waitMinuteQuota();<a name="line.549"></a>
+<span class="sourceLineNo">550</span> assertEquals(3, doGets(20, tables[0]));<a name="line.550"></a>
+<span class="sourceLineNo">551</span><a name="line.551"></a>
+<span class="sourceLineNo">552</span> admin.setQuota(QuotaSettingsFactory.unthrottleTable(TABLE_NAMES[0]));<a name="line.552"></a>
+<span class="sourceLineNo">553</span> triggerTableCacheRefresh(true, TABLE_NAMES[0]);<a name="line.553"></a>
+<span class="sourceLineNo">554</span> }<a name="line.554"></a>
+<span class="sourceLineNo">555</span><a name="line.555"></a>
+<span class="sourceLineNo">556</span> private int doPuts(int maxOps, final Table... tables) throws Exception {<a name="line.556"></a>
+<span class="sourceLineNo">557</span> return doPuts(maxOps, -1, tables);<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> private int doPuts(int maxOps, int valueSize, final Table... tables) throws Exception {<a name="line.560"></a>
+<span class="sourceLineNo">561</span> int count = 0;<a name="line.561"></a>
+<span class="sourceLineNo">562</span> try {<a name="line.562"></a>
+<span class="sourceLineNo">563</span> while (count < maxOps) {<a name="line.563"></a>
+<span class="sourceLineNo">564</span> Put put = new Put(Bytes.toBytes("row-" + count));<a name="line.564"></a>
+<span class="sourceLineNo">565</span> byte[] value;<a name="line.565"></a>
+<span class="sourceLineNo">566</span> if (valueSize < 0) {<a name="line.566"></a>
+<span class="sourceLineNo">567</span> value = Bytes.toBytes("data-" + count);<a name="line.567"></a>
+<span class="sourceLineNo">568</span> } else {<a name="line.568"></a>
+<span class="sourceLineNo">569</span> value = generateValue(valueSize);<a name="line.569"></a>
+<span class="sourceLineNo">570</span> }<a name="line.570"></a>
+<span class="sourceLineNo">571</span> put.addColumn(FAMILY, QUALIFIER, value);<a name="line.571"></a>
+<span class="sourceLineNo">572</span> for (final Table table : tables) {<a name="line.572"></a>
+<span class="sourceLineNo">573</span> table.put(put);<a name="line.573"></a>
+<span class="sourceLineNo">574</span> }<a name="line.574"></a>
+<span class="sourceLineNo">575</span> count += tables.length;<a name="line.575"></a>
+<span class="sourceLineNo">576</span> }<a name="line.576"></a>
+<span class="sourceLineNo">577</span> } catch (RpcThrottlingException e) {<a name="line.577"></a>
+<span class="sourceLineNo">578</span> LOG.error("put failed after nRetries=" + count, e);<a name="line.578"></a>
+<span class="sourceLineNo">579</span> }<a name="line.579"></a>
+<span class="sourceLineNo">580</span> return count;<a name="line.580"></a>
+<span class="sourceLineNo">581</span> }<a name="line.581"></a>
+<span class="sourceLineNo">582</span><a name="line.582"></a>
+<span class="sourceLineNo">583</span> private byte[] generateValue(int valueSize) {<a name="line.583"></a>
+<span class="sourceLineNo">584</span> byte[] bytes = new byte[valueSize];<a name="line.584"></a>
+<span class="sourceLineNo">585</span> for (int i = 0; i < valueSize; i++) {<a name="line.585"></a>
+<span class="sourceLineNo">586</span> bytes[i] = 'a';<a name="line.586"></a>
+<span class="sourceLineNo">587</span> }<a name="line.587"></a>
+<span class="sourceLineNo">588</span> return bytes;<a name="line.588"></a>
+<span class="sourceLineNo">589</span> }<a name="line.589"></a>
+<span class="sourceLineNo">590</span><a name="line.590"></a>
+<span class="sourceLineNo">591</span> private long doGets(int maxOps, final Table... tables) throws Exception {<a name="line.591"></a>
+<span class="sourceLineNo">592</span> int count = 0;<a name="line.592"></a>
+<span class="sourceLineNo">593</span> try {<a name="line.593"></a>
+<span class="sourceLineNo">594</span> while (count < maxOps) {<a name="line.594"></a>
+<span class="sourceLineNo">595</span> Get get = new Get(Bytes.toBytes("row-" + count));<a name="line.595"></a>
+<span class="sourceLineNo">596</span> for (final Table table: tables) {<a name="line.596"></a>
+<span class="sourceLineNo">597</span> table.get(get);<a name="line.597"></a>
+<span class="sourceLineNo">598</span> }<a name="line.598"></a>
+<span class="sourceLineNo">599</span> count += tables.length;<a name="line.599"></a>
+<span class="sourceLineNo">600</span> }<a name="line.600"></a>
+<span class="sourceLineNo">601</span> } catch (RpcThrottlingException e) {<a name="line.601"></a>
+<span class="sourceLineNo">602</span> LOG.error("get failed after nRetries=" + count, e);<a name="line.602"></a>
+<span class="sourceLineNo">603</span> }<a name="line.603"></a>
+<span class="sourceLineNo">604</span> return count;<a name="line.604"></a>
+<span class="sourceLineNo">605</span> }<a name="line.605"></a>
+<span class="sourceLineNo">606</span><a name="line.606"></a>
+<span class="sourceLineNo">607</span> private void triggerUserCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.607"></a>
+<span class="sourceLineNo">608</span> triggerCacheRefresh(bypass, true, false, false, tables);<a name="line.608"></a>
+<span class="sourceLineNo">609</span> }<a name="line.609"></a>
+<span class="sourceLineNo">610</span><a name="line.610"></a>
+<span class="sourceLineNo">611</span> private void triggerTableCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.611"></a>
+<span class="sourceLineNo">612</span> triggerCacheRefresh(bypass, false, true, false, tables);<a name="line.612"></a>
+<span class="sourceLineNo">613</span> }<a name="line.613"></a>
+<span class="sourceLineNo">614</span><a name="line.614"></a>
+<span class="sourceLineNo">615</span> private void triggerNamespaceCacheRefresh(boolean bypass, TableName... tables) throws Exception {<a name="line.615"></a>
+<span class="sourceLineNo">616</span> triggerCacheRefresh(bypass, false, false, true, tables);<a name="line.616"></a>
+<span class="sourceLineNo">617</span> }<a name="line.617"></a>
+<span class="sourceLineNo">618</span><a name="line.618"></a>
+<span class="sourceLineNo">619</span> private void triggerCacheRefresh(boolean bypass, boolean userLimiter, boolean tableLimiter,<a name="line.619"></a>
+<span class="sourceLineNo">620</span> boolean nsLimiter, final TableName... tables) throws Exception {<a name="line.620"></a>
+<span class="sourceLineNo">621</span> envEdge.incValue(2 * REFRESH_TIME);<a name="line.621"></a>
+<span class="sourceLineNo">622</span> for (RegionServerThread rst: TEST_UTIL.getMiniHBaseCluster().getRegionServerThreads()) {<a name="line.622"></a>
+<span class="sourceLineNo">623</span> RegionServerRpcQuotaManager quotaManager = rst.getRegionServer().getRegionServerRpcQuotaManager();<a name="line.623"></a>
+<span class="sourceLineNo">624</span> QuotaCache quotaCache = quotaManager.getQuotaCache();<a name="line.624"></a>
+<span class="sourceLineNo">625</span><a name="line.625"></a>
+<span class="sourceLineNo">626</span> quotaCache.triggerCacheRefresh();<a name="line.626"></a>
+<span class="sourceLineNo">627</span> // sleep for cache update<a name="line.627"></a>
+<span class="sourceLineNo">628</span> Thread.sleep(250);<a name="line.628"></a>
+<span class="sourceLineNo">629</span><a name="line.629"></a>
+<span class="sourceLineNo">630</span> for (TableName table: tables) {<a name="line.630"></a>
+<span class="sourceLineNo">631</span> quotaCache.getTableLimiter(table);<a name="line.631"></a>
+<span class="sourceLineNo">632</span> }<a name="line.632"></a>
+<span class="sourceLineNo">633</span><a name="line.633"></a>
+<span class="sourceLineNo">634</span> boolean isUpdated = false;<a name="line.634"></a>
+<span class="sourceLineNo">635</span> while (!isUpdated) {<a name="line.635"></a>
+<span class="sourceLineNo">636</span> quotaCache.triggerCacheRefresh();<a name="line.636"></a>
+<span class="sourceLineNo">637</span> isUpdated = true;<a name="line.637"></a>
+<span class="sourceLineNo">638</span> for (TableName table: tables) {<a name="line.638"></a>
+<span class="sourceLineNo">639</span> boolean isBypass = true;<a name="line.639"></a>
+<span class="sourceLineNo">640</span> if (userLimiter) {<a name="line.640"></a>
+<span class="sourceLineNo">641</span> isBypass &= quotaCache.getUserLimiter(User.getCurrent().getUGI(), table).isBypass();<a name="line.641"></a>
+<span class="sourceLineNo">642</span> }<a name="line.642"></a>
+<span class="sourceLineNo">643</span> if (tableLimiter) {<a name="line.643"></a>
+<span class="sourceLineNo">644</span> isBypass &= quotaCache.getTableLimiter(table).isBypass();<a name="line.644"></a>
+<span class="sourceLineNo">645</span> }<a name="line.645"></a>
+<span class="sourceLineNo">646</span> if (nsLimiter) {<a name="line.646"></a>
+<span class="sourceLineNo">647</span> isBypass &= quotaCache.getNamespaceLimiter(table.getNamespaceAsString()).isBypass();<a name="line.647"></a>
+<span class="sourceLineNo">648</span> }<a name="line.648"></a>
+<span class="sourceLineNo">649</span> if (isBypass != bypass) {<a name="line.649"></a>
+<span class="sourceLineNo">650</span> envEdge.incValue(100);<a name="line.650"></a>
+<span class="sourceLineNo">651</span> isUpdated = false;<a name="line.651"></a>
+<span class="sourceLineNo">652</span> break;<a name="line.652"></a>
+<span class="sourceLineNo">653</span> }<a name="line.653"></a>
+<span class="sourceLineNo">654</span> }<a name="line.654"></a>
+<span class="sourceLineNo">655</span> }<a name="line.655"></a>
+<span class="sourceLineNo">656</span><a name="line.656"></a>
+<span class="sourceLineNo">657</span> LOG.debug("QuotaCache");<a name="line.657"></a>
+<span class="sourceLineNo">658</span> LOG.debug(Objects.toString(quotaCache.getNamespaceQuotaCache()));<a name="line.658"></a>
+<span class="sourceLineNo">659</span> LOG.debug(Objects.toString(quotaCache.getTableQuotaCache()));<a name="line.659"></a>
+<span class="sourceLineNo">660</span> LOG.debug(Objects.toString(quotaCache.getUserQuotaCache()));<a name="line.660"></a>
+<span class="sourceLineNo">661</span> }<a name="line.661"></a>
+<span class="sourceLineNo">662</span> }<a name="line.662"></a>
+<span class="sourceLineNo">663</span><a name="line.663"></a>
+<span class="sourceLineNo">664</span> private void waitMinuteQuota() {<a name="line.664"></a>
+<span class="sourceLineNo">665</span> envEdge.incValue(70000);<a name="line.665"></a>
+<span class="sourceLineNo">666</span> }<a name="line.666"></a>
+<span class="sourceLineNo">667</span>}<a name="line.667"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
new file mode 100644
index 0000000..84c709c
--- /dev/null
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
@@ -0,0 +1,150 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<html lang="en">
+<head>
+<title>Source code</title>
+<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
+</head>
+<body>
+<div class="sourceContainer">
+<pre><span class="sourceLineNo">001</span>/**<a name="line.1"></a>
+<span class="sourceLineNo">002</span> * Licensed to the Apache Software Foundation (ASF) under one<a name="line.2"></a>
+<span class="sourceLineNo">003</span> * or more contributor license agreements. See the NOTICE file<a name="line.3"></a>
+<span class="sourceLineNo">004</span> * distributed with this work for additional information<a name="line.4"></a>
+<span class="sourceLineNo">005</span> * regarding copyright ownership. The ASF licenses this file<a name="line.5"></a>
+<span class="sourceLineNo">006</span> * to you under the Apache License, Version 2.0 (the<a name="line.6"></a>
+<span class="sourceLineNo">007</span> * "License"); you may not use this file except in compliance<a name="line.7"></a>
+<span class="sourceLineNo">008</span> * with the License. You may obtain a copy of the License at<a name="line.8"></a>
+<span class="sourceLineNo">009</span> *<a name="line.9"></a>
+<span class="sourceLineNo">010</span> * http://www.apache.org/licenses/LICENSE-2.0<a name="line.10"></a>
+<span class="sourceLineNo">011</span> *<a name="line.11"></a>
+<span class="sourceLineNo">012</span> * Unless required by applicable law or agreed to in writing, software<a name="line.12"></a>
+<span class="sourceLineNo">013</span> * distributed under the License is distributed on an "AS IS" BASIS,<a name="line.13"></a>
+<span class="sourceLineNo">014</span> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<a name="line.14"></a>
+<span class="sourceLineNo">015</span> * See the License for the specific language governing permissions and<a name="line.15"></a>
+<span class="sourceLineNo">016</span> * limitations under the License.<a name="line.16"></a>
+<span class="sourceLineNo">017</span> */<a name="line.17"></a>
+<span class="sourceLineNo">018</span>package org.apache.hadoop.hbase.wal;<a name="line.18"></a>
+<span class="sourceLineNo">019</span><a name="line.19"></a>
+<span class="sourceLineNo">020</span>import static org.junit.Assert.assertNotNull;<a name="line.20"></a>
+<span class="sourceLineNo">021</span>import static org.junit.Assert.assertSame;<a name="line.21"></a>
+<span class="sourceLineNo">022</span><a name="line.22"></a>
+<span class="sourceLineNo">023</span>import java.io.IOException;<a name="line.23"></a>
+<span class="sourceLineNo">024</span>import java.util.List;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import java.util.concurrent.ExecutionException;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import java.util.concurrent.ForkJoinPool;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import java.util.concurrent.Future;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.conf.Configuration;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.HBaseClassTestRule;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.testclassification.RegionServerTests;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.testclassification.SmallTests;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.junit.ClassRule;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.junit.Test;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.junit.experimental.categories.Category;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.mockito.Mockito;<a name="line.37"></a>
+<span class="sourceLineNo">038</span><a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.apache.hbase.thirdparty.com.google.common.collect.Iterables;<a name="line.39"></a>
+<span class="sourceLineNo">040</span><a name="line.40"></a>
+<span class="sourceLineNo">041</span>/**<a name="line.41"></a>
+<span class="sourceLineNo">042</span> * Testcase for HBASE-21503.<a name="line.42"></a>
+<span class="sourceLineNo">043</span> */<a name="line.43"></a>
+<span class="sourceLineNo">044</span>@Category({ RegionServerTests.class, SmallTests.class })<a name="line.44"></a>
+<span class="sourceLineNo">045</span>public class TestRaceBetweenGetWALAndGetWALs {<a name="line.45"></a>
+<span class="sourceLineNo">046</span><a name="line.46"></a>
+<span class="sourceLineNo">047</span> @ClassRule<a name="line.47"></a>
+<span class="sourceLineNo">048</span> public static final HBaseClassTestRule CLASS_RULE =<a name="line.48"></a>
+<span class="sourceLineNo">049</span> HBaseClassTestRule.forClass(TestRaceBetweenGetWALAndGetWALs.class);<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span> private static Future<List<WAL>> GET_WALS_FUTURE;<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span> private static final class FSWALProvider extends AbstractFSWALProvider<AbstractFSWAL<?>> {<a name="line.53"></a>
+<span class="sourceLineNo">054</span><a name="line.54"></a>
+<span class="sourceLineNo">055</span> @Override<a name="line.55"></a>
+<span class="sourceLineNo">056</span> protected AbstractFSWAL<?> createWAL() throws IOException {<a name="line.56"></a>
+<span class="sourceLineNo">057</span> // just like what may do in the WALListeners, schedule an asynchronous task to call the<a name="line.57"></a>
+<span class="sourceLineNo">058</span> // getWALs method.<a name="line.58"></a>
+<span class="sourceLineNo">059</span> GET_WALS_FUTURE = ForkJoinPool.commonPool().submit(this::getWALs);<a name="line.59"></a>
+<span class="sourceLineNo">060</span> // sleep a while to make the getWALs arrive before we return<a name="line.60"></a>
+<span class="sourceLineNo">061</span> Threads.sleep(2000);<a name="line.61"></a>
+<span class="sourceLineNo">062</span> return Mockito.mock(AbstractFSWAL.class);<a name="line.62"></a>
+<span class="sourceLineNo">063</span> }<a name="line.63"></a>
+<span class="sourceLineNo">064</span><a name="line.64"></a>
+<span class="sourceLineNo">065</span> @Override<a name="line.65"></a>
+<span class="sourceLineNo">066</span> protected void doInit(Configuration conf) throws IOException {<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><a name="line.69"></a>
+<span class="sourceLineNo">070</span> @Test<a name="line.70"></a>
+<span class="sourceLineNo">071</span> public void testRace() throws IOException, InterruptedException, ExecutionException {<a name="line.71"></a>
+<span class="sourceLineNo">072</span> FSWALProvider p = new FSWALProvider();<a name="line.72"></a>
+<span class="sourceLineNo">073</span> WAL wal = p.getWAL(null);<a name="line.73"></a>
+<span class="sourceLineNo">074</span> assertNotNull(GET_WALS_FUTURE);<a name="line.74"></a>
+<span class="sourceLineNo">075</span> List<WAL> wals = GET_WALS_FUTURE.get();<a name="line.75"></a>
+<span class="sourceLineNo">076</span> assertSame(wal, Iterables.getOnlyElement(wals));<a name="line.76"></a>
+<span class="sourceLineNo">077</span> }<a name="line.77"></a>
+<span class="sourceLineNo">078</span>}<a name="line.78"></a>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</pre>
+</div>
+</body>
+</html>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html b/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
new file mode 100644
index 0000000..84c709c
--- /dev/null
+++ b/testdevapidocs/src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
@@ -0,0 +1,150 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<html lang="en">
+<head>
+<title>Source code</title>
+<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
+</head>
+<body>
+<div class="sourceContainer">
+<pre><span class="sourceLineNo">001</span>/**<a name="line.1"></a>
+<span class="sourceLineNo">002</span> * Licensed to the Apache Software Foundation (ASF) under one<a name="line.2"></a>
+<span class="sourceLineNo">003</span> * or more contributor license agreements. See the NOTICE file<a name="line.3"></a>
+<span class="sourceLineNo">004</span> * distributed with this work for additional information<a name="line.4"></a>
+<span class="sourceLineNo">005</span> * regarding copyright ownership. The ASF licenses this file<a name="line.5"></a>
+<span class="sourceLineNo">006</span> * to you under the Apache License, Version 2.0 (the<a name="line.6"></a>
+<span class="sourceLineNo">007</span> * "License"); you may not use this file except in compliance<a name="line.7"></a>
+<span class="sourceLineNo">008</span> * with the License. You may obtain a copy of the License at<a name="line.8"></a>
+<span class="sourceLineNo">009</span> *<a name="line.9"></a>
+<span class="sourceLineNo">010</span> * http://www.apache.org/licenses/LICENSE-2.0<a name="line.10"></a>
+<span class="sourceLineNo">011</span> *<a name="line.11"></a>
+<span class="sourceLineNo">012</span> * Unless required by applicable law or agreed to in writing, software<a name="line.12"></a>
+<span class="sourceLineNo">013</span> * distributed under the License is distributed on an "AS IS" BASIS,<a name="line.13"></a>
+<span class="sourceLineNo">014</span> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<a name="line.14"></a>
+<span class="sourceLineNo">015</span> * See the License for the specific language governing permissions and<a name="line.15"></a>
+<span class="sourceLineNo">016</span> * limitations under the License.<a name="line.16"></a>
+<span class="sourceLineNo">017</span> */<a name="line.17"></a>
+<span class="sourceLineNo">018</span>package org.apache.hadoop.hbase.wal;<a name="line.18"></a>
+<span class="sourceLineNo">019</span><a name="line.19"></a>
+<span class="sourceLineNo">020</span>import static org.junit.Assert.assertNotNull;<a name="line.20"></a>
+<span class="sourceLineNo">021</span>import static org.junit.Assert.assertSame;<a name="line.21"></a>
+<span class="sourceLineNo">022</span><a name="line.22"></a>
+<span class="sourceLineNo">023</span>import java.io.IOException;<a name="line.23"></a>
+<span class="sourceLineNo">024</span>import java.util.List;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import java.util.concurrent.ExecutionException;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import java.util.concurrent.ForkJoinPool;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import java.util.concurrent.Future;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.apache.hadoop.conf.Configuration;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.HBaseClassTestRule;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.30"></a>
+<span class="sourceLineNo">031</span>import org.apache.hadoop.hbase.testclassification.RegionServerTests;<a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.hbase.testclassification.SmallTests;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.hbase.util.Threads;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.junit.ClassRule;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.junit.Test;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.junit.experimental.categories.Category;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.mockito.Mockito;<a name="line.37"></a>
+<span class="sourceLineNo">038</span><a name="line.38"></a>
+<span class="sourceLineNo">039</span>import org.apache.hbase.thirdparty.com.google.common.collect.Iterables;<a name="line.39"></a>
+<span class="sourceLineNo">040</span><a name="line.40"></a>
+<span class="sourceLineNo">041</span>/**<a name="line.41"></a>
+<span class="sourceLineNo">042</span> * Testcase for HBASE-21503.<a name="line.42"></a>
+<span class="sourceLineNo">043</span> */<a name="line.43"></a>
+<span class="sourceLineNo">044</span>@Category({ RegionServerTests.class, SmallTests.class })<a name="line.44"></a>
+<span class="sourceLineNo">045</span>public class TestRaceBetweenGetWALAndGetWALs {<a name="line.45"></a>
+<span class="sourceLineNo">046</span><a name="line.46"></a>
+<span class="sourceLineNo">047</span> @ClassRule<a name="line.47"></a>
+<span class="sourceLineNo">048</span> public static final HBaseClassTestRule CLASS_RULE =<a name="line.48"></a>
+<span class="sourceLineNo">049</span> HBaseClassTestRule.forClass(TestRaceBetweenGetWALAndGetWALs.class);<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span> private static Future<List<WAL>> GET_WALS_FUTURE;<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span> private static final class FSWALProvider extends AbstractFSWALProvider<AbstractFSWAL<?>> {<a name="line.53"></a>
+<span class="sourceLineNo">054</span><a name="line.54"></a>
+<span class="sourceLineNo">055</span> @Override<a name="line.55"></a>
+<span class="sourceLineNo">056</span> protected AbstractFSWAL<?> createWAL() throws IOException {<a name="line.56"></a>
+<span class="sourceLineNo">057</span> // just like what may do in the WALListeners, schedule an asynchronous task to call the<a name="line.57"></a>
+<span class="sourceLineNo">058</span> // getWALs method.<a name="line.58"></a>
+<span class="sourceLineNo">059</span> GET_WALS_FUTURE = ForkJoinPool.commonPool().submit(this::getWALs);<a name="line.59"></a>
+<span class="sourceLineNo">060</span> // sleep a while to make the getWALs arrive before we return<a name="line.60"></a>
+<span class="sourceLineNo">061</span> Threads.sleep(2000);<a name="line.61"></a>
+<span class="sourceLineNo">062</span> return Mockito.mock(AbstractFSWAL.class);<a name="line.62"></a>
+<span class="sourceLineNo">063</span> }<a name="line.63"></a>
+<span class="sourceLineNo">064</span><a name="line.64"></a>
+<span class="sourceLineNo">065</span> @Override<a name="line.65"></a>
+<span class="sourceLineNo">066</span> protected void doInit(Configuration conf) throws IOException {<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><a name="line.69"></a>
+<span class="sourceLineNo">070</span> @Test<a name="line.70"></a>
+<span class="sourceLineNo">071</span> public void testRace() throws IOException, InterruptedException, ExecutionException {<a name="line.71"></a>
+<span class="sourceLineNo">072</span> FSWALProvider p = new FSWALProvider();<a name="line.72"></a>
+<span class="sourceLineNo">073</span> WAL wal = p.getWAL(null);<a name="line.73"></a>
+<span class="sourceLineNo">074</span> assertNotNull(GET_WALS_FUTURE);<a name="line.74"></a>
+<span class="sourceLineNo">075</span> List<WAL> wals = GET_WALS_FUTURE.get();<a name="line.75"></a>
+<span class="sourceLineNo">076</span> assertSame(wal, Iterables.getOnlyElement(wals));<a name="line.76"></a>
+<span class="sourceLineNo">077</span> }<a name="line.77"></a>
+<span class="sourceLineNo">078</span>}<a name="line.78"></a>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+</pre>
+</div>
+</body>
+</html>
[10/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.QuotaGlobalsSettingsBypass.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.QuotaGlobalsSettingsBypass.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.QuotaGlobalsSettingsBypass.html
index 2f1d985..e55c7bd 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.QuotaGlobalsSettingsBypass.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.QuotaGlobalsSettingsBypass.html
@@ -151,244 +151,256 @@
<span class="sourceLineNo">143</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.143"></a>
<span class="sourceLineNo">144</span> ThrottleType.READ_SIZE, throttle.getReadSize()));<a name="line.144"></a>
<span class="sourceLineNo">145</span> }<a name="line.145"></a>
-<span class="sourceLineNo">146</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.149"></a>
-<span class="sourceLineNo">150</span> if (protoQuota == null) {<a name="line.150"></a>
-<span class="sourceLineNo">151</span> return null;<a name="line.151"></a>
-<span class="sourceLineNo">152</span> }<a name="line.152"></a>
-<span class="sourceLineNo">153</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.153"></a>
-<span class="sourceLineNo">154</span> throw new IllegalArgumentException(<a name="line.154"></a>
-<span class="sourceLineNo">155</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.155"></a>
-<span class="sourceLineNo">156</span> }<a name="line.156"></a>
-<span class="sourceLineNo">157</span> if (table != null) {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> if (protoQuota.getRemove()) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> return new SpaceLimitSettings(table);<a name="line.159"></a>
-<span class="sourceLineNo">160</span> }<a name="line.160"></a>
-<span class="sourceLineNo">161</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.161"></a>
-<span class="sourceLineNo">162</span> } else {<a name="line.162"></a>
-<span class="sourceLineNo">163</span> if (protoQuota.getRemove()) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span> return new SpaceLimitSettings(namespace);<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span> // namespace must be non-null<a name="line.166"></a>
-<span class="sourceLineNo">167</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.167"></a>
+<span class="sourceLineNo">146</span> if (throttle.hasReqCapacityUnit()) {<a name="line.146"></a>
+<span class="sourceLineNo">147</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.147"></a>
+<span class="sourceLineNo">148</span> ThrottleType.REQUEST_CAPACITY_UNIT, throttle.getReqCapacityUnit()));<a name="line.148"></a>
+<span class="sourceLineNo">149</span> }<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (throttle.hasReadCapacityUnit()) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.151"></a>
+<span class="sourceLineNo">152</span> ThrottleType.READ_CAPACITY_UNIT, throttle.getReadCapacityUnit()));<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span> if (throttle.hasWriteCapacityUnit()) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.155"></a>
+<span class="sourceLineNo">156</span> ThrottleType.WRITE_CAPACITY_UNIT, throttle.getWriteCapacityUnit()));<a name="line.156"></a>
+<span class="sourceLineNo">157</span> }<a name="line.157"></a>
+<span class="sourceLineNo">158</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.161"></a>
+<span class="sourceLineNo">162</span> if (protoQuota == null) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span> return null;<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.165"></a>
+<span class="sourceLineNo">166</span> throw new IllegalArgumentException(<a name="line.166"></a>
+<span class="sourceLineNo">167</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.167"></a>
<span class="sourceLineNo">168</span> }<a name="line.168"></a>
-<span class="sourceLineNo">169</span> }<a name="line.169"></a>
-<span class="sourceLineNo">170</span><a name="line.170"></a>
-<span class="sourceLineNo">171</span> /* ==========================================================================<a name="line.171"></a>
-<span class="sourceLineNo">172</span> * RPC Throttle<a name="line.172"></a>
-<span class="sourceLineNo">173</span> */<a name="line.173"></a>
-<span class="sourceLineNo">174</span><a name="line.174"></a>
-<span class="sourceLineNo">175</span> /**<a name="line.175"></a>
-<span class="sourceLineNo">176</span> * Throttle the specified user.<a name="line.176"></a>
-<span class="sourceLineNo">177</span> *<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * @param userName the user to throttle<a name="line.178"></a>
-<span class="sourceLineNo">179</span> * @param type the type of throttling<a name="line.179"></a>
-<span class="sourceLineNo">180</span> * @param limit the allowed number of request/data per timeUnit<a name="line.180"></a>
-<span class="sourceLineNo">181</span> * @param timeUnit the limit time unit<a name="line.181"></a>
-<span class="sourceLineNo">182</span> * @return the quota settings<a name="line.182"></a>
-<span class="sourceLineNo">183</span> */<a name="line.183"></a>
-<span class="sourceLineNo">184</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.184"></a>
-<span class="sourceLineNo">185</span> final long limit, final TimeUnit timeUnit) {<a name="line.185"></a>
-<span class="sourceLineNo">186</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.186"></a>
-<span class="sourceLineNo">187</span> }<a name="line.187"></a>
-<span class="sourceLineNo">188</span><a name="line.188"></a>
-<span class="sourceLineNo">189</span> /**<a name="line.189"></a>
-<span class="sourceLineNo">190</span> * Throttle the specified user on the specified table.<a name="line.190"></a>
-<span class="sourceLineNo">191</span> *<a name="line.191"></a>
-<span class="sourceLineNo">192</span> * @param userName the user to throttle<a name="line.192"></a>
-<span class="sourceLineNo">193</span> * @param tableName the table to throttle<a name="line.193"></a>
-<span class="sourceLineNo">194</span> * @param type the type of throttling<a name="line.194"></a>
-<span class="sourceLineNo">195</span> * @param limit the allowed number of request/data per timeUnit<a name="line.195"></a>
-<span class="sourceLineNo">196</span> * @param timeUnit the limit time unit<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * @return the quota settings<a name="line.197"></a>
-<span class="sourceLineNo">198</span> */<a name="line.198"></a>
-<span class="sourceLineNo">199</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.199"></a>
-<span class="sourceLineNo">200</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span> /**<a name="line.204"></a>
-<span class="sourceLineNo">205</span> * Throttle the specified user on the specified namespace.<a name="line.205"></a>
-<span class="sourceLineNo">206</span> *<a name="line.206"></a>
-<span class="sourceLineNo">207</span> * @param userName the user to throttle<a name="line.207"></a>
-<span class="sourceLineNo">208</span> * @param namespace the namespace to throttle<a name="line.208"></a>
-<span class="sourceLineNo">209</span> * @param type the type of throttling<a name="line.209"></a>
-<span class="sourceLineNo">210</span> * @param limit the allowed number of request/data per timeUnit<a name="line.210"></a>
-<span class="sourceLineNo">211</span> * @param timeUnit the limit time unit<a name="line.211"></a>
-<span class="sourceLineNo">212</span> * @return the quota settings<a name="line.212"></a>
-<span class="sourceLineNo">213</span> */<a name="line.213"></a>
-<span class="sourceLineNo">214</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.214"></a>
-<span class="sourceLineNo">215</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.215"></a>
-<span class="sourceLineNo">216</span> return throttle(userName, null, namespace, type, limit, timeUnit);<a name="line.216"></a>
-<span class="sourceLineNo">217</span> }<a name="line.217"></a>
-<span class="sourceLineNo">218</span><a name="line.218"></a>
-<span class="sourceLineNo">219</span> /**<a name="line.219"></a>
-<span class="sourceLineNo">220</span> * Remove the throttling for the specified user.<a name="line.220"></a>
-<span class="sourceLineNo">221</span> *<a name="line.221"></a>
-<span class="sourceLineNo">222</span> * @param userName the user<a name="line.222"></a>
-<span class="sourceLineNo">223</span> * @return the quota settings<a name="line.223"></a>
-<span class="sourceLineNo">224</span> */<a name="line.224"></a>
-<span class="sourceLineNo">225</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.225"></a>
-<span class="sourceLineNo">226</span> return throttle(userName, null, null, null, 0, null);<a name="line.226"></a>
-<span class="sourceLineNo">227</span> }<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span> /**<a name="line.229"></a>
-<span class="sourceLineNo">230</span> * Remove the throttling for the specified user on the specified table.<a name="line.230"></a>
-<span class="sourceLineNo">231</span> *<a name="line.231"></a>
-<span class="sourceLineNo">232</span> * @param userName the user<a name="line.232"></a>
-<span class="sourceLineNo">233</span> * @param tableName the table<a name="line.233"></a>
-<span class="sourceLineNo">234</span> * @return the quota settings<a name="line.234"></a>
-<span class="sourceLineNo">235</span> */<a name="line.235"></a>
-<span class="sourceLineNo">236</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.237"></a>
-<span class="sourceLineNo">238</span> }<a name="line.238"></a>
-<span class="sourceLineNo">239</span><a name="line.239"></a>
-<span class="sourceLineNo">240</span> /**<a name="line.240"></a>
-<span class="sourceLineNo">241</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.241"></a>
-<span class="sourceLineNo">242</span> *<a name="line.242"></a>
-<span class="sourceLineNo">243</span> * @param userName the user<a name="line.243"></a>
-<span class="sourceLineNo">244</span> * @param namespace the namespace<a name="line.244"></a>
-<span class="sourceLineNo">245</span> * @return the quota settings<a name="line.245"></a>
-<span class="sourceLineNo">246</span> */<a name="line.246"></a>
-<span class="sourceLineNo">247</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.247"></a>
-<span class="sourceLineNo">248</span> return throttle(userName, null, namespace, null, 0, null);<a name="line.248"></a>
-<span class="sourceLineNo">249</span> }<a name="line.249"></a>
-<span class="sourceLineNo">250</span><a name="line.250"></a>
-<span class="sourceLineNo">251</span> /**<a name="line.251"></a>
-<span class="sourceLineNo">252</span> * Throttle the specified table.<a name="line.252"></a>
-<span class="sourceLineNo">253</span> *<a name="line.253"></a>
-<span class="sourceLineNo">254</span> * @param tableName the table to throttle<a name="line.254"></a>
-<span class="sourceLineNo">255</span> * @param type the type of throttling<a name="line.255"></a>
-<span class="sourceLineNo">256</span> * @param limit the allowed number of request/data per timeUnit<a name="line.256"></a>
-<span class="sourceLineNo">257</span> * @param timeUnit the limit time unit<a name="line.257"></a>
-<span class="sourceLineNo">258</span> * @return the quota settings<a name="line.258"></a>
-<span class="sourceLineNo">259</span> */<a name="line.259"></a>
-<span class="sourceLineNo">260</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.260"></a>
-<span class="sourceLineNo">261</span> final long limit, final TimeUnit timeUnit) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.262"></a>
-<span class="sourceLineNo">263</span> }<a name="line.263"></a>
-<span class="sourceLineNo">264</span><a name="line.264"></a>
-<span class="sourceLineNo">265</span> /**<a name="line.265"></a>
-<span class="sourceLineNo">266</span> * Remove the throttling for the specified table.<a name="line.266"></a>
-<span class="sourceLineNo">267</span> *<a name="line.267"></a>
-<span class="sourceLineNo">268</span> * @param tableName the table<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * @return the quota settings<a name="line.269"></a>
-<span class="sourceLineNo">270</span> */<a name="line.270"></a>
-<span class="sourceLineNo">271</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.271"></a>
-<span class="sourceLineNo">272</span> return throttle(null, tableName, null, null, 0, null);<a name="line.272"></a>
-<span class="sourceLineNo">273</span> }<a name="line.273"></a>
-<span class="sourceLineNo">274</span><a name="line.274"></a>
-<span class="sourceLineNo">275</span> /**<a name="line.275"></a>
-<span class="sourceLineNo">276</span> * Throttle the specified namespace.<a name="line.276"></a>
-<span class="sourceLineNo">277</span> *<a name="line.277"></a>
-<span class="sourceLineNo">278</span> * @param namespace the namespace to throttle<a name="line.278"></a>
-<span class="sourceLineNo">279</span> * @param type the type of throttling<a name="line.279"></a>
-<span class="sourceLineNo">280</span> * @param limit the allowed number of request/data per timeUnit<a name="line.280"></a>
-<span class="sourceLineNo">281</span> * @param timeUnit the limit time unit<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * @return the quota settings<a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.284"></a>
-<span class="sourceLineNo">285</span> final long limit, final TimeUnit timeUnit) {<a name="line.285"></a>
-<span class="sourceLineNo">286</span> return throttle(null, null, namespace, type, limit, timeUnit);<a name="line.286"></a>
-<span class="sourceLineNo">287</span> }<a name="line.287"></a>
-<span class="sourceLineNo">288</span><a name="line.288"></a>
-<span class="sourceLineNo">289</span> /**<a name="line.289"></a>
-<span class="sourceLineNo">290</span> * Remove the throttling for the specified namespace.<a name="line.290"></a>
-<span class="sourceLineNo">291</span> *<a name="line.291"></a>
-<span class="sourceLineNo">292</span> * @param namespace the namespace<a name="line.292"></a>
-<span class="sourceLineNo">293</span> * @return the quota settings<a name="line.293"></a>
-<span class="sourceLineNo">294</span> */<a name="line.294"></a>
-<span class="sourceLineNo">295</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span> return throttle(null, null, namespace, null, 0, null);<a name="line.296"></a>
-<span class="sourceLineNo">297</span> }<a name="line.297"></a>
-<span class="sourceLineNo">298</span><a name="line.298"></a>
-<span class="sourceLineNo">299</span> /* Throttle helper */<a name="line.299"></a>
-<span class="sourceLineNo">300</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.300"></a>
-<span class="sourceLineNo">301</span> final String namespace, final ThrottleType type, final long limit,<a name="line.301"></a>
-<span class="sourceLineNo">302</span> final TimeUnit timeUnit) {<a name="line.302"></a>
-<span class="sourceLineNo">303</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.303"></a>
-<span class="sourceLineNo">304</span> if (type != null) {<a name="line.304"></a>
-<span class="sourceLineNo">305</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.305"></a>
-<span class="sourceLineNo">306</span> }<a name="line.306"></a>
-<span class="sourceLineNo">307</span> if (timeUnit != null) {<a name="line.307"></a>
-<span class="sourceLineNo">308</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.308"></a>
-<span class="sourceLineNo">309</span> }<a name="line.309"></a>
-<span class="sourceLineNo">310</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<a name="line.310"></a>
-<span class="sourceLineNo">311</span> }<a name="line.311"></a>
-<span class="sourceLineNo">312</span><a name="line.312"></a>
-<span class="sourceLineNo">313</span> /* ==========================================================================<a name="line.313"></a>
-<span class="sourceLineNo">314</span> * Global Settings<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> /**<a name="line.317"></a>
-<span class="sourceLineNo">318</span> * Set the "bypass global settings" for the specified user<a name="line.318"></a>
-<span class="sourceLineNo">319</span> *<a name="line.319"></a>
-<span class="sourceLineNo">320</span> * @param userName the user to throttle<a name="line.320"></a>
-<span class="sourceLineNo">321</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.321"></a>
-<span class="sourceLineNo">322</span> * @return the quota settings<a name="line.322"></a>
-<span class="sourceLineNo">323</span> */<a name="line.323"></a>
-<span class="sourceLineNo">324</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.324"></a>
-<span class="sourceLineNo">325</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<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> /* ==========================================================================<a name="line.328"></a>
-<span class="sourceLineNo">329</span> * FileSystem Space Settings<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> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.333"></a>
-<span class="sourceLineNo">334</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.334"></a>
-<span class="sourceLineNo">335</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.335"></a>
-<span class="sourceLineNo">336</span> *<a name="line.336"></a>
-<span class="sourceLineNo">337</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.337"></a>
-<span class="sourceLineNo">338</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.338"></a>
-<span class="sourceLineNo">339</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.339"></a>
-<span class="sourceLineNo">340</span> * @return An {@link QuotaSettings} object.<a name="line.340"></a>
-<span class="sourceLineNo">341</span> */<a name="line.341"></a>
-<span class="sourceLineNo">342</span> public static QuotaSettings limitTableSpace(<a name="line.342"></a>
-<span class="sourceLineNo">343</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.344"></a>
-<span class="sourceLineNo">345</span> }<a name="line.345"></a>
-<span class="sourceLineNo">346</span><a name="line.346"></a>
-<span class="sourceLineNo">347</span> /**<a name="line.347"></a>
-<span class="sourceLineNo">348</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.348"></a>
-<span class="sourceLineNo">349</span> * table.<a name="line.349"></a>
-<span class="sourceLineNo">350</span> *<a name="line.350"></a>
-<span class="sourceLineNo">351</span> * @param tableName The name of the table to remove the quota for.<a name="line.351"></a>
-<span class="sourceLineNo">352</span> * @return A {@link QuotaSettings} object.<a name="line.352"></a>
+<span class="sourceLineNo">169</span> if (table != null) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (protoQuota.getRemove()) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> return new SpaceLimitSettings(table);<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.173"></a>
+<span class="sourceLineNo">174</span> } else {<a name="line.174"></a>
+<span class="sourceLineNo">175</span> if (protoQuota.getRemove()) {<a name="line.175"></a>
+<span class="sourceLineNo">176</span> return new SpaceLimitSettings(namespace);<a name="line.176"></a>
+<span class="sourceLineNo">177</span> }<a name="line.177"></a>
+<span class="sourceLineNo">178</span> // namespace must be non-null<a name="line.178"></a>
+<span class="sourceLineNo">179</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.179"></a>
+<span class="sourceLineNo">180</span> }<a name="line.180"></a>
+<span class="sourceLineNo">181</span> }<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> /* ==========================================================================<a name="line.183"></a>
+<span class="sourceLineNo">184</span> * RPC Throttle<a name="line.184"></a>
+<span class="sourceLineNo">185</span> */<a name="line.185"></a>
+<span class="sourceLineNo">186</span><a name="line.186"></a>
+<span class="sourceLineNo">187</span> /**<a name="line.187"></a>
+<span class="sourceLineNo">188</span> * Throttle the specified user.<a name="line.188"></a>
+<span class="sourceLineNo">189</span> *<a name="line.189"></a>
+<span class="sourceLineNo">190</span> * @param userName the user to throttle<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * @param type the type of throttling<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * @param limit the allowed number of request/data per timeUnit<a name="line.192"></a>
+<span class="sourceLineNo">193</span> * @param timeUnit the limit time unit<a name="line.193"></a>
+<span class="sourceLineNo">194</span> * @return the quota settings<a name="line.194"></a>
+<span class="sourceLineNo">195</span> */<a name="line.195"></a>
+<span class="sourceLineNo">196</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.196"></a>
+<span class="sourceLineNo">197</span> final long limit, final TimeUnit timeUnit) {<a name="line.197"></a>
+<span class="sourceLineNo">198</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span><a name="line.200"></a>
+<span class="sourceLineNo">201</span> /**<a name="line.201"></a>
+<span class="sourceLineNo">202</span> * Throttle the specified user on the specified table.<a name="line.202"></a>
+<span class="sourceLineNo">203</span> *<a name="line.203"></a>
+<span class="sourceLineNo">204</span> * @param userName the user to throttle<a name="line.204"></a>
+<span class="sourceLineNo">205</span> * @param tableName the table to throttle<a name="line.205"></a>
+<span class="sourceLineNo">206</span> * @param type the type of throttling<a name="line.206"></a>
+<span class="sourceLineNo">207</span> * @param limit the allowed number of request/data per timeUnit<a name="line.207"></a>
+<span class="sourceLineNo">208</span> * @param timeUnit the limit time unit<a name="line.208"></a>
+<span class="sourceLineNo">209</span> * @return the quota settings<a name="line.209"></a>
+<span class="sourceLineNo">210</span> */<a name="line.210"></a>
+<span class="sourceLineNo">211</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.211"></a>
+<span class="sourceLineNo">212</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.212"></a>
+<span class="sourceLineNo">213</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.213"></a>
+<span class="sourceLineNo">214</span> }<a name="line.214"></a>
+<span class="sourceLineNo">215</span><a name="line.215"></a>
+<span class="sourceLineNo">216</span> /**<a name="line.216"></a>
+<span class="sourceLineNo">217</span> * Throttle the specified user on the specified namespace.<a name="line.217"></a>
+<span class="sourceLineNo">218</span> *<a name="line.218"></a>
+<span class="sourceLineNo">219</span> * @param userName the user to throttle<a name="line.219"></a>
+<span class="sourceLineNo">220</span> * @param namespace the namespace to throttle<a name="line.220"></a>
+<span class="sourceLineNo">221</span> * @param type the type of throttling<a name="line.221"></a>
+<span class="sourceLineNo">222</span> * @param limit the allowed number of request/data per timeUnit<a name="line.222"></a>
+<span class="sourceLineNo">223</span> * @param timeUnit the limit time unit<a name="line.223"></a>
+<span class="sourceLineNo">224</span> * @return the quota settings<a name="line.224"></a>
+<span class="sourceLineNo">225</span> */<a name="line.225"></a>
+<span class="sourceLineNo">226</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.226"></a>
+<span class="sourceLineNo">227</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> return throttle(userName, null, namespace, type, limit, timeUnit);<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> /**<a name="line.231"></a>
+<span class="sourceLineNo">232</span> * Remove the throttling for the specified user.<a name="line.232"></a>
+<span class="sourceLineNo">233</span> *<a name="line.233"></a>
+<span class="sourceLineNo">234</span> * @param userName the user<a name="line.234"></a>
+<span class="sourceLineNo">235</span> * @return the quota settings<a name="line.235"></a>
+<span class="sourceLineNo">236</span> */<a name="line.236"></a>
+<span class="sourceLineNo">237</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.237"></a>
+<span class="sourceLineNo">238</span> return throttle(userName, null, null, null, 0, null);<a name="line.238"></a>
+<span class="sourceLineNo">239</span> }<a name="line.239"></a>
+<span class="sourceLineNo">240</span><a name="line.240"></a>
+<span class="sourceLineNo">241</span> /**<a name="line.241"></a>
+<span class="sourceLineNo">242</span> * Remove the throttling for the specified user on the specified table.<a name="line.242"></a>
+<span class="sourceLineNo">243</span> *<a name="line.243"></a>
+<span class="sourceLineNo">244</span> * @param userName the user<a name="line.244"></a>
+<span class="sourceLineNo">245</span> * @param tableName the table<a name="line.245"></a>
+<span class="sourceLineNo">246</span> * @return the quota settings<a name="line.246"></a>
+<span class="sourceLineNo">247</span> */<a name="line.247"></a>
+<span class="sourceLineNo">248</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.248"></a>
+<span class="sourceLineNo">249</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.249"></a>
+<span class="sourceLineNo">250</span> }<a name="line.250"></a>
+<span class="sourceLineNo">251</span><a name="line.251"></a>
+<span class="sourceLineNo">252</span> /**<a name="line.252"></a>
+<span class="sourceLineNo">253</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.253"></a>
+<span class="sourceLineNo">254</span> *<a name="line.254"></a>
+<span class="sourceLineNo">255</span> * @param userName the user<a name="line.255"></a>
+<span class="sourceLineNo">256</span> * @param namespace the namespace<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * @return the quota settings<a name="line.257"></a>
+<span class="sourceLineNo">258</span> */<a name="line.258"></a>
+<span class="sourceLineNo">259</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> return throttle(userName, null, namespace, null, 0, null);<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> /**<a name="line.263"></a>
+<span class="sourceLineNo">264</span> * Throttle the specified table.<a name="line.264"></a>
+<span class="sourceLineNo">265</span> *<a name="line.265"></a>
+<span class="sourceLineNo">266</span> * @param tableName the table to throttle<a name="line.266"></a>
+<span class="sourceLineNo">267</span> * @param type the type of throttling<a name="line.267"></a>
+<span class="sourceLineNo">268</span> * @param limit the allowed number of request/data per timeUnit<a name="line.268"></a>
+<span class="sourceLineNo">269</span> * @param timeUnit the limit time unit<a name="line.269"></a>
+<span class="sourceLineNo">270</span> * @return the quota settings<a name="line.270"></a>
+<span class="sourceLineNo">271</span> */<a name="line.271"></a>
+<span class="sourceLineNo">272</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.272"></a>
+<span class="sourceLineNo">273</span> final long limit, final TimeUnit timeUnit) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.274"></a>
+<span class="sourceLineNo">275</span> }<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> * Remove the throttling for the specified table.<a name="line.278"></a>
+<span class="sourceLineNo">279</span> *<a name="line.279"></a>
+<span class="sourceLineNo">280</span> * @param tableName the table<a name="line.280"></a>
+<span class="sourceLineNo">281</span> * @return the quota settings<a name="line.281"></a>
+<span class="sourceLineNo">282</span> */<a name="line.282"></a>
+<span class="sourceLineNo">283</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> return throttle(null, tableName, null, null, 0, null);<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> /**<a name="line.287"></a>
+<span class="sourceLineNo">288</span> * Throttle the specified namespace.<a name="line.288"></a>
+<span class="sourceLineNo">289</span> *<a name="line.289"></a>
+<span class="sourceLineNo">290</span> * @param namespace the namespace to throttle<a name="line.290"></a>
+<span class="sourceLineNo">291</span> * @param type the type of throttling<a name="line.291"></a>
+<span class="sourceLineNo">292</span> * @param limit the allowed number of request/data per timeUnit<a name="line.292"></a>
+<span class="sourceLineNo">293</span> * @param timeUnit the limit time unit<a name="line.293"></a>
+<span class="sourceLineNo">294</span> * @return the quota settings<a name="line.294"></a>
+<span class="sourceLineNo">295</span> */<a name="line.295"></a>
+<span class="sourceLineNo">296</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.296"></a>
+<span class="sourceLineNo">297</span> final long limit, final TimeUnit timeUnit) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span> return throttle(null, null, namespace, type, limit, timeUnit);<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> /**<a name="line.301"></a>
+<span class="sourceLineNo">302</span> * Remove the throttling for the specified namespace.<a name="line.302"></a>
+<span class="sourceLineNo">303</span> *<a name="line.303"></a>
+<span class="sourceLineNo">304</span> * @param namespace the namespace<a name="line.304"></a>
+<span class="sourceLineNo">305</span> * @return the quota settings<a name="line.305"></a>
+<span class="sourceLineNo">306</span> */<a name="line.306"></a>
+<span class="sourceLineNo">307</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.307"></a>
+<span class="sourceLineNo">308</span> return throttle(null, null, namespace, null, 0, null);<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> /* Throttle helper */<a name="line.311"></a>
+<span class="sourceLineNo">312</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.312"></a>
+<span class="sourceLineNo">313</span> final String namespace, final ThrottleType type, final long limit,<a name="line.313"></a>
+<span class="sourceLineNo">314</span> final TimeUnit timeUnit) {<a name="line.314"></a>
+<span class="sourceLineNo">315</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.315"></a>
+<span class="sourceLineNo">316</span> if (type != null) {<a name="line.316"></a>
+<span class="sourceLineNo">317</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.317"></a>
+<span class="sourceLineNo">318</span> }<a name="line.318"></a>
+<span class="sourceLineNo">319</span> if (timeUnit != null) {<a name="line.319"></a>
+<span class="sourceLineNo">320</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.320"></a>
+<span class="sourceLineNo">321</span> }<a name="line.321"></a>
+<span class="sourceLineNo">322</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<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> /* ==========================================================================<a name="line.325"></a>
+<span class="sourceLineNo">326</span> * Global Settings<a name="line.326"></a>
+<span class="sourceLineNo">327</span> */<a name="line.327"></a>
+<span class="sourceLineNo">328</span><a name="line.328"></a>
+<span class="sourceLineNo">329</span> /**<a name="line.329"></a>
+<span class="sourceLineNo">330</span> * Set the "bypass global settings" for the specified user<a name="line.330"></a>
+<span class="sourceLineNo">331</span> *<a name="line.331"></a>
+<span class="sourceLineNo">332</span> * @param userName the user to throttle<a name="line.332"></a>
+<span class="sourceLineNo">333</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.333"></a>
+<span class="sourceLineNo">334</span> * @return the quota settings<a name="line.334"></a>
+<span class="sourceLineNo">335</span> */<a name="line.335"></a>
+<span class="sourceLineNo">336</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.336"></a>
+<span class="sourceLineNo">337</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<a name="line.337"></a>
+<span class="sourceLineNo">338</span> }<a name="line.338"></a>
+<span class="sourceLineNo">339</span><a name="line.339"></a>
+<span class="sourceLineNo">340</span> /* ==========================================================================<a name="line.340"></a>
+<span class="sourceLineNo">341</span> * FileSystem Space Settings<a name="line.341"></a>
+<span class="sourceLineNo">342</span> */<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span> /**<a name="line.344"></a>
+<span class="sourceLineNo">345</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.345"></a>
+<span class="sourceLineNo">346</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.346"></a>
+<span class="sourceLineNo">347</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.347"></a>
+<span class="sourceLineNo">348</span> *<a name="line.348"></a>
+<span class="sourceLineNo">349</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.349"></a>
+<span class="sourceLineNo">350</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.350"></a>
+<span class="sourceLineNo">351</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.351"></a>
+<span class="sourceLineNo">352</span> * @return An {@link QuotaSettings} object.<a name="line.352"></a>
<span class="sourceLineNo">353</span> */<a name="line.353"></a>
-<span class="sourceLineNo">354</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.354"></a>
-<span class="sourceLineNo">355</span> return new SpaceLimitSettings(tableName);<a name="line.355"></a>
-<span class="sourceLineNo">356</span> }<a name="line.356"></a>
-<span class="sourceLineNo">357</span><a name="line.357"></a>
-<span class="sourceLineNo">358</span> /**<a name="line.358"></a>
-<span class="sourceLineNo">359</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.359"></a>
-<span class="sourceLineNo">360</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.360"></a>
-<span class="sourceLineNo">361</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.361"></a>
+<span class="sourceLineNo">354</span> public static QuotaSettings limitTableSpace(<a name="line.354"></a>
+<span class="sourceLineNo">355</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.356"></a>
+<span class="sourceLineNo">357</span> }<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.360"></a>
+<span class="sourceLineNo">361</span> * table.<a name="line.361"></a>
<span class="sourceLineNo">362</span> *<a name="line.362"></a>
-<span class="sourceLineNo">363</span> * @param namespace The namespace on which the quota should be applied.<a name="line.363"></a>
-<span class="sourceLineNo">364</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.364"></a>
-<span class="sourceLineNo">365</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.365"></a>
-<span class="sourceLineNo">366</span> * @return An {@link QuotaSettings} object.<a name="line.366"></a>
-<span class="sourceLineNo">367</span> */<a name="line.367"></a>
-<span class="sourceLineNo">368</span> public static QuotaSettings limitNamespaceSpace(<a name="line.368"></a>
-<span class="sourceLineNo">369</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.369"></a>
-<span class="sourceLineNo">370</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.374"></a>
-<span class="sourceLineNo">375</span> * namespace.<a name="line.375"></a>
-<span class="sourceLineNo">376</span> *<a name="line.376"></a>
-<span class="sourceLineNo">377</span> * @param namespace The namespace to remove the quota on.<a name="line.377"></a>
-<span class="sourceLineNo">378</span> * @return A {@link QuotaSettings} object.<a name="line.378"></a>
+<span class="sourceLineNo">363</span> * @param tableName The name of the table to remove the quota for.<a name="line.363"></a>
+<span class="sourceLineNo">364</span> * @return A {@link QuotaSettings} object.<a name="line.364"></a>
+<span class="sourceLineNo">365</span> */<a name="line.365"></a>
+<span class="sourceLineNo">366</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.366"></a>
+<span class="sourceLineNo">367</span> return new SpaceLimitSettings(tableName);<a name="line.367"></a>
+<span class="sourceLineNo">368</span> }<a name="line.368"></a>
+<span class="sourceLineNo">369</span><a name="line.369"></a>
+<span class="sourceLineNo">370</span> /**<a name="line.370"></a>
+<span class="sourceLineNo">371</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.371"></a>
+<span class="sourceLineNo">372</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.372"></a>
+<span class="sourceLineNo">373</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.373"></a>
+<span class="sourceLineNo">374</span> *<a name="line.374"></a>
+<span class="sourceLineNo">375</span> * @param namespace The namespace on which the quota should be applied.<a name="line.375"></a>
+<span class="sourceLineNo">376</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.376"></a>
+<span class="sourceLineNo">377</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.377"></a>
+<span class="sourceLineNo">378</span> * @return An {@link QuotaSettings} object.<a name="line.378"></a>
<span class="sourceLineNo">379</span> */<a name="line.379"></a>
-<span class="sourceLineNo">380</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.380"></a>
-<span class="sourceLineNo">381</span> return new SpaceLimitSettings(namespace);<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">380</span> public static QuotaSettings limitNamespaceSpace(<a name="line.380"></a>
+<span class="sourceLineNo">381</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.381"></a>
+<span class="sourceLineNo">382</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<a name="line.382"></a>
+<span class="sourceLineNo">383</span> }<a name="line.383"></a>
+<span class="sourceLineNo">384</span><a name="line.384"></a>
+<span class="sourceLineNo">385</span> /**<a name="line.385"></a>
+<span class="sourceLineNo">386</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.386"></a>
+<span class="sourceLineNo">387</span> * namespace.<a name="line.387"></a>
+<span class="sourceLineNo">388</span> *<a name="line.388"></a>
+<span class="sourceLineNo">389</span> * @param namespace The namespace to remove the quota on.<a name="line.389"></a>
+<span class="sourceLineNo">390</span> * @return A {@link QuotaSettings} object.<a name="line.390"></a>
+<span class="sourceLineNo">391</span> */<a name="line.391"></a>
+<span class="sourceLineNo">392</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span> return new SpaceLimitSettings(namespace);<a name="line.393"></a>
+<span class="sourceLineNo">394</span> }<a name="line.394"></a>
+<span class="sourceLineNo">395</span>}<a name="line.395"></a>
[11/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
index 8d66107..7e55aa0 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
@@ -29,109 +29,148 @@
<span class="sourceLineNo">021</span>import java.util.Arrays;<a name="line.21"></a>
<span class="sourceLineNo">022</span>import java.util.List;<a name="line.22"></a>
<span class="sourceLineNo">023</span><a name="line.23"></a>
-<span class="sourceLineNo">024</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.24"></a>
-<span class="sourceLineNo">025</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.25"></a>
-<span class="sourceLineNo">026</span>import org.slf4j.Logger;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import org.slf4j.LoggerFactory;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.28"></a>
-<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.client.Result;<a name="line.29"></a>
-<span class="sourceLineNo">030</span><a name="line.30"></a>
-<span class="sourceLineNo">031</span>@InterfaceAudience.Private<a name="line.31"></a>
-<span class="sourceLineNo">032</span>@InterfaceStability.Evolving<a name="line.32"></a>
-<span class="sourceLineNo">033</span>public class DefaultOperationQuota implements OperationQuota {<a name="line.33"></a>
-<span class="sourceLineNo">034</span> private static final Logger LOG = LoggerFactory.getLogger(DefaultOperationQuota.class);<a name="line.34"></a>
-<span class="sourceLineNo">035</span><a name="line.35"></a>
-<span class="sourceLineNo">036</span> private final List<QuotaLimiter> limiters;<a name="line.36"></a>
-<span class="sourceLineNo">037</span> private long writeAvailable = 0;<a name="line.37"></a>
-<span class="sourceLineNo">038</span> private long readAvailable = 0;<a name="line.38"></a>
-<span class="sourceLineNo">039</span> private long writeConsumed = 0;<a name="line.39"></a>
-<span class="sourceLineNo">040</span> private long readConsumed = 0;<a name="line.40"></a>
-<span class="sourceLineNo">041</span> private final long[] operationSize;<a name="line.41"></a>
-<span class="sourceLineNo">042</span><a name="line.42"></a>
-<span class="sourceLineNo">043</span> public DefaultOperationQuota(final QuotaLimiter... limiters) {<a name="line.43"></a>
-<span class="sourceLineNo">044</span> this(Arrays.asList(limiters));<a name="line.44"></a>
-<span class="sourceLineNo">045</span> }<a name="line.45"></a>
-<span class="sourceLineNo">046</span><a name="line.46"></a>
-<span class="sourceLineNo">047</span> /**<a name="line.47"></a>
-<span class="sourceLineNo">048</span> * NOTE: The order matters. It should be something like [user, table, namespace, global]<a name="line.48"></a>
-<span class="sourceLineNo">049</span> */<a name="line.49"></a>
-<span class="sourceLineNo">050</span> public DefaultOperationQuota(final List<QuotaLimiter> limiters) {<a name="line.50"></a>
-<span class="sourceLineNo">051</span> this.limiters = limiters;<a name="line.51"></a>
-<span class="sourceLineNo">052</span> int size = OperationType.values().length;<a name="line.52"></a>
-<span class="sourceLineNo">053</span> operationSize = new long[size];<a name="line.53"></a>
-<span class="sourceLineNo">054</span><a name="line.54"></a>
-<span class="sourceLineNo">055</span> for (int i = 0; i < size; ++i) {<a name="line.55"></a>
-<span class="sourceLineNo">056</span> operationSize[i] = 0;<a name="line.56"></a>
-<span class="sourceLineNo">057</span> }<a name="line.57"></a>
-<span class="sourceLineNo">058</span> }<a name="line.58"></a>
-<span class="sourceLineNo">059</span><a name="line.59"></a>
-<span class="sourceLineNo">060</span> @Override<a name="line.60"></a>
-<span class="sourceLineNo">061</span> public void checkQuota(int numWrites, int numReads, int numScans)<a name="line.61"></a>
-<span class="sourceLineNo">062</span> throws RpcThrottlingException {<a name="line.62"></a>
-<span class="sourceLineNo">063</span> writeConsumed = estimateConsume(OperationType.MUTATE, numWrites, 100);<a name="line.63"></a>
-<span class="sourceLineNo">064</span> readConsumed = estimateConsume(OperationType.GET, numReads, 100);<a name="line.64"></a>
-<span class="sourceLineNo">065</span> readConsumed += estimateConsume(OperationType.SCAN, numScans, 1000);<a name="line.65"></a>
-<span class="sourceLineNo">066</span><a name="line.66"></a>
-<span class="sourceLineNo">067</span> writeAvailable = Long.MAX_VALUE;<a name="line.67"></a>
-<span class="sourceLineNo">068</span> readAvailable = Long.MAX_VALUE;<a name="line.68"></a>
-<span class="sourceLineNo">069</span> for (final QuotaLimiter limiter: limiters) {<a name="line.69"></a>
-<span class="sourceLineNo">070</span> if (limiter.isBypass()) continue;<a name="line.70"></a>
-<span class="sourceLineNo">071</span><a name="line.71"></a>
-<span class="sourceLineNo">072</span> limiter.checkQuota(numWrites, writeConsumed, numReads + numScans, readConsumed);<a name="line.72"></a>
-<span class="sourceLineNo">073</span> readAvailable = Math.min(readAvailable, limiter.getReadAvailable());<a name="line.73"></a>
-<span class="sourceLineNo">074</span> writeAvailable = Math.min(writeAvailable, limiter.getWriteAvailable());<a name="line.74"></a>
-<span class="sourceLineNo">075</span> }<a name="line.75"></a>
-<span class="sourceLineNo">076</span><a name="line.76"></a>
-<span class="sourceLineNo">077</span> for (final QuotaLimiter limiter: limiters) {<a name="line.77"></a>
-<span class="sourceLineNo">078</span> limiter.grabQuota(numWrites, writeConsumed, numReads + numScans, readConsumed);<a name="line.78"></a>
-<span class="sourceLineNo">079</span> }<a name="line.79"></a>
-<span class="sourceLineNo">080</span> }<a name="line.80"></a>
-<span class="sourceLineNo">081</span><a name="line.81"></a>
-<span class="sourceLineNo">082</span> @Override<a name="line.82"></a>
-<span class="sourceLineNo">083</span> public void close() {<a name="line.83"></a>
-<span class="sourceLineNo">084</span> // Adjust the quota consumed for the specified operation<a name="line.84"></a>
-<span class="sourceLineNo">085</span> long writeDiff = operationSize[OperationType.MUTATE.ordinal()] - writeConsumed;<a name="line.85"></a>
-<span class="sourceLineNo">086</span> long readDiff = operationSize[OperationType.GET.ordinal()] +<a name="line.86"></a>
-<span class="sourceLineNo">087</span> operationSize[OperationType.SCAN.ordinal()] - readConsumed;<a name="line.87"></a>
-<span class="sourceLineNo">088</span><a name="line.88"></a>
-<span class="sourceLineNo">089</span> for (final QuotaLimiter limiter: limiters) {<a name="line.89"></a>
-<span class="sourceLineNo">090</span> if (writeDiff != 0) limiter.consumeWrite(writeDiff);<a name="line.90"></a>
-<span class="sourceLineNo">091</span> if (readDiff != 0) limiter.consumeRead(readDiff);<a name="line.91"></a>
-<span class="sourceLineNo">092</span> }<a name="line.92"></a>
-<span class="sourceLineNo">093</span> }<a name="line.93"></a>
-<span class="sourceLineNo">094</span><a name="line.94"></a>
-<span class="sourceLineNo">095</span> @Override<a name="line.95"></a>
-<span class="sourceLineNo">096</span> public long getReadAvailable() {<a name="line.96"></a>
-<span class="sourceLineNo">097</span> return readAvailable;<a name="line.97"></a>
-<span class="sourceLineNo">098</span> }<a name="line.98"></a>
-<span class="sourceLineNo">099</span><a name="line.99"></a>
-<span class="sourceLineNo">100</span> @Override<a name="line.100"></a>
-<span class="sourceLineNo">101</span> public long getWriteAvailable() {<a name="line.101"></a>
-<span class="sourceLineNo">102</span> return writeAvailable;<a name="line.102"></a>
-<span class="sourceLineNo">103</span> }<a name="line.103"></a>
-<span class="sourceLineNo">104</span><a name="line.104"></a>
-<span class="sourceLineNo">105</span> @Override<a name="line.105"></a>
-<span class="sourceLineNo">106</span> public void addGetResult(final Result result) {<a name="line.106"></a>
-<span class="sourceLineNo">107</span> operationSize[OperationType.GET.ordinal()] += QuotaUtil.calculateResultSize(result);<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 void addScanResult(final List<Result> results) {<a name="line.111"></a>
-<span class="sourceLineNo">112</span> operationSize[OperationType.SCAN.ordinal()] += QuotaUtil.calculateResultSize(results);<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 void addMutation(final Mutation mutation) {<a name="line.116"></a>
-<span class="sourceLineNo">117</span> operationSize[OperationType.MUTATE.ordinal()] += QuotaUtil.calculateMutationSize(mutation);<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> private long estimateConsume(final OperationType type, int numReqs, long avgSize) {<a name="line.120"></a>
-<span class="sourceLineNo">121</span> if (numReqs > 0) {<a name="line.121"></a>
-<span class="sourceLineNo">122</span> return avgSize * numReqs;<a name="line.122"></a>
-<span class="sourceLineNo">123</span> }<a name="line.123"></a>
-<span class="sourceLineNo">124</span> return 0;<a name="line.124"></a>
-<span class="sourceLineNo">125</span> }<a name="line.125"></a>
-<span class="sourceLineNo">126</span>}<a name="line.126"></a>
+<span class="sourceLineNo">024</span>import org.apache.hadoop.conf.Configuration;<a name="line.24"></a>
+<span class="sourceLineNo">025</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.25"></a>
+<span class="sourceLineNo">026</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.26"></a>
+<span class="sourceLineNo">027</span>import org.slf4j.Logger;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import org.slf4j.LoggerFactory;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import org.apache.hadoop.hbase.client.Mutation;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import org.apache.hadoop.hbase.client.Result;<a name="line.30"></a>
+<span class="sourceLineNo">031</span><a name="line.31"></a>
+<span class="sourceLineNo">032</span>@InterfaceAudience.Private<a name="line.32"></a>
+<span class="sourceLineNo">033</span>@InterfaceStability.Evolving<a name="line.33"></a>
+<span class="sourceLineNo">034</span>public class DefaultOperationQuota implements OperationQuota {<a name="line.34"></a>
+<span class="sourceLineNo">035</span> private static final Logger LOG = LoggerFactory.getLogger(DefaultOperationQuota.class);<a name="line.35"></a>
+<span class="sourceLineNo">036</span><a name="line.36"></a>
+<span class="sourceLineNo">037</span> private final List<QuotaLimiter> limiters;<a name="line.37"></a>
+<span class="sourceLineNo">038</span> private final long writeCapacityUnit;<a name="line.38"></a>
+<span class="sourceLineNo">039</span> private final long readCapacityUnit;<a name="line.39"></a>
+<span class="sourceLineNo">040</span><a name="line.40"></a>
+<span class="sourceLineNo">041</span> private long writeAvailable = 0;<a name="line.41"></a>
+<span class="sourceLineNo">042</span> private long readAvailable = 0;<a name="line.42"></a>
+<span class="sourceLineNo">043</span> private long writeConsumed = 0;<a name="line.43"></a>
+<span class="sourceLineNo">044</span> private long readConsumed = 0;<a name="line.44"></a>
+<span class="sourceLineNo">045</span> private long writeCapacityUnitConsumed = 0;<a name="line.45"></a>
+<span class="sourceLineNo">046</span> private long readCapacityUnitConsumed = 0;<a name="line.46"></a>
+<span class="sourceLineNo">047</span> private final long[] operationSize;<a name="line.47"></a>
+<span class="sourceLineNo">048</span><a name="line.48"></a>
+<span class="sourceLineNo">049</span> public DefaultOperationQuota(final Configuration conf, final QuotaLimiter... limiters) {<a name="line.49"></a>
+<span class="sourceLineNo">050</span> this(conf, Arrays.asList(limiters));<a name="line.50"></a>
+<span class="sourceLineNo">051</span> }<a name="line.51"></a>
+<span class="sourceLineNo">052</span><a name="line.52"></a>
+<span class="sourceLineNo">053</span> /**<a name="line.53"></a>
+<span class="sourceLineNo">054</span> * NOTE: The order matters. It should be something like [user, table, namespace, global]<a name="line.54"></a>
+<span class="sourceLineNo">055</span> */<a name="line.55"></a>
+<span class="sourceLineNo">056</span> public DefaultOperationQuota(final Configuration conf, final List<QuotaLimiter> limiters) {<a name="line.56"></a>
+<span class="sourceLineNo">057</span> this.writeCapacityUnit =<a name="line.57"></a>
+<span class="sourceLineNo">058</span> conf.getLong(QuotaUtil.WRITE_CAPACITY_UNIT_CONF_KEY, QuotaUtil.DEFAULT_WRITE_CAPACITY_UNIT);<a name="line.58"></a>
+<span class="sourceLineNo">059</span> this.readCapacityUnit =<a name="line.59"></a>
+<span class="sourceLineNo">060</span> conf.getLong(QuotaUtil.READ_CAPACITY_UNIT_CONF_KEY, QuotaUtil.DEFAULT_READ_CAPACITY_UNIT);<a name="line.60"></a>
+<span class="sourceLineNo">061</span> this.limiters = limiters;<a name="line.61"></a>
+<span class="sourceLineNo">062</span> int size = OperationType.values().length;<a name="line.62"></a>
+<span class="sourceLineNo">063</span> operationSize = new long[size];<a name="line.63"></a>
+<span class="sourceLineNo">064</span><a name="line.64"></a>
+<span class="sourceLineNo">065</span> for (int i = 0; i < size; ++i) {<a name="line.65"></a>
+<span class="sourceLineNo">066</span> operationSize[i] = 0;<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><a name="line.69"></a>
+<span class="sourceLineNo">070</span> @Override<a name="line.70"></a>
+<span class="sourceLineNo">071</span> public void checkQuota(int numWrites, int numReads, int numScans) throws RpcThrottlingException {<a name="line.71"></a>
+<span class="sourceLineNo">072</span> writeConsumed = estimateConsume(OperationType.MUTATE, numWrites, 100);<a name="line.72"></a>
+<span class="sourceLineNo">073</span> readConsumed = estimateConsume(OperationType.GET, numReads, 100);<a name="line.73"></a>
+<span class="sourceLineNo">074</span> readConsumed += estimateConsume(OperationType.SCAN, numScans, 1000);<a name="line.74"></a>
+<span class="sourceLineNo">075</span><a name="line.75"></a>
+<span class="sourceLineNo">076</span> writeCapacityUnitConsumed = calculateWriteCapacityUnit(writeConsumed);<a name="line.76"></a>
+<span class="sourceLineNo">077</span> readCapacityUnitConsumed = calculateReadCapacityUnit(readConsumed);<a name="line.77"></a>
+<span class="sourceLineNo">078</span><a name="line.78"></a>
+<span class="sourceLineNo">079</span> writeAvailable = Long.MAX_VALUE;<a name="line.79"></a>
+<span class="sourceLineNo">080</span> readAvailable = Long.MAX_VALUE;<a name="line.80"></a>
+<span class="sourceLineNo">081</span> for (final QuotaLimiter limiter : limiters) {<a name="line.81"></a>
+<span class="sourceLineNo">082</span> if (limiter.isBypass()) continue;<a name="line.82"></a>
+<span class="sourceLineNo">083</span><a name="line.83"></a>
+<span class="sourceLineNo">084</span> limiter.checkQuota(numWrites, writeConsumed, numReads + numScans, readConsumed,<a name="line.84"></a>
+<span class="sourceLineNo">085</span> writeCapacityUnitConsumed, readCapacityUnitConsumed);<a name="line.85"></a>
+<span class="sourceLineNo">086</span> readAvailable = Math.min(readAvailable, limiter.getReadAvailable());<a name="line.86"></a>
+<span class="sourceLineNo">087</span> writeAvailable = Math.min(writeAvailable, limiter.getWriteAvailable());<a name="line.87"></a>
+<span class="sourceLineNo">088</span> }<a name="line.88"></a>
+<span class="sourceLineNo">089</span><a name="line.89"></a>
+<span class="sourceLineNo">090</span> for (final QuotaLimiter limiter : limiters) {<a name="line.90"></a>
+<span class="sourceLineNo">091</span> limiter.grabQuota(numWrites, writeConsumed, numReads + numScans, readConsumed,<a name="line.91"></a>
+<span class="sourceLineNo">092</span> writeCapacityUnitConsumed, readCapacityUnitConsumed);<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>
+<span class="sourceLineNo">096</span> @Override<a name="line.96"></a>
+<span class="sourceLineNo">097</span> public void close() {<a name="line.97"></a>
+<span class="sourceLineNo">098</span> // Adjust the quota consumed for the specified operation<a name="line.98"></a>
+<span class="sourceLineNo">099</span> long writeDiff = operationSize[OperationType.MUTATE.ordinal()] - writeConsumed;<a name="line.99"></a>
+<span class="sourceLineNo">100</span> long readDiff = operationSize[OperationType.GET.ordinal()]<a name="line.100"></a>
+<span class="sourceLineNo">101</span> + operationSize[OperationType.SCAN.ordinal()] - readConsumed;<a name="line.101"></a>
+<span class="sourceLineNo">102</span> long writeCapacityUnitDiff = calculateWriteCapacityUnitDiff(<a name="line.102"></a>
+<span class="sourceLineNo">103</span> operationSize[OperationType.MUTATE.ordinal()], writeConsumed);<a name="line.103"></a>
+<span class="sourceLineNo">104</span> long readCapacityUnitDiff = calculateReadCapacityUnitDiff(<a name="line.104"></a>
+<span class="sourceLineNo">105</span> operationSize[OperationType.GET.ordinal()] + operationSize[OperationType.SCAN.ordinal()],<a name="line.105"></a>
+<span class="sourceLineNo">106</span> readConsumed);<a name="line.106"></a>
+<span class="sourceLineNo">107</span><a name="line.107"></a>
+<span class="sourceLineNo">108</span> for (final QuotaLimiter limiter : limiters) {<a name="line.108"></a>
+<span class="sourceLineNo">109</span> if (writeDiff != 0) {<a name="line.109"></a>
+<span class="sourceLineNo">110</span> limiter.consumeWrite(writeDiff, writeCapacityUnitDiff);<a name="line.110"></a>
+<span class="sourceLineNo">111</span> }<a name="line.111"></a>
+<span class="sourceLineNo">112</span> if (readDiff != 0) {<a name="line.112"></a>
+<span class="sourceLineNo">113</span> limiter.consumeRead(readDiff, readCapacityUnitDiff);<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> }<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 long getReadAvailable() {<a name="line.119"></a>
+<span class="sourceLineNo">120</span> return readAvailable;<a name="line.120"></a>
+<span class="sourceLineNo">121</span> }<a name="line.121"></a>
+<span class="sourceLineNo">122</span><a name="line.122"></a>
+<span class="sourceLineNo">123</span> @Override<a name="line.123"></a>
+<span class="sourceLineNo">124</span> public long getWriteAvailable() {<a name="line.124"></a>
+<span class="sourceLineNo">125</span> return writeAvailable;<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> @Override<a name="line.128"></a>
+<span class="sourceLineNo">129</span> public void addGetResult(final Result result) {<a name="line.129"></a>
+<span class="sourceLineNo">130</span> operationSize[OperationType.GET.ordinal()] += QuotaUtil.calculateResultSize(result);<a name="line.130"></a>
+<span class="sourceLineNo">131</span> }<a name="line.131"></a>
+<span class="sourceLineNo">132</span><a name="line.132"></a>
+<span class="sourceLineNo">133</span> @Override<a name="line.133"></a>
+<span class="sourceLineNo">134</span> public void addScanResult(final List<Result> results) {<a name="line.134"></a>
+<span class="sourceLineNo">135</span> operationSize[OperationType.SCAN.ordinal()] += QuotaUtil.calculateResultSize(results);<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> @Override<a name="line.138"></a>
+<span class="sourceLineNo">139</span> public void addMutation(final Mutation mutation) {<a name="line.139"></a>
+<span class="sourceLineNo">140</span> operationSize[OperationType.MUTATE.ordinal()] += QuotaUtil.calculateMutationSize(mutation);<a name="line.140"></a>
+<span class="sourceLineNo">141</span> }<a name="line.141"></a>
+<span class="sourceLineNo">142</span><a name="line.142"></a>
+<span class="sourceLineNo">143</span> private long estimateConsume(final OperationType type, int numReqs, long avgSize) {<a name="line.143"></a>
+<span class="sourceLineNo">144</span> if (numReqs > 0) {<a name="line.144"></a>
+<span class="sourceLineNo">145</span> return avgSize * numReqs;<a name="line.145"></a>
+<span class="sourceLineNo">146</span> }<a name="line.146"></a>
+<span class="sourceLineNo">147</span> return 0;<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> private long calculateWriteCapacityUnit(final long size) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> return (long) Math.ceil(size * 1.0 / this.writeCapacityUnit);<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> private long calculateReadCapacityUnit(final long size) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span> return (long) Math.ceil(size * 1.0 / this.readCapacityUnit);<a name="line.155"></a>
+<span class="sourceLineNo">156</span> }<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span> private long calculateWriteCapacityUnitDiff(final long actualSize, final long estimateSize) {<a name="line.158"></a>
+<span class="sourceLineNo">159</span> return calculateWriteCapacityUnit(actualSize) - calculateWriteCapacityUnit(estimateSize);<a name="line.159"></a>
+<span class="sourceLineNo">160</span> }<a name="line.160"></a>
+<span class="sourceLineNo">161</span><a name="line.161"></a>
+<span class="sourceLineNo">162</span> private long calculateReadCapacityUnitDiff(final long actualSize, final long estimateSize) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span> return calculateReadCapacityUnit(actualSize) - calculateReadCapacityUnit(estimateSize);<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span>}<a name="line.165"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
index 55e5099..80a2ae7 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
@@ -157,158 +157,185 @@
<span class="sourceLineNo">149</span> case READ_SIZE:<a name="line.149"></a>
<span class="sourceLineNo">150</span> throttleBuilder.setReadSize(otherProto.getTimedQuota());<a name="line.150"></a>
<span class="sourceLineNo">151</span> break;<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> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> // Propagate the space quota portion<a name="line.156"></a>
-<span class="sourceLineNo">157</span> QuotaProtos.SpaceQuota.Builder spaceBuilder = (spaceProto == null<a name="line.157"></a>
-<span class="sourceLineNo">158</span> ? null : spaceProto.toBuilder());<a name="line.158"></a>
-<span class="sourceLineNo">159</span> if (other instanceof SpaceLimitSettings) {<a name="line.159"></a>
-<span class="sourceLineNo">160</span> if (spaceBuilder == null) {<a name="line.160"></a>
-<span class="sourceLineNo">161</span> spaceBuilder = QuotaProtos.SpaceQuota.newBuilder();<a name="line.161"></a>
-<span class="sourceLineNo">162</span> }<a name="line.162"></a>
-<span class="sourceLineNo">163</span> SpaceLimitSettings settingsToMerge = (SpaceLimitSettings) other;<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span> QuotaProtos.SpaceLimitRequest spaceRequest = settingsToMerge.getProto();<a name="line.165"></a>
-<span class="sourceLineNo">166</span><a name="line.166"></a>
-<span class="sourceLineNo">167</span> // The message contained the expect SpaceQuota object<a name="line.167"></a>
-<span class="sourceLineNo">168</span> if (spaceRequest.hasQuota()) {<a name="line.168"></a>
-<span class="sourceLineNo">169</span> SpaceQuota quotaToMerge = spaceRequest.getQuota();<a name="line.169"></a>
-<span class="sourceLineNo">170</span> // Validate that the two settings are for the same target.<a name="line.170"></a>
-<span class="sourceLineNo">171</span> // SpaceQuotas either apply to a table or a namespace (no user spacequota).<a name="line.171"></a>
-<span class="sourceLineNo">172</span> if (!Objects.equals(getTableName(), settingsToMerge.getTableName())<a name="line.172"></a>
-<span class="sourceLineNo">173</span> && !Objects.equals(getNamespace(), settingsToMerge.getNamespace())) {<a name="line.173"></a>
-<span class="sourceLineNo">174</span> throw new IllegalArgumentException(<a name="line.174"></a>
-<span class="sourceLineNo">175</span> "Cannot merge " + settingsToMerge + " into " + this);<a name="line.175"></a>
-<span class="sourceLineNo">176</span> }<a name="line.176"></a>
-<span class="sourceLineNo">177</span><a name="line.177"></a>
-<span class="sourceLineNo">178</span> if (quotaToMerge.getRemove()) {<a name="line.178"></a>
-<span class="sourceLineNo">179</span> // Update the builder to propagate the removal<a name="line.179"></a>
-<span class="sourceLineNo">180</span> spaceBuilder.setRemove(true).clearSoftLimit().clearViolationPolicy();<a name="line.180"></a>
-<span class="sourceLineNo">181</span> } else {<a name="line.181"></a>
-<span class="sourceLineNo">182</span> // Add the new settings to the existing settings<a name="line.182"></a>
-<span class="sourceLineNo">183</span> spaceBuilder.mergeFrom(quotaToMerge);<a name="line.183"></a>
-<span class="sourceLineNo">184</span> }<a name="line.184"></a>
-<span class="sourceLineNo">185</span> }<a name="line.185"></a>
-<span class="sourceLineNo">186</span> }<a name="line.186"></a>
+<span class="sourceLineNo">152</span> case REQUEST_CAPACITY_UNIT:<a name="line.152"></a>
+<span class="sourceLineNo">153</span> throttleBuilder.setReqCapacityUnit(otherProto.getTimedQuota());<a name="line.153"></a>
+<span class="sourceLineNo">154</span> break;<a name="line.154"></a>
+<span class="sourceLineNo">155</span> case READ_CAPACITY_UNIT:<a name="line.155"></a>
+<span class="sourceLineNo">156</span> throttleBuilder.setReadCapacityUnit(otherProto.getTimedQuota());<a name="line.156"></a>
+<span class="sourceLineNo">157</span> break;<a name="line.157"></a>
+<span class="sourceLineNo">158</span> case WRITE_CAPACITY_UNIT:<a name="line.158"></a>
+<span class="sourceLineNo">159</span> throttleBuilder.setWriteCapacityUnit(otherProto.getTimedQuota());<a name="line.159"></a>
+<span class="sourceLineNo">160</span> break;<a name="line.160"></a>
+<span class="sourceLineNo">161</span> default:<a name="line.161"></a>
+<span class="sourceLineNo">162</span> }<a name="line.162"></a>
+<span class="sourceLineNo">163</span> }<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span><a name="line.165"></a>
+<span class="sourceLineNo">166</span> // Propagate the space quota portion<a name="line.166"></a>
+<span class="sourceLineNo">167</span> QuotaProtos.SpaceQuota.Builder spaceBuilder = (spaceProto == null<a name="line.167"></a>
+<span class="sourceLineNo">168</span> ? null : spaceProto.toBuilder());<a name="line.168"></a>
+<span class="sourceLineNo">169</span> if (other instanceof SpaceLimitSettings) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (spaceBuilder == null) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> spaceBuilder = QuotaProtos.SpaceQuota.newBuilder();<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> SpaceLimitSettings settingsToMerge = (SpaceLimitSettings) other;<a name="line.173"></a>
+<span class="sourceLineNo">174</span><a name="line.174"></a>
+<span class="sourceLineNo">175</span> QuotaProtos.SpaceLimitRequest spaceRequest = settingsToMerge.getProto();<a name="line.175"></a>
+<span class="sourceLineNo">176</span><a name="line.176"></a>
+<span class="sourceLineNo">177</span> // The message contained the expect SpaceQuota object<a name="line.177"></a>
+<span class="sourceLineNo">178</span> if (spaceRequest.hasQuota()) {<a name="line.178"></a>
+<span class="sourceLineNo">179</span> SpaceQuota quotaToMerge = spaceRequest.getQuota();<a name="line.179"></a>
+<span class="sourceLineNo">180</span> // Validate that the two settings are for the same target.<a name="line.180"></a>
+<span class="sourceLineNo">181</span> // SpaceQuotas either apply to a table or a namespace (no user spacequota).<a name="line.181"></a>
+<span class="sourceLineNo">182</span> if (!Objects.equals(getTableName(), settingsToMerge.getTableName())<a name="line.182"></a>
+<span class="sourceLineNo">183</span> && !Objects.equals(getNamespace(), settingsToMerge.getNamespace())) {<a name="line.183"></a>
+<span class="sourceLineNo">184</span> throw new IllegalArgumentException(<a name="line.184"></a>
+<span class="sourceLineNo">185</span> "Cannot merge " + settingsToMerge + " into " + this);<a name="line.185"></a>
+<span class="sourceLineNo">186</span> }<a name="line.186"></a>
<span class="sourceLineNo">187</span><a name="line.187"></a>
-<span class="sourceLineNo">188</span> Boolean bypassGlobals = this.bypassGlobals;<a name="line.188"></a>
-<span class="sourceLineNo">189</span> if (other instanceof QuotaGlobalsSettingsBypass) {<a name="line.189"></a>
-<span class="sourceLineNo">190</span> bypassGlobals = ((QuotaGlobalsSettingsBypass) other).getBypass();<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> if (throttleBuilder == null &&<a name="line.193"></a>
-<span class="sourceLineNo">194</span> (spaceBuilder == null || (spaceBuilder.hasRemove() && spaceBuilder.getRemove()))<a name="line.194"></a>
-<span class="sourceLineNo">195</span> && bypassGlobals == null) {<a name="line.195"></a>
-<span class="sourceLineNo">196</span> return null;<a name="line.196"></a>
-<span class="sourceLineNo">197</span> }<a name="line.197"></a>
-<span class="sourceLineNo">198</span><a name="line.198"></a>
-<span class="sourceLineNo">199</span> return new GlobalQuotaSettingsImpl(<a name="line.199"></a>
-<span class="sourceLineNo">200</span> getUserName(), getTableName(), getNamespace(),<a name="line.200"></a>
-<span class="sourceLineNo">201</span> (throttleBuilder == null ? null : throttleBuilder.build()), bypassGlobals,<a name="line.201"></a>
-<span class="sourceLineNo">202</span> (spaceBuilder == null ? null : spaceBuilder.build()));<a name="line.202"></a>
-<span class="sourceLineNo">203</span> }<a name="line.203"></a>
-<span class="sourceLineNo">204</span><a name="line.204"></a>
-<span class="sourceLineNo">205</span> private void validateTimedQuota(final TimedQuota timedQuota) throws IOException {<a name="line.205"></a>
-<span class="sourceLineNo">206</span> if (timedQuota.getSoftLimit() < 1) {<a name="line.206"></a>
-<span class="sourceLineNo">207</span> throw new DoNotRetryIOException(new UnsupportedOperationException(<a name="line.207"></a>
-<span class="sourceLineNo">208</span> "The throttle limit must be greater then 0, got " + timedQuota.getSoftLimit()));<a name="line.208"></a>
-<span class="sourceLineNo">209</span> }<a name="line.209"></a>
-<span class="sourceLineNo">210</span> }<a name="line.210"></a>
-<span class="sourceLineNo">211</span><a name="line.211"></a>
-<span class="sourceLineNo">212</span> @Override<a name="line.212"></a>
-<span class="sourceLineNo">213</span> public String toString() {<a name="line.213"></a>
-<span class="sourceLineNo">214</span> StringBuilder builder = new StringBuilder();<a name="line.214"></a>
-<span class="sourceLineNo">215</span> builder.append("GlobalQuota: ");<a name="line.215"></a>
-<span class="sourceLineNo">216</span> if (throttleProto != null) {<a name="line.216"></a>
-<span class="sourceLineNo">217</span> Map<ThrottleType,TimedQuota> throttleQuotas = buildThrottleQuotas(throttleProto);<a name="line.217"></a>
-<span class="sourceLineNo">218</span> builder.append(" { TYPE => THROTTLE ");<a name="line.218"></a>
-<span class="sourceLineNo">219</span> for (Entry<ThrottleType,TimedQuota> entry : throttleQuotas.entrySet()) {<a name="line.219"></a>
-<span class="sourceLineNo">220</span> final ThrottleType type = entry.getKey();<a name="line.220"></a>
-<span class="sourceLineNo">221</span> final TimedQuota timedQuota = entry.getValue();<a name="line.221"></a>
-<span class="sourceLineNo">222</span> builder.append("{THROTTLE_TYPE => ").append(type.name()).append(", LIMIT => ");<a name="line.222"></a>
-<span class="sourceLineNo">223</span> if (timedQuota.hasSoftLimit()) {<a name="line.223"></a>
-<span class="sourceLineNo">224</span> switch (type) {<a name="line.224"></a>
-<span class="sourceLineNo">225</span> case REQUEST_NUMBER:<a name="line.225"></a>
-<span class="sourceLineNo">226</span> case WRITE_NUMBER:<a name="line.226"></a>
-<span class="sourceLineNo">227</span> case READ_NUMBER:<a name="line.227"></a>
-<span class="sourceLineNo">228</span> builder.append(String.format("%dreq", timedQuota.getSoftLimit()));<a name="line.228"></a>
-<span class="sourceLineNo">229</span> break;<a name="line.229"></a>
-<span class="sourceLineNo">230</span> case REQUEST_SIZE:<a name="line.230"></a>
-<span class="sourceLineNo">231</span> case WRITE_SIZE:<a name="line.231"></a>
-<span class="sourceLineNo">232</span> case READ_SIZE:<a name="line.232"></a>
-<span class="sourceLineNo">233</span> builder.append(sizeToString(timedQuota.getSoftLimit()));<a name="line.233"></a>
-<span class="sourceLineNo">234</span> break;<a name="line.234"></a>
-<span class="sourceLineNo">235</span> }<a name="line.235"></a>
-<span class="sourceLineNo">236</span> } else if (timedQuota.hasShare()) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> builder.append(String.format("%.2f%%", timedQuota.getShare()));<a name="line.237"></a>
-<span class="sourceLineNo">238</span> }<a name="line.238"></a>
-<span class="sourceLineNo">239</span> builder.append('/');<a name="line.239"></a>
-<span class="sourceLineNo">240</span> builder.append(timeToString(ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit())));<a name="line.240"></a>
-<span class="sourceLineNo">241</span> if (timedQuota.hasScope()) {<a name="line.241"></a>
-<span class="sourceLineNo">242</span> builder.append(", SCOPE => ");<a name="line.242"></a>
-<span class="sourceLineNo">243</span> builder.append(timedQuota.getScope().toString());<a name="line.243"></a>
-<span class="sourceLineNo">244</span> }<a name="line.244"></a>
-<span class="sourceLineNo">245</span> }<a name="line.245"></a>
-<span class="sourceLineNo">246</span> builder.append( "} } ");<a name="line.246"></a>
-<span class="sourceLineNo">247</span> } else {<a name="line.247"></a>
-<span class="sourceLineNo">248</span> builder.append(" {} ");<a name="line.248"></a>
-<span class="sourceLineNo">249</span> }<a name="line.249"></a>
-<span class="sourceLineNo">250</span> if (bypassGlobals != null) {<a name="line.250"></a>
-<span class="sourceLineNo">251</span> builder.append(" { GLOBAL_BYPASS => " + bypassGlobals + " } ");<a name="line.251"></a>
-<span class="sourceLineNo">252</span> }<a name="line.252"></a>
-<span class="sourceLineNo">253</span> if (spaceProto != null) {<a name="line.253"></a>
-<span class="sourceLineNo">254</span> builder.append(" { TYPE => SPACE");<a name="line.254"></a>
-<span class="sourceLineNo">255</span> if (getTableName() != null) {<a name="line.255"></a>
-<span class="sourceLineNo">256</span> builder.append(", TABLE => ").append(getTableName());<a name="line.256"></a>
-<span class="sourceLineNo">257</span> }<a name="line.257"></a>
-<span class="sourceLineNo">258</span> if (getNamespace() != null) {<a name="line.258"></a>
-<span class="sourceLineNo">259</span> builder.append(", NAMESPACE => ").append(getNamespace());<a name="line.259"></a>
+<span class="sourceLineNo">188</span> if (quotaToMerge.getRemove()) {<a name="line.188"></a>
+<span class="sourceLineNo">189</span> // Update the builder to propagate the removal<a name="line.189"></a>
+<span class="sourceLineNo">190</span> spaceBuilder.setRemove(true).clearSoftLimit().clearViolationPolicy();<a name="line.190"></a>
+<span class="sourceLineNo">191</span> } else {<a name="line.191"></a>
+<span class="sourceLineNo">192</span> // Add the new settings to the existing settings<a name="line.192"></a>
+<span class="sourceLineNo">193</span> spaceBuilder.mergeFrom(quotaToMerge);<a name="line.193"></a>
+<span class="sourceLineNo">194</span> }<a name="line.194"></a>
+<span class="sourceLineNo">195</span> }<a name="line.195"></a>
+<span class="sourceLineNo">196</span> }<a name="line.196"></a>
+<span class="sourceLineNo">197</span><a name="line.197"></a>
+<span class="sourceLineNo">198</span> Boolean bypassGlobals = this.bypassGlobals;<a name="line.198"></a>
+<span class="sourceLineNo">199</span> if (other instanceof QuotaGlobalsSettingsBypass) {<a name="line.199"></a>
+<span class="sourceLineNo">200</span> bypassGlobals = ((QuotaGlobalsSettingsBypass) other).getBypass();<a name="line.200"></a>
+<span class="sourceLineNo">201</span> }<a name="line.201"></a>
+<span class="sourceLineNo">202</span><a name="line.202"></a>
+<span class="sourceLineNo">203</span> if (throttleBuilder == null &&<a name="line.203"></a>
+<span class="sourceLineNo">204</span> (spaceBuilder == null || (spaceBuilder.hasRemove() && spaceBuilder.getRemove()))<a name="line.204"></a>
+<span class="sourceLineNo">205</span> && bypassGlobals == null) {<a name="line.205"></a>
+<span class="sourceLineNo">206</span> return null;<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> return new GlobalQuotaSettingsImpl(<a name="line.209"></a>
+<span class="sourceLineNo">210</span> getUserName(), getTableName(), getNamespace(),<a name="line.210"></a>
+<span class="sourceLineNo">211</span> (throttleBuilder == null ? null : throttleBuilder.build()), bypassGlobals,<a name="line.211"></a>
+<span class="sourceLineNo">212</span> (spaceBuilder == null ? null : spaceBuilder.build()));<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> private void validateTimedQuota(final TimedQuota timedQuota) throws IOException {<a name="line.215"></a>
+<span class="sourceLineNo">216</span> if (timedQuota.getSoftLimit() < 1) {<a name="line.216"></a>
+<span class="sourceLineNo">217</span> throw new DoNotRetryIOException(new UnsupportedOperationException(<a name="line.217"></a>
+<span class="sourceLineNo">218</span> "The throttle limit must be greater then 0, got " + timedQuota.getSoftLimit()));<a name="line.218"></a>
+<span class="sourceLineNo">219</span> }<a name="line.219"></a>
+<span class="sourceLineNo">220</span> }<a name="line.220"></a>
+<span class="sourceLineNo">221</span><a name="line.221"></a>
+<span class="sourceLineNo">222</span> @Override<a name="line.222"></a>
+<span class="sourceLineNo">223</span> public String toString() {<a name="line.223"></a>
+<span class="sourceLineNo">224</span> StringBuilder builder = new StringBuilder();<a name="line.224"></a>
+<span class="sourceLineNo">225</span> builder.append("GlobalQuota: ");<a name="line.225"></a>
+<span class="sourceLineNo">226</span> if (throttleProto != null) {<a name="line.226"></a>
+<span class="sourceLineNo">227</span> Map<ThrottleType,TimedQuota> throttleQuotas = buildThrottleQuotas(throttleProto);<a name="line.227"></a>
+<span class="sourceLineNo">228</span> builder.append(" { TYPE => THROTTLE ");<a name="line.228"></a>
+<span class="sourceLineNo">229</span> for (Entry<ThrottleType,TimedQuota> entry : throttleQuotas.entrySet()) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span> final ThrottleType type = entry.getKey();<a name="line.230"></a>
+<span class="sourceLineNo">231</span> final TimedQuota timedQuota = entry.getValue();<a name="line.231"></a>
+<span class="sourceLineNo">232</span> builder.append("{THROTTLE_TYPE => ").append(type.name()).append(", LIMIT => ");<a name="line.232"></a>
+<span class="sourceLineNo">233</span> if (timedQuota.hasSoftLimit()) {<a name="line.233"></a>
+<span class="sourceLineNo">234</span> switch (type) {<a name="line.234"></a>
+<span class="sourceLineNo">235</span> case REQUEST_NUMBER:<a name="line.235"></a>
+<span class="sourceLineNo">236</span> case WRITE_NUMBER:<a name="line.236"></a>
+<span class="sourceLineNo">237</span> case READ_NUMBER:<a name="line.237"></a>
+<span class="sourceLineNo">238</span> builder.append(String.format("%dreq", timedQuota.getSoftLimit()));<a name="line.238"></a>
+<span class="sourceLineNo">239</span> break;<a name="line.239"></a>
+<span class="sourceLineNo">240</span> case REQUEST_SIZE:<a name="line.240"></a>
+<span class="sourceLineNo">241</span> case WRITE_SIZE:<a name="line.241"></a>
+<span class="sourceLineNo">242</span> case READ_SIZE:<a name="line.242"></a>
+<span class="sourceLineNo">243</span> builder.append(sizeToString(timedQuota.getSoftLimit()));<a name="line.243"></a>
+<span class="sourceLineNo">244</span> break;<a name="line.244"></a>
+<span class="sourceLineNo">245</span> case REQUEST_CAPACITY_UNIT:<a name="line.245"></a>
+<span class="sourceLineNo">246</span> case READ_CAPACITY_UNIT:<a name="line.246"></a>
+<span class="sourceLineNo">247</span> case WRITE_CAPACITY_UNIT:<a name="line.247"></a>
+<span class="sourceLineNo">248</span> builder.append(String.format("%dCU", timedQuota.getSoftLimit()));<a name="line.248"></a>
+<span class="sourceLineNo">249</span> default:<a name="line.249"></a>
+<span class="sourceLineNo">250</span> }<a name="line.250"></a>
+<span class="sourceLineNo">251</span> } else if (timedQuota.hasShare()) {<a name="line.251"></a>
+<span class="sourceLineNo">252</span> builder.append(String.format("%.2f%%", timedQuota.getShare()));<a name="line.252"></a>
+<span class="sourceLineNo">253</span> }<a name="line.253"></a>
+<span class="sourceLineNo">254</span> builder.append('/');<a name="line.254"></a>
+<span class="sourceLineNo">255</span> builder.append(timeToString(ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit())));<a name="line.255"></a>
+<span class="sourceLineNo">256</span> if (timedQuota.hasScope()) {<a name="line.256"></a>
+<span class="sourceLineNo">257</span> builder.append(", SCOPE => ");<a name="line.257"></a>
+<span class="sourceLineNo">258</span> builder.append(timedQuota.getScope().toString());<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> if (spaceProto.getRemove()) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span> builder.append(", REMOVE => ").append(spaceProto.getRemove());<a name="line.262"></a>
-<span class="sourceLineNo">263</span> } else {<a name="line.263"></a>
-<span class="sourceLineNo">264</span> builder.append(", LIMIT => ").append(spaceProto.getSoftLimit());<a name="line.264"></a>
-<span class="sourceLineNo">265</span> builder.append(", VIOLATION_POLICY => ").append(spaceProto.getViolationPolicy());<a name="line.265"></a>
-<span class="sourceLineNo">266</span> }<a name="line.266"></a>
-<span class="sourceLineNo">267</span> builder.append(" } ");<a name="line.267"></a>
-<span class="sourceLineNo">268</span> }<a name="line.268"></a>
-<span class="sourceLineNo">269</span> return builder.toString();<a name="line.269"></a>
-<span class="sourceLineNo">270</span> }<a name="line.270"></a>
-<span class="sourceLineNo">271</span><a name="line.271"></a>
-<span class="sourceLineNo">272</span> private Map<ThrottleType,TimedQuota> buildThrottleQuotas(Throttle proto) {<a name="line.272"></a>
-<span class="sourceLineNo">273</span> HashMap<ThrottleType,TimedQuota> quotas = new HashMap<>();<a name="line.273"></a>
-<span class="sourceLineNo">274</span> if (proto.hasReadNum()) {<a name="line.274"></a>
-<span class="sourceLineNo">275</span> quotas.put(ThrottleType.READ_NUMBER, proto.getReadNum());<a name="line.275"></a>
-<span class="sourceLineNo">276</span> }<a name="line.276"></a>
-<span class="sourceLineNo">277</span> if (proto.hasReadSize()) {<a name="line.277"></a>
-<span class="sourceLineNo">278</span> quotas.put(ThrottleType.READ_SIZE, proto.getReadSize());<a name="line.278"></a>
-<span class="sourceLineNo">279</span> }<a name="line.279"></a>
-<span class="sourceLineNo">280</span> if (proto.hasReqNum()) {<a name="line.280"></a>
-<span class="sourceLineNo">281</span> quotas.put(ThrottleType.REQUEST_NUMBER, proto.getReqNum());<a name="line.281"></a>
-<span class="sourceLineNo">282</span> }<a name="line.282"></a>
-<span class="sourceLineNo">283</span> if (proto.hasReqSize()) {<a name="line.283"></a>
-<span class="sourceLineNo">284</span> quotas.put(ThrottleType.REQUEST_SIZE, proto.getReqSize());<a name="line.284"></a>
-<span class="sourceLineNo">285</span> }<a name="line.285"></a>
-<span class="sourceLineNo">286</span> if (proto.hasWriteNum()) {<a name="line.286"></a>
-<span class="sourceLineNo">287</span> quotas.put(ThrottleType.WRITE_NUMBER, proto.getWriteNum());<a name="line.287"></a>
-<span class="sourceLineNo">288</span> }<a name="line.288"></a>
-<span class="sourceLineNo">289</span> if (proto.hasWriteSize()) {<a name="line.289"></a>
-<span class="sourceLineNo">290</span> quotas.put(ThrottleType.WRITE_SIZE, proto.getWriteSize());<a name="line.290"></a>
+<span class="sourceLineNo">261</span> builder.append( "} } ");<a name="line.261"></a>
+<span class="sourceLineNo">262</span> } else {<a name="line.262"></a>
+<span class="sourceLineNo">263</span> builder.append(" {} ");<a name="line.263"></a>
+<span class="sourceLineNo">264</span> }<a name="line.264"></a>
+<span class="sourceLineNo">265</span> if (bypassGlobals != null) {<a name="line.265"></a>
+<span class="sourceLineNo">266</span> builder.append(" { GLOBAL_BYPASS => " + bypassGlobals + " } ");<a name="line.266"></a>
+<span class="sourceLineNo">267</span> }<a name="line.267"></a>
+<span class="sourceLineNo">268</span> if (spaceProto != null) {<a name="line.268"></a>
+<span class="sourceLineNo">269</span> builder.append(" { TYPE => SPACE");<a name="line.269"></a>
+<span class="sourceLineNo">270</span> if (getTableName() != null) {<a name="line.270"></a>
+<span class="sourceLineNo">271</span> builder.append(", TABLE => ").append(getTableName());<a name="line.271"></a>
+<span class="sourceLineNo">272</span> }<a name="line.272"></a>
+<span class="sourceLineNo">273</span> if (getNamespace() != null) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span> builder.append(", NAMESPACE => ").append(getNamespace());<a name="line.274"></a>
+<span class="sourceLineNo">275</span> }<a name="line.275"></a>
+<span class="sourceLineNo">276</span> if (spaceProto.getRemove()) {<a name="line.276"></a>
+<span class="sourceLineNo">277</span> builder.append(", REMOVE => ").append(spaceProto.getRemove());<a name="line.277"></a>
+<span class="sourceLineNo">278</span> } else {<a name="line.278"></a>
+<span class="sourceLineNo">279</span> builder.append(", LIMIT => ").append(spaceProto.getSoftLimit());<a name="line.279"></a>
+<span class="sourceLineNo">280</span> builder.append(", VIOLATION_POLICY => ").append(spaceProto.getViolationPolicy());<a name="line.280"></a>
+<span class="sourceLineNo">281</span> }<a name="line.281"></a>
+<span class="sourceLineNo">282</span> builder.append(" } ");<a name="line.282"></a>
+<span class="sourceLineNo">283</span> }<a name="line.283"></a>
+<span class="sourceLineNo">284</span> return builder.toString();<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> private Map<ThrottleType,TimedQuota> buildThrottleQuotas(Throttle proto) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span> HashMap<ThrottleType,TimedQuota> quotas = new HashMap<>();<a name="line.288"></a>
+<span class="sourceLineNo">289</span> if (proto.hasReadNum()) {<a name="line.289"></a>
+<span class="sourceLineNo">290</span> quotas.put(ThrottleType.READ_NUMBER, proto.getReadNum());<a name="line.290"></a>
<span class="sourceLineNo">291</span> }<a name="line.291"></a>
-<span class="sourceLineNo">292</span> return quotas;<a name="line.292"></a>
-<span class="sourceLineNo">293</span> }<a name="line.293"></a>
-<span class="sourceLineNo">294</span><a name="line.294"></a>
-<span class="sourceLineNo">295</span> private void clearThrottleBuilder(QuotaProtos.Throttle.Builder builder) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span> builder.clearReadNum();<a name="line.296"></a>
-<span class="sourceLineNo">297</span> builder.clearReadSize();<a name="line.297"></a>
-<span class="sourceLineNo">298</span> builder.clearReqNum();<a name="line.298"></a>
-<span class="sourceLineNo">299</span> builder.clearReqSize();<a name="line.299"></a>
-<span class="sourceLineNo">300</span> builder.clearWriteNum();<a name="line.300"></a>
-<span class="sourceLineNo">301</span> builder.clearWriteSize();<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">292</span> if (proto.hasReadSize()) {<a name="line.292"></a>
+<span class="sourceLineNo">293</span> quotas.put(ThrottleType.READ_SIZE, proto.getReadSize());<a name="line.293"></a>
+<span class="sourceLineNo">294</span> }<a name="line.294"></a>
+<span class="sourceLineNo">295</span> if (proto.hasReqNum()) {<a name="line.295"></a>
+<span class="sourceLineNo">296</span> quotas.put(ThrottleType.REQUEST_NUMBER, proto.getReqNum());<a name="line.296"></a>
+<span class="sourceLineNo">297</span> }<a name="line.297"></a>
+<span class="sourceLineNo">298</span> if (proto.hasReqSize()) {<a name="line.298"></a>
+<span class="sourceLineNo">299</span> quotas.put(ThrottleType.REQUEST_SIZE, proto.getReqSize());<a name="line.299"></a>
+<span class="sourceLineNo">300</span> }<a name="line.300"></a>
+<span class="sourceLineNo">301</span> if (proto.hasWriteNum()) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span> quotas.put(ThrottleType.WRITE_NUMBER, proto.getWriteNum());<a name="line.302"></a>
+<span class="sourceLineNo">303</span> }<a name="line.303"></a>
+<span class="sourceLineNo">304</span> if (proto.hasWriteSize()) {<a name="line.304"></a>
+<span class="sourceLineNo">305</span> quotas.put(ThrottleType.WRITE_SIZE, proto.getWriteSize());<a name="line.305"></a>
+<span class="sourceLineNo">306</span> }<a name="line.306"></a>
+<span class="sourceLineNo">307</span> if (proto.hasReqCapacityUnit()) {<a name="line.307"></a>
+<span class="sourceLineNo">308</span> quotas.put(ThrottleType.REQUEST_CAPACITY_UNIT, proto.getReqCapacityUnit());<a name="line.308"></a>
+<span class="sourceLineNo">309</span> }<a name="line.309"></a>
+<span class="sourceLineNo">310</span> if (proto.hasReadCapacityUnit()) {<a name="line.310"></a>
+<span class="sourceLineNo">311</span> quotas.put(ThrottleType.READ_CAPACITY_UNIT, proto.getReqCapacityUnit());<a name="line.311"></a>
+<span class="sourceLineNo">312</span> }<a name="line.312"></a>
+<span class="sourceLineNo">313</span> if (proto.hasWriteCapacityUnit()) {<a name="line.313"></a>
+<span class="sourceLineNo">314</span> quotas.put(ThrottleType.WRITE_CAPACITY_UNIT, proto.getWriteCapacityUnit());<a name="line.314"></a>
+<span class="sourceLineNo">315</span> }<a name="line.315"></a>
+<span class="sourceLineNo">316</span> return quotas;<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> private void clearThrottleBuilder(QuotaProtos.Throttle.Builder builder) {<a name="line.319"></a>
+<span class="sourceLineNo">320</span> builder.clearReadNum();<a name="line.320"></a>
+<span class="sourceLineNo">321</span> builder.clearReadSize();<a name="line.321"></a>
+<span class="sourceLineNo">322</span> builder.clearReqNum();<a name="line.322"></a>
+<span class="sourceLineNo">323</span> builder.clearReqSize();<a name="line.323"></a>
+<span class="sourceLineNo">324</span> builder.clearWriteNum();<a name="line.324"></a>
+<span class="sourceLineNo">325</span> builder.clearWriteSize();<a name="line.325"></a>
+<span class="sourceLineNo">326</span> builder.clearReadCapacityUnit();<a name="line.326"></a>
+<span class="sourceLineNo">327</span> builder.clearReadCapacityUnit();<a name="line.327"></a>
+<span class="sourceLineNo">328</span> builder.clearWriteCapacityUnit();<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>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
index b110a2c..b4ae98c 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
@@ -28,65 +28,66 @@
<span class="sourceLineNo">020</span><a name="line.20"></a>
<span class="sourceLineNo">021</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.21"></a>
<span class="sourceLineNo">022</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.22"></a>
-<span class="sourceLineNo">023</span>import org.apache.hadoop.hbase.quotas.OperationQuota.OperationType;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>/**<a name="line.25"></a>
-<span class="sourceLineNo">026</span> * Noop quota limiter returned when no limiter is associated to the user/table<a name="line.26"></a>
-<span class="sourceLineNo">027</span> */<a name="line.27"></a>
-<span class="sourceLineNo">028</span>@InterfaceAudience.Private<a name="line.28"></a>
-<span class="sourceLineNo">029</span>@InterfaceStability.Evolving<a name="line.29"></a>
-<span class="sourceLineNo">030</span>class NoopQuotaLimiter implements QuotaLimiter {<a name="line.30"></a>
-<span class="sourceLineNo">031</span> private static QuotaLimiter instance = new NoopQuotaLimiter();<a name="line.31"></a>
-<span class="sourceLineNo">032</span><a name="line.32"></a>
-<span class="sourceLineNo">033</span> private NoopQuotaLimiter() {<a name="line.33"></a>
-<span class="sourceLineNo">034</span> // no-op<a name="line.34"></a>
-<span class="sourceLineNo">035</span> }<a name="line.35"></a>
-<span class="sourceLineNo">036</span><a name="line.36"></a>
-<span class="sourceLineNo">037</span> @Override<a name="line.37"></a>
-<span class="sourceLineNo">038</span> public void checkQuota(long writeReqs, long estimateWriteSize, long readReqs,<a name="line.38"></a>
-<span class="sourceLineNo">039</span> long estimateReadSize) throws RpcThrottlingException {<a name="line.39"></a>
+<span class="sourceLineNo">023</span><a name="line.23"></a>
+<span class="sourceLineNo">024</span>/**<a name="line.24"></a>
+<span class="sourceLineNo">025</span> * Noop quota limiter returned when no limiter is associated to the user/table<a name="line.25"></a>
+<span class="sourceLineNo">026</span> */<a name="line.26"></a>
+<span class="sourceLineNo">027</span>@InterfaceAudience.Private<a name="line.27"></a>
+<span class="sourceLineNo">028</span>@InterfaceStability.Evolving<a name="line.28"></a>
+<span class="sourceLineNo">029</span>class NoopQuotaLimiter implements QuotaLimiter {<a name="line.29"></a>
+<span class="sourceLineNo">030</span> private static QuotaLimiter instance = new NoopQuotaLimiter();<a name="line.30"></a>
+<span class="sourceLineNo">031</span><a name="line.31"></a>
+<span class="sourceLineNo">032</span> private NoopQuotaLimiter() {<a name="line.32"></a>
+<span class="sourceLineNo">033</span> // no-op<a name="line.33"></a>
+<span class="sourceLineNo">034</span> }<a name="line.34"></a>
+<span class="sourceLineNo">035</span><a name="line.35"></a>
+<span class="sourceLineNo">036</span> @Override<a name="line.36"></a>
+<span class="sourceLineNo">037</span> public void checkQuota(long writeReqs, long estimateWriteSize, long readReqs,<a name="line.37"></a>
+<span class="sourceLineNo">038</span> long estimateReadSize, long estimateWriteCapacityUnit, long estimateReadCapacityUnit)<a name="line.38"></a>
+<span class="sourceLineNo">039</span> throws RpcThrottlingException {<a name="line.39"></a>
<span class="sourceLineNo">040</span> // no-op<a name="line.40"></a>
<span class="sourceLineNo">041</span> }<a name="line.41"></a>
<span class="sourceLineNo">042</span><a name="line.42"></a>
<span class="sourceLineNo">043</span> @Override<a name="line.43"></a>
-<span class="sourceLineNo">044</span> public void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize) {<a name="line.44"></a>
-<span class="sourceLineNo">045</span> // no-op<a name="line.45"></a>
-<span class="sourceLineNo">046</span> }<a name="line.46"></a>
-<span class="sourceLineNo">047</span><a name="line.47"></a>
-<span class="sourceLineNo">048</span> @Override<a name="line.48"></a>
-<span class="sourceLineNo">049</span> public void consumeWrite(final long size) {<a name="line.49"></a>
-<span class="sourceLineNo">050</span> // no-op<a name="line.50"></a>
-<span class="sourceLineNo">051</span> }<a name="line.51"></a>
-<span class="sourceLineNo">052</span><a name="line.52"></a>
-<span class="sourceLineNo">053</span> @Override<a name="line.53"></a>
-<span class="sourceLineNo">054</span> public void consumeRead(final long size) {<a name="line.54"></a>
-<span class="sourceLineNo">055</span> // no-op<a name="line.55"></a>
-<span class="sourceLineNo">056</span> }<a name="line.56"></a>
-<span class="sourceLineNo">057</span><a name="line.57"></a>
-<span class="sourceLineNo">058</span> @Override<a name="line.58"></a>
-<span class="sourceLineNo">059</span> public boolean isBypass() {<a name="line.59"></a>
-<span class="sourceLineNo">060</span> return true;<a name="line.60"></a>
-<span class="sourceLineNo">061</span> }<a name="line.61"></a>
-<span class="sourceLineNo">062</span><a name="line.62"></a>
-<span class="sourceLineNo">063</span> @Override<a name="line.63"></a>
-<span class="sourceLineNo">064</span> public long getWriteAvailable() {<a name="line.64"></a>
-<span class="sourceLineNo">065</span> throw new UnsupportedOperationException();<a name="line.65"></a>
-<span class="sourceLineNo">066</span> }<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span> @Override<a name="line.68"></a>
-<span class="sourceLineNo">069</span> public long getReadAvailable() {<a name="line.69"></a>
-<span class="sourceLineNo">070</span> throw new UnsupportedOperationException();<a name="line.70"></a>
-<span class="sourceLineNo">071</span> }<a name="line.71"></a>
-<span class="sourceLineNo">072</span><a name="line.72"></a>
-<span class="sourceLineNo">073</span> @Override<a name="line.73"></a>
-<span class="sourceLineNo">074</span> public String toString() {<a name="line.74"></a>
-<span class="sourceLineNo">075</span> return "NoopQuotaLimiter";<a name="line.75"></a>
-<span class="sourceLineNo">076</span> }<a name="line.76"></a>
-<span class="sourceLineNo">077</span><a name="line.77"></a>
-<span class="sourceLineNo">078</span> public static QuotaLimiter get() {<a name="line.78"></a>
-<span class="sourceLineNo">079</span> return instance;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> }<a name="line.80"></a>
-<span class="sourceLineNo">081</span>}<a name="line.81"></a>
+<span class="sourceLineNo">044</span> public void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize,<a name="line.44"></a>
+<span class="sourceLineNo">045</span> long writeCapacityUnit, long readCapacityUnit) {<a name="line.45"></a>
+<span class="sourceLineNo">046</span> // no-op<a name="line.46"></a>
+<span class="sourceLineNo">047</span> }<a name="line.47"></a>
+<span class="sourceLineNo">048</span><a name="line.48"></a>
+<span class="sourceLineNo">049</span> @Override<a name="line.49"></a>
+<span class="sourceLineNo">050</span> public void consumeWrite(final long size, long capacityUnit) {<a name="line.50"></a>
+<span class="sourceLineNo">051</span> // no-op<a name="line.51"></a>
+<span class="sourceLineNo">052</span> }<a name="line.52"></a>
+<span class="sourceLineNo">053</span><a name="line.53"></a>
+<span class="sourceLineNo">054</span> @Override<a name="line.54"></a>
+<span class="sourceLineNo">055</span> public void consumeRead(final long size, long capacityUnit) {<a name="line.55"></a>
+<span class="sourceLineNo">056</span> // no-op<a name="line.56"></a>
+<span class="sourceLineNo">057</span> }<a name="line.57"></a>
+<span class="sourceLineNo">058</span><a name="line.58"></a>
+<span class="sourceLineNo">059</span> @Override<a name="line.59"></a>
+<span class="sourceLineNo">060</span> public boolean isBypass() {<a name="line.60"></a>
+<span class="sourceLineNo">061</span> return true;<a name="line.61"></a>
+<span class="sourceLineNo">062</span> }<a name="line.62"></a>
+<span class="sourceLineNo">063</span><a name="line.63"></a>
+<span class="sourceLineNo">064</span> @Override<a name="line.64"></a>
+<span class="sourceLineNo">065</span> public long getWriteAvailable() {<a name="line.65"></a>
+<span class="sourceLineNo">066</span> throw new UnsupportedOperationException();<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> @Override<a name="line.69"></a>
+<span class="sourceLineNo">070</span> public long getReadAvailable() {<a name="line.70"></a>
+<span class="sourceLineNo">071</span> throw new UnsupportedOperationException();<a name="line.71"></a>
+<span class="sourceLineNo">072</span> }<a name="line.72"></a>
+<span class="sourceLineNo">073</span><a name="line.73"></a>
+<span class="sourceLineNo">074</span> @Override<a name="line.74"></a>
+<span class="sourceLineNo">075</span> public String toString() {<a name="line.75"></a>
+<span class="sourceLineNo">076</span> return "NoopQuotaLimiter";<a name="line.76"></a>
+<span class="sourceLineNo">077</span> }<a name="line.77"></a>
+<span class="sourceLineNo">078</span><a name="line.78"></a>
+<span class="sourceLineNo">079</span> public static QuotaLimiter get() {<a name="line.79"></a>
+<span class="sourceLineNo">080</span> return instance;<a name="line.80"></a>
+<span class="sourceLineNo">081</span> }<a name="line.81"></a>
+<span class="sourceLineNo">082</span>}<a name="line.82"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
index ee8178a..878091b 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
@@ -28,59 +28,65 @@
<span class="sourceLineNo">020</span><a name="line.20"></a>
<span class="sourceLineNo">021</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.21"></a>
<span class="sourceLineNo">022</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.22"></a>
-<span class="sourceLineNo">023</span>import org.apache.hadoop.hbase.quotas.OperationQuota.OperationType;<a name="line.23"></a>
-<span class="sourceLineNo">024</span><a name="line.24"></a>
-<span class="sourceLineNo">025</span>/**<a name="line.25"></a>
-<span class="sourceLineNo">026</span> * Internal interface used to interact with the user/table quota.<a name="line.26"></a>
-<span class="sourceLineNo">027</span> */<a name="line.27"></a>
-<span class="sourceLineNo">028</span>@InterfaceAudience.Private<a name="line.28"></a>
-<span class="sourceLineNo">029</span>@InterfaceStability.Evolving<a name="line.29"></a>
-<span class="sourceLineNo">030</span>public interface QuotaLimiter {<a name="line.30"></a>
-<span class="sourceLineNo">031</span> /**<a name="line.31"></a>
-<span class="sourceLineNo">032</span> * Checks if it is possible to execute the specified operation.<a name="line.32"></a>
-<span class="sourceLineNo">033</span> *<a name="line.33"></a>
-<span class="sourceLineNo">034</span> * @param writeReqs the write requests that will be checked against the available quota<a name="line.34"></a>
-<span class="sourceLineNo">035</span> * @param estimateWriteSize the write size that will be checked against the available quota<a name="line.35"></a>
-<span class="sourceLineNo">036</span> * @param readReqs the read requests that will be checked against the available quota<a name="line.36"></a>
-<span class="sourceLineNo">037</span> * @param estimateReadSize the read size that will be checked against the available quota<a name="line.37"></a>
-<span class="sourceLineNo">038</span> * @throws RpcThrottlingException thrown if not enough available resources to perform operation.<a name="line.38"></a>
-<span class="sourceLineNo">039</span> */<a name="line.39"></a>
-<span class="sourceLineNo">040</span> void checkQuota(long writeReqs, long estimateWriteSize, long readReqs, long estimateReadSize)<a name="line.40"></a>
-<span class="sourceLineNo">041</span> throws RpcThrottlingException;<a name="line.41"></a>
-<span class="sourceLineNo">042</span><a name="line.42"></a>
-<span class="sourceLineNo">043</span> /**<a name="line.43"></a>
-<span class="sourceLineNo">044</span> * Removes the specified write and read amount from the quota.<a name="line.44"></a>
-<span class="sourceLineNo">045</span> * At this point the write and read amount will be an estimate,<a name="line.45"></a>
-<span class="sourceLineNo">046</span> * that will be later adjusted with a consumeWrite()/consumeRead() call.<a name="line.46"></a>
-<span class="sourceLineNo">047</span> *<a name="line.47"></a>
-<span class="sourceLineNo">048</span> * @param writeReqs the write requests that will be removed from the current quota<a name="line.48"></a>
-<span class="sourceLineNo">049</span> * @param writeSize the write size that will be removed from the current quota<a name="line.49"></a>
-<span class="sourceLineNo">050</span> * @param readReqs the read requests that will be removed from the current quota<a name="line.50"></a>
-<span class="sourceLineNo">051</span> * @param readSize the read size that will be removed from the current quota<a name="line.51"></a>
-<span class="sourceLineNo">052</span> */<a name="line.52"></a>
-<span class="sourceLineNo">053</span> void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize);<a name="line.53"></a>
-<span class="sourceLineNo">054</span><a name="line.54"></a>
-<span class="sourceLineNo">055</span> /**<a name="line.55"></a>
-<span class="sourceLineNo">056</span> * Removes or add back some write amount to the quota.<a name="line.56"></a>
-<span class="sourceLineNo">057</span> * (called at the end of an operation in case the estimate quota was off)<a name="line.57"></a>
-<span class="sourceLineNo">058</span> */<a name="line.58"></a>
-<span class="sourceLineNo">059</span> void consumeWrite(long size);<a name="line.59"></a>
+<span class="sourceLineNo">023</span><a name="line.23"></a>
+<span class="sourceLineNo">024</span>/**<a name="line.24"></a>
+<span class="sourceLineNo">025</span> * Internal interface used to interact with the user/table quota.<a name="line.25"></a>
+<span class="sourceLineNo">026</span> */<a name="line.26"></a>
+<span class="sourceLineNo">027</span>@InterfaceAudience.Private<a name="line.27"></a>
+<span class="sourceLineNo">028</span>@InterfaceStability.Evolving<a name="line.28"></a>
+<span class="sourceLineNo">029</span>public interface QuotaLimiter {<a name="line.29"></a>
+<span class="sourceLineNo">030</span> /**<a name="line.30"></a>
+<span class="sourceLineNo">031</span> * Checks if it is possible to execute the specified operation.<a name="line.31"></a>
+<span class="sourceLineNo">032</span> *<a name="line.32"></a>
+<span class="sourceLineNo">033</span> * @param writeReqs the write requests that will be checked against the available quota<a name="line.33"></a>
+<span class="sourceLineNo">034</span> * @param estimateWriteSize the write size that will be checked against the available quota<a name="line.34"></a>
+<span class="sourceLineNo">035</span> * @param readReqs the read requests that will be checked against the available quota<a name="line.35"></a>
+<span class="sourceLineNo">036</span> * @param estimateReadSize the read size that will be checked against the available quota<a name="line.36"></a>
+<span class="sourceLineNo">037</span> * @param estimateWriteCapacityUnit the write capacity unit that will be checked against the<a name="line.37"></a>
+<span class="sourceLineNo">038</span> * available quota<a name="line.38"></a>
+<span class="sourceLineNo">039</span> * @param estimateReadCapacityUnit the read capacity unit that will be checked against the<a name="line.39"></a>
+<span class="sourceLineNo">040</span> * available quota<a name="line.40"></a>
+<span class="sourceLineNo">041</span> * @throws RpcThrottlingException thrown if not enough available resources to perform operation.<a name="line.41"></a>
+<span class="sourceLineNo">042</span> */<a name="line.42"></a>
+<span class="sourceLineNo">043</span> void checkQuota(long writeReqs, long estimateWriteSize, long readReqs, long estimateReadSize,<a name="line.43"></a>
+<span class="sourceLineNo">044</span> long estimateWriteCapacityUnit, long estimateReadCapacityUnit) throws RpcThrottlingException;<a name="line.44"></a>
+<span class="sourceLineNo">045</span><a name="line.45"></a>
+<span class="sourceLineNo">046</span> /**<a name="line.46"></a>
+<span class="sourceLineNo">047</span> * Removes the specified write and read amount from the quota.<a name="line.47"></a>
+<span class="sourceLineNo">048</span> * At this point the write and read amount will be an estimate,<a name="line.48"></a>
+<span class="sourceLineNo">049</span> * that will be later adjusted with a consumeWrite()/consumeRead() call.<a name="line.49"></a>
+<span class="sourceLineNo">050</span> *<a name="line.50"></a>
+<span class="sourceLineNo">051</span> * @param writeReqs the write requests that will be removed from the current quota<a name="line.51"></a>
+<span class="sourceLineNo">052</span> * @param writeSize the write size that will be removed from the current quota<a name="line.52"></a>
+<span class="sourceLineNo">053</span> * @param readReqs the read requests that will be removed from the current quota<a name="line.53"></a>
+<span class="sourceLineNo">054</span> * @param readSize the read size that will be removed from the current quota<a name="line.54"></a>
+<span class="sourceLineNo">055</span> * @param writeCapacityUnit the write capacity unit that will be removed from the current quota<a name="line.55"></a>
+<span class="sourceLineNo">056</span> * @param readCapacityUnit the read capacity unit num that will be removed from the current quota<a name="line.56"></a>
+<span class="sourceLineNo">057</span> */<a name="line.57"></a>
+<span class="sourceLineNo">058</span> void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize,<a name="line.58"></a>
+<span class="sourceLineNo">059</span> long writeCapacityUnit, long readCapacityUnit);<a name="line.59"></a>
<span class="sourceLineNo">060</span><a name="line.60"></a>
<span class="sourceLineNo">061</span> /**<a name="line.61"></a>
-<span class="sourceLineNo">062</span> * Removes or add back some read amount to the quota.<a name="line.62"></a>
+<span class="sourceLineNo">062</span> * Removes or add back some write amount to the quota.<a name="line.62"></a>
<span class="sourceLineNo">063</span> * (called at the end of an operation in case the estimate quota was off)<a name="line.63"></a>
<span class="sourceLineNo">064</span> */<a name="line.64"></a>
-<span class="sourceLineNo">065</span> void consumeRead(long size);<a name="line.65"></a>
+<span class="sourceLineNo">065</span> void consumeWrite(long size, long capacityUnit);<a name="line.65"></a>
<span class="sourceLineNo">066</span><a name="line.66"></a>
-<span class="sourceLineNo">067</span> /** @return true if the limiter is a noop */<a name="line.67"></a>
-<span class="sourceLineNo">068</span> boolean isBypass();<a name="line.68"></a>
-<span class="sourceLineNo">069</span><a name="line.69"></a>
-<span class="sourceLineNo">070</span> /** @return the number of bytes available to read to avoid exceeding the quota */<a name="line.70"></a>
-<span class="sourceLineNo">071</span> long getReadAvailable();<a name="line.71"></a>
+<span class="sourceLineNo">067</span> /**<a name="line.67"></a>
+<span class="sourceLineNo">068</span> * Removes or add back some read amount to the quota.<a name="line.68"></a>
+<span class="sourceLineNo">069</span> * (called at the end of an operation in case the estimate quota was off)<a name="line.69"></a>
+<span class="sourceLineNo">070</span> */<a name="line.70"></a>
+<span class="sourceLineNo">071</span> void consumeRead(long size, long capacityUnit);<a name="line.71"></a>
<span class="sourceLineNo">072</span><a name="line.72"></a>
-<span class="sourceLineNo">073</span> /** @return the number of bytes available to write to avoid exceeding the quota */<a name="line.73"></a>
-<span class="sourceLineNo">074</span> long getWriteAvailable();<a name="line.74"></a>
-<span class="sourceLineNo">075</span>}<a name="line.75"></a>
+<span class="sourceLineNo">073</span> /** @return true if the limiter is a noop */<a name="line.73"></a>
+<span class="sourceLineNo">074</span> boolean isBypass();<a name="line.74"></a>
+<span class="sourceLineNo">075</span><a name="line.75"></a>
+<span class="sourceLineNo">076</span> /** @return the number of bytes available to read to avoid exceeding the quota */<a name="line.76"></a>
+<span class="sourceLineNo">077</span> long getReadAvailable();<a name="line.77"></a>
+<span class="sourceLineNo">078</span><a name="line.78"></a>
+<span class="sourceLineNo">079</span> /** @return the number of bytes available to write to avoid exceeding the quota */<a name="line.79"></a>
+<span class="sourceLineNo">080</span> long getWriteAvailable();<a name="line.80"></a>
+<span class="sourceLineNo">081</span>}<a name="line.81"></a>
[03/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/downloads.html
----------------------------------------------------------------------
diff --git a/downloads.html b/downloads.html
index 3d1fa93..5ec8a45 100644
--- a/downloads.html
+++ b/downloads.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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Apache HBase Downloads</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -461,7 +461,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/export_control.html
----------------------------------------------------------------------
diff --git a/export_control.html b/export_control.html
index f6570f0..b718e6e 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Export Control
@@ -341,7 +341,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/index.html
----------------------------------------------------------------------
diff --git a/index.html b/index.html
index 048ec54..8c9825e 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Apache HBaseâ„¢ Home</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -421,7 +421,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/integration.html
----------------------------------------------------------------------
diff --git a/integration.html b/integration.html
index fe14463..f62b6eb 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – CI Management</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -301,7 +301,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/issue-tracking.html
----------------------------------------------------------------------
diff --git a/issue-tracking.html b/issue-tracking.html
index ca30679..60cd1fa 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Issue Management</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -298,7 +298,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/license.html
----------------------------------------------------------------------
diff --git a/license.html b/license.html
index 874a038..ab4a29d 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Licenses</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -501,7 +501,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/mail-lists.html
----------------------------------------------------------------------
diff --git a/mail-lists.html b/mail-lists.html
index 3214b3e..5e60ec9 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Mailing Lists</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -351,7 +351,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/metrics.html
----------------------------------------------------------------------
diff --git a/metrics.html b/metrics.html
index c997bd0..fcfd43e 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Apache HBase (TM) Metrics
@@ -469,7 +469,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/old_news.html
----------------------------------------------------------------------
diff --git a/old_news.html b/old_news.html
index d7384c1..20487f5 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Old Apache HBase (TM) News
@@ -450,7 +450,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/plugin-management.html
----------------------------------------------------------------------
diff --git a/plugin-management.html b/plugin-management.html
index 7052e48..6c823bf 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Plugin Management</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -450,7 +450,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/plugins.html
----------------------------------------------------------------------
diff --git a/plugins.html b/plugins.html
index f057ddc..7ef6f28 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Plugins</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -381,7 +381,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/poweredbyhbase.html
----------------------------------------------------------------------
diff --git a/poweredbyhbase.html b/poweredbyhbase.html
index 5b09648..c8c4378 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Powered By Apache HBase™</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -779,7 +779,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/project-info.html
----------------------------------------------------------------------
diff --git a/project-info.html b/project-info.html
index a54f396..8e6866a 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Information</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -345,7 +345,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/project-reports.html
----------------------------------------------------------------------
diff --git a/project-reports.html b/project-reports.html
index f1cd3c1..cd7d9d5 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Generated Reports</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -315,7 +315,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/project-summary.html
----------------------------------------------------------------------
diff --git a/project-summary.html b/project-summary.html
index e37e2a7..2c0041a 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Summary</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/pseudo-distributed.html
----------------------------------------------------------------------
diff --git a/pseudo-distributed.html b/pseudo-distributed.html
index b8656a1..2d4a02f 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Running Apache HBase (TM) in pseudo-distributed mode
@@ -318,7 +318,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/replication.html
----------------------------------------------------------------------
diff --git a/replication.html b/replication.html
index 3a8c75b..52229e0 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Apache HBase (TM) Replication
@@ -313,7 +313,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/resources.html
----------------------------------------------------------------------
diff --git a/resources.html b/resources.html
index 07b901e..71b16aa 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<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.4-HBase.min.css" />
@@ -341,7 +341,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/source-repository.html
----------------------------------------------------------------------
diff --git a/source-repository.html b/source-repository.html
index 8a50ce0..a2fb6cc 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Source Code Management</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -309,7 +309,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/sponsors.html
----------------------------------------------------------------------
diff --git a/sponsors.html b/sponsors.html
index a546445..027227a 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Apache HBase™ Sponsors</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -343,7 +343,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/supportingprojects.html
----------------------------------------------------------------------
diff --git a/supportingprojects.html b/supportingprojects.html
index c9bea28..c8ba6de 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Supporting Projects</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -530,7 +530,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/team-list.html
----------------------------------------------------------------------
diff --git a/team-list.html b/team-list.html
index 8ccd744..43c98fd 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Team</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -776,7 +776,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/allclasses-frame.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/allclasses-frame.html b/testdevapidocs/allclasses-frame.html
index 31516e6..43d1254 100644
--- a/testdevapidocs/allclasses-frame.html
+++ b/testdevapidocs/allclasses-frame.html
@@ -1762,6 +1762,8 @@
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaStatusRPCs.html" title="class in org.apache.hadoop.hbase.quotas" target="classFrame">TestQuotaStatusRPCs</a></li>
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaTableUtil.html" title="class in org.apache.hadoop.hbase.quotas" target="classFrame">TestQuotaTableUtil</a></li>
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas" target="classFrame">TestQuotaThrottle</a></li>
+<li><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestRaceBetweenGetWALAndGetWALs</a></li>
+<li><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></li>
<li><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html" title="class in org.apache.hadoop.hbase.replication.regionserver" target="classFrame">TestRaceWhenCreatingReplicationSource</a></li>
<li><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.LocalReplicationEndpoint.html" title="class in org.apache.hadoop.hbase.replication.regionserver" target="classFrame">TestRaceWhenCreatingReplicationSource.LocalReplicationEndpoint</a></li>
<li><a href="org/apache/hadoop/hbase/filter/TestRandomRowFilter.html" title="class in org.apache.hadoop.hbase.filter" target="classFrame">TestRandomRowFilter</a></li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/allclasses-noframe.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/allclasses-noframe.html b/testdevapidocs/allclasses-noframe.html
index 349145b..059d28a 100644
--- a/testdevapidocs/allclasses-noframe.html
+++ b/testdevapidocs/allclasses-noframe.html
@@ -1762,6 +1762,8 @@
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaStatusRPCs.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaStatusRPCs</a></li>
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaTableUtil.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaTableUtil</a></li>
<li><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></li>
+<li><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></li>
+<li><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></li>
<li><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html" title="class in org.apache.hadoop.hbase.replication.regionserver">TestRaceWhenCreatingReplicationSource</a></li>
<li><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.LocalReplicationEndpoint.html" title="class in org.apache.hadoop.hbase.replication.regionserver">TestRaceWhenCreatingReplicationSource.LocalReplicationEndpoint</a></li>
<li><a href="org/apache/hadoop/hbase/filter/TestRandomRowFilter.html" title="class in org.apache.hadoop.hbase.filter">TestRandomRowFilter</a></li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/index-all.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/index-all.html b/testdevapidocs/index-all.html
index 5f3d0f7..ae3d656 100644
--- a/testdevapidocs/index-all.html
+++ b/testdevapidocs/index-all.html
@@ -6753,6 +6753,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestFSHLogProvider.html#CLASS_RULE">CLASS_RULE</a></span> - Static variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal">TestFSHLogProvider</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#CLASS_RULE">CLASS_RULE</a></span> - Static variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html#CLASS_RULE">CLASS_RULE</a></span> - Static variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal">TestReadWriteSeqIdFiles</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestSecureWAL.html#CLASS_RULE">CLASS_RULE</a></span> - Static variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestSecureWAL.html" title="class in org.apache.hadoop.hbase.wal">TestSecureWAL</a></dt>
@@ -11090,6 +11092,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/IOTestProvider.html#createWAL--">createWAL()</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/IOTestProvider.html" title="class in org.apache.hadoop.hbase.wal">IOTestProvider</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#createWAL--">createWAL()</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/TestHRegion.html#createWALCompatibleWithFaultyFileSystem-java.lang.String-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.TableName-">createWALCompatibleWithFaultyFileSystem(String, Configuration, TableName)</a></span> - Static method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/TestHRegion.html" title="class in org.apache.hadoop.hbase.regionserver">TestHRegion</a></dt>
<dd>
<div class="block">Create a WAL outside of the usual helper in
@@ -12572,6 +12576,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/mapreduce/TestHFileOutputFormat2.html#doIncrementalLoadTest-boolean-boolean-boolean-java.util.List-">doIncrementalLoadTest(boolean, boolean, boolean, List<String>)</a></span> - Method in class org.apache.hadoop.hbase.mapreduce.<a href="org/apache/hadoop/hbase/mapreduce/TestHFileOutputFormat2.html" title="class in org.apache.hadoop.hbase.mapreduce">TestHFileOutputFormat2</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#doInit-org.apache.hadoop.conf.Configuration-">doInit(Configuration)</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/test/IntegrationTestLoadAndVerify.html#doLoad-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.HTableDescriptor-">doLoad(Configuration, HTableDescriptor)</a></span> - Method in class org.apache.hadoop.hbase.test.<a href="org/apache/hadoop/hbase/test/IntegrationTestLoadAndVerify.html" title="class in org.apache.hadoop.hbase.test">IntegrationTestLoadAndVerify</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/test/IntegrationTestWithCellVisibilityLoadAndVerify.html#doLoad-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.HTableDescriptor-">doLoad(Configuration, HTableDescriptor)</a></span> - Method in class org.apache.hadoop.hbase.test.<a href="org/apache/hadoop/hbase/test/IntegrationTestWithCellVisibilityLoadAndVerify.html" title="class in org.apache.hadoop.hbase.test">IntegrationTestWithCellVisibilityLoadAndVerify</a></dt>
@@ -12661,6 +12667,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#doPuts-int-org.apache.hadoop.hbase.client.Table...-">doPuts(int, Table...)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#doPuts-int-int-org.apache.hadoop.hbase.client.Table...-">doPuts(int, int, Table...)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/security/visibility/TestVisibilityLabelsWithDeletes.html#doPuts-org.apache.hadoop.hbase.TableName-">doPuts(TableName)</a></span> - Method in class org.apache.hadoop.hbase.security.visibility.<a href="org/apache/hadoop/hbase/security/visibility/TestVisibilityLabelsWithDeletes.html" title="class in org.apache.hadoop.hbase.security.visibility">TestVisibilityLabelsWithDeletes</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/security/visibility/TestVisibilityLabelsWithDeletes.html#doPutsWithDiffCols-org.apache.hadoop.hbase.TableName-">doPutsWithDiffCols(TableName)</a></span> - Method in class org.apache.hadoop.hbase.security.visibility.<a href="org/apache/hadoop/hbase/security/visibility/TestVisibilityLabelsWithDeletes.html" title="class in org.apache.hadoop.hbase.security.visibility">TestVisibilityLabelsWithDeletes</a></dt>
@@ -15658,6 +15666,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/util/TestFSTableDescriptors.FSTableDescriptorsTest.html#FSTableDescriptorsTest-org.apache.hadoop.conf.Configuration-org.apache.hadoop.fs.FileSystem-org.apache.hadoop.fs.Path-boolean-boolean-">FSTableDescriptorsTest(Configuration, FileSystem, Path, boolean, boolean)</a></span> - Constructor for class org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/TestFSTableDescriptors.FSTableDescriptorsTest.html" title="class in org.apache.hadoop.hbase.util">TestFSTableDescriptors.FSTableDescriptorsTest</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#FSWALProvider--">FSWALProvider()</a></span> - Constructor for class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/FaultyFSLog.html#ft">ft</a></span> - Variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/FaultyFSLog.html" title="class in org.apache.hadoop.hbase.wal">FaultyFSLog</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestSpaceQuotasWithSnapshots.html#FUDGE_FOR_TABLE_SIZE">FUDGE_FOR_TABLE_SIZE</a></span> - Static variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestSpaceQuotasWithSnapshots.html" title="class in org.apache.hadoop.hbase.quotas">TestSpaceQuotasWithSnapshots</a></dt>
@@ -15867,6 +15877,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/IntegrationTestLazyCfLoading.DataGenerator.html#generateValue-byte:A-byte:A-byte:A-">generateValue(byte[], byte[], byte[])</a></span> - Method in class org.apache.hadoop.hbase.<a href="org/apache/hadoop/hbase/IntegrationTestLazyCfLoading.DataGenerator.html" title="class in org.apache.hadoop.hbase">IntegrationTestLazyCfLoading.DataGenerator</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#generateValue-int-">generateValue(int)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/CreateRandomStoreFile.html#generateValue--">generateValue()</a></span> - Method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/CreateRandomStoreFile.html" title="class in org.apache.hadoop.hbase.regionserver">CreateRandomStoreFile</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/rest/PerformanceEvaluation.html#generateValue-java.util.Random-">generateValue(Random)</a></span> - Static method in class org.apache.hadoop.hbase.rest.<a href="org/apache/hadoop/hbase/rest/PerformanceEvaluation.html" title="class in org.apache.hadoop.hbase.rest">PerformanceEvaluation</a></dt>
@@ -15992,6 +16004,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/test/IntegrationTestTimeBoundedRequestsWithRegionReplicas.html#GET_TIMEOUT_KEY">GET_TIMEOUT_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.test.<a href="org/apache/hadoop/hbase/test/IntegrationTestTimeBoundedRequestsWithRegionReplicas.html" title="class in org.apache.hadoop.hbase.test">IntegrationTestTimeBoundedRequestsWithRegionReplicas</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#GET_WALS_FUTURE">GET_WALS_FUTURE</a></span> - Static variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/security/access/SecureTestUtil.html#getAccessControllers-org.apache.hadoop.hbase.MiniHBaseCluster-">getAccessControllers(MiniHBaseCluster)</a></span> - Static method in class org.apache.hadoop.hbase.security.access.<a href="org/apache/hadoop/hbase/security/access/SecureTestUtil.html" title="class in org.apache.hadoop.hbase.security.access">SecureTestUtil</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/IntegrationTestDDLMasterFailover.Worker.html#getAction--">getAction()</a></span> - Method in class org.apache.hadoop.hbase.<a href="org/apache/hadoop/hbase/IntegrationTestDDLMasterFailover.Worker.html" title="class in org.apache.hadoop.hbase">IntegrationTestDDLMasterFailover.Worker</a></dt>
@@ -59391,11 +59405,21 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html#testRace--">testRace()</a></span> - Method in class org.apache.hadoop.hbase.replication.regionserver.<a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html" title="class in org.apache.hadoop.hbase.replication.regionserver">TestRaceWhenCreatingReplicationSource</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#testRace--">testRace()</a></span> - Method in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/TestScanner.html#testRaceBetweenClientAndTimeout--">testRaceBetweenClientAndTimeout()</a></span> - Method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/TestScanner.html" title="class in org.apache.hadoop.hbase.regionserver">TestScanner</a></dt>
<dd>
<div class="block">Test that closing a scanner while a client is using it doesn't throw
NPEs but instead a UnknownScannerException.</div>
</dd>
+<dt><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs</span></a> - Class in <a href="org/apache/hadoop/hbase/wal/package-summary.html">org.apache.hadoop.hbase.wal</a></dt>
+<dd>
+<div class="block">Testcase for HBASE-21503.</div>
+</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#TestRaceBetweenGetWALAndGetWALs--">TestRaceBetweenGetWALAndGetWALs()</a></span> - Constructor for class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></dt>
+<dd> </dd>
+<dt><a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</span></a> - Class in <a href="org/apache/hadoop/hbase/wal/package-summary.html">org.apache.hadoop.hbase.wal</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/TestSplitLogWorker.html#testRaceForTask--">testRaceForTask()</a></span> - Method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/TestSplitLogWorker.html" title="class in org.apache.hadoop.hbase.regionserver">TestSplitLogWorker</a></dt>
<dd> </dd>
<dt><a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html" title="class in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">TestRaceWhenCreatingReplicationSource</span></a> - Class in <a href="org/apache/hadoop/hbase/replication/regionserver/package-summary.html">org.apache.hadoop.hbase.replication.regionserver</a></dt>
@@ -63275,6 +63299,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveRPCQuota--">testSetGetRemoveRPCQuota()</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaAdmin</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveRPCQuota-org.apache.hadoop.hbase.quotas.ThrottleType-">testSetGetRemoveRPCQuota(ThrottleType)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaAdmin</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveSpaceQuota--">testSetGetRemoveSpaceQuota()</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaAdmin</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/mapreduce/TestMultiTableSnapshotInputFormatImpl.html#testSetInputCreatesRestoreDirectoriesUnderRootRestoreDir--">testSetInputCreatesRestoreDirectoriesUnderRootRestoreDir()</a></span> - Method in class org.apache.hadoop.hbase.mapreduce.<a href="org/apache/hadoop/hbase/mapreduce/TestMultiTableSnapshotInputFormatImpl.html" title="class in org.apache.hadoop.hbase.mapreduce">TestMultiTableSnapshotInputFormatImpl</a></dt>
@@ -65290,6 +65316,8 @@
</dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestTableQuotaViolationStore.html#TestTableQuotaViolationStore--">TestTableQuotaViolationStore()</a></span> - Constructor for class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestTableQuotaViolationStore.html" title="class in org.apache.hadoop.hbase.quotas">TestTableQuotaViolationStore</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableReadCapacityUnitThrottle--">testTableReadCapacityUnitThrottle()</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/mapred/TestTableInputFormat.html#testTableRecordReader--">testTableRecordReader()</a></span> - Method in class org.apache.hadoop.hbase.mapred.<a href="org/apache/hadoop/hbase/mapred/TestTableInputFormat.html" title="class in org.apache.hadoop.hbase.mapred">TestTableInputFormat</a></dt>
<dd>
<div class="block">Run test assuming no errors using mapred api.</div>
@@ -65451,6 +65479,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/TestMetricsTableLatencies.html#testTableWrapperAggregateMetrics--">testTableWrapperAggregateMetrics()</a></span> - Method in class org.apache.hadoop.hbase.regionserver.<a href="org/apache/hadoop/hbase/regionserver/TestMetricsTableLatencies.html" title="class in org.apache.hadoop.hbase.regionserver">TestMetricsTableLatencies</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableWriteCapacityUnitThrottle--">testTableWriteCapacityUnitThrottle()</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas">TestQuotaThrottle</a></dt>
+<dd> </dd>
<dt><a href="org/apache/hadoop/hbase/io/TestTagCompressionContext.html" title="class in org.apache.hadoop.hbase.io"><span class="typeNameLink">TestTagCompressionContext</span></a> - Class in <a href="org/apache/hadoop/hbase/io/package-summary.html">org.apache.hadoop.hbase.io</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/TestTagCompressionContext.html#TestTagCompressionContext--">TestTagCompressionContext()</a></span> - Constructor for class org.apache.hadoop.hbase.io.<a href="org/apache/hadoop/hbase/io/TestTagCompressionContext.html" title="class in org.apache.hadoop.hbase.io">TestTagCompressionContext</a></dt>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/class-use/HBaseClassTestRule.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/class-use/HBaseClassTestRule.html b/testdevapidocs/org/apache/hadoop/hbase/class-use/HBaseClassTestRule.html
index b8100d8..d856cb4 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/class-use/HBaseClassTestRule.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/class-use/HBaseClassTestRule.html
@@ -6841,42 +6841,46 @@
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALSplitBoundedLogWriterCreation.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplitBoundedLogWriterCreation.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestRaceBetweenGetWALAndGetWALs.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALMethods.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALMethods.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestWALSplitBoundedLogWriterCreation.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplitBoundedLogWriterCreation.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALOpenAfterDNRollingStart.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALOpenAfterDNRollingStart.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestWALMethods.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALMethods.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestReadWriteSeqIdFiles.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestWALOpenAfterDNRollingStart.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALOpenAfterDNRollingStart.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALReaderOnSecureWAL.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALReaderOnSecureWAL.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestReadWriteSeqIdFiles.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestSecureWAL.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestSecureWAL.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestWALReaderOnSecureWAL.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALReaderOnSecureWAL.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestBoundedRegionGroupingStrategy.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestBoundedRegionGroupingStrategy.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestSecureWAL.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestSecureWAL.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALRootDir.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALRootDir.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestBoundedRegionGroupingStrategy.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestBoundedRegionGroupingStrategy.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TestWALSplitCompressed.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplitCompressed.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TestWALRootDir.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALRootDir.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
+<td class="colLast"><span class="typeNameLabel">TestWALSplitCompressed.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplitCompressed.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
<td class="colLast"><span class="typeNameLabel">TestDisabledWAL.</span><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestDisabledWAL.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
</tr>
</tbody>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/package-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/package-tree.html b/testdevapidocs/org/apache/hadoop/hbase/package-tree.html
index d751ccc..1add7db 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -579,15 +579,15 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/ClusterManager.ServiceType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterManager.ServiceType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ScanPerformanceEvaluation.ScanCounter.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ScanPerformanceEvaluation.ScanCounter</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ResourceChecker.Phase.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ResourceChecker.Phase</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/RESTApiClusterManager.RoleCommand.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">RESTApiClusterManager.RoleCommand</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/IntegrationTestRegionReplicaPerf.Stat.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">IntegrationTestRegionReplicaPerf.Stat</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/IntegrationTestDDLMasterFailover.ACTION.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">IntegrationTestDDLMasterFailover.ACTION</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/RESTApiClusterManager.Service.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">RESTApiClusterManager.Service</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HBaseClusterManager.CommandProvider.Operation.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HBaseClusterManager.CommandProvider.Operation</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/IntegrationTestDDLMasterFailover.ACTION.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">IntegrationTestDDLMasterFailover.ACTION</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/RESTApiClusterManager.RoleCommand.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">RESTApiClusterManager.RoleCommand</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/PerformanceEvaluation.Counter.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">PerformanceEvaluation.Counter</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ScanPerformanceEvaluation.ScanCounter.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ScanPerformanceEvaluation.ScanCounter</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HBaseClusterManager.CommandProvider.Operation.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HBaseClusterManager.CommandProvider.Operation</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/IntegrationTestRegionReplicaPerf.Stat.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">IntegrationTestRegionReplicaPerf.Stat</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ResourceChecker.Phase.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ResourceChecker.Phase</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/ClusterManager.ServiceType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">ClusterManager.ServiceType</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html b/testdevapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
index 46cc200..0673e84 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -234,10 +234,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.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestStateMachineProcedure.TestSMProcedureState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestStateMachineProcedure.TestSMProcedureState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestProcedureBypass.StuckStateMachineState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestProcedureBypass.StuckStateMachineState</span></a></li>
<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestYieldProcedures.TestStateMachineProcedure.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestYieldProcedures.TestStateMachineProcedure.State</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestStateMachineProcedure.TestSMProcedureState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestStateMachineProcedure.TestSMProcedureState</span></a></li>
<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestProcedureRecovery.TestStateMachineProcedure.State.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestProcedureRecovery.TestStateMachineProcedure.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.procedure2.<a href="../../../../../org/apache/hadoop/hbase/procedure2/TestProcedureBypass.StuckStateMachineState.html" title="enum in org.apache.hadoop.hbase.procedure2"><span class="typeNameLink">TestProcedureBypass.StuckStateMachineState</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html b/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
index 353d658..2a3f528 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html
@@ -18,7 +18,7 @@
catch(err) {
}
//-->
-var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":9,"i8":9,"i9":10,"i10":10,"i11":10,"i12":10,"i13":10,"i14":10,"i15":10,"i16":10,"i17":10,"i18":10,"i19":10,"i20":10};
+var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":9,"i8":9,"i9":10,"i10":10,"i11":10,"i12":10,"i13":10,"i14":10,"i15":10,"i16":10,"i17":10,"i18":10,"i19":10,"i20":10,"i21":10};
var tabs = {65535:["t0","All Methods"],1:["t1","Static Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
@@ -234,41 +234,45 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveRPCQuota--">testSetGetRemoveRPCQuota</a></span>()</code> </td>
</tr>
<tr id="i12" class="altColor">
+<td class="colFirst"><code>private void</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveRPCQuota-org.apache.hadoop.hbase.quotas.ThrottleType-">testSetGetRemoveRPCQuota</a></span>(org.apache.hadoop.hbase.quotas.ThrottleType throttleType)</code> </td>
+</tr>
+<tr id="i13" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetGetRemoveSpaceQuota--">testSetGetRemoveSpaceQuota</a></span>()</code> </td>
</tr>
-<tr id="i13" class="rowColor">
+<tr id="i14" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetModifyRemoveRPCQuota--">testSetModifyRemoveRPCQuota</a></span>()</code> </td>
</tr>
-<tr id="i14" class="altColor">
+<tr id="i15" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSetModifyRemoveSpaceQuota--">testSetModifyRemoveSpaceQuota</a></span>()</code> </td>
</tr>
-<tr id="i15" class="rowColor">
+<tr id="i16" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testSimpleScan--">testSimpleScan</a></span>()</code> </td>
</tr>
-<tr id="i16" class="altColor">
+<tr id="i17" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#testThrottleType--">testThrottleType</a></span>()</code> </td>
</tr>
-<tr id="i17" class="rowColor">
+<tr id="i18" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#verifyFetchableViaAPI-org.apache.hadoop.hbase.client.Admin-org.apache.hadoop.hbase.quotas.ThrottleType-long-java.util.concurrent.TimeUnit-">verifyFetchableViaAPI</a></span>(org.apache.hadoop.hbase.client.Admin admin,
org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> tu)</code> </td>
</tr>
-<tr id="i18" class="altColor">
+<tr id="i19" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#verifyNotFetchableViaAPI-org.apache.hadoop.hbase.client.Admin-">verifyNotFetchableViaAPI</a></span>(org.apache.hadoop.hbase.client.Admin admin)</code> </td>
</tr>
-<tr id="i19" class="rowColor">
+<tr id="i20" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#verifyRecordNotPresentInQuotaTable--">verifyRecordNotPresentInQuotaTable</a></span>()</code> </td>
</tr>
-<tr id="i20" class="altColor">
+<tr id="i21" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#verifyRecordPresentInQuotaTable-org.apache.hadoop.hbase.quotas.ThrottleType-long-java.util.concurrent.TimeUnit-">verifyRecordPresentInQuotaTable</a></span>(org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
@@ -503,13 +507,27 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</dl>
</li>
</ul>
+<a name="testSetGetRemoveRPCQuota-org.apache.hadoop.hbase.quotas.ThrottleType-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>testSetGetRemoveRPCQuota</h4>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.462">testSetGetRemoveRPCQuota</a>(org.apache.hadoop.hbase.quotas.ThrottleType throttleType)
+ 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>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
<a name="testSetModifyRemoveRPCQuota--">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>testSetModifyRemoveRPCQuota</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.482">testSetModifyRemoveRPCQuota</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.487">testSetModifyRemoveRPCQuota</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>
@@ -523,7 +541,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>verifyRecordPresentInQuotaTable</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.518">verifyRecordPresentInQuotaTable</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.523">verifyRecordPresentInQuotaTable</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> tu)
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>
@@ -539,7 +557,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>verifyRecordNotPresentInQuotaTable</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.530">verifyRecordNotPresentInQuotaTable</a>()
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.535">verifyRecordNotPresentInQuotaTable</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>
@@ -553,7 +571,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>verifyFetchableViaAPI</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.538">verifyFetchableViaAPI</a>(org.apache.hadoop.hbase.client.Admin admin,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.543">verifyFetchableViaAPI</a>(org.apache.hadoop.hbase.client.Admin admin,
org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> tu)
@@ -570,7 +588,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>verifyNotFetchableViaAPI</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.546">verifyNotFetchableViaAPI</a>(org.apache.hadoop.hbase.client.Admin admin)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.551">verifyNotFetchableViaAPI</a>(org.apache.hadoop.hbase.client.Admin admin)
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 +602,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>assertRPCQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.553">assertRPCQuota</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.558">assertRPCQuota</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> tu,
org.apache.hadoop.hbase.Cell cell)
@@ -601,7 +619,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>assertRPCQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.593">assertRPCQuota</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.611">assertRPCQuota</a>(org.apache.hadoop.hbase.quotas.ThrottleType type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> tu,
org.apache.hadoop.hbase.quotas.QuotaSettings actualSettings)
@@ -618,7 +636,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>assertSpaceQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.604">assertSpaceQuota</a>(long sizeLimit,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.622">assertSpaceQuota</a>(long sizeLimit,
org.apache.hadoop.hbase.quotas.SpaceViolationPolicy violationPolicy,
org.apache.hadoop.hbase.Cell cell)
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>
@@ -634,7 +652,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>assertSpaceQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.614">assertSpaceQuota</a>(long sizeLimit,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.632">assertSpaceQuota</a>(long sizeLimit,
org.apache.hadoop.hbase.quotas.SpaceViolationPolicy violationPolicy,
org.apache.hadoop.hbase.quotas.QuotaSettings actualSettings)</pre>
</li>
@@ -645,7 +663,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>countResults</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.624">countResults</a>(org.apache.hadoop.hbase.quotas.QuotaFilter filter)
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaAdmin.html#line.642">countResults</a>(org.apache.hadoop.hbase.quotas.QuotaFilter filter)
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>
[13/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.html b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.html
index f3731d4..c85704a 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.html
@@ -164,6 +164,14 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<th class="colLast" scope="col">Field and Description</th>
</tr>
<tr class="altColor">
+<td class="colFirst"><code>static long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_READ_CAPACITY_UNIT">DEFAULT_READ_CAPACITY_UNIT</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>static long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_WRITE_CAPACITY_UNIT">DEFAULT_WRITE_CAPACITY_UNIT</a></span></code> </td>
+</tr>
+<tr class="altColor">
<td class="colFirst"><code>private static org.slf4j.Logger</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.html#LOG">LOG</a></span></code> </td>
</tr>
@@ -181,6 +189,14 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<div class="block">Table descriptor for Quota internal table</div>
</td>
</tr>
+<tr class="altColor">
+<td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.html#READ_CAPACITY_UNIT_CONF_KEY">READ_CAPACITY_UNIT_CONF_KEY</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.html#WRITE_CAPACITY_UNIT_CONF_KEY">WRITE_CAPACITY_UNIT_CONF_KEY</a></span></code> </td>
+</tr>
</table>
<ul class="blockList">
<li class="blockList"><a name="fields.inherited.from.class.org.apache.hadoop.hbase.quotas.QuotaTableUtil">
@@ -417,13 +433,65 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
</dl>
</li>
</ul>
+<a name="READ_CAPACITY_UNIT_CONF_KEY">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>READ_CAPACITY_UNIT_CONF_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/quotas/QuotaUtil.html#line.60">READ_CAPACITY_UNIT_CONF_KEY</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.quotas.QuotaUtil.READ_CAPACITY_UNIT_CONF_KEY">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
+<a name="DEFAULT_READ_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>DEFAULT_READ_CAPACITY_UNIT</h4>
+<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.62">DEFAULT_READ_CAPACITY_UNIT</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.quotas.QuotaUtil.DEFAULT_READ_CAPACITY_UNIT">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
+<a name="WRITE_CAPACITY_UNIT_CONF_KEY">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>WRITE_CAPACITY_UNIT_CONF_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/quotas/QuotaUtil.html#line.63">WRITE_CAPACITY_UNIT_CONF_KEY</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.quotas.QuotaUtil.WRITE_CAPACITY_UNIT_CONF_KEY">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
+<a name="DEFAULT_WRITE_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>DEFAULT_WRITE_CAPACITY_UNIT</h4>
+<pre>public static final long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.65">DEFAULT_WRITE_CAPACITY_UNIT</a></pre>
+<dl>
+<dt><span class="seeLabel">See Also:</span></dt>
+<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.quotas.QuotaUtil.DEFAULT_WRITE_CAPACITY_UNIT">Constant Field Values</a></dd>
+</dl>
+</li>
+</ul>
<a name="QUOTA_TABLE_DESC">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>QUOTA_TABLE_DESC</h4>
-<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/HTableDescriptor.html" title="class in org.apache.hadoop.hbase">HTableDescriptor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.61">QUOTA_TABLE_DESC</a></pre>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/HTableDescriptor.html" title="class in org.apache.hadoop.hbase">HTableDescriptor</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.68">QUOTA_TABLE_DESC</a></pre>
<div class="block">Table descriptor for Quota internal table</div>
</li>
</ul>
@@ -458,7 +526,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>isQuotaEnabled</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.79">isQuotaEnabled</a>(org.apache.hadoop.conf.Configuration conf)</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.86">isQuotaEnabled</a>(org.apache.hadoop.conf.Configuration conf)</pre>
<div class="block">Returns true if the support for quota is enabled</div>
</li>
</ul>
@@ -468,7 +536,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addTableQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.86">addTableQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.93">addTableQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
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>
@@ -484,7 +552,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteTableQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.91">deleteTableQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.98">deleteTableQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</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>
<dl>
@@ -499,7 +567,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addNamespaceQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.96">addNamespaceQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.103">addNamespaceQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
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>
@@ -515,7 +583,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteNamespaceQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.101">deleteNamespaceQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.108">deleteNamespaceQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace)
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>
@@ -530,7 +598,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.106">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.113">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
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>
@@ -546,7 +614,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.111">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.118">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
@@ -563,7 +631,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.116">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.123">addUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
@@ -580,7 +648,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.122">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.129">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user)
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>
@@ -595,7 +663,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.127">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.134">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</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>
@@ -611,7 +679,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteUserQuota</h4>
-<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.133">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.140">deleteUserQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> user,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace)
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>
@@ -627,7 +695,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addQuotas</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.139">addQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.146">addQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
byte[] rowKey,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
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>
@@ -643,7 +711,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>addQuotas</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.144">addQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.151">addQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
byte[] rowKey,
byte[] qualifier,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Quotas data)
@@ -660,7 +728,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteQuotas</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.151">deleteQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.158">deleteQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
byte[] rowKey)
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>
@@ -675,7 +743,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>deleteQuotas</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.156">deleteQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.163">deleteQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
byte[] rowKey,
byte[] qualifier)
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>
@@ -691,7 +759,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>fetchUserQuotas</h4>
-<pre>public static <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/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/UserQuotaState.html" title="class in org.apache.hadoop.hbase.quotas">UserQuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.165">fetchUserQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static <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/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/UserQuotaState.html" title="class in org.apache.hadoop.hbase.quotas">UserQuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.172">fetchUserQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<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/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>> gets)
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>
@@ -706,7 +774,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>fetchTableQuotas</h4>
-<pre>public static <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="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.207">fetchTableQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static <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="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.214">fetchTableQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<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/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>> gets)
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>
@@ -721,7 +789,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>fetchNamespaceQuotas</h4>
-<pre>public static <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/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.218">fetchNamespaceQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>public static <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/lang/String.html?is-external=true" title="class or interface in java.lang">String</a>,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.225">fetchNamespaceQuotas</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<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/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>> gets)
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>
@@ -736,7 +804,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>fetchGlobalQuotas</h4>
-<pre>public static <K> <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><K,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.229">fetchGlobalQuotas</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> type,
+<pre>public static <K> <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><K,<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaState.html" title="class in org.apache.hadoop.hbase.quotas">QuotaState</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.236">fetchGlobalQuotas</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> type,
<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<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/Get.html" title="class in org.apache.hadoop.hbase.client">Get</a>> gets,
<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaUtil.KeyFromRow</a><K> kfr)
@@ -753,7 +821,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>doPut</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.267">doPut</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.274">doPut</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="../../../../../org/apache/hadoop/hbase/client/Put.html" title="class in org.apache.hadoop.hbase.client">Put</a> put)
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>
@@ -768,7 +836,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>doDelete</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.274">doDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.281">doDelete</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Connection.html" title="interface in org.apache.hadoop.hbase.client">Connection</a> connection,
<a href="../../../../../org/apache/hadoop/hbase/client/Delete.html" title="class in org.apache.hadoop.hbase.client">Delete</a> delete)
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>
@@ -783,7 +851,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>calculateMutationSize</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.284">calculateMutationSize</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a> mutation)</pre>
+<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.291">calculateMutationSize</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a> mutation)</pre>
</li>
</ul>
<a name="calculateResultSize-org.apache.hadoop.hbase.client.Result-">
@@ -792,7 +860,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockList">
<li class="blockList">
<h4>calculateResultSize</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.294">calculateResultSize</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> result)</pre>
+<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.301">calculateResultSize</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> result)</pre>
</li>
</ul>
<a name="calculateResultSize-java.util.List-">
@@ -801,7 +869,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaTableUtil.ht
<ul class="blockListLast">
<li class="blockList">
<h4>calculateResultSize</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.302">calculateResultSize</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> results)</pre>
+<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.309">calculateResultSize</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> results)</pre>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html b/devapidocs/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
index 5388bef..bfe5221 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
@@ -366,7 +366,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.132">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.133">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas">OperationQuota.OperationType</a> type)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
@@ -391,7 +391,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.151">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.152">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
<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.shaded.protobuf.generated.ClientProtos.Action> actions)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
@@ -416,7 +416,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.176">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html#line.177">checkQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.html" title="interface in org.apache.hadoop.hbase.regionserver">Region</a> region,
int numWrites,
int numReads,
int numScans)
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleSettings.html b/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
index 11f8ae6..5c02889 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
@@ -380,7 +380,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.htm
<ul class="blockList">
<li class="blockList">
<h4>merge</h4>
-<pre>protected <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleSettings.html" title="class in org.apache.hadoop.hbase.quotas">ThrottleSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.115">merge</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> other)
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleSettings.html" title="class in org.apache.hadoop.hbase.quotas">ThrottleSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.121">merge</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> other)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from class: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html#merge-org.apache.hadoop.hbase.quotas.QuotaSettings-">QuotaSettings</a></code></span></div>
<div class="block">Merges the provided settings with <code>this</code> and returns a new settings
@@ -403,7 +403,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.htm
<ul class="blockList">
<li class="blockList">
<h4>validateTimedQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.149">validateTimedQuota</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota timedQuota)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.155">validateTimedQuota</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota timedQuota)
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>
@@ -417,7 +417,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.htm
<ul class="blockListLast">
<li class="blockList">
<h4>fromTimedQuota</h4>
-<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleSettings.html" title="class in org.apache.hadoop.hbase.quotas">ThrottleSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.156">fromTimedQuota</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> userName,
+<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleSettings.html" title="class in org.apache.hadoop.hbase.quotas">ThrottleSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html#line.162">fromTimedQuota</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html b/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
index 5a84c6a..5803857 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
@@ -140,15 +140,25 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?i
<th class="colOne" scope="col">Enum Constant and Description</th>
</tr>
<tr class="altColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_CAPACITY_UNIT">READ_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the read data capacity unit</div>
+</td>
+</tr>
+<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_NUMBER">READ_NUMBER</a></span></code>
<div class="block">Throttling based on the number of read requests per time-unit</div>
</td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_SIZE">READ_SIZE</a></span></code>
<div class="block">Throttling based on the read data size</div>
</td>
</tr>
+<tr class="rowColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#REQUEST_CAPACITY_UNIT">REQUEST_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the read+write capacity unit</div>
+</td>
+</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#REQUEST_NUMBER">REQUEST_NUMBER</a></span></code>
<div class="block">Throttling based on the number of requests per time-unit</div>
@@ -160,11 +170,16 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?i
</td>
</tr>
<tr class="altColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_CAPACITY_UNIT">WRITE_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the write data capacity unit</div>
+</td>
+</tr>
+<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_NUMBER">WRITE_NUMBER</a></span></code>
<div class="block">Throttling based on the number of write requests per time-unit</div>
</td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_SIZE">WRITE_SIZE</a></span></code>
<div class="block">Throttling based on the write data size</div>
</td>
@@ -279,13 +294,43 @@ the order they are declared.</div>
<a name="READ_SIZE">
<!-- -->
</a>
-<ul class="blockListLast">
+<ul class="blockList">
<li class="blockList">
<h4>READ_SIZE</h4>
<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.43">READ_SIZE</a></pre>
<div class="block">Throttling based on the read data size</div>
</li>
</ul>
+<a name="REQUEST_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>REQUEST_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.46">REQUEST_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the read+write capacity unit</div>
+</li>
+</ul>
+<a name="WRITE_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>WRITE_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.49">WRITE_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the write data capacity unit</div>
+</li>
+</ul>
+<a name="READ_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>READ_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.52">READ_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the read data capacity unit</div>
+</li>
+</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html b/devapidocs/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
index 75c5276..426225c 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
@@ -143,12 +143,20 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readReqsLimiter">readReqsLimiter</a></span></code> </td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readCapacityUnitLimiter">readCapacityUnitLimiter</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readReqsLimiter">readReqsLimiter</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readSizeLimiter">readSizeLimiter</a></span></code> </td>
</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#reqCapacityUnitLimiter">reqCapacityUnitLimiter</a></span></code> </td>
+</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#reqSizeLimiter">reqSizeLimiter</a></span></code> </td>
@@ -159,10 +167,14 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeReqsLimiter">writeReqsLimiter</a></span></code> </td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeCapacityUnitLimiter">writeCapacityUnitLimiter</a></span></code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeReqsLimiter">writeReqsLimiter</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeSizeLimiter">writeSizeLimiter</a></span></code> </td>
</tr>
</table>
@@ -201,22 +213,26 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeRead-long-">consumeRead</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeRead-long-long-">consumeRead</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some read amount to the quota.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeWrite-long-">consumeWrite</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeWrite-long-long-">consumeWrite</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some write amount to the quota.</div>
</td>
</tr>
@@ -234,10 +250,12 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#grabQuota-long-long-long-long-">grabQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota</a></span>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</code>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</code>
<div class="block">Removes the specified write and read amount from the quota.</div>
</td>
</tr>
@@ -337,12 +355,39 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<a name="readSizeLimiter">
<!-- -->
</a>
-<ul class="blockListLast">
+<ul class="blockList">
<li class="blockList">
<h4>readSizeLimiter</h4>
<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.42">readSizeLimiter</a></pre>
</li>
</ul>
+<a name="reqCapacityUnitLimiter">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>reqCapacityUnitLimiter</h4>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.43">reqCapacityUnitLimiter</a></pre>
+</li>
+</ul>
+<a name="writeCapacityUnitLimiter">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>writeCapacityUnitLimiter</h4>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.44">writeCapacityUnitLimiter</a></pre>
+</li>
+</ul>
+<a name="readCapacityUnitLimiter">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>readCapacityUnitLimiter</h4>
+<pre>private <a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.45">readCapacityUnitLimiter</a></pre>
+</li>
+</ul>
</li>
</ul>
<!-- ========= CONSTRUCTOR DETAIL ======== -->
@@ -357,7 +402,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockListLast">
<li class="blockList">
<h4>TimeBasedLimiter</h4>
-<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.44">TimeBasedLimiter</a>()</pre>
+<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.47">TimeBasedLimiter</a>()</pre>
</li>
</ul>
</li>
@@ -374,7 +419,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>fromThrottle</h4>
-<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.64">fromThrottle</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle throttle)</pre>
+<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.73">fromThrottle</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle throttle)</pre>
</li>
</ul>
<a name="update-org.apache.hadoop.hbase.quotas.TimeBasedLimiter-">
@@ -383,7 +428,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>update</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.99">update</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a> other)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.123">update</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a> other)</pre>
</li>
</ul>
<a name="setFromTimedQuota-org.apache.hadoop.hbase.quotas.RateLimiter-org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota-">
@@ -392,90 +437,102 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>setFromTimedQuota</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.108">setFromTimedQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> limiter,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.135">setFromTimedQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a> limiter,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota timedQuota)</pre>
</li>
</ul>
-<a name="checkQuota-long-long-long-long-">
+<a name="checkQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.113">checkQuota</a>(long writeReqs,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.140">checkQuota</a>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)
throws <a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">QuotaLimiter</a></code></span></div>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Checks if it is possible to execute the specified operation.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>writeReqs</code> - the write requests that will be checked against the available quota</dd>
<dd><code>estimateWriteSize</code> - the write size that will be checked against the available quota</dd>
<dd><code>readReqs</code> - the read requests that will be checked against the available quota</dd>
<dd><code>estimateReadSize</code> - the read size that will be checked against the available quota</dd>
+<dd><code>estimateWriteCapacityUnit</code> - the write capacity unit that will be checked against the
+ available quota</dd>
+<dd><code>estimateReadCapacityUnit</code> - the read capacity unit that will be checked against the
+ available quota</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></code> - thrown if not enough available resources to perform operation.</dd>
</dl>
</li>
</ul>
-<a name="grabQuota-long-long-long-long-">
+<a name="grabQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>grabQuota</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.145">grabQuota</a>(long writeReqs,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.185">grabQuota</a>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">QuotaLimiter</a></code></span></div>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes the specified write and read amount from the quota.
At this point the write and read amount will be an estimate,
that will be later adjusted with a consumeWrite()/consumeRead() call.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>writeReqs</code> - the write requests that will be removed from the current quota</dd>
<dd><code>writeSize</code> - the write size that will be removed from the current quota</dd>
<dd><code>readReqs</code> - the read requests that will be removed from the current quota</dd>
<dd><code>readSize</code> - the read size that will be removed from the current quota</dd>
+<dd><code>writeCapacityUnit</code> - the write capacity unit that will be removed from the current quota</dd>
+<dd><code>readCapacityUnit</code> - the read capacity unit num that will be removed from the current quota</dd>
</dl>
</li>
</ul>
-<a name="consumeWrite-long-">
+<a name="consumeWrite-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeWrite</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.162">consumeWrite</a>(long size)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">QuotaLimiter</a></code></span></div>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.211">consumeWrite</a>(long size,
+ long capacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes or add back some write amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">consumeWrite</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">consumeWrite</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
</dl>
</li>
</ul>
-<a name="consumeRead-long-">
+<a name="consumeRead-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeRead</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.168">consumeRead</a>(long size)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">QuotaLimiter</a></code></span></div>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.219">consumeRead</a>(long size,
+ long capacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes or add back some read amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">consumeRead</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">consumeRead</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
</dl>
</li>
</ul>
@@ -485,7 +542,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>isBypass</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.174">isBypass</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.227">isBypass</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#isBypass--">isBypass</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -500,7 +557,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>getWriteAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.179">getWriteAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.232">getWriteAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#getWriteAvailable--">getWriteAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -515,7 +572,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>getReadAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.184">getReadAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#line.237">getReadAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#getReadAvailable--">getReadAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -530,7 +587,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<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/quotas/TimeBasedLimiter.html#line.189">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/quotas/TimeBasedLimiter.html#line.242">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/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/class-use/QuotaLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/QuotaLimiter.html b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/QuotaLimiter.html
index 80218c7..00442c4 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/QuotaLimiter.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/QuotaLimiter.html
@@ -283,7 +283,8 @@
</tr>
<tbody>
<tr class="altColor">
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota</a></span>(<a href="../../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</code> </td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota</a></span>(org.apache.hadoop.conf.Configuration conf,
+ <a href="../../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</code> </td>
</tr>
</tbody>
</table>
@@ -294,7 +295,8 @@
</tr>
<tbody>
<tr class="altColor">
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-java.util.List-">DefaultOperationQuota</a></span>(<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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-java.util.List-">DefaultOperationQuota</a></span>(org.apache.hadoop.conf.Configuration conf,
+ <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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</code>
<div class="block">NOTE: The order matters.</div>
</td>
</tr>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RateLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RateLimiter.html b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RateLimiter.html
index 98d0b58..7877f02 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RateLimiter.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RateLimiter.html
@@ -125,12 +125,20 @@
<tbody>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readReqsLimiter">readReqsLimiter</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readCapacityUnitLimiter">readCapacityUnitLimiter</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readReqsLimiter">readReqsLimiter</a></span></code> </td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readSizeLimiter">readSizeLimiter</a></span></code> </td>
</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#reqCapacityUnitLimiter">reqCapacityUnitLimiter</a></span></code> </td>
+</tr>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#reqSizeLimiter">reqSizeLimiter</a></span></code> </td>
@@ -141,10 +149,14 @@
</tr>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
-<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeReqsLimiter">writeReqsLimiter</a></span></code> </td>
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeCapacityUnitLimiter">writeCapacityUnitLimiter</a></span></code> </td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeReqsLimiter">writeReqsLimiter</a></span></code> </td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/RateLimiter.html" title="class in org.apache.hadoop.hbase.quotas">RateLimiter</a></code></td>
<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeSizeLimiter">writeSizeLimiter</a></span></code> </td>
</tr>
</tbody>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RpcThrottlingException.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RpcThrottlingException.html b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RpcThrottlingException.html
index f5a70f3..451c37a 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RpcThrottlingException.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/class-use/RpcThrottlingException.html
@@ -124,26 +124,32 @@
</tr>
<tr class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><span class="typeNameLabel">TimeBasedLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code> </td>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><span class="typeNameLabel">QuotaLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><span class="typeNameLabel">QuotaLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><span class="typeNameLabel">NoopQuotaLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><span class="typeNameLabel">NoopQuotaLimiter.</span><code><span class="memberNameLink"><a href="../../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code> </td>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code> </td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>private <a href="../../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a></code></td>
[16/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/checkstyle-aggregate.html
----------------------------------------------------------------------
diff --git a/checkstyle-aggregate.html b/checkstyle-aggregate.html
index deaf0b6..a14f98b 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Checkstyle Results</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -291,10 +291,10 @@
<th><img src="images/icon_warning_sml.gif" alt="" /> Warnings</th>
<th><img src="images/icon_error_sml.gif" alt="" /> Errors</th></tr>
<tr class="b">
-<td>3812</td>
+<td>3813</td>
<td>0</td>
<td>0</td>
-<td>14996</td></tr></table></div>
+<td>14984</td></tr></table></div>
<div class="section">
<h2><a name="Files"></a>Files</h2>
<table border="0" class="table table-striped">
@@ -5742,7 +5742,7 @@
<td><a href="#org.apache.hadoop.hbase.quotas.DefaultOperationQuota.java">org/apache/hadoop/hbase/quotas/DefaultOperationQuota.java</a></td>
<td>0</td>
<td>0</td>
-<td>4</td></tr>
+<td>2</td></tr>
<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.FileSystemUtilizationChore.java">org/apache/hadoop/hbase/quotas/FileSystemUtilizationChore.java</a></td>
<td>0</td>
@@ -5777,7 +5777,7 @@
<td><a href="#org.apache.hadoop.hbase.quotas.NoopQuotaLimiter.java">org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.java</a></td>
<td>0</td>
<td>0</td>
-<td>3</td></tr>
+<td>1</td></tr>
<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.OperationQuota.java">org/apache/hadoop/hbase/quotas/OperationQuota.java</a></td>
<td>0</td>
@@ -5789,3906 +5789,3901 @@
<td>0</td>
<td>6</td></tr>
<tr class="a">
-<td><a href="#org.apache.hadoop.hbase.quotas.QuotaLimiter.java">org/apache/hadoop/hbase/quotas/QuotaLimiter.java</a></td>
-<td>0</td>
-<td>0</td>
-<td>2</td></tr>
-<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaLimiterFactory.java">org/apache/hadoop/hbase/quotas/QuotaLimiterFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaObserverChore.java">org/apache/hadoop/hbase/quotas/QuotaObserverChore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaRetriever.java">org/apache/hadoop/hbase/quotas/QuotaRetriever.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaSettings.java">org/apache/hadoop/hbase/quotas/QuotaSettings.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaSettingsFactory.java">org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaState.java">org/apache/hadoop/hbase/quotas/QuotaState.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaTableUtil.java">org/apache/hadoop/hbase/quotas/QuotaTableUtil.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.QuotaUtil.java">org/apache/hadoop/hbase/quotas/QuotaUtil.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.RateLimiter.java">org/apache/hadoop/hbase/quotas/RateLimiter.java</a></td>
<td>0</td>
<td>0</td>
<td>18</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.RegionServerRpcQuotaManager.java">org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.RegionServerSpaceQuotaManager.java">org/apache/hadoop/hbase/quotas/RegionServerSpaceQuotaManager.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.SnapshotQuotaObserverChore.java">org/apache/hadoop/hbase/quotas/SnapshotQuotaObserverChore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceLimitSettings.java">org/apache/hadoop/hbase/quotas/SpaceLimitSettings.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceQuotaRefresherChore.java">org/apache/hadoop/hbase/quotas/SpaceQuotaRefresherChore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot.java">org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshot.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifier.java">org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifier.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierFactory.java">org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifierFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshotNotifierForTest.java">org/apache/hadoop/hbase/quotas/SpaceQuotaSnapshotNotifierForTest.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/SpaceViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.SpaceViolationPolicyEnforcementFactory.java">org/apache/hadoop/hbase/quotas/SpaceViolationPolicyEnforcementFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TableQuotaSnapshotStore.java">org/apache/hadoop/hbase/quotas/TableQuotaSnapshotStore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestFileSystemUtilizationChore.java">org/apache/hadoop/hbase/quotas/TestFileSystemUtilizationChore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TestNamespaceQuotaViolationStore.java">org/apache/hadoop/hbase/quotas/TestNamespaceQuotaViolationStore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestQuotaFilter.java">org/apache/hadoop/hbase/quotas/TestQuotaFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TestQuotaObserverChoreWithMiniCluster.java">org/apache/hadoop/hbase/quotas/TestQuotaObserverChoreWithMiniCluster.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestQuotaSettingsFactory.java">org/apache/hadoop/hbase/quotas/TestQuotaSettingsFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TestQuotaStatusRPCs.java">org/apache/hadoop/hbase/quotas/TestQuotaStatusRPCs.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestQuotaThrottle.java">org/apache/hadoop/hbase/quotas/TestQuotaThrottle.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TestRateLimiter.java">org/apache/hadoop/hbase/quotas/TestRateLimiter.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestSpaceQuotas.java">org/apache/hadoop/hbase/quotas/TestSpaceQuotas.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.TestTableQuotaViolationStore.java">org/apache/hadoop/hbase/quotas/TestTableQuotaViolationStore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TestTablesWithQuotas.java">org/apache/hadoop/hbase/quotas/TestTablesWithQuotas.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.ThrottleSettings.java">org/apache/hadoop/hbase/quotas/ThrottleSettings.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.TimeBasedLimiter.java">org/apache/hadoop/hbase/quotas/TimeBasedLimiter.java</a></td>
<td>0</td>
<td>0</td>
-<td>7</td></tr>
-<tr class="b">
+<td>1</td></tr>
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.UserQuotaState.java">org/apache/hadoop/hbase/quotas/UserQuotaState.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.BaseViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/BaseViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.DefaultViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/DefaultViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.DisableTableViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/DisableTableViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.NoInsertsViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/NoInsertsViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.NoWritesCompactionsViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/NoWritesCompactionsViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.NoWritesViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/NoWritesViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.quotas.policies.TestBulkLoadCheckingViolationPolicyEnforcement.java">org/apache/hadoop/hbase/quotas/policies/TestBulkLoadCheckingViolationPolicyEnforcement.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.AbstractMemStore.java">org/apache/hadoop/hbase/regionserver/AbstractMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.AbstractMultiFileWriter.java">org/apache/hadoop/hbase/regionserver/AbstractMultiFileWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.AbstractTestDateTieredCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/AbstractTestDateTieredCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.AnnotationReadingPriorityFunction.java">org/apache/hadoop/hbase/regionserver/AnnotationReadingPriorityFunction.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.BaseRowProcessor.java">org/apache/hadoop/hbase/regionserver/BaseRowProcessor.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.BusyRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/BusyRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ByteBufferChunkKeyValue.java">org/apache/hadoop/hbase/regionserver/ByteBufferChunkKeyValue.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CSLMImmutableSegment.java">org/apache/hadoop/hbase/regionserver/CSLMImmutableSegment.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellArrayImmutableSegment.java">org/apache/hadoop/hbase/regionserver/CellArrayImmutableSegment.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellArrayMap.java">org/apache/hadoop/hbase/regionserver/CellArrayMap.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellChunkMap.java">org/apache/hadoop/hbase/regionserver/CellChunkMap.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellFlatMap.java">org/apache/hadoop/hbase/regionserver/CellFlatMap.java</a></td>
<td>0</td>
<td>0</td>
<td>11</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellSet.java">org/apache/hadoop/hbase/regionserver/CellSet.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CellSink.java">org/apache/hadoop/hbase/regionserver/CellSink.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ChangedReadersObserver.java">org/apache/hadoop/hbase/regionserver/ChangedReadersObserver.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.Chunk.java">org/apache/hadoop/hbase/regionserver/Chunk.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ChunkCreator.java">org/apache/hadoop/hbase/regionserver/ChunkCreator.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactSplit.java">org/apache/hadoop/hbase/regionserver/CompactSplit.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactedHFilesDischargeHandler.java">org/apache/hadoop/hbase/regionserver/CompactedHFilesDischargeHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactedHFilesDischarger.java">org/apache/hadoop/hbase/regionserver/CompactedHFilesDischarger.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactingMemStore.java">org/apache/hadoop/hbase/regionserver/CompactingMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactionPipeline.java">org/apache/hadoop/hbase/regionserver/CompactionPipeline.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompactionTool.java">org/apache/hadoop/hbase/regionserver/CompactionTool.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CompositeImmutableSegment.java">org/apache/hadoop/hbase/regionserver/CompositeImmutableSegment.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ConstantSizeRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/ConstantSizeRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.CreateRandomStoreFile.java">org/apache/hadoop/hbase/regionserver/CreateRandomStoreFile.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.DataBlockEncodingTool.java">org/apache/hadoop/hbase/regionserver/DataBlockEncodingTool.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.DateTieredStoreEngine.java">org/apache/hadoop/hbase/regionserver/DateTieredStoreEngine.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.DefaultHeapMemoryTuner.java">org/apache/hadoop/hbase/regionserver/DefaultHeapMemoryTuner.java</a></td>
<td>0</td>
<td>0</td>
<td>31</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.DefaultMemStore.java">org/apache/hadoop/hbase/regionserver/DefaultMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.DefaultStoreFlusher.java">org/apache/hadoop/hbase/regionserver/DefaultStoreFlusher.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.DelegatingKeyValueScanner.java">org/apache/hadoop/hbase/regionserver/DelegatingKeyValueScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.DelimitedKeyPrefixRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/DelimitedKeyPrefixRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.DisabledRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/DisabledRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.FavoredNodesForRegion.java">org/apache/hadoop/hbase/regionserver/FavoredNodesForRegion.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.FifoRpcSchedulerFactory.java">org/apache/hadoop/hbase/regionserver/FifoRpcSchedulerFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.FlushPolicyFactory.java">org/apache/hadoop/hbase/regionserver/FlushPolicyFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.FlushRequestListener.java">org/apache/hadoop/hbase/regionserver/FlushRequestListener.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.FlushRequester.java">org/apache/hadoop/hbase/regionserver/FlushRequester.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.HMobStore.java">org/apache/hadoop/hbase/regionserver/HMobStore.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.HRegion.java">org/apache/hadoop/hbase/regionserver/HRegion.java</a></td>
<td>0</td>
<td>0</td>
<td>209</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.HRegionFileSystem.java">org/apache/hadoop/hbase/regionserver/HRegionFileSystem.java</a></td>
<td>0</td>
<td>0</td>
<td>47</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.HRegionServer.java">org/apache/hadoop/hbase/regionserver/HRegionServer.java</a></td>
<td>0</td>
<td>0</td>
<td>76</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.HRegionServerCommandLine.java">org/apache/hadoop/hbase/regionserver/HRegionServerCommandLine.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.HStore.java">org/apache/hadoop/hbase/regionserver/HStore.java</a></td>
<td>0</td>
<td>0</td>
<td>43</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.HStoreFile.java">org/apache/hadoop/hbase/regionserver/HStoreFile.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.HeapMemoryManager.java">org/apache/hadoop/hbase/regionserver/HeapMemoryManager.java</a></td>
<td>0</td>
<td>0</td>
<td>11</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.HeapMemoryTuner.java">org/apache/hadoop/hbase/regionserver/HeapMemoryTuner.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ImmutableSegment.java">org/apache/hadoop/hbase/regionserver/ImmutableSegment.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.IncreasingToUpperBoundRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/IncreasingToUpperBoundRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.InternalScan.java">org/apache/hadoop/hbase/regionserver/InternalScan.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.InternalScanner.java">org/apache/hadoop/hbase/regionserver/InternalScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.KeyPrefixRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/KeyPrefixRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.KeyValueHeap.java">org/apache/hadoop/hbase/regionserver/KeyValueHeap.java</a></td>
<td>0</td>
<td>0</td>
<td>11</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.KeyValueScanner.java">org/apache/hadoop/hbase/regionserver/KeyValueScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.LeaseException.java">org/apache/hadoop/hbase/regionserver/LeaseException.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.Leases.java">org/apache/hadoop/hbase/regionserver/Leases.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.LogRoller.java">org/apache/hadoop/hbase/regionserver/LogRoller.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStore.java">org/apache/hadoop/hbase/regionserver/MemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreCompactor.java">org/apache/hadoop/hbase/regionserver/MemStoreCompactor.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreFlusher.java">org/apache/hadoop/hbase/regionserver/MemStoreFlusher.java</a></td>
<td>0</td>
<td>0</td>
<td>29</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreLAB.java">org/apache/hadoop/hbase/regionserver/MemStoreLAB.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreLABImpl.java">org/apache/hadoop/hbase/regionserver/MemStoreLABImpl.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreMergerSegmentsIterator.java">org/apache/hadoop/hbase/regionserver/MemStoreMergerSegmentsIterator.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreSegmentsIterator.java">org/apache/hadoop/hbase/regionserver/MemStoreSegmentsIterator.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MemStoreSnapshot.java">org/apache/hadoop/hbase/regionserver/MemStoreSnapshot.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsRegion.java">org/apache/hadoop/hbase/regionserver/MetricsRegion.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsRegionServer.java">org/apache/hadoop/hbase/regionserver/MetricsRegionServer.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsRegionServerWrapperImpl.java">org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapperImpl.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsRegionServerWrapperStub.java">org/apache/hadoop/hbase/regionserver/MetricsRegionServerWrapperStub.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsTable.java">org/apache/hadoop/hbase/regionserver/MetricsTable.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsTableSource.java">org/apache/hadoop/hbase/regionserver/MetricsTableSource.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsTableWrapperAggregateImpl.java">org/apache/hadoop/hbase/regionserver/MetricsTableWrapperAggregateImpl.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MetricsTableWrapperStub.java">org/apache/hadoop/hbase/regionserver/MetricsTableWrapperStub.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MiniBatchOperationInProgress.java">org/apache/hadoop/hbase/regionserver/MiniBatchOperationInProgress.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MobReferenceOnlyFilter.java">org/apache/hadoop/hbase/regionserver/MobReferenceOnlyFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MultiVersionConcurrencyControl.java">org/apache/hadoop/hbase/regionserver/MultiVersionConcurrencyControl.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.MutableOnlineRegions.java">org/apache/hadoop/hbase/regionserver/MutableOnlineRegions.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.MutableSegment.java">org/apache/hadoop/hbase/regionserver/MutableSegment.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.NoTagByteBufferChunkKeyValue.java">org/apache/hadoop/hbase/regionserver/NoTagByteBufferChunkKeyValue.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.NonLazyKeyValueScanner.java">org/apache/hadoop/hbase/regionserver/NonLazyKeyValueScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.NonReversedNonLazyKeyValueScanner.java">org/apache/hadoop/hbase/regionserver/NonReversedNonLazyKeyValueScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.OOMERegionServer.java">org/apache/hadoop/hbase/regionserver/OOMERegionServer.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.OnlineRegions.java">org/apache/hadoop/hbase/regionserver/OnlineRegions.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.OperationStatus.java">org/apache/hadoop/hbase/regionserver/OperationStatus.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RSDumpServlet.java">org/apache/hadoop/hbase/regionserver/RSDumpServlet.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RSRpcServices.java">org/apache/hadoop/hbase/regionserver/RSRpcServices.java</a></td>
<td>0</td>
<td>0</td>
<td>64</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RSStatusServlet.java">org/apache/hadoop/hbase/regionserver/RSStatusServlet.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.Region.java">org/apache/hadoop/hbase/regionserver/Region.java</a></td>
<td>0</td>
<td>0</td>
<td>25</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionAsTable.java">org/apache/hadoop/hbase/regionserver/RegionAsTable.java</a></td>
<td>0</td>
<td>0</td>
<td>41</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionCoprocessorHost.java">org/apache/hadoop/hbase/regionserver/RegionCoprocessorHost.java</a></td>
<td>0</td>
<td>0</td>
<td>79</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionScanner.java">org/apache/hadoop/hbase/regionserver/RegionScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionServerAccounting.java">org/apache/hadoop/hbase/regionserver/RegionServerAccounting.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionServerCoprocessorHost.java">org/apache/hadoop/hbase/regionserver/RegionServerCoprocessorHost.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionServerServices.java">org/apache/hadoop/hbase/regionserver/RegionServerServices.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionServicesForStores.java">org/apache/hadoop/hbase/regionserver/RegionServicesForStores.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/RegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ReplicationSinkService.java">org/apache/hadoop/hbase/regionserver/ReplicationSinkService.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ReversedKeyValueHeap.java">org/apache/hadoop/hbase/regionserver/ReversedKeyValueHeap.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ReversedRegionScannerImpl.java">org/apache/hadoop/hbase/regionserver/ReversedRegionScannerImpl.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ReversedStoreScanner.java">org/apache/hadoop/hbase/regionserver/ReversedStoreScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.RowProcessor.java">org/apache/hadoop/hbase/regionserver/RowProcessor.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.RpcSchedulerFactory.java">org/apache/hadoop/hbase/regionserver/RpcSchedulerFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ScanInfo.java">org/apache/hadoop/hbase/regionserver/ScanInfo.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ScanOptions.java">org/apache/hadoop/hbase/regionserver/ScanOptions.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ScannerContext.java">org/apache/hadoop/hbase/regionserver/ScannerContext.java</a></td>
<td>0</td>
<td>0</td>
<td>9</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ScannerIdGenerator.java">org/apache/hadoop/hbase/regionserver/ScannerIdGenerator.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.SecureBulkLoadManager.java">org/apache/hadoop/hbase/regionserver/SecureBulkLoadManager.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.Segment.java">org/apache/hadoop/hbase/regionserver/Segment.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.SegmentFactory.java">org/apache/hadoop/hbase/regionserver/SegmentFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.SegmentScanner.java">org/apache/hadoop/hbase/regionserver/SegmentScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ServerNonceManager.java">org/apache/hadoop/hbase/regionserver/ServerNonceManager.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.ShipperListener.java">org/apache/hadoop/hbase/regionserver/ShipperListener.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.ShutdownHook.java">org/apache/hadoop/hbase/regionserver/ShutdownHook.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.SimpleRpcSchedulerFactory.java">org/apache/hadoop/hbase/regionserver/SimpleRpcSchedulerFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.SplitRequest.java">org/apache/hadoop/hbase/regionserver/SplitRequest.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.SteppingSplitPolicy.java">org/apache/hadoop/hbase/regionserver/SteppingSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.Store.java">org/apache/hadoop/hbase/regionserver/Store.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileComparators.java">org/apache/hadoop/hbase/regionserver/StoreFileComparators.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileInfo.java">org/apache/hadoop/hbase/regionserver/StoreFileInfo.java</a></td>
<td>0</td>
<td>0</td>
<td>18</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileManager.java">org/apache/hadoop/hbase/regionserver/StoreFileManager.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileReader.java">org/apache/hadoop/hbase/regionserver/StoreFileReader.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileScanner.java">org/apache/hadoop/hbase/regionserver/StoreFileScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>12</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFileWriter.java">org/apache/hadoop/hbase/regionserver/StoreFileWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFlushContext.java">org/apache/hadoop/hbase/regionserver/StoreFlushContext.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreFlusher.java">org/apache/hadoop/hbase/regionserver/StoreFlusher.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreScanner.java">org/apache/hadoop/hbase/regionserver/StoreScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>21</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StoreUtils.java">org/apache/hadoop/hbase/regionserver/StoreUtils.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StorefileRefresherChore.java">org/apache/hadoop/hbase/regionserver/StorefileRefresherChore.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StripeMultiFileWriter.java">org/apache/hadoop/hbase/regionserver/StripeMultiFileWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StripeStoreConfig.java">org/apache/hadoop/hbase/regionserver/StripeStoreConfig.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StripeStoreEngine.java">org/apache/hadoop/hbase/regionserver/StripeStoreEngine.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.StripeStoreFileManager.java">org/apache/hadoop/hbase/regionserver/StripeStoreFileManager.java</a></td>
<td>0</td>
<td>0</td>
<td>14</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.StripeStoreFlusher.java">org/apache/hadoop/hbase/regionserver/StripeStoreFlusher.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestAtomicOperation.java">org/apache/hadoop/hbase/regionserver/TestAtomicOperation.java</a></td>
<td>0</td>
<td>0</td>
<td>13</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestBlocksRead.java">org/apache/hadoop/hbase/regionserver/TestBlocksRead.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestBlocksScanned.java">org/apache/hadoop/hbase/regionserver/TestBlocksScanned.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestBulkLoad.java">org/apache/hadoop/hbase/regionserver/TestBulkLoad.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCacheOnWriteInSchema.java">org/apache/hadoop/hbase/regionserver/TestCacheOnWriteInSchema.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCellFlatSet.java">org/apache/hadoop/hbase/regionserver/TestCellFlatSet.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCellSkipListSet.java">org/apache/hadoop/hbase/regionserver/TestCellSkipListSet.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestClearRegionBlockCache.java">org/apache/hadoop/hbase/regionserver/TestClearRegionBlockCache.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestColumnSeeking.java">org/apache/hadoop/hbase/regionserver/TestColumnSeeking.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompactSplitThread.java">org/apache/hadoop/hbase/regionserver/TestCompactSplitThread.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompactingMemStore.java">org/apache/hadoop/hbase/regionserver/TestCompactingMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompactingToCellFlatMapMemStore.java">org/apache/hadoop/hbase/regionserver/TestCompactingToCellFlatMapMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompaction.java">org/apache/hadoop/hbase/regionserver/TestCompaction.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompactionState.java">org/apache/hadoop/hbase/regionserver/TestCompactionState.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestCompoundBloomFilter.java">org/apache/hadoop/hbase/regionserver/TestCompoundBloomFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestDateTieredCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/TestDateTieredCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestDateTieredCompactionPolicyOverflow.java">org/apache/hadoop/hbase/regionserver/TestDateTieredCompactionPolicyOverflow.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestDefaultMemStore.java">org/apache/hadoop/hbase/regionserver/TestDefaultMemStore.java</a></td>
<td>0</td>
<td>0</td>
<td>17</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestDeleteMobTable.java">org/apache/hadoop/hbase/regionserver/TestDeleteMobTable.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestEndToEndSplitTransaction.java">org/apache/hadoop/hbase/regionserver/TestEndToEndSplitTransaction.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestFSErrorsExposed.java">org/apache/hadoop/hbase/regionserver/TestFSErrorsExposed.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestFailedAppendAndSync.java">org/apache/hadoop/hbase/regionserver/TestFailedAppendAndSync.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestGetClosestAtOrBefore.java">org/apache/hadoop/hbase/regionserver/TestGetClosestAtOrBefore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHMobStore.java">org/apache/hadoop/hbase/regionserver/TestHMobStore.java</a></td>
<td>0</td>
<td>0</td>
<td>12</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegion.java">org/apache/hadoop/hbase/regionserver/TestHRegion.java</a></td>
<td>0</td>
<td>0</td>
<td>29</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionFileSystem.java">org/apache/hadoop/hbase/regionserver/TestHRegionFileSystem.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionInfo.java">org/apache/hadoop/hbase/regionserver/TestHRegionInfo.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionOnCluster.java">org/apache/hadoop/hbase/regionserver/TestHRegionOnCluster.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionReplayEvents.java">org/apache/hadoop/hbase/regionserver/TestHRegionReplayEvents.java</a></td>
<td>0</td>
<td>0</td>
<td>16</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionServerBulkLoad.java">org/apache/hadoop/hbase/regionserver/TestHRegionServerBulkLoad.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHRegionServerBulkLoadWithOldClient.java">org/apache/hadoop/hbase/regionserver/TestHRegionServerBulkLoadWithOldClient.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHStore.java">org/apache/hadoop/hbase/regionserver/TestHStore.java</a></td>
<td>0</td>
<td>0</td>
<td>40</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestHStoreFile.java">org/apache/hadoop/hbase/regionserver/TestHStoreFile.java</a></td>
<td>0</td>
<td>0</td>
<td>22</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestJoinedScanners.java">org/apache/hadoop/hbase/regionserver/TestJoinedScanners.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestKeepDeletes.java">org/apache/hadoop/hbase/regionserver/TestKeepDeletes.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestKeyValueHeap.java">org/apache/hadoop/hbase/regionserver/TestKeyValueHeap.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestKeyValueScanFixture.java">org/apache/hadoop/hbase/regionserver/TestKeyValueScanFixture.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMajorCompaction.java">org/apache/hadoop/hbase/regionserver/TestMajorCompaction.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMasterAddressTracker.java">org/apache/hadoop/hbase/regionserver/TestMasterAddressTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMemStoreLAB.java">org/apache/hadoop/hbase/regionserver/TestMemStoreLAB.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMemstoreLABWithoutPool.java">org/apache/hadoop/hbase/regionserver/TestMemstoreLABWithoutPool.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMetricsRegion.java">org/apache/hadoop/hbase/regionserver/TestMetricsRegion.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMetricsRegionServer.java">org/apache/hadoop/hbase/regionserver/TestMetricsRegionServer.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMinorCompaction.java">org/apache/hadoop/hbase/regionserver/TestMinorCompaction.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMobStoreScanner.java">org/apache/hadoop/hbase/regionserver/TestMobStoreScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMultiColumnScanner.java">org/apache/hadoop/hbase/regionserver/TestMultiColumnScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>9</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMultiLogThreshold.java">org/apache/hadoop/hbase/regionserver/TestMultiLogThreshold.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestMultiVersionConcurrencyControl.java">org/apache/hadoop/hbase/regionserver/TestMultiVersionConcurrencyControl.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestParallelPut.java">org/apache/hadoop/hbase/regionserver/TestParallelPut.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestPerColumnFamilyFlush.java">org/apache/hadoop/hbase/regionserver/TestPerColumnFamilyFlush.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestPriorityRpc.java">org/apache/hadoop/hbase/regionserver/TestPriorityRpc.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestQosFunction.java">org/apache/hadoop/hbase/regionserver/TestQosFunction.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRSKilledWhenInitializing.java">org/apache/hadoop/hbase/regionserver/TestRSKilledWhenInitializing.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRecoveredEdits.java">org/apache/hadoop/hbase/regionserver/TestRecoveredEdits.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionIncrement.java">org/apache/hadoop/hbase/regionserver/TestRegionIncrement.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionInfoBuilder.java">org/apache/hadoop/hbase/regionserver/TestRegionInfoBuilder.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionMergeTransactionOnCluster.java">org/apache/hadoop/hbase/regionserver/TestRegionMergeTransactionOnCluster.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionOpen.java">org/apache/hadoop/hbase/regionserver/TestRegionOpen.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionReplicaFailover.java">org/apache/hadoop/hbase/regionserver/TestRegionReplicaFailover.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionReplicas.java">org/apache/hadoop/hbase/regionserver/TestRegionReplicas.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerAbort.java">org/apache/hadoop/hbase/regionserver/TestRegionServerAbort.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerHostname.java">org/apache/hadoop/hbase/regionserver/TestRegionServerHostname.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerMetrics.java">org/apache/hadoop/hbase/regionserver/TestRegionServerMetrics.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerNoMaster.java">org/apache/hadoop/hbase/regionserver/TestRegionServerNoMaster.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerOnlineConfigChange.java">org/apache/hadoop/hbase/regionserver/TestRegionServerOnlineConfigChange.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerReadRequestMetrics.java">org/apache/hadoop/hbase/regionserver/TestRegionServerReadRequestMetrics.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionServerReportForDuty.java">org/apache/hadoop/hbase/regionserver/TestRegionServerReportForDuty.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRegionSplitPolicy.java">org/apache/hadoop/hbase/regionserver/TestRegionSplitPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestResettingCounters.java">org/apache/hadoop/hbase/regionserver/TestResettingCounters.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestReversibleScanners.java">org/apache/hadoop/hbase/regionserver/TestReversibleScanners.java</a></td>
<td>0</td>
<td>0</td>
<td>15</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestRowTooBig.java">org/apache/hadoop/hbase/regionserver/TestRowTooBig.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestScanWithBloomError.java">org/apache/hadoop/hbase/regionserver/TestScanWithBloomError.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestScanner.java">org/apache/hadoop/hbase/regionserver/TestScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>12</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestScannerHeartbeatMessages.java">org/apache/hadoop/hbase/regionserver/TestScannerHeartbeatMessages.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestScannerRetriableFailure.java">org/apache/hadoop/hbase/regionserver/TestScannerRetriableFailure.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestScannerWithBulkload.java">org/apache/hadoop/hbase/regionserver/TestScannerWithBulkload.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSeekOptimizations.java">org/apache/hadoop/hbase/regionserver/TestSeekOptimizations.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestServerNonceManager.java">org/apache/hadoop/hbase/regionserver/TestServerNonceManager.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSettingTimeoutOnBlockingPoint.java">org/apache/hadoop/hbase/regionserver/TestSettingTimeoutOnBlockingPoint.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSimpleTimeRangeTracker.java">org/apache/hadoop/hbase/regionserver/TestSimpleTimeRangeTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSplitLogWorker.java">org/apache/hadoop/hbase/regionserver/TestSplitLogWorker.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSplitTransactionOnCluster.java">org/apache/hadoop/hbase/regionserver/TestSplitTransactionOnCluster.java</a></td>
<td>0</td>
<td>0</td>
<td>27</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestStoreFileInfo.java">org/apache/hadoop/hbase/regionserver/TestStoreFileInfo.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestStoreFileRefresherChore.java">org/apache/hadoop/hbase/regionserver/TestStoreFileRefresherChore.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestStoreScanner.java">org/apache/hadoop/hbase/regionserver/TestStoreScanner.java</a></td>
<td>0</td>
<td>0</td>
<td>12</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestStripeStoreFileManager.java">org/apache/hadoop/hbase/regionserver/TestStripeStoreFileManager.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestSyncTimeRangeTracker.java">org/apache/hadoop/hbase/regionserver/TestSyncTimeRangeTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestTags.java">org/apache/hadoop/hbase/regionserver/TestTags.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestTimestampFilterSeekHint.java">org/apache/hadoop/hbase/regionserver/TestTimestampFilterSeekHint.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestWALLockup.java">org/apache/hadoop/hbase/regionserver/TestWALLockup.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestWALMonotonicallyIncreasingSeqId.java">org/apache/hadoop/hbase/regionserver/TestWALMonotonicallyIncreasingSeqId.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.TestWalAndCompactingMemStoreFlush.java">org/apache/hadoop/hbase/regionserver/TestWalAndCompactingMemStoreFlush.java</a></td>
<td>0</td>
<td>0</td>
<td>9</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.TimeRangeTracker.java">org/apache/hadoop/hbase/regionserver/TimeRangeTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.CompactionConfiguration.java">org/apache/hadoop/hbase/regionserver/compactions/CompactionConfiguration.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.CompactionProgress.java">org/apache/hadoop/hbase/regionserver/compactions/CompactionProgress.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.CompactionRequest.java">org/apache/hadoop/hbase/regionserver/compactions/CompactionRequest.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.CompactionRequester.java">org/apache/hadoop/hbase/regionserver/compactions/CompactionRequester.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.Compactor.java">org/apache/hadoop/hbase/regionserver/compactions/Compactor.java</a></td>
<td>0</td>
<td>0</td>
<td>13</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.CurrentHourProvider.java">org/apache/hadoop/hbase/regionserver/compactions/CurrentHourProvider.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.DefaultCompactor.java">org/apache/hadoop/hbase/regionserver/compactions/DefaultCompactor.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.OffPeakHours.java">org/apache/hadoop/hbase/regionserver/compactions/OffPeakHours.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.PerfTestCompactionPolicies.java">org/apache/hadoop/hbase/regionserver/compactions/PerfTestCompactionPolicies.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.RatioBasedCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/compactions/RatioBasedCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.SortedCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/compactions/SortedCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.SpikyFileListGenerator.java">org/apache/hadoop/hbase/regionserver/compactions/SpikyFileListGenerator.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.StripeCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/compactions/StripeCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>10</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.StripeCompactor.java">org/apache/hadoop/hbase/regionserver/compactions/StripeCompactor.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.TestCompactor.java">org/apache/hadoop/hbase/regionserver/compactions/TestCompactor.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.compactions.TestStripeCompactionPolicy.java">org/apache/hadoop/hbase/regionserver/compactions/TestStripeCompactionPolicy.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.CloseRegionHandler.java">org/apache/hadoop/hbase/regionserver/handler/CloseRegionHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.OpenPriorityRegionHandler.java">org/apache/hadoop/hbase/regionserver/handler/OpenPriorityRegionHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.OpenRegionHandler.java">org/apache/hadoop/hbase/regionserver/handler/OpenRegionHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.ParallelSeekHandler.java">org/apache/hadoop/hbase/regionserver/handler/ParallelSeekHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.RegionReplicaFlushHandler.java">org/apache/hadoop/hbase/regionserver/handler/RegionReplicaFlushHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.handler.WALSplitterHandler.java">org/apache/hadoop/hbase/regionserver/handler/WALSplitterHandler.java</a></td>
<td>0</td>
<td>0</td>
<td>22</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.ColumnTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/ColumnTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.CompactionScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/CompactionScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.DeleteTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/DeleteTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.DropDeletesCompactionScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/DropDeletesCompactionScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.ExplicitColumnTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/ExplicitColumnTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.IncludeAllCompactionQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/IncludeAllCompactionQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.MajorCompactionScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/MajorCompactionScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.MinorCompactionScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/MinorCompactionScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.NewVersionBehaviorTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/NewVersionBehaviorTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>20</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.NormalUserScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/NormalUserScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.RawScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/RawScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.ScanDeleteTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/ScanDeleteTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.ScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.ScanWildcardColumnTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/ScanWildcardColumnTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.StripeCompactionScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.TestExplicitColumnTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/TestExplicitColumnTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.TestScanDeleteTracker.java">org/apache/hadoop/hbase/regionserver/querymatcher/TestScanDeleteTracker.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.TestUserScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/TestUserScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>17</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.querymatcher.UserScanQueryMatcher.java">org/apache/hadoop/hbase/regionserver/querymatcher/UserScanQueryMatcher.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.snapshot.FlushSnapshotSubprocedure.java">org/apache/hadoop/hbase/regionserver/snapshot/FlushSnapshotSubprocedure.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.snapshot.RegionServerSnapshotManager.java">org/apache/hadoop/hbase/regionserver/snapshot/RegionServerSnapshotManager.java</a></td>
<td>0</td>
<td>0</td>
<td>19</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.CompactionThroughputControllerFactory.java">org/apache/hadoop/hbase/regionserver/throttle/CompactionThroughputControllerFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.FlushThroughputControllerFactory.java">org/apache/hadoop/hbase/regionserver/throttle/FlushThroughputControllerFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.NoLimitThroughputController.java">org/apache/hadoop/hbase/regionserver/throttle/NoLimitThroughputController.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.PressureAwareCompactionThroughputController.java">org/apache/hadoop/hbase/regionserver/throttle/PressureAwareCompactionThroughputController.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.PressureAwareFlushThroughputController.java">org/apache/hadoop/hbase/regionserver/throttle/PressureAwareFlushThroughputController.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.PressureAwareThroughputController.java">org/apache/hadoop/hbase/regionserver/throttle/PressureAwareThroughputController.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.throttle.ThroughputController.java">org/apache/hadoop/hbase/regionserver/throttle/ThroughputController.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL.java">org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractProtobufLogWriter.java">org/apache/hadoop/hbase/regionserver/wal/AbstractProtobufLogWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractTestFSWAL.java">org/apache/hadoop/hbase/regionserver/wal/AbstractTestFSWAL.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractTestLogRolling.java">org/apache/hadoop/hbase/regionserver/wal/AbstractTestLogRolling.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractTestProtobufLog.java">org/apache/hadoop/hbase/regionserver/wal/AbstractTestProtobufLog.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.AbstractTestWALReplay.java">org/apache/hadoop/hbase/regionserver/wal/AbstractTestWALReplay.java</a></td>
<td>0</td>
<td>0</td>
<td>38</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.CompressionContext.java">org/apache/hadoop/hbase/regionserver/wal/CompressionContext.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.Compressor.java">org/apache/hadoop/hbase/regionserver/wal/Compressor.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.FSHLog.java">org/apache/hadoop/hbase/regionserver/wal/FSHLog.java</a></td>
<td>0</td>
<td>0</td>
<td>8</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.FSWALEntry.java">org/apache/hadoop/hbase/regionserver/wal/FSWALEntry.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.FailedLogCloseException.java">org/apache/hadoop/hbase/regionserver/wal/FailedLogCloseException.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.FailedSyncBeforeLogCloseException.java">org/apache/hadoop/hbase/regionserver/wal/FailedSyncBeforeLogCloseException.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.FaultyProtobufLogReader.java">org/apache/hadoop/hbase/regionserver/wal/FaultyProtobufLogReader.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.InstrumentedLogWriter.java">org/apache/hadoop/hbase/regionserver/wal/InstrumentedLogWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.MetricsWAL.java">org/apache/hadoop/hbase/regionserver/wal/MetricsWAL.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.ProtobufLogReader.java">org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.java</a></td>
<td>0</td>
<td>0</td>
<td>20</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.ReaderBase.java">org/apache/hadoop/hbase/regionserver/wal/ReaderBase.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.SecureProtobufLogReader.java">org/apache/hadoop/hbase/regionserver/wal/SecureProtobufLogReader.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.SecureProtobufLogWriter.java">org/apache/hadoop/hbase/regionserver/wal/SecureProtobufLogWriter.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.SecureWALCellCodec.java">org/apache/hadoop/hbase/regionserver/wal/SecureWALCellCodec.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.SequenceIdAccounting.java">org/apache/hadoop/hbase/regionserver/wal/SequenceIdAccounting.java</a></td>
<td>0</td>
<td>0</td>
<td>13</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.TestLogRolling.java">org/apache/hadoop/hbase/regionserver/wal/TestLogRolling.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.TestLogRollingNoCluster.java">org/apache/hadoop/hbase/regionserver/wal/TestLogRollingNoCluster.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.TestWALConfiguration.java">org/apache/hadoop/hbase/regionserver/wal/TestWALConfiguration.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.WALActionsListener.java">org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.WALCellCodec.java">org/apache/hadoop/hbase/regionserver/wal/WALCellCodec.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.WALCoprocessorHost.java">org/apache/hadoop/hbase/regionserver/wal/WALCoprocessorHost.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.regionserver.wal.WALUtil.java">org/apache/hadoop/hbase/regionserver/wal/WALUtil.java</a></td>
<td>0</td>
<td>0</td>
<td>5</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.BaseReplicationEndpoint.java">org/apache/hadoop/hbase/replication/BaseReplicationEndpoint.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.BulkLoadCellFilter.java">org/apache/hadoop/hbase/replication/BulkLoadCellFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.ClusterMarkingEntryFilter.java">org/apache/hadoop/hbase/replication/ClusterMarkingEntryFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.HBaseReplicationEndpoint.java">org/apache/hadoop/hbase/replication/HBaseReplicationEndpoint.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.ReplicationEndpoint.java">org/apache/hadoop/hbase/replication/ReplicationEndpoint.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.ReplicationException.java">org/apache/hadoop/hbase/replication/ReplicationException.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.SystemTableWALEntryFilter.java">org/apache/hadoop/hbase/replication/SystemTableWALEntryFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.TestMasterReplication.java">org/apache/hadoop/hbase/replication/TestMasterReplication.java</a></td>
<td>0</td>
<td>0</td>
<td>12</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.TestMultiSlaveReplication.java">org/apache/hadoop/hbase/replication/TestMultiSlaveReplication.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.TestPerTableCFReplication.java">org/apache/hadoop/hbase/replication/TestPerTableCFReplication.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.TestReplicationDisableInactivePeer.java">org/apache/hadoop/hbase/replication/TestReplicationDisableInactivePeer.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.TestReplicationEndpoint.java">org/apache/hadoop/hbase/replication/TestReplicationEndpoint.java</a></td>
<td>0</td>
<td>0</td>
<td>7</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.TestReplicationKillMasterRSCompressed.java">org/apache/hadoop/hbase/replication/TestReplicationKillMasterRSCompressed.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.TestReplicationWithTags.java">org/apache/hadoop/hbase/replication/TestReplicationWithTags.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.TestVerifyReplication.java">org/apache/hadoop/hbase/replication/TestVerifyReplication.java</a></td>
<td>0</td>
<td>0</td>
<td>9</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.WALCellFilter.java">org/apache/hadoop/hbase/replication/WALCellFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.WALEntryFilter.java">org/apache/hadoop/hbase/replication/WALEntryFilter.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.ZKReplicationQueueStorage.java">org/apache/hadoop/hbase/replication/ZKReplicationQueueStorage.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.master.ReplicationLogCleaner.java">org/apache/hadoop/hbase/replication/master/ReplicationLogCleaner.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.DumpReplicationQueues.java">org/apache/hadoop/hbase/replication/regionserver/DumpReplicationQueues.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.HFileReplicator.java">org/apache/hadoop/hbase/replication/regionserver/HFileReplicator.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.MetricsSink.java">org/apache/hadoop/hbase/replication/regionserver/MetricsSink.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.MetricsSource.java">org/apache/hadoop/hbase/replication/regionserver/MetricsSource.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.RegionReplicaReplicationEndpoint.java">org/apache/hadoop/hbase/replication/regionserver/RegionReplicaReplicationEndpoint.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.Replication.java">org/apache/hadoop/hbase/replication/regionserver/Replication.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationLoad.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationLoad.java</a></td>
<td>0</td>
<td>0</td>
<td>6</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationObserver.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationObserver.java</a></td>
<td>0</td>
<td>0</td>
<td>4</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationSink.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationSink.java</a></td>
<td>0</td>
<td>0</td>
<td>11</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationSourceFactory.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceFactory.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationSourceInterface.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceInterface.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationSourceManager.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceManager.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.ReplicationThrottler.java">org/apache/hadoop/hbase/replication/regionserver/ReplicationThrottler.java</a></td>
<td>0</td>
<td>0</td>
<td>2</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.TestGlobalReplicationThrottler.java">org/apache/hadoop/hbase/replication/regionserver/TestGlobalReplicationThrottler.java</a></td>
<td>0</td>
<td>0</td>
<td>3</td></tr>
-<tr class="b">
+<tr class="a">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.TestRegionReplicaReplicationEndpointNoMaster.java">org/apache/hadoop/hbase/replication/regionserver/TestRegionReplicaReplicationEndpointNoMaster.java</a></td>
<td>0</td>
<td>0</td>
<td>1</td></tr>
-<tr class="a">
+<tr class="b">
<td><a href="#org.apache.hadoop.hbase.replication.regionserver.TestReplica
<TRUNCATED>
[14/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html b/devapidocs/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
index ec24917..52195d9 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html
@@ -18,7 +18,7 @@
catch(err) {
}
//-->
-var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":10};
+var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10,"i5":10,"i6":10,"i7":10,"i8":10,"i9":10,"i10":10,"i11":10};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
@@ -115,7 +115,7 @@ var activeTableTab = "activeTableTab";
<br>
<pre>@InterfaceAudience.Private
@InterfaceStability.Evolving
-public class <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.33">DefaultOperationQuota</a>
+public class <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.34">DefaultOperationQuota</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a></pre>
</li>
@@ -169,6 +169,14 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
</tr>
<tr class="altColor">
<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#readCapacityUnit">readCapacityUnit</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#readCapacityUnitConsumed">readCapacityUnitConsumed</a></span></code> </td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private long</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#readConsumed">readConsumed</a></span></code> </td>
</tr>
<tr class="rowColor">
@@ -177,6 +185,14 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
</tr>
<tr class="altColor">
<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#writeCapacityUnit">writeCapacityUnit</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#writeCapacityUnitConsumed">writeCapacityUnitConsumed</a></span></code> </td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private long</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#writeConsumed">writeConsumed</a></span></code> </td>
</tr>
</table>
@@ -194,12 +210,14 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<th class="colOne" scope="col">Constructor and Description</th>
</tr>
<tr class="altColor">
-<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-java.util.List-">DefaultOperationQuota</a></span>(<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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</code>
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-java.util.List-">DefaultOperationQuota</a></span>(org.apache.hadoop.conf.Configuration conf,
+ <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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</code>
<div class="block">NOTE: The order matters.</div>
</td>
</tr>
<tr class="rowColor">
-<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota</a></span>(<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</code> </td>
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota</a></span>(org.apache.hadoop.conf.Configuration conf,
+ <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</code> </td>
</tr>
</table>
</li>
@@ -235,6 +253,24 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
</td>
</tr>
<tr id="i3" class="rowColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateReadCapacityUnit-long-">calculateReadCapacityUnit</a></span>(long size)</code> </td>
+</tr>
+<tr id="i4" class="altColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateReadCapacityUnitDiff-long-long-">calculateReadCapacityUnitDiff</a></span>(long actualSize,
+ long estimateSize)</code> </td>
+</tr>
+<tr id="i5" class="rowColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateWriteCapacityUnit-long-">calculateWriteCapacityUnit</a></span>(long size)</code> </td>
+</tr>
+<tr id="i6" class="altColor">
+<td class="colFirst"><code>private long</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateWriteCapacityUnitDiff-long-long-">calculateWriteCapacityUnitDiff</a></span>(long actualSize,
+ long estimateSize)</code> </td>
+</tr>
+<tr id="i7" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#checkQuota-int-int-int-">checkQuota</a></span>(int numWrites,
int numReads,
@@ -242,23 +278,23 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<div class="block">Checks if it is possible to execute the specified operation.</div>
</td>
</tr>
-<tr id="i4" class="altColor">
+<tr id="i8" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#close--">close</a></span>()</code>
<div class="block">Cleanup method on operation completion</div>
</td>
</tr>
-<tr id="i5" class="rowColor">
+<tr id="i9" class="rowColor">
<td class="colFirst"><code>private long</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#estimateConsume-org.apache.hadoop.hbase.quotas.OperationQuota.OperationType-int-long-">estimateConsume</a></span>(<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas">OperationQuota.OperationType</a> type,
int numReqs,
long avgSize)</code> </td>
</tr>
-<tr id="i6" class="altColor">
+<tr id="i10" class="altColor">
<td class="colFirst"><code>long</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#getReadAvailable--">getReadAvailable</a></span>()</code> </td>
</tr>
-<tr id="i7" class="rowColor">
+<tr id="i11" class="rowColor">
<td class="colFirst"><code>long</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#getWriteAvailable--">getWriteAvailable</a></span>()</code> </td>
</tr>
@@ -290,7 +326,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>LOG</h4>
-<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.34">LOG</a></pre>
+<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.35">LOG</a></pre>
</li>
</ul>
<a name="limiters">
@@ -299,7 +335,25 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>limiters</h4>
-<pre>private final <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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.36">limiters</a></pre>
+<pre>private final <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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.37">limiters</a></pre>
+</li>
+</ul>
+<a name="writeCapacityUnit">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>writeCapacityUnit</h4>
+<pre>private final long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.38">writeCapacityUnit</a></pre>
+</li>
+</ul>
+<a name="readCapacityUnit">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>readCapacityUnit</h4>
+<pre>private final long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.39">readCapacityUnit</a></pre>
</li>
</ul>
<a name="writeAvailable">
@@ -308,7 +362,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>writeAvailable</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.37">writeAvailable</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.41">writeAvailable</a></pre>
</li>
</ul>
<a name="readAvailable">
@@ -317,7 +371,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>readAvailable</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.38">readAvailable</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.42">readAvailable</a></pre>
</li>
</ul>
<a name="writeConsumed">
@@ -326,7 +380,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>writeConsumed</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.39">writeConsumed</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.43">writeConsumed</a></pre>
</li>
</ul>
<a name="readConsumed">
@@ -335,7 +389,25 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>readConsumed</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.40">readConsumed</a></pre>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.44">readConsumed</a></pre>
+</li>
+</ul>
+<a name="writeCapacityUnitConsumed">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>writeCapacityUnitConsumed</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.45">writeCapacityUnitConsumed</a></pre>
+</li>
+</ul>
+<a name="readCapacityUnitConsumed">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>readCapacityUnitConsumed</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.46">readCapacityUnitConsumed</a></pre>
</li>
</ul>
<a name="operationSize">
@@ -344,7 +416,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockListLast">
<li class="blockList">
<h4>operationSize</h4>
-<pre>private final long[] <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.41">operationSize</a></pre>
+<pre>private final long[] <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.47">operationSize</a></pre>
</li>
</ul>
</li>
@@ -355,22 +427,24 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<!-- -->
</a>
<h3>Constructor Detail</h3>
-<a name="DefaultOperationQuota-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">
+<a name="DefaultOperationQuota-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>DefaultOperationQuota</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.43">DefaultOperationQuota</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</pre>
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.49">DefaultOperationQuota</a>(org.apache.hadoop.conf.Configuration conf,
+ <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>... limiters)</pre>
</li>
</ul>
-<a name="DefaultOperationQuota-java.util.List-">
+<a name="DefaultOperationQuota-org.apache.hadoop.conf.Configuration-java.util.List-">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>DefaultOperationQuota</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.50">DefaultOperationQuota</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</pre>
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.56">DefaultOperationQuota</a>(org.apache.hadoop.conf.Configuration conf,
+ <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/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a>> limiters)</pre>
<div class="block">NOTE: The order matters. It should be something like [user, table, namespace, global]</div>
</li>
</ul>
@@ -388,7 +462,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.61">checkQuota</a>(int numWrites,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.71">checkQuota</a>(int numWrites,
int numReads,
int numScans)
throws <a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
@@ -415,7 +489,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>close</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.83">close</a>()</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.97">close</a>()</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#close--">OperationQuota</a></code></span></div>
<div class="block">Cleanup method on operation completion</div>
<dl>
@@ -430,7 +504,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>getReadAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.96">getReadAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.119">getReadAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#getReadAvailable--">getReadAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a></code></dd>
@@ -445,7 +519,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>getWriteAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.101">getWriteAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.124">getWriteAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#getWriteAvailable--">getWriteAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a></code></dd>
@@ -460,7 +534,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>addGetResult</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.106">addGetResult</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> result)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.129">addGetResult</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a> result)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#addGetResult-org.apache.hadoop.hbase.client.Result-">OperationQuota</a></code></span></div>
<div class="block">Add a get result. This will be used to calculate the exact quota and
have a better short-read average size for the next time.</div>
@@ -476,7 +550,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>addScanResult</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.111">addScanResult</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> results)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.134">addScanResult</a>(<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><<a href="../../../../../org/apache/hadoop/hbase/client/Result.html" title="class in org.apache.hadoop.hbase.client">Result</a>> results)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#addScanResult-java.util.List-">OperationQuota</a></code></span></div>
<div class="block">Add a scan result. This will be used to calculate the exact quota and
have a better long-read average size for the next time.</div>
@@ -492,7 +566,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<ul class="blockList">
<li class="blockList">
<h4>addMutation</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.116">addMutation</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a> mutation)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.139">addMutation</a>(<a href="../../../../../org/apache/hadoop/hbase/client/Mutation.html" title="class in org.apache.hadoop.hbase.client">Mutation</a> mutation)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.html#addMutation-org.apache.hadoop.hbase.client.Mutation-">OperationQuota</a></code></span></div>
<div class="block">Add a mutation result. This will be used to calculate the exact quota and
have a better mutation average size for the next time.</div>
@@ -505,14 +579,52 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota
<a name="estimateConsume-org.apache.hadoop.hbase.quotas.OperationQuota.OperationType-int-long-">
<!-- -->
</a>
-<ul class="blockListLast">
+<ul class="blockList">
<li class="blockList">
<h4>estimateConsume</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.120">estimateConsume</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas">OperationQuota.OperationType</a> type,
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.143">estimateConsume</a>(<a href="../../../../../org/apache/hadoop/hbase/quotas/OperationQuota.OperationType.html" title="enum in org.apache.hadoop.hbase.quotas">OperationQuota.OperationType</a> type,
int numReqs,
long avgSize)</pre>
</li>
</ul>
+<a name="calculateWriteCapacityUnit-long-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>calculateWriteCapacityUnit</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.150">calculateWriteCapacityUnit</a>(long size)</pre>
+</li>
+</ul>
+<a name="calculateReadCapacityUnit-long-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>calculateReadCapacityUnit</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.154">calculateReadCapacityUnit</a>(long size)</pre>
+</li>
+</ul>
+<a name="calculateWriteCapacityUnitDiff-long-long-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>calculateWriteCapacityUnitDiff</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.158">calculateWriteCapacityUnitDiff</a>(long actualSize,
+ long estimateSize)</pre>
+</li>
+</ul>
+<a name="calculateReadCapacityUnitDiff-long-long-">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>calculateReadCapacityUnitDiff</h4>
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#line.162">calculateReadCapacityUnitDiff</a>(long actualSize,
+ long estimateSize)</pre>
+</li>
+</ul>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html b/devapidocs/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
index 83742b6..015b236 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html
@@ -435,7 +435,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/GlobalQuotaSettin
<ul class="blockList">
<li class="blockList">
<h4>validateTimedQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.205">validateTimedQuota</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota timedQuota)
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.215">validateTimedQuota</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota timedQuota)
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>
@@ -449,7 +449,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/GlobalQuotaSettin
<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/quotas/GlobalQuotaSettingsImpl.html#line.213">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/quotas/GlobalQuotaSettingsImpl.html#line.223">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>
@@ -462,7 +462,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/GlobalQuotaSettin
<ul class="blockList">
<li class="blockList">
<h4>buildThrottleQuotas</h4>
-<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a>,org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.272">buildThrottleQuotas</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle proto)</pre>
+<pre>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/Map.html?is-external=true" title="class or interface in java.util">Map</a><<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a>,org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.TimedQuota> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.287">buildThrottleQuotas</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle proto)</pre>
</li>
</ul>
<a name="clearThrottleBuilder-org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle.Builder-">
@@ -471,7 +471,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/quotas/GlobalQuotaSettin
<ul class="blockListLast">
<li class="blockList">
<h4>clearThrottleBuilder</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.295">clearThrottleBuilder</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle.Builder builder)</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/GlobalQuotaSettingsImpl.html#line.319">clearThrottleBuilder</a>(org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.Throttle.Builder builder)</pre>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html b/devapidocs/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
index f77193d..d427ff0 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html
@@ -115,7 +115,7 @@ var activeTableTab = "activeTableTab";
<br>
<pre>@InterfaceAudience.Private
@InterfaceStability.Evolving
-class <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.30">NoopQuotaLimiter</a>
+class <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.29">NoopQuotaLimiter</a>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></pre>
<div class="block">Noop quota limiter returned when no limiter is associated to the user/table</div>
@@ -177,22 +177,26 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeRead-long-">consumeRead</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeRead-long-long-">consumeRead</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some read amount to the quota.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeWrite-long-">consumeWrite</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeWrite-long-long-">consumeWrite</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some write amount to the quota.</div>
</td>
</tr>
@@ -210,10 +214,12 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota</a></span>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</code>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</code>
<div class="block">Removes the specified write and read amount from the quota.</div>
</td>
</tr>
@@ -253,7 +259,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockListLast">
<li class="blockList">
<h4>instance</h4>
-<pre>private static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.31">instance</a></pre>
+<pre>private static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.30">instance</a></pre>
</li>
</ul>
</li>
@@ -270,7 +276,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockListLast">
<li class="blockList">
<h4>NoopQuotaLimiter</h4>
-<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.33">NoopQuotaLimiter</a>()</pre>
+<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.32">NoopQuotaLimiter</a>()</pre>
</li>
</ul>
</li>
@@ -281,33 +287,39 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<!-- -->
</a>
<h3>Method Detail</h3>
-<a name="checkQuota-long-long-long-long-">
+<a name="checkQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.38">checkQuota</a>(long writeReqs,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.37">checkQuota</a>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)
throws <a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">QuotaLimiter</a></code></span></div>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Checks if it is possible to execute the specified operation.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>writeReqs</code> - the write requests that will be checked against the available quota</dd>
<dd><code>estimateWriteSize</code> - the write size that will be checked against the available quota</dd>
<dd><code>readReqs</code> - the read requests that will be checked against the available quota</dd>
<dd><code>estimateReadSize</code> - the read size that will be checked against the available quota</dd>
+<dd><code>estimateWriteCapacityUnit</code> - the write capacity unit that will be checked against the
+ available quota</dd>
+<dd><code>estimateReadCapacityUnit</code> - the read capacity unit that will be checked against the
+ available quota</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></code> - thrown if not enough available resources to perform operation.</dd>
</dl>
</li>
</ul>
-<a name="grabQuota-long-long-long-long-">
+<a name="grabQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
@@ -316,51 +328,57 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.44">grabQuota</a>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">QuotaLimiter</a></code></span></div>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes the specified write and read amount from the quota.
At this point the write and read amount will be an estimate,
that will be later adjusted with a consumeWrite()/consumeRead() call.</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>writeReqs</code> - the write requests that will be removed from the current quota</dd>
<dd><code>writeSize</code> - the write size that will be removed from the current quota</dd>
<dd><code>readReqs</code> - the read requests that will be removed from the current quota</dd>
<dd><code>readSize</code> - the read size that will be removed from the current quota</dd>
+<dd><code>writeCapacityUnit</code> - the write capacity unit that will be removed from the current quota</dd>
+<dd><code>readCapacityUnit</code> - the read capacity unit num that will be removed from the current quota</dd>
</dl>
</li>
</ul>
-<a name="consumeWrite-long-">
+<a name="consumeWrite-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeWrite</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.49">consumeWrite</a>(long size)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">QuotaLimiter</a></code></span></div>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.50">consumeWrite</a>(long size,
+ long capacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes or add back some write amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">consumeWrite</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">consumeWrite</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
</dl>
</li>
</ul>
-<a name="consumeRead-long-">
+<a name="consumeRead-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeRead</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.54">consumeRead</a>(long size)</pre>
-<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">QuotaLimiter</a></code></span></div>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.55">consumeRead</a>(long size,
+ long capacityUnit)</pre>
+<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">QuotaLimiter</a></code></span></div>
<div class="block">Removes or add back some read amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
-<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">consumeRead</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
+<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">consumeRead</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
</dl>
</li>
</ul>
@@ -370,7 +388,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>isBypass</h4>
-<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.59">isBypass</a>()</pre>
+<pre>public boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.60">isBypass</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#isBypass--">isBypass</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -385,7 +403,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>getWriteAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.64">getWriteAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.65">getWriteAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#getWriteAvailable--">getWriteAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -400,7 +418,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockList">
<li class="blockList">
<h4>getReadAvailable</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.69">getReadAvailable</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.70">getReadAvailable</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#getReadAvailable--">getReadAvailable</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></code></dd>
@@ -415,7 +433,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<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/quotas/NoopQuotaLimiter.html#line.74">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/quotas/NoopQuotaLimiter.html#line.75">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>
@@ -428,7 +446,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.h
<ul class="blockListLast">
<li class="blockList">
<h4>get</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.78">get</a>()</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#line.79">get</a>()</pre>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaLimiter.html b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
index d390618..3262481 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaLimiter.html
@@ -107,7 +107,7 @@ var activeTableTab = "activeTableTab";
<br>
<pre>@InterfaceAudience.Private
@InterfaceStability.Evolving
-public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.30">QuotaLimiter</a></pre>
+public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.29">QuotaLimiter</a></pre>
<div class="block">Internal interface used to interact with the user/table quota.</div>
</li>
</ul>
@@ -129,22 +129,26 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota</a></span>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)</code>
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)</code>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">consumeRead</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">consumeRead</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some read amount to the quota.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">consumeWrite</a></span>(long size)</code>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">consumeWrite</a></span>(long size,
+ long capacityUnit)</code>
<div class="block">Removes or add back some write amount to the quota.</div>
</td>
</tr>
@@ -158,10 +162,12 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code>void</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota</a></span>(long writeReqs,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota</a></span>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</code>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</code>
<div class="block">Removes the specified write and read amount from the quota.</div>
</td>
</tr>
@@ -184,16 +190,18 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<!-- -->
</a>
<h3>Method Detail</h3>
-<a name="checkQuota-long-long-long-long-">
+<a name="checkQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>checkQuota</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.40">checkQuota</a>(long writeReqs,
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.43">checkQuota</a>(long writeReqs,
long estimateWriteSize,
long readReqs,
- long estimateReadSize)
+ long estimateReadSize,
+ long estimateWriteCapacityUnit,
+ long estimateReadCapacityUnit)
throws <a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></pre>
<div class="block">Checks if it is possible to execute the specified operation.</div>
<dl>
@@ -202,21 +210,27 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<dd><code>estimateWriteSize</code> - the write size that will be checked against the available quota</dd>
<dd><code>readReqs</code> - the read requests that will be checked against the available quota</dd>
<dd><code>estimateReadSize</code> - the read size that will be checked against the available quota</dd>
+<dd><code>estimateWriteCapacityUnit</code> - the write capacity unit that will be checked against the
+ available quota</dd>
+<dd><code>estimateReadCapacityUnit</code> - the read capacity unit that will be checked against the
+ available quota</dd>
<dt><span class="throwsLabel">Throws:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.html" title="class in org.apache.hadoop.hbase.quotas">RpcThrottlingException</a></code> - thrown if not enough available resources to perform operation.</dd>
</dl>
</li>
</ul>
-<a name="grabQuota-long-long-long-long-">
+<a name="grabQuota-long-long-long-long-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>grabQuota</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.53">grabQuota</a>(long writeReqs,
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.58">grabQuota</a>(long writeReqs,
long writeSize,
long readReqs,
- long readSize)</pre>
+ long readSize,
+ long writeCapacityUnit,
+ long readCapacityUnit)</pre>
<div class="block">Removes the specified write and read amount from the quota.
At this point the write and read amount will be an estimate,
that will be later adjusted with a consumeWrite()/consumeRead() call.</div>
@@ -226,27 +240,31 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<dd><code>writeSize</code> - the write size that will be removed from the current quota</dd>
<dd><code>readReqs</code> - the read requests that will be removed from the current quota</dd>
<dd><code>readSize</code> - the read size that will be removed from the current quota</dd>
+<dd><code>writeCapacityUnit</code> - the write capacity unit that will be removed from the current quota</dd>
+<dd><code>readCapacityUnit</code> - the read capacity unit num that will be removed from the current quota</dd>
</dl>
</li>
</ul>
-<a name="consumeWrite-long-">
+<a name="consumeWrite-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeWrite</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.59">consumeWrite</a>(long size)</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.65">consumeWrite</a>(long size,
+ long capacityUnit)</pre>
<div class="block">Removes or add back some write amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
</li>
</ul>
-<a name="consumeRead-long-">
+<a name="consumeRead-long-long-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>consumeRead</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.65">consumeRead</a>(long size)</pre>
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.71">consumeRead</a>(long size,
+ long capacityUnit)</pre>
<div class="block">Removes or add back some read amount to the quota.
(called at the end of an operation in case the estimate quota was off)</div>
</li>
@@ -257,7 +275,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<ul class="blockList">
<li class="blockList">
<h4>isBypass</h4>
-<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.68">isBypass</a>()</pre>
+<pre>boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.74">isBypass</a>()</pre>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if the limiter is a noop</dd>
@@ -270,7 +288,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<ul class="blockList">
<li class="blockList">
<h4>getReadAvailable</h4>
-<pre>long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.71">getReadAvailable</a>()</pre>
+<pre>long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.77">getReadAvailable</a>()</pre>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the number of bytes available to read to avoid exceeding the quota</dd>
@@ -283,7 +301,7 @@ public interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas
<ul class="blockListLast">
<li class="blockList">
<h4>getWriteAvailable</h4>
-<pre>long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.74">getWriteAvailable</a>()</pre>
+<pre>long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaLimiter.html#line.80">getWriteAvailable</a>()</pre>
<dl>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>the number of bytes available to write to avoid exceeding the quota</dd>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
index ccc8493..a3531fa 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
@@ -461,7 +461,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>fromSpace</h4>
-<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.149">fromSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table,
+<pre>static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.161">fromSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> table,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
org.apache.hadoop.hbase.shaded.protobuf.generated.QuotaProtos.SpaceQuota protoQuota)</pre>
</li>
@@ -472,7 +472,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.184">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.196">throttleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -494,7 +494,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.199">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.211">throttleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
@@ -518,7 +518,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.214">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.226">throttleUser</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> userName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
@@ -542,7 +542,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.225">unthrottleUser</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> userName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.237">unthrottleUser</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> userName)</pre>
<div class="block">Remove the throttling for the specified user.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -558,7 +558,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.236">unthrottleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.248">unthrottleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Remove the throttling for the specified user on the specified table.</div>
<dl>
@@ -576,7 +576,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.247">unthrottleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.259">unthrottleUser</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> userName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace)</pre>
<div class="block">Remove the throttling for the specified user on the specified namespace.</div>
<dl>
@@ -594,7 +594,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleTable</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.260">throttleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.272">throttleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -616,7 +616,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleTable</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.271">unthrottleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.283">unthrottleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Remove the throttling for the specified table.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -632,7 +632,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleNamespace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.284">throttleNamespace</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> namespace,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.296">throttleNamespace</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> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -654,7 +654,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleNamespace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.295">unthrottleNamespace</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> namespace)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.307">unthrottleNamespace</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> namespace)</pre>
<div class="block">Remove the throttling for the specified namespace.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -670,7 +670,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttle</h4>
-<pre>private static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.300">throttle</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> userName,
+<pre>private static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.312">throttle</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
@@ -684,7 +684,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>bypassGlobals</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.324">bypassGlobals</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.336">bypassGlobals</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> userName,
boolean bypassGlobals)</pre>
<div class="block">Set the "bypass global settings" for the specified user</div>
<dl>
@@ -702,7 +702,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>limitTableSpace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.342">limitTableSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.354">limitTableSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
long sizeLimit,
<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas">SpaceViolationPolicy</a> violationPolicy)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to limit the FileSystem space usage for the given table
@@ -724,7 +724,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>removeTableSpaceLimit</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.354">removeTableSpaceLimit</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.366">removeTableSpaceLimit</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to remove the FileSystem space quota for the given
table.</div>
<dl>
@@ -741,7 +741,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>limitNamespaceSpace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.368">limitNamespaceSpace</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> namespace,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.380">limitNamespaceSpace</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> namespace,
long sizeLimit,
<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas">SpaceViolationPolicy</a> violationPolicy)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to limit the FileSystem space usage for the given
@@ -763,7 +763,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>removeNamespaceSpaceLimit</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.380">removeNamespaceSpaceLimit</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> namespace)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.392">removeNamespaceSpaceLimit</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> namespace)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to remove the FileSystem space quota for the given
namespace.</div>
<dl>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
index d8aeb03..4a661cf 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
@@ -105,7 +105,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>private static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.260">QuotaUtil.KeyFromRow</a><T></pre>
+<pre>private static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html#line.267">QuotaUtil.KeyFromRow</a><T></pre>
</li>
</ul>
</div>
@@ -149,7 +149,7 @@ var activeTableTab = "activeTableTab";
<ul class="blockListLast">
<li class="blockList">
<h4>getKeyFromRow</h4>
-<pre><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html" title="type parameter in QuotaUtil.KeyFromRow">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html#line.261">getKeyFromRow</a>(byte[] row)</pre>
+<pre><a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html" title="type parameter in QuotaUtil.KeyFromRow">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html#line.268">getKeyFromRow</a>(byte[] row)</pre>
</li>
</ul>
</li>
[07/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html
index 455d344..ed0431e 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.html
@@ -65,258 +65,265 @@
<span class="sourceLineNo">057</span> public static final String QUOTA_CONF_KEY = "hbase.quota.enabled";<a name="line.57"></a>
<span class="sourceLineNo">058</span> private static final boolean QUOTA_ENABLED_DEFAULT = false;<a name="line.58"></a>
<span class="sourceLineNo">059</span><a name="line.59"></a>
-<span class="sourceLineNo">060</span> /** Table descriptor for Quota internal table */<a name="line.60"></a>
-<span class="sourceLineNo">061</span> public static final HTableDescriptor QUOTA_TABLE_DESC =<a name="line.61"></a>
-<span class="sourceLineNo">062</span> new HTableDescriptor(QUOTA_TABLE_NAME);<a name="line.62"></a>
-<span class="sourceLineNo">063</span> static {<a name="line.63"></a>
-<span class="sourceLineNo">064</span> QUOTA_TABLE_DESC.addFamily(<a name="line.64"></a>
-<span class="sourceLineNo">065</span> new HColumnDescriptor(QUOTA_FAMILY_INFO)<a name="line.65"></a>
-<span class="sourceLineNo">066</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.66"></a>
-<span class="sourceLineNo">067</span> .setBloomFilterType(BloomType.ROW)<a name="line.67"></a>
-<span class="sourceLineNo">068</span> .setMaxVersions(1)<a name="line.68"></a>
-<span class="sourceLineNo">069</span> );<a name="line.69"></a>
-<span class="sourceLineNo">070</span> QUOTA_TABLE_DESC.addFamily(<a name="line.70"></a>
-<span class="sourceLineNo">071</span> new HColumnDescriptor(QUOTA_FAMILY_USAGE)<a name="line.71"></a>
-<span class="sourceLineNo">072</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.72"></a>
-<span class="sourceLineNo">073</span> .setBloomFilterType(BloomType.ROW)<a name="line.73"></a>
-<span class="sourceLineNo">074</span> .setMaxVersions(1)<a name="line.74"></a>
-<span class="sourceLineNo">075</span> );<a name="line.75"></a>
-<span class="sourceLineNo">076</span> }<a name="line.76"></a>
-<span class="sourceLineNo">077</span><a name="line.77"></a>
-<span class="sourceLineNo">078</span> /** Returns true if the support for quota is enabled */<a name="line.78"></a>
-<span class="sourceLineNo">079</span> public static boolean isQuotaEnabled(final Configuration conf) {<a name="line.79"></a>
-<span class="sourceLineNo">080</span> return conf.getBoolean(QUOTA_CONF_KEY, QUOTA_ENABLED_DEFAULT);<a name="line.80"></a>
-<span class="sourceLineNo">081</span> }<a name="line.81"></a>
-<span class="sourceLineNo">082</span><a name="line.82"></a>
-<span class="sourceLineNo">083</span> /* =========================================================================<a name="line.83"></a>
-<span class="sourceLineNo">084</span> * Quota "settings" helpers<a name="line.84"></a>
-<span class="sourceLineNo">085</span> */<a name="line.85"></a>
-<span class="sourceLineNo">086</span> public static void addTableQuota(final Connection connection, final TableName table,<a name="line.86"></a>
-<span class="sourceLineNo">087</span> final Quotas data) throws IOException {<a name="line.87"></a>
-<span class="sourceLineNo">088</span> addQuotas(connection, getTableRowKey(table), data);<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> public static void deleteTableQuota(final Connection connection, final TableName table)<a name="line.91"></a>
-<span class="sourceLineNo">092</span> throws IOException {<a name="line.92"></a>
-<span class="sourceLineNo">093</span> deleteQuotas(connection, getTableRowKey(table));<a name="line.93"></a>
-<span class="sourceLineNo">094</span> }<a name="line.94"></a>
-<span class="sourceLineNo">095</span><a name="line.95"></a>
-<span class="sourceLineNo">096</span> public static void addNamespaceQuota(final Connection connection, final String namespace,<a name="line.96"></a>
-<span class="sourceLineNo">097</span> final Quotas data) throws IOException {<a name="line.97"></a>
-<span class="sourceLineNo">098</span> addQuotas(connection, getNamespaceRowKey(namespace), data);<a name="line.98"></a>
-<span class="sourceLineNo">099</span> }<a name="line.99"></a>
-<span class="sourceLineNo">100</span><a name="line.100"></a>
-<span class="sourceLineNo">101</span> public static void deleteNamespaceQuota(final Connection connection, final String namespace)<a name="line.101"></a>
-<span class="sourceLineNo">102</span> throws IOException {<a name="line.102"></a>
-<span class="sourceLineNo">103</span> deleteQuotas(connection, getNamespaceRowKey(namespace));<a name="line.103"></a>
-<span class="sourceLineNo">104</span> }<a name="line.104"></a>
-<span class="sourceLineNo">105</span><a name="line.105"></a>
-<span class="sourceLineNo">106</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.106"></a>
-<span class="sourceLineNo">107</span> final Quotas data) throws IOException {<a name="line.107"></a>
-<span class="sourceLineNo">108</span> addQuotas(connection, getUserRowKey(user), data);<a name="line.108"></a>
-<span class="sourceLineNo">109</span> }<a name="line.109"></a>
-<span class="sourceLineNo">110</span><a name="line.110"></a>
-<span class="sourceLineNo">111</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.111"></a>
-<span class="sourceLineNo">112</span> final TableName table, final Quotas data) throws IOException {<a name="line.112"></a>
-<span class="sourceLineNo">113</span> addQuotas(connection, getUserRowKey(user), getSettingsQualifierForUserTable(table), data);<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> public static void addUserQuota(final Connection connection, final String user,<a name="line.116"></a>
-<span class="sourceLineNo">117</span> final String namespace, final Quotas data) throws IOException {<a name="line.117"></a>
-<span class="sourceLineNo">118</span> addQuotas(connection, getUserRowKey(user),<a name="line.118"></a>
-<span class="sourceLineNo">119</span> getSettingsQualifierForUserNamespace(namespace), data);<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> public static void deleteUserQuota(final Connection connection, final String user)<a name="line.122"></a>
-<span class="sourceLineNo">123</span> throws IOException {<a name="line.123"></a>
-<span class="sourceLineNo">124</span> deleteQuotas(connection, getUserRowKey(user));<a name="line.124"></a>
-<span class="sourceLineNo">125</span> }<a name="line.125"></a>
-<span class="sourceLineNo">126</span><a name="line.126"></a>
-<span class="sourceLineNo">127</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.127"></a>
-<span class="sourceLineNo">128</span> final TableName table) throws IOException {<a name="line.128"></a>
-<span class="sourceLineNo">129</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.129"></a>
-<span class="sourceLineNo">130</span> getSettingsQualifierForUserTable(table));<a name="line.130"></a>
-<span class="sourceLineNo">131</span> }<a name="line.131"></a>
-<span class="sourceLineNo">132</span><a name="line.132"></a>
-<span class="sourceLineNo">133</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.133"></a>
-<span class="sourceLineNo">134</span> final String namespace) throws IOException {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.135"></a>
-<span class="sourceLineNo">136</span> getSettingsQualifierForUserNamespace(namespace));<a name="line.136"></a>
-<span class="sourceLineNo">137</span> }<a name="line.137"></a>
-<span class="sourceLineNo">138</span><a name="line.138"></a>
-<span class="sourceLineNo">139</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.139"></a>
-<span class="sourceLineNo">140</span> final Quotas data) throws IOException {<a name="line.140"></a>
-<span class="sourceLineNo">141</span> addQuotas(connection, rowKey, QUOTA_QUALIFIER_SETTINGS, data);<a name="line.141"></a>
-<span class="sourceLineNo">142</span> }<a name="line.142"></a>
-<span class="sourceLineNo">143</span><a name="line.143"></a>
-<span class="sourceLineNo">144</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.144"></a>
-<span class="sourceLineNo">145</span> final byte[] qualifier, final Quotas data) throws IOException {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> Put put = new Put(rowKey);<a name="line.146"></a>
-<span class="sourceLineNo">147</span> put.addColumn(QUOTA_FAMILY_INFO, qualifier, quotasToData(data));<a name="line.147"></a>
-<span class="sourceLineNo">148</span> doPut(connection, put);<a name="line.148"></a>
+<span class="sourceLineNo">060</span> public static final String READ_CAPACITY_UNIT_CONF_KEY = "hbase.quota.read.capacity.unit";<a name="line.60"></a>
+<span class="sourceLineNo">061</span> // the default one read capacity unit is 1024 bytes (1KB)<a name="line.61"></a>
+<span class="sourceLineNo">062</span> public static final long DEFAULT_READ_CAPACITY_UNIT = 1024;<a name="line.62"></a>
+<span class="sourceLineNo">063</span> public static final String WRITE_CAPACITY_UNIT_CONF_KEY = "hbase.quota.write.capacity.unit";<a name="line.63"></a>
+<span class="sourceLineNo">064</span> // the default one write capacity unit is 1024 bytes (1KB)<a name="line.64"></a>
+<span class="sourceLineNo">065</span> public static final long DEFAULT_WRITE_CAPACITY_UNIT = 1024;<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span> /** Table descriptor for Quota internal table */<a name="line.67"></a>
+<span class="sourceLineNo">068</span> public static final HTableDescriptor QUOTA_TABLE_DESC =<a name="line.68"></a>
+<span class="sourceLineNo">069</span> new HTableDescriptor(QUOTA_TABLE_NAME);<a name="line.69"></a>
+<span class="sourceLineNo">070</span> static {<a name="line.70"></a>
+<span class="sourceLineNo">071</span> QUOTA_TABLE_DESC.addFamily(<a name="line.71"></a>
+<span class="sourceLineNo">072</span> new HColumnDescriptor(QUOTA_FAMILY_INFO)<a name="line.72"></a>
+<span class="sourceLineNo">073</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.73"></a>
+<span class="sourceLineNo">074</span> .setBloomFilterType(BloomType.ROW)<a name="line.74"></a>
+<span class="sourceLineNo">075</span> .setMaxVersions(1)<a name="line.75"></a>
+<span class="sourceLineNo">076</span> );<a name="line.76"></a>
+<span class="sourceLineNo">077</span> QUOTA_TABLE_DESC.addFamily(<a name="line.77"></a>
+<span class="sourceLineNo">078</span> new HColumnDescriptor(QUOTA_FAMILY_USAGE)<a name="line.78"></a>
+<span class="sourceLineNo">079</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.79"></a>
+<span class="sourceLineNo">080</span> .setBloomFilterType(BloomType.ROW)<a name="line.80"></a>
+<span class="sourceLineNo">081</span> .setMaxVersions(1)<a name="line.81"></a>
+<span class="sourceLineNo">082</span> );<a name="line.82"></a>
+<span class="sourceLineNo">083</span> }<a name="line.83"></a>
+<span class="sourceLineNo">084</span><a name="line.84"></a>
+<span class="sourceLineNo">085</span> /** Returns true if the support for quota is enabled */<a name="line.85"></a>
+<span class="sourceLineNo">086</span> public static boolean isQuotaEnabled(final Configuration conf) {<a name="line.86"></a>
+<span class="sourceLineNo">087</span> return conf.getBoolean(QUOTA_CONF_KEY, QUOTA_ENABLED_DEFAULT);<a name="line.87"></a>
+<span class="sourceLineNo">088</span> }<a name="line.88"></a>
+<span class="sourceLineNo">089</span><a name="line.89"></a>
+<span class="sourceLineNo">090</span> /* =========================================================================<a name="line.90"></a>
+<span class="sourceLineNo">091</span> * Quota "settings" helpers<a name="line.91"></a>
+<span class="sourceLineNo">092</span> */<a name="line.92"></a>
+<span class="sourceLineNo">093</span> public static void addTableQuota(final Connection connection, final TableName table,<a name="line.93"></a>
+<span class="sourceLineNo">094</span> final Quotas data) throws IOException {<a name="line.94"></a>
+<span class="sourceLineNo">095</span> addQuotas(connection, getTableRowKey(table), data);<a name="line.95"></a>
+<span class="sourceLineNo">096</span> }<a name="line.96"></a>
+<span class="sourceLineNo">097</span><a name="line.97"></a>
+<span class="sourceLineNo">098</span> public static void deleteTableQuota(final Connection connection, final TableName table)<a name="line.98"></a>
+<span class="sourceLineNo">099</span> throws IOException {<a name="line.99"></a>
+<span class="sourceLineNo">100</span> deleteQuotas(connection, getTableRowKey(table));<a name="line.100"></a>
+<span class="sourceLineNo">101</span> }<a name="line.101"></a>
+<span class="sourceLineNo">102</span><a name="line.102"></a>
+<span class="sourceLineNo">103</span> public static void addNamespaceQuota(final Connection connection, final String namespace,<a name="line.103"></a>
+<span class="sourceLineNo">104</span> final Quotas data) throws IOException {<a name="line.104"></a>
+<span class="sourceLineNo">105</span> addQuotas(connection, getNamespaceRowKey(namespace), data);<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> public static void deleteNamespaceQuota(final Connection connection, final String namespace)<a name="line.108"></a>
+<span class="sourceLineNo">109</span> throws IOException {<a name="line.109"></a>
+<span class="sourceLineNo">110</span> deleteQuotas(connection, getNamespaceRowKey(namespace));<a name="line.110"></a>
+<span class="sourceLineNo">111</span> }<a name="line.111"></a>
+<span class="sourceLineNo">112</span><a name="line.112"></a>
+<span class="sourceLineNo">113</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.113"></a>
+<span class="sourceLineNo">114</span> final Quotas data) throws IOException {<a name="line.114"></a>
+<span class="sourceLineNo">115</span> addQuotas(connection, getUserRowKey(user), data);<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> public static void addUserQuota(final Connection connection, final String user,<a name="line.118"></a>
+<span class="sourceLineNo">119</span> final TableName table, final Quotas data) throws IOException {<a name="line.119"></a>
+<span class="sourceLineNo">120</span> addQuotas(connection, getUserRowKey(user), getSettingsQualifierForUserTable(table), data);<a name="line.120"></a>
+<span class="sourceLineNo">121</span> }<a name="line.121"></a>
+<span class="sourceLineNo">122</span><a name="line.122"></a>
+<span class="sourceLineNo">123</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.123"></a>
+<span class="sourceLineNo">124</span> final String namespace, final Quotas data) throws IOException {<a name="line.124"></a>
+<span class="sourceLineNo">125</span> addQuotas(connection, getUserRowKey(user),<a name="line.125"></a>
+<span class="sourceLineNo">126</span> getSettingsQualifierForUserNamespace(namespace), data);<a name="line.126"></a>
+<span class="sourceLineNo">127</span> }<a name="line.127"></a>
+<span class="sourceLineNo">128</span><a name="line.128"></a>
+<span class="sourceLineNo">129</span> public static void deleteUserQuota(final Connection connection, final String user)<a name="line.129"></a>
+<span class="sourceLineNo">130</span> throws IOException {<a name="line.130"></a>
+<span class="sourceLineNo">131</span> deleteQuotas(connection, getUserRowKey(user));<a name="line.131"></a>
+<span class="sourceLineNo">132</span> }<a name="line.132"></a>
+<span class="sourceLineNo">133</span><a name="line.133"></a>
+<span class="sourceLineNo">134</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.134"></a>
+<span class="sourceLineNo">135</span> final TableName table) throws IOException {<a name="line.135"></a>
+<span class="sourceLineNo">136</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.136"></a>
+<span class="sourceLineNo">137</span> getSettingsQualifierForUserTable(table));<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> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.140"></a>
+<span class="sourceLineNo">141</span> final String namespace) throws IOException {<a name="line.141"></a>
+<span class="sourceLineNo">142</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.142"></a>
+<span class="sourceLineNo">143</span> getSettingsQualifierForUserNamespace(namespace));<a name="line.143"></a>
+<span class="sourceLineNo">144</span> }<a name="line.144"></a>
+<span class="sourceLineNo">145</span><a name="line.145"></a>
+<span class="sourceLineNo">146</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.146"></a>
+<span class="sourceLineNo">147</span> final Quotas data) throws IOException {<a name="line.147"></a>
+<span class="sourceLineNo">148</span> addQuotas(connection, rowKey, QUOTA_QUALIFIER_SETTINGS, data);<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> private static void deleteQuotas(final Connection connection, final byte[] rowKey)<a name="line.151"></a>
-<span class="sourceLineNo">152</span> throws IOException {<a name="line.152"></a>
-<span class="sourceLineNo">153</span> deleteQuotas(connection, rowKey, null);<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> private static void deleteQuotas(final Connection connection, final byte[] rowKey,<a name="line.156"></a>
-<span class="sourceLineNo">157</span> final byte[] qualifier) throws IOException {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> Delete delete = new Delete(rowKey);<a name="line.158"></a>
-<span class="sourceLineNo">159</span> if (qualifier != null) {<a name="line.159"></a>
-<span class="sourceLineNo">160</span> delete.addColumns(QUOTA_FAMILY_INFO, qualifier);<a name="line.160"></a>
-<span class="sourceLineNo">161</span> }<a name="line.161"></a>
-<span class="sourceLineNo">162</span> doDelete(connection, delete);<a name="line.162"></a>
-<span class="sourceLineNo">163</span> }<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span> public static Map<String, UserQuotaState> fetchUserQuotas(final Connection connection,<a name="line.165"></a>
-<span class="sourceLineNo">166</span> final List<Get> gets) throws IOException {<a name="line.166"></a>
-<span class="sourceLineNo">167</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.167"></a>
-<span class="sourceLineNo">168</span> Result[] results = doGet(connection, gets);<a name="line.168"></a>
-<span class="sourceLineNo">169</span><a name="line.169"></a>
-<span class="sourceLineNo">170</span> Map<String, UserQuotaState> userQuotas = new HashMap<>(results.length);<a name="line.170"></a>
-<span class="sourceLineNo">171</span> for (int i = 0; i < results.length; ++i) {<a name="line.171"></a>
-<span class="sourceLineNo">172</span> byte[] key = gets.get(i).getRow();<a name="line.172"></a>
-<span class="sourceLineNo">173</span> assert isUserRowKey(key);<a name="line.173"></a>
-<span class="sourceLineNo">174</span> String user = getUserFromRowKey(key);<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> final UserQuotaState quotaInfo = new UserQuotaState(nowTs);<a name="line.176"></a>
-<span class="sourceLineNo">177</span> userQuotas.put(user, quotaInfo);<a name="line.177"></a>
-<span class="sourceLineNo">178</span><a name="line.178"></a>
-<span class="sourceLineNo">179</span> if (results[i].isEmpty()) continue;<a name="line.179"></a>
-<span class="sourceLineNo">180</span> assert Bytes.equals(key, results[i].getRow());<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span> try {<a name="line.182"></a>
-<span class="sourceLineNo">183</span> parseUserResult(user, results[i], new UserQuotasVisitor() {<a name="line.183"></a>
-<span class="sourceLineNo">184</span> @Override<a name="line.184"></a>
-<span class="sourceLineNo">185</span> public void visitUserQuotas(String userName, String namespace, Quotas quotas) {<a name="line.185"></a>
-<span class="sourceLineNo">186</span> quotaInfo.setQuotas(namespace, quotas);<a name="line.186"></a>
-<span class="sourceLineNo">187</span> }<a name="line.187"></a>
+<span class="sourceLineNo">151</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.151"></a>
+<span class="sourceLineNo">152</span> final byte[] qualifier, final Quotas data) throws IOException {<a name="line.152"></a>
+<span class="sourceLineNo">153</span> Put put = new Put(rowKey);<a name="line.153"></a>
+<span class="sourceLineNo">154</span> put.addColumn(QUOTA_FAMILY_INFO, qualifier, quotasToData(data));<a name="line.154"></a>
+<span class="sourceLineNo">155</span> doPut(connection, put);<a name="line.155"></a>
+<span class="sourceLineNo">156</span> }<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span> private static void deleteQuotas(final Connection connection, final byte[] rowKey)<a name="line.158"></a>
+<span class="sourceLineNo">159</span> throws IOException {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> deleteQuotas(connection, rowKey, null);<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> private static void deleteQuotas(final Connection connection, final byte[] rowKey,<a name="line.163"></a>
+<span class="sourceLineNo">164</span> final byte[] qualifier) throws IOException {<a name="line.164"></a>
+<span class="sourceLineNo">165</span> Delete delete = new Delete(rowKey);<a name="line.165"></a>
+<span class="sourceLineNo">166</span> if (qualifier != null) {<a name="line.166"></a>
+<span class="sourceLineNo">167</span> delete.addColumns(QUOTA_FAMILY_INFO, qualifier);<a name="line.167"></a>
+<span class="sourceLineNo">168</span> }<a name="line.168"></a>
+<span class="sourceLineNo">169</span> doDelete(connection, delete);<a name="line.169"></a>
+<span class="sourceLineNo">170</span> }<a name="line.170"></a>
+<span class="sourceLineNo">171</span><a name="line.171"></a>
+<span class="sourceLineNo">172</span> public static Map<String, UserQuotaState> fetchUserQuotas(final Connection connection,<a name="line.172"></a>
+<span class="sourceLineNo">173</span> final List<Get> gets) throws IOException {<a name="line.173"></a>
+<span class="sourceLineNo">174</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.174"></a>
+<span class="sourceLineNo">175</span> Result[] results = doGet(connection, gets);<a name="line.175"></a>
+<span class="sourceLineNo">176</span><a name="line.176"></a>
+<span class="sourceLineNo">177</span> Map<String, UserQuotaState> userQuotas = new HashMap<>(results.length);<a name="line.177"></a>
+<span class="sourceLineNo">178</span> for (int i = 0; i < results.length; ++i) {<a name="line.178"></a>
+<span class="sourceLineNo">179</span> byte[] key = gets.get(i).getRow();<a name="line.179"></a>
+<span class="sourceLineNo">180</span> assert isUserRowKey(key);<a name="line.180"></a>
+<span class="sourceLineNo">181</span> String user = getUserFromRowKey(key);<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> final UserQuotaState quotaInfo = new UserQuotaState(nowTs);<a name="line.183"></a>
+<span class="sourceLineNo">184</span> userQuotas.put(user, quotaInfo);<a name="line.184"></a>
+<span class="sourceLineNo">185</span><a name="line.185"></a>
+<span class="sourceLineNo">186</span> if (results[i].isEmpty()) continue;<a name="line.186"></a>
+<span class="sourceLineNo">187</span> assert Bytes.equals(key, results[i].getRow());<a name="line.187"></a>
<span class="sourceLineNo">188</span><a name="line.188"></a>
-<span class="sourceLineNo">189</span> @Override<a name="line.189"></a>
-<span class="sourceLineNo">190</span> public void visitUserQuotas(String userName, TableName table, Quotas quotas) {<a name="line.190"></a>
-<span class="sourceLineNo">191</span> quotaInfo.setQuotas(table, quotas);<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> @Override<a name="line.194"></a>
-<span class="sourceLineNo">195</span> public void visitUserQuotas(String userName, Quotas quotas) {<a name="line.195"></a>
-<span class="sourceLineNo">196</span> quotaInfo.setQuotas(quotas);<a name="line.196"></a>
-<span class="sourceLineNo">197</span> }<a name="line.197"></a>
-<span class="sourceLineNo">198</span> });<a name="line.198"></a>
-<span class="sourceLineNo">199</span> } catch (IOException e) {<a name="line.199"></a>
-<span class="sourceLineNo">200</span> LOG.error("Unable to parse user '" + user + "' quotas", e);<a name="line.200"></a>
-<span class="sourceLineNo">201</span> userQuotas.remove(user);<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span> }<a name="line.203"></a>
-<span class="sourceLineNo">204</span> return userQuotas;<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> public static Map<TableName, QuotaState> fetchTableQuotas(final Connection connection,<a name="line.207"></a>
-<span class="sourceLineNo">208</span> final List<Get> gets) throws IOException {<a name="line.208"></a>
-<span class="sourceLineNo">209</span> return fetchGlobalQuotas("table", connection, gets, new KeyFromRow<TableName>() {<a name="line.209"></a>
-<span class="sourceLineNo">210</span> @Override<a name="line.210"></a>
-<span class="sourceLineNo">211</span> public TableName getKeyFromRow(final byte[] row) {<a name="line.211"></a>
-<span class="sourceLineNo">212</span> assert isTableRowKey(row);<a name="line.212"></a>
-<span class="sourceLineNo">213</span> return getTableFromRowKey(row);<a name="line.213"></a>
-<span class="sourceLineNo">214</span> }<a name="line.214"></a>
-<span class="sourceLineNo">215</span> });<a name="line.215"></a>
-<span class="sourceLineNo">216</span> }<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span> public static Map<String, QuotaState> fetchNamespaceQuotas(final Connection connection,<a name="line.218"></a>
-<span class="sourceLineNo">219</span> final List<Get> gets) throws IOException {<a name="line.219"></a>
-<span class="sourceLineNo">220</span> return fetchGlobalQuotas("namespace", connection, gets, new KeyFromRow<String>() {<a name="line.220"></a>
-<span class="sourceLineNo">221</span> @Override<a name="line.221"></a>
-<span class="sourceLineNo">222</span> public String getKeyFromRow(final byte[] row) {<a name="line.222"></a>
-<span class="sourceLineNo">223</span> assert isNamespaceRowKey(row);<a name="line.223"></a>
-<span class="sourceLineNo">224</span> return getNamespaceFromRowKey(row);<a name="line.224"></a>
-<span class="sourceLineNo">225</span> }<a name="line.225"></a>
-<span class="sourceLineNo">226</span> });<a name="line.226"></a>
-<span class="sourceLineNo">227</span> }<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span> public static <K> Map<K, QuotaState> fetchGlobalQuotas(final String type,<a name="line.229"></a>
-<span class="sourceLineNo">230</span> final Connection connection, final List<Get> gets, final KeyFromRow<K> kfr)<a name="line.230"></a>
-<span class="sourceLineNo">231</span> throws IOException {<a name="line.231"></a>
-<span class="sourceLineNo">232</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.232"></a>
-<span class="sourceLineNo">233</span> Result[] results = doGet(connection, gets);<a name="line.233"></a>
-<span class="sourceLineNo">234</span><a name="line.234"></a>
-<span class="sourceLineNo">235</span> Map<K, QuotaState> globalQuotas = new HashMap<>(results.length);<a name="line.235"></a>
-<span class="sourceLineNo">236</span> for (int i = 0; i < results.length; ++i) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> byte[] row = gets.get(i).getRow();<a name="line.237"></a>
-<span class="sourceLineNo">238</span> K key = kfr.getKeyFromRow(row);<a name="line.238"></a>
-<span class="sourceLineNo">239</span><a name="line.239"></a>
-<span class="sourceLineNo">240</span> QuotaState quotaInfo = new QuotaState(nowTs);<a name="line.240"></a>
-<span class="sourceLineNo">241</span> globalQuotas.put(key, quotaInfo);<a name="line.241"></a>
-<span class="sourceLineNo">242</span><a name="line.242"></a>
-<span class="sourceLineNo">243</span> if (results[i].isEmpty()) continue;<a name="line.243"></a>
-<span class="sourceLineNo">244</span> assert Bytes.equals(row, results[i].getRow());<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span> byte[] data = results[i].getValue(QUOTA_FAMILY_INFO, QUOTA_QUALIFIER_SETTINGS);<a name="line.246"></a>
-<span class="sourceLineNo">247</span> if (data == null) continue;<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span> try {<a name="line.249"></a>
-<span class="sourceLineNo">250</span> Quotas quotas = quotasFromData(data);<a name="line.250"></a>
-<span class="sourceLineNo">251</span> quotaInfo.setQuotas(quotas);<a name="line.251"></a>
-<span class="sourceLineNo">252</span> } catch (IOException e) {<a name="line.252"></a>
-<span class="sourceLineNo">253</span> LOG.error("Unable to parse " + type + " '" + key + "' quotas", e);<a name="line.253"></a>
-<span class="sourceLineNo">254</span> globalQuotas.remove(key);<a name="line.254"></a>
-<span class="sourceLineNo">255</span> }<a name="line.255"></a>
-<span class="sourceLineNo">256</span> }<a name="line.256"></a>
-<span class="sourceLineNo">257</span> return globalQuotas;<a name="line.257"></a>
-<span class="sourceLineNo">258</span> }<a name="line.258"></a>
-<span class="sourceLineNo">259</span><a name="line.259"></a>
-<span class="sourceLineNo">260</span> private static interface KeyFromRow<T> {<a name="line.260"></a>
-<span class="sourceLineNo">261</span> T getKeyFromRow(final byte[] row);<a name="line.261"></a>
-<span class="sourceLineNo">262</span> }<a name="line.262"></a>
-<span class="sourceLineNo">263</span><a name="line.263"></a>
-<span class="sourceLineNo">264</span> /* =========================================================================<a name="line.264"></a>
-<span class="sourceLineNo">265</span> * HTable helpers<a name="line.265"></a>
-<span class="sourceLineNo">266</span> */<a name="line.266"></a>
-<span class="sourceLineNo">267</span> private static void doPut(final Connection connection, final Put put)<a name="line.267"></a>
-<span class="sourceLineNo">268</span> throws IOException {<a name="line.268"></a>
-<span class="sourceLineNo">269</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.269"></a>
-<span class="sourceLineNo">270</span> table.put(put);<a name="line.270"></a>
-<span class="sourceLineNo">271</span> }<a name="line.271"></a>
-<span class="sourceLineNo">272</span> }<a name="line.272"></a>
-<span class="sourceLineNo">273</span><a name="line.273"></a>
-<span class="sourceLineNo">274</span> private static void doDelete(final Connection connection, final Delete delete)<a name="line.274"></a>
+<span class="sourceLineNo">189</span> try {<a name="line.189"></a>
+<span class="sourceLineNo">190</span> parseUserResult(user, results[i], new UserQuotasVisitor() {<a name="line.190"></a>
+<span class="sourceLineNo">191</span> @Override<a name="line.191"></a>
+<span class="sourceLineNo">192</span> public void visitUserQuotas(String userName, String namespace, Quotas quotas) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span> quotaInfo.setQuotas(namespace, quotas);<a name="line.193"></a>
+<span class="sourceLineNo">194</span> }<a name="line.194"></a>
+<span class="sourceLineNo">195</span><a name="line.195"></a>
+<span class="sourceLineNo">196</span> @Override<a name="line.196"></a>
+<span class="sourceLineNo">197</span> public void visitUserQuotas(String userName, TableName table, Quotas quotas) {<a name="line.197"></a>
+<span class="sourceLineNo">198</span> quotaInfo.setQuotas(table, quotas);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span><a name="line.200"></a>
+<span class="sourceLineNo">201</span> @Override<a name="line.201"></a>
+<span class="sourceLineNo">202</span> public void visitUserQuotas(String userName, Quotas quotas) {<a name="line.202"></a>
+<span class="sourceLineNo">203</span> quotaInfo.setQuotas(quotas);<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> } catch (IOException e) {<a name="line.206"></a>
+<span class="sourceLineNo">207</span> LOG.error("Unable to parse user '" + user + "' quotas", e);<a name="line.207"></a>
+<span class="sourceLineNo">208</span> userQuotas.remove(user);<a name="line.208"></a>
+<span class="sourceLineNo">209</span> }<a name="line.209"></a>
+<span class="sourceLineNo">210</span> }<a name="line.210"></a>
+<span class="sourceLineNo">211</span> return userQuotas;<a name="line.211"></a>
+<span class="sourceLineNo">212</span> }<a name="line.212"></a>
+<span class="sourceLineNo">213</span><a name="line.213"></a>
+<span class="sourceLineNo">214</span> public static Map<TableName, QuotaState> fetchTableQuotas(final Connection connection,<a name="line.214"></a>
+<span class="sourceLineNo">215</span> final List<Get> gets) throws IOException {<a name="line.215"></a>
+<span class="sourceLineNo">216</span> return fetchGlobalQuotas("table", connection, gets, new KeyFromRow<TableName>() {<a name="line.216"></a>
+<span class="sourceLineNo">217</span> @Override<a name="line.217"></a>
+<span class="sourceLineNo">218</span> public TableName getKeyFromRow(final byte[] row) {<a name="line.218"></a>
+<span class="sourceLineNo">219</span> assert isTableRowKey(row);<a name="line.219"></a>
+<span class="sourceLineNo">220</span> return getTableFromRowKey(row);<a name="line.220"></a>
+<span class="sourceLineNo">221</span> }<a name="line.221"></a>
+<span class="sourceLineNo">222</span> });<a name="line.222"></a>
+<span class="sourceLineNo">223</span> }<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span> public static Map<String, QuotaState> fetchNamespaceQuotas(final Connection connection,<a name="line.225"></a>
+<span class="sourceLineNo">226</span> final List<Get> gets) throws IOException {<a name="line.226"></a>
+<span class="sourceLineNo">227</span> return fetchGlobalQuotas("namespace", connection, gets, new KeyFromRow<String>() {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> @Override<a name="line.228"></a>
+<span class="sourceLineNo">229</span> public String getKeyFromRow(final byte[] row) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span> assert isNamespaceRowKey(row);<a name="line.230"></a>
+<span class="sourceLineNo">231</span> return getNamespaceFromRowKey(row);<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> }<a name="line.234"></a>
+<span class="sourceLineNo">235</span><a name="line.235"></a>
+<span class="sourceLineNo">236</span> public static <K> Map<K, QuotaState> fetchGlobalQuotas(final String type,<a name="line.236"></a>
+<span class="sourceLineNo">237</span> final Connection connection, final List<Get> gets, final KeyFromRow<K> kfr)<a name="line.237"></a>
+<span class="sourceLineNo">238</span> throws IOException {<a name="line.238"></a>
+<span class="sourceLineNo">239</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.239"></a>
+<span class="sourceLineNo">240</span> Result[] results = doGet(connection, gets);<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span> Map<K, QuotaState> globalQuotas = new HashMap<>(results.length);<a name="line.242"></a>
+<span class="sourceLineNo">243</span> for (int i = 0; i < results.length; ++i) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span> byte[] row = gets.get(i).getRow();<a name="line.244"></a>
+<span class="sourceLineNo">245</span> K key = kfr.getKeyFromRow(row);<a name="line.245"></a>
+<span class="sourceLineNo">246</span><a name="line.246"></a>
+<span class="sourceLineNo">247</span> QuotaState quotaInfo = new QuotaState(nowTs);<a name="line.247"></a>
+<span class="sourceLineNo">248</span> globalQuotas.put(key, quotaInfo);<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span> if (results[i].isEmpty()) continue;<a name="line.250"></a>
+<span class="sourceLineNo">251</span> assert Bytes.equals(row, results[i].getRow());<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span> byte[] data = results[i].getValue(QUOTA_FAMILY_INFO, QUOTA_QUALIFIER_SETTINGS);<a name="line.253"></a>
+<span class="sourceLineNo">254</span> if (data == null) continue;<a name="line.254"></a>
+<span class="sourceLineNo">255</span><a name="line.255"></a>
+<span class="sourceLineNo">256</span> try {<a name="line.256"></a>
+<span class="sourceLineNo">257</span> Quotas quotas = quotasFromData(data);<a name="line.257"></a>
+<span class="sourceLineNo">258</span> quotaInfo.setQuotas(quotas);<a name="line.258"></a>
+<span class="sourceLineNo">259</span> } catch (IOException e) {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> LOG.error("Unable to parse " + type + " '" + key + "' quotas", e);<a name="line.260"></a>
+<span class="sourceLineNo">261</span> globalQuotas.remove(key);<a name="line.261"></a>
+<span class="sourceLineNo">262</span> }<a name="line.262"></a>
+<span class="sourceLineNo">263</span> }<a name="line.263"></a>
+<span class="sourceLineNo">264</span> return globalQuotas;<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> private static interface KeyFromRow<T> {<a name="line.267"></a>
+<span class="sourceLineNo">268</span> T getKeyFromRow(final byte[] row);<a name="line.268"></a>
+<span class="sourceLineNo">269</span> }<a name="line.269"></a>
+<span class="sourceLineNo">270</span><a name="line.270"></a>
+<span class="sourceLineNo">271</span> /* =========================================================================<a name="line.271"></a>
+<span class="sourceLineNo">272</span> * HTable helpers<a name="line.272"></a>
+<span class="sourceLineNo">273</span> */<a name="line.273"></a>
+<span class="sourceLineNo">274</span> private static void doPut(final Connection connection, final Put put)<a name="line.274"></a>
<span class="sourceLineNo">275</span> throws IOException {<a name="line.275"></a>
<span class="sourceLineNo">276</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.276"></a>
-<span class="sourceLineNo">277</span> table.delete(delete);<a name="line.277"></a>
+<span class="sourceLineNo">277</span> table.put(put);<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> /* =========================================================================<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * Data Size Helpers<a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static long calculateMutationSize(final Mutation mutation) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span> long size = 0;<a name="line.285"></a>
-<span class="sourceLineNo">286</span> for (Map.Entry<byte [], List<Cell>> entry : mutation.getFamilyCellMap().entrySet()) {<a name="line.286"></a>
-<span class="sourceLineNo">287</span> for (Cell cell : entry.getValue()) {<a name="line.287"></a>
-<span class="sourceLineNo">288</span> size += KeyValueUtil.length(cell);<a name="line.288"></a>
-<span class="sourceLineNo">289</span> }<a name="line.289"></a>
-<span class="sourceLineNo">290</span> }<a name="line.290"></a>
-<span class="sourceLineNo">291</span> return size;<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> public static long calculateResultSize(final Result result) {<a name="line.294"></a>
-<span class="sourceLineNo">295</span> long size = 0;<a name="line.295"></a>
-<span class="sourceLineNo">296</span> for (Cell cell : result.rawCells()) {<a name="line.296"></a>
-<span class="sourceLineNo">297</span> size += KeyValueUtil.length(cell);<a name="line.297"></a>
-<span class="sourceLineNo">298</span> }<a name="line.298"></a>
-<span class="sourceLineNo">299</span> return size;<a name="line.299"></a>
-<span class="sourceLineNo">300</span> }<a name="line.300"></a>
-<span class="sourceLineNo">301</span><a name="line.301"></a>
-<span class="sourceLineNo">302</span> public static long calculateResultSize(final List<Result> results) {<a name="line.302"></a>
-<span class="sourceLineNo">303</span> long size = 0;<a name="line.303"></a>
-<span class="sourceLineNo">304</span> for (Result result: results) {<a name="line.304"></a>
-<span class="sourceLineNo">305</span> for (Cell cell : result.rawCells()) {<a name="line.305"></a>
-<span class="sourceLineNo">306</span> size += KeyValueUtil.length(cell);<a name="line.306"></a>
-<span class="sourceLineNo">307</span> }<a name="line.307"></a>
-<span class="sourceLineNo">308</span> }<a name="line.308"></a>
-<span class="sourceLineNo">309</span> return size;<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">281</span> private static void doDelete(final Connection connection, final Delete delete)<a name="line.281"></a>
+<span class="sourceLineNo">282</span> throws IOException {<a name="line.282"></a>
+<span class="sourceLineNo">283</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> table.delete(delete);<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><a name="line.287"></a>
+<span class="sourceLineNo">288</span> /* =========================================================================<a name="line.288"></a>
+<span class="sourceLineNo">289</span> * Data Size Helpers<a name="line.289"></a>
+<span class="sourceLineNo">290</span> */<a name="line.290"></a>
+<span class="sourceLineNo">291</span> public static long calculateMutationSize(final Mutation mutation) {<a name="line.291"></a>
+<span class="sourceLineNo">292</span> long size = 0;<a name="line.292"></a>
+<span class="sourceLineNo">293</span> for (Map.Entry<byte [], List<Cell>> entry : mutation.getFamilyCellMap().entrySet()) {<a name="line.293"></a>
+<span class="sourceLineNo">294</span> for (Cell cell : entry.getValue()) {<a name="line.294"></a>
+<span class="sourceLineNo">295</span> size += KeyValueUtil.length(cell);<a name="line.295"></a>
+<span class="sourceLineNo">296</span> }<a name="line.296"></a>
+<span class="sourceLineNo">297</span> }<a name="line.297"></a>
+<span class="sourceLineNo">298</span> return size;<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> public static long calculateResultSize(final Result result) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span> long size = 0;<a name="line.302"></a>
+<span class="sourceLineNo">303</span> for (Cell cell : result.rawCells()) {<a name="line.303"></a>
+<span class="sourceLineNo">304</span> size += KeyValueUtil.length(cell);<a name="line.304"></a>
+<span class="sourceLineNo">305</span> }<a name="line.305"></a>
+<span class="sourceLineNo">306</span> return size;<a name="line.306"></a>
+<span class="sourceLineNo">307</span> }<a name="line.307"></a>
+<span class="sourceLineNo">308</span><a name="line.308"></a>
+<span class="sourceLineNo">309</span> public static long calculateResultSize(final List<Result> results) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span> long size = 0;<a name="line.310"></a>
+<span class="sourceLineNo">311</span> for (Result result: results) {<a name="line.311"></a>
+<span class="sourceLineNo">312</span> for (Cell cell : result.rawCells()) {<a name="line.312"></a>
+<span class="sourceLineNo">313</span> size += KeyValueUtil.length(cell);<a name="line.313"></a>
+<span class="sourceLineNo">314</span> }<a name="line.314"></a>
+<span class="sourceLineNo">315</span> }<a name="line.315"></a>
+<span class="sourceLineNo">316</span> return size;<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>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
index 0864582..158d904 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/RegionServerRpcQuotaManager.html
@@ -110,7 +110,7 @@
<span class="sourceLineNo">102</span> LOG.trace("get quota for ugi=" + ugi + " table=" + table + " userLimiter=" + userLimiter);<a name="line.102"></a>
<span class="sourceLineNo">103</span> }<a name="line.103"></a>
<span class="sourceLineNo">104</span> if (!useNoop) {<a name="line.104"></a>
-<span class="sourceLineNo">105</span> return new DefaultOperationQuota(userLimiter);<a name="line.105"></a>
+<span class="sourceLineNo">105</span> return new DefaultOperationQuota(this.rsServices.getConfiguration(), userLimiter);<a name="line.105"></a>
<span class="sourceLineNo">106</span> }<a name="line.106"></a>
<span class="sourceLineNo">107</span> } else {<a name="line.107"></a>
<span class="sourceLineNo">108</span> QuotaLimiter nsLimiter = quotaCache.getNamespaceLimiter(table.getNamespaceAsString());<a name="line.108"></a>
@@ -121,91 +121,92 @@
<span class="sourceLineNo">113</span> userLimiter + " tableLimiter=" + tableLimiter + " nsLimiter=" + nsLimiter);<a name="line.113"></a>
<span class="sourceLineNo">114</span> }<a name="line.114"></a>
<span class="sourceLineNo">115</span> if (!useNoop) {<a name="line.115"></a>
-<span class="sourceLineNo">116</span> return new DefaultOperationQuota(userLimiter, tableLimiter, nsLimiter);<a name="line.116"></a>
-<span class="sourceLineNo">117</span> }<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> return NoopOperationQuota.get();<a name="line.120"></a>
-<span class="sourceLineNo">121</span> }<a name="line.121"></a>
-<span class="sourceLineNo">122</span><a name="line.122"></a>
-<span class="sourceLineNo">123</span> /**<a name="line.123"></a>
-<span class="sourceLineNo">124</span> * Check the quota for the current (rpc-context) user.<a name="line.124"></a>
-<span class="sourceLineNo">125</span> * Returns the OperationQuota used to get the available quota and<a name="line.125"></a>
-<span class="sourceLineNo">126</span> * to report the data/usage of the operation.<a name="line.126"></a>
-<span class="sourceLineNo">127</span> * @param region the region where the operation will be performed<a name="line.127"></a>
-<span class="sourceLineNo">128</span> * @param type the operation type<a name="line.128"></a>
-<span class="sourceLineNo">129</span> * @return the OperationQuota<a name="line.129"></a>
-<span class="sourceLineNo">130</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.130"></a>
-<span class="sourceLineNo">131</span> */<a name="line.131"></a>
-<span class="sourceLineNo">132</span> public OperationQuota checkQuota(final Region region,<a name="line.132"></a>
-<span class="sourceLineNo">133</span> final OperationQuota.OperationType type) throws IOException, RpcThrottlingException {<a name="line.133"></a>
-<span class="sourceLineNo">134</span> switch (type) {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> case SCAN: return checkQuota(region, 0, 0, 1);<a name="line.135"></a>
-<span class="sourceLineNo">136</span> case GET: return checkQuota(region, 0, 1, 0);<a name="line.136"></a>
-<span class="sourceLineNo">137</span> case MUTATE: return checkQuota(region, 1, 0, 0);<a name="line.137"></a>
-<span class="sourceLineNo">138</span> }<a name="line.138"></a>
-<span class="sourceLineNo">139</span> throw new RuntimeException("Invalid operation type: " + type);<a name="line.139"></a>
-<span class="sourceLineNo">140</span> }<a name="line.140"></a>
-<span class="sourceLineNo">141</span><a name="line.141"></a>
-<span class="sourceLineNo">142</span> /**<a name="line.142"></a>
-<span class="sourceLineNo">143</span> * Check the quota for the current (rpc-context) user.<a name="line.143"></a>
-<span class="sourceLineNo">144</span> * Returns the OperationQuota used to get the available quota and<a name="line.144"></a>
-<span class="sourceLineNo">145</span> * to report the data/usage of the operation.<a name="line.145"></a>
-<span class="sourceLineNo">146</span> * @param region the region where the operation will be performed<a name="line.146"></a>
-<span class="sourceLineNo">147</span> * @param actions the "multi" actions to perform<a name="line.147"></a>
-<span class="sourceLineNo">148</span> * @return the OperationQuota<a name="line.148"></a>
-<span class="sourceLineNo">149</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.149"></a>
-<span class="sourceLineNo">150</span> */<a name="line.150"></a>
-<span class="sourceLineNo">151</span> public OperationQuota checkQuota(final Region region,<a name="line.151"></a>
-<span class="sourceLineNo">152</span> final List<ClientProtos.Action> actions) throws IOException, RpcThrottlingException {<a name="line.152"></a>
-<span class="sourceLineNo">153</span> int numWrites = 0;<a name="line.153"></a>
-<span class="sourceLineNo">154</span> int numReads = 0;<a name="line.154"></a>
-<span class="sourceLineNo">155</span> for (final ClientProtos.Action action: actions) {<a name="line.155"></a>
-<span class="sourceLineNo">156</span> if (action.hasMutation()) {<a name="line.156"></a>
-<span class="sourceLineNo">157</span> numWrites++;<a name="line.157"></a>
-<span class="sourceLineNo">158</span> } else if (action.hasGet()) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> numReads++;<a name="line.159"></a>
-<span class="sourceLineNo">160</span> }<a name="line.160"></a>
-<span class="sourceLineNo">161</span> }<a name="line.161"></a>
-<span class="sourceLineNo">162</span> return checkQuota(region, numWrites, numReads, 0);<a name="line.162"></a>
-<span class="sourceLineNo">163</span> }<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span> /**<a name="line.165"></a>
-<span class="sourceLineNo">166</span> * Check the quota for the current (rpc-context) user.<a name="line.166"></a>
-<span class="sourceLineNo">167</span> * Returns the OperationQuota used to get the available quota and<a name="line.167"></a>
-<span class="sourceLineNo">168</span> * to report the data/usage of the operation.<a name="line.168"></a>
-<span class="sourceLineNo">169</span> * @param region the region where the operation will be performed<a name="line.169"></a>
-<span class="sourceLineNo">170</span> * @param numWrites number of writes to perform<a name="line.170"></a>
-<span class="sourceLineNo">171</span> * @param numReads number of short-reads to perform<a name="line.171"></a>
-<span class="sourceLineNo">172</span> * @param numScans number of scan to perform<a name="line.172"></a>
-<span class="sourceLineNo">173</span> * @return the OperationQuota<a name="line.173"></a>
-<span class="sourceLineNo">174</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.174"></a>
-<span class="sourceLineNo">175</span> */<a name="line.175"></a>
-<span class="sourceLineNo">176</span> private OperationQuota checkQuota(final Region region,<a name="line.176"></a>
-<span class="sourceLineNo">177</span> final int numWrites, final int numReads, final int numScans)<a name="line.177"></a>
-<span class="sourceLineNo">178</span> throws IOException, RpcThrottlingException {<a name="line.178"></a>
-<span class="sourceLineNo">179</span> Optional<User> user = RpcServer.getRequestUser();<a name="line.179"></a>
-<span class="sourceLineNo">180</span> UserGroupInformation ugi;<a name="line.180"></a>
-<span class="sourceLineNo">181</span> if (user.isPresent()) {<a name="line.181"></a>
-<span class="sourceLineNo">182</span> ugi = user.get().getUGI();<a name="line.182"></a>
-<span class="sourceLineNo">183</span> } else {<a name="line.183"></a>
-<span class="sourceLineNo">184</span> ugi = User.getCurrent().getUGI();<a name="line.184"></a>
-<span class="sourceLineNo">185</span> }<a name="line.185"></a>
-<span class="sourceLineNo">186</span> TableName table = region.getTableDescriptor().getTableName();<a name="line.186"></a>
-<span class="sourceLineNo">187</span><a name="line.187"></a>
-<span class="sourceLineNo">188</span> OperationQuota quota = getQuota(ugi, table);<a name="line.188"></a>
-<span class="sourceLineNo">189</span> try {<a name="line.189"></a>
-<span class="sourceLineNo">190</span> quota.checkQuota(numWrites, numReads, numScans);<a name="line.190"></a>
-<span class="sourceLineNo">191</span> } catch (RpcThrottlingException e) {<a name="line.191"></a>
-<span class="sourceLineNo">192</span> LOG.debug("Throttling exception for user=" + ugi.getUserName() +<a name="line.192"></a>
-<span class="sourceLineNo">193</span> " table=" + table + " numWrites=" + numWrites +<a name="line.193"></a>
-<span class="sourceLineNo">194</span> " numReads=" + numReads + " numScans=" + numScans +<a name="line.194"></a>
-<span class="sourceLineNo">195</span> ": " + e.getMessage());<a name="line.195"></a>
-<span class="sourceLineNo">196</span> throw e;<a name="line.196"></a>
-<span class="sourceLineNo">197</span> }<a name="line.197"></a>
-<span class="sourceLineNo">198</span> return quota;<a name="line.198"></a>
-<span class="sourceLineNo">199</span> }<a name="line.199"></a>
-<span class="sourceLineNo">200</span>}<a name="line.200"></a>
+<span class="sourceLineNo">116</span> return new DefaultOperationQuota(this.rsServices.getConfiguration(), userLimiter,<a name="line.116"></a>
+<span class="sourceLineNo">117</span> tableLimiter, nsLimiter);<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> }<a name="line.120"></a>
+<span class="sourceLineNo">121</span> return NoopOperationQuota.get();<a name="line.121"></a>
+<span class="sourceLineNo">122</span> }<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>
+<span class="sourceLineNo">125</span> * Check the quota for the current (rpc-context) user.<a name="line.125"></a>
+<span class="sourceLineNo">126</span> * Returns the OperationQuota used to get the available quota and<a name="line.126"></a>
+<span class="sourceLineNo">127</span> * to report the data/usage of the operation.<a name="line.127"></a>
+<span class="sourceLineNo">128</span> * @param region the region where the operation will be performed<a name="line.128"></a>
+<span class="sourceLineNo">129</span> * @param type the operation type<a name="line.129"></a>
+<span class="sourceLineNo">130</span> * @return the OperationQuota<a name="line.130"></a>
+<span class="sourceLineNo">131</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.131"></a>
+<span class="sourceLineNo">132</span> */<a name="line.132"></a>
+<span class="sourceLineNo">133</span> public OperationQuota checkQuota(final Region region,<a name="line.133"></a>
+<span class="sourceLineNo">134</span> final OperationQuota.OperationType type) throws IOException, RpcThrottlingException {<a name="line.134"></a>
+<span class="sourceLineNo">135</span> switch (type) {<a name="line.135"></a>
+<span class="sourceLineNo">136</span> case SCAN: return checkQuota(region, 0, 0, 1);<a name="line.136"></a>
+<span class="sourceLineNo">137</span> case GET: return checkQuota(region, 0, 1, 0);<a name="line.137"></a>
+<span class="sourceLineNo">138</span> case MUTATE: return checkQuota(region, 1, 0, 0);<a name="line.138"></a>
+<span class="sourceLineNo">139</span> }<a name="line.139"></a>
+<span class="sourceLineNo">140</span> throw new RuntimeException("Invalid operation type: " + type);<a name="line.140"></a>
+<span class="sourceLineNo">141</span> }<a name="line.141"></a>
+<span class="sourceLineNo">142</span><a name="line.142"></a>
+<span class="sourceLineNo">143</span> /**<a name="line.143"></a>
+<span class="sourceLineNo">144</span> * Check the quota for the current (rpc-context) user.<a name="line.144"></a>
+<span class="sourceLineNo">145</span> * Returns the OperationQuota used to get the available quota and<a name="line.145"></a>
+<span class="sourceLineNo">146</span> * to report the data/usage of the operation.<a name="line.146"></a>
+<span class="sourceLineNo">147</span> * @param region the region where the operation will be performed<a name="line.147"></a>
+<span class="sourceLineNo">148</span> * @param actions the "multi" actions to perform<a name="line.148"></a>
+<span class="sourceLineNo">149</span> * @return the OperationQuota<a name="line.149"></a>
+<span class="sourceLineNo">150</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.150"></a>
+<span class="sourceLineNo">151</span> */<a name="line.151"></a>
+<span class="sourceLineNo">152</span> public OperationQuota checkQuota(final Region region,<a name="line.152"></a>
+<span class="sourceLineNo">153</span> final List<ClientProtos.Action> actions) throws IOException, RpcThrottlingException {<a name="line.153"></a>
+<span class="sourceLineNo">154</span> int numWrites = 0;<a name="line.154"></a>
+<span class="sourceLineNo">155</span> int numReads = 0;<a name="line.155"></a>
+<span class="sourceLineNo">156</span> for (final ClientProtos.Action action: actions) {<a name="line.156"></a>
+<span class="sourceLineNo">157</span> if (action.hasMutation()) {<a name="line.157"></a>
+<span class="sourceLineNo">158</span> numWrites++;<a name="line.158"></a>
+<span class="sourceLineNo">159</span> } else if (action.hasGet()) {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> numReads++;<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> return checkQuota(region, numWrites, numReads, 0);<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span><a name="line.165"></a>
+<span class="sourceLineNo">166</span> /**<a name="line.166"></a>
+<span class="sourceLineNo">167</span> * Check the quota for the current (rpc-context) user.<a name="line.167"></a>
+<span class="sourceLineNo">168</span> * Returns the OperationQuota used to get the available quota and<a name="line.168"></a>
+<span class="sourceLineNo">169</span> * to report the data/usage of the operation.<a name="line.169"></a>
+<span class="sourceLineNo">170</span> * @param region the region where the operation will be performed<a name="line.170"></a>
+<span class="sourceLineNo">171</span> * @param numWrites number of writes to perform<a name="line.171"></a>
+<span class="sourceLineNo">172</span> * @param numReads number of short-reads to perform<a name="line.172"></a>
+<span class="sourceLineNo">173</span> * @param numScans number of scan to perform<a name="line.173"></a>
+<span class="sourceLineNo">174</span> * @return the OperationQuota<a name="line.174"></a>
+<span class="sourceLineNo">175</span> * @throws RpcThrottlingException if the operation cannot be executed due to quota exceeded.<a name="line.175"></a>
+<span class="sourceLineNo">176</span> */<a name="line.176"></a>
+<span class="sourceLineNo">177</span> private OperationQuota checkQuota(final Region region,<a name="line.177"></a>
+<span class="sourceLineNo">178</span> final int numWrites, final int numReads, final int numScans)<a name="line.178"></a>
+<span class="sourceLineNo">179</span> throws IOException, RpcThrottlingException {<a name="line.179"></a>
+<span class="sourceLineNo">180</span> Optional<User> user = RpcServer.getRequestUser();<a name="line.180"></a>
+<span class="sourceLineNo">181</span> UserGroupInformation ugi;<a name="line.181"></a>
+<span class="sourceLineNo">182</span> if (user.isPresent()) {<a name="line.182"></a>
+<span class="sourceLineNo">183</span> ugi = user.get().getUGI();<a name="line.183"></a>
+<span class="sourceLineNo">184</span> } else {<a name="line.184"></a>
+<span class="sourceLineNo">185</span> ugi = User.getCurrent().getUGI();<a name="line.185"></a>
+<span class="sourceLineNo">186</span> }<a name="line.186"></a>
+<span class="sourceLineNo">187</span> TableName table = region.getTableDescriptor().getTableName();<a name="line.187"></a>
+<span class="sourceLineNo">188</span><a name="line.188"></a>
+<span class="sourceLineNo">189</span> OperationQuota quota = getQuota(ugi, table);<a name="line.189"></a>
+<span class="sourceLineNo">190</span> try {<a name="line.190"></a>
+<span class="sourceLineNo">191</span> quota.checkQuota(numWrites, numReads, numScans);<a name="line.191"></a>
+<span class="sourceLineNo">192</span> } catch (RpcThrottlingException e) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span> LOG.debug("Throttling exception for user=" + ugi.getUserName() +<a name="line.193"></a>
+<span class="sourceLineNo">194</span> " table=" + table + " numWrites=" + numWrites +<a name="line.194"></a>
+<span class="sourceLineNo">195</span> " numReads=" + numReads + " numScans=" + numScans +<a name="line.195"></a>
+<span class="sourceLineNo">196</span> ": " + e.getMessage());<a name="line.196"></a>
+<span class="sourceLineNo">197</span> throw e;<a name="line.197"></a>
+<span class="sourceLineNo">198</span> }<a name="line.198"></a>
+<span class="sourceLineNo">199</span> return quota;<a name="line.199"></a>
+<span class="sourceLineNo">200</span> }<a name="line.200"></a>
+<span class="sourceLineNo">201</span>}<a name="line.201"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
index e3974d6..34b5c93 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleSettings.html
@@ -103,73 +103,79 @@
<span class="sourceLineNo">095</span> case READ_SIZE:<a name="line.95"></a>
<span class="sourceLineNo">096</span> builder.append(sizeToString(timedQuota.getSoftLimit()));<a name="line.96"></a>
<span class="sourceLineNo">097</span> break;<a name="line.97"></a>
-<span class="sourceLineNo">098</span> }<a name="line.98"></a>
-<span class="sourceLineNo">099</span> } else if (timedQuota.hasShare()) {<a name="line.99"></a>
-<span class="sourceLineNo">100</span> builder.append(String.format("%.2f%%", timedQuota.getShare()));<a name="line.100"></a>
-<span class="sourceLineNo">101</span> }<a name="line.101"></a>
-<span class="sourceLineNo">102</span> builder.append('/');<a name="line.102"></a>
-<span class="sourceLineNo">103</span> builder.append(timeToString(ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit())));<a name="line.103"></a>
-<span class="sourceLineNo">104</span> if (timedQuota.hasScope()) {<a name="line.104"></a>
-<span class="sourceLineNo">105</span> builder.append(", SCOPE => ");<a name="line.105"></a>
-<span class="sourceLineNo">106</span> builder.append(timedQuota.getScope().toString());<a name="line.106"></a>
+<span class="sourceLineNo">098</span> case REQUEST_CAPACITY_UNIT:<a name="line.98"></a>
+<span class="sourceLineNo">099</span> case READ_CAPACITY_UNIT:<a name="line.99"></a>
+<span class="sourceLineNo">100</span> case WRITE_CAPACITY_UNIT:<a name="line.100"></a>
+<span class="sourceLineNo">101</span> builder.append(String.format("%dCU", timedQuota.getSoftLimit()));<a name="line.101"></a>
+<span class="sourceLineNo">102</span> break;<a name="line.102"></a>
+<span class="sourceLineNo">103</span> default:<a name="line.103"></a>
+<span class="sourceLineNo">104</span> }<a name="line.104"></a>
+<span class="sourceLineNo">105</span> } else if (timedQuota.hasShare()) {<a name="line.105"></a>
+<span class="sourceLineNo">106</span> builder.append(String.format("%.2f%%", timedQuota.getShare()));<a name="line.106"></a>
<span class="sourceLineNo">107</span> }<a name="line.107"></a>
-<span class="sourceLineNo">108</span> } else {<a name="line.108"></a>
-<span class="sourceLineNo">109</span> builder.append(", LIMIT => NONE");<a name="line.109"></a>
-<span class="sourceLineNo">110</span> }<a name="line.110"></a>
-<span class="sourceLineNo">111</span> return builder.toString();<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> @Override<a name="line.114"></a>
-<span class="sourceLineNo">115</span> protected ThrottleSettings merge(QuotaSettings other) throws IOException {<a name="line.115"></a>
-<span class="sourceLineNo">116</span> if (other instanceof ThrottleSettings) {<a name="line.116"></a>
-<span class="sourceLineNo">117</span> ThrottleSettings otherThrottle = (ThrottleSettings) other;<a name="line.117"></a>
-<span class="sourceLineNo">118</span><a name="line.118"></a>
-<span class="sourceLineNo">119</span> // Make sure this and the other target the same "subject"<a name="line.119"></a>
-<span class="sourceLineNo">120</span> validateQuotaTarget(other);<a name="line.120"></a>
-<span class="sourceLineNo">121</span><a name="line.121"></a>
-<span class="sourceLineNo">122</span> QuotaProtos.ThrottleRequest.Builder builder = proto.toBuilder();<a name="line.122"></a>
-<span class="sourceLineNo">123</span> if (!otherThrottle.proto.hasType()) {<a name="line.123"></a>
-<span class="sourceLineNo">124</span> return null;<a name="line.124"></a>
-<span class="sourceLineNo">125</span> }<a name="line.125"></a>
-<span class="sourceLineNo">126</span><a name="line.126"></a>
-<span class="sourceLineNo">127</span> QuotaProtos.ThrottleRequest otherProto = otherThrottle.proto;<a name="line.127"></a>
-<span class="sourceLineNo">128</span> if (otherProto.hasTimedQuota()) {<a name="line.128"></a>
-<span class="sourceLineNo">129</span> if (otherProto.hasTimedQuota()) {<a name="line.129"></a>
-<span class="sourceLineNo">130</span> validateTimedQuota(otherProto.getTimedQuota());<a name="line.130"></a>
-<span class="sourceLineNo">131</span> }<a name="line.131"></a>
+<span class="sourceLineNo">108</span> builder.append('/');<a name="line.108"></a>
+<span class="sourceLineNo">109</span> builder.append(timeToString(ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit())));<a name="line.109"></a>
+<span class="sourceLineNo">110</span> if (timedQuota.hasScope()) {<a name="line.110"></a>
+<span class="sourceLineNo">111</span> builder.append(", SCOPE => ");<a name="line.111"></a>
+<span class="sourceLineNo">112</span> builder.append(timedQuota.getScope().toString());<a name="line.112"></a>
+<span class="sourceLineNo">113</span> }<a name="line.113"></a>
+<span class="sourceLineNo">114</span> } else {<a name="line.114"></a>
+<span class="sourceLineNo">115</span> builder.append(", LIMIT => NONE");<a name="line.115"></a>
+<span class="sourceLineNo">116</span> }<a name="line.116"></a>
+<span class="sourceLineNo">117</span> return builder.toString();<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> @Override<a name="line.120"></a>
+<span class="sourceLineNo">121</span> protected ThrottleSettings merge(QuotaSettings other) throws IOException {<a name="line.121"></a>
+<span class="sourceLineNo">122</span> if (other instanceof ThrottleSettings) {<a name="line.122"></a>
+<span class="sourceLineNo">123</span> ThrottleSettings otherThrottle = (ThrottleSettings) other;<a name="line.123"></a>
+<span class="sourceLineNo">124</span><a name="line.124"></a>
+<span class="sourceLineNo">125</span> // Make sure this and the other target the same "subject"<a name="line.125"></a>
+<span class="sourceLineNo">126</span> validateQuotaTarget(other);<a name="line.126"></a>
+<span class="sourceLineNo">127</span><a name="line.127"></a>
+<span class="sourceLineNo">128</span> QuotaProtos.ThrottleRequest.Builder builder = proto.toBuilder();<a name="line.128"></a>
+<span class="sourceLineNo">129</span> if (!otherThrottle.proto.hasType()) {<a name="line.129"></a>
+<span class="sourceLineNo">130</span> return null;<a name="line.130"></a>
+<span class="sourceLineNo">131</span> }<a name="line.131"></a>
<span class="sourceLineNo">132</span><a name="line.132"></a>
-<span class="sourceLineNo">133</span> if (!proto.getType().equals(otherProto.getType())) {<a name="line.133"></a>
-<span class="sourceLineNo">134</span> throw new IllegalArgumentException(<a name="line.134"></a>
-<span class="sourceLineNo">135</span> "Cannot merge a ThrottleRequest for " + proto.getType() + " with " +<a name="line.135"></a>
-<span class="sourceLineNo">136</span> otherProto.getType());<a name="line.136"></a>
+<span class="sourceLineNo">133</span> QuotaProtos.ThrottleRequest otherProto = otherThrottle.proto;<a name="line.133"></a>
+<span class="sourceLineNo">134</span> if (otherProto.hasTimedQuota()) {<a name="line.134"></a>
+<span class="sourceLineNo">135</span> if (otherProto.hasTimedQuota()) {<a name="line.135"></a>
+<span class="sourceLineNo">136</span> validateTimedQuota(otherProto.getTimedQuota());<a name="line.136"></a>
<span class="sourceLineNo">137</span> }<a name="line.137"></a>
-<span class="sourceLineNo">138</span> QuotaProtos.TimedQuota.Builder timedQuotaBuilder = proto.getTimedQuota().toBuilder();<a name="line.138"></a>
-<span class="sourceLineNo">139</span> timedQuotaBuilder.mergeFrom(otherProto.getTimedQuota());<a name="line.139"></a>
-<span class="sourceLineNo">140</span><a name="line.140"></a>
-<span class="sourceLineNo">141</span> QuotaProtos.ThrottleRequest mergedReq = builder.setTimedQuota(<a name="line.141"></a>
-<span class="sourceLineNo">142</span> timedQuotaBuilder.build()).build();<a name="line.142"></a>
-<span class="sourceLineNo">143</span> return new ThrottleSettings(getUserName(), getTableName(), getNamespace(), mergedReq);<a name="line.143"></a>
-<span class="sourceLineNo">144</span> }<a name="line.144"></a>
-<span class="sourceLineNo">145</span> }<a name="line.145"></a>
-<span class="sourceLineNo">146</span> return this;<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> private void validateTimedQuota(final TimedQuota timedQuota) throws IOException {<a name="line.149"></a>
-<span class="sourceLineNo">150</span> if (timedQuota.getSoftLimit() < 1) {<a name="line.150"></a>
-<span class="sourceLineNo">151</span> throw new DoNotRetryIOException(new UnsupportedOperationException(<a name="line.151"></a>
-<span class="sourceLineNo">152</span> "The throttle limit must be greater then 0, got " + timedQuota.getSoftLimit()));<a name="line.152"></a>
-<span class="sourceLineNo">153</span> }<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> static ThrottleSettings fromTimedQuota(final String userName,<a name="line.156"></a>
-<span class="sourceLineNo">157</span> final TableName tableName, final String namespace,<a name="line.157"></a>
-<span class="sourceLineNo">158</span> ThrottleType type, QuotaProtos.TimedQuota timedQuota) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.159"></a>
-<span class="sourceLineNo">160</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.160"></a>
-<span class="sourceLineNo">161</span> builder.setTimedQuota(timedQuota);<a name="line.161"></a>
-<span class="sourceLineNo">162</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<a name="line.162"></a>
-<span class="sourceLineNo">163</span> }<a name="line.163"></a>
-<span class="sourceLineNo">164</span>}<a name="line.164"></a>
+<span class="sourceLineNo">138</span><a name="line.138"></a>
+<span class="sourceLineNo">139</span> if (!proto.getType().equals(otherProto.getType())) {<a name="line.139"></a>
+<span class="sourceLineNo">140</span> throw new IllegalArgumentException(<a name="line.140"></a>
+<span class="sourceLineNo">141</span> "Cannot merge a ThrottleRequest for " + proto.getType() + " with " +<a name="line.141"></a>
+<span class="sourceLineNo">142</span> otherProto.getType());<a name="line.142"></a>
+<span class="sourceLineNo">143</span> }<a name="line.143"></a>
+<span class="sourceLineNo">144</span> QuotaProtos.TimedQuota.Builder timedQuotaBuilder = proto.getTimedQuota().toBuilder();<a name="line.144"></a>
+<span class="sourceLineNo">145</span> timedQuotaBuilder.mergeFrom(otherProto.getTimedQuota());<a name="line.145"></a>
+<span class="sourceLineNo">146</span><a name="line.146"></a>
+<span class="sourceLineNo">147</span> QuotaProtos.ThrottleRequest mergedReq = builder.setTimedQuota(<a name="line.147"></a>
+<span class="sourceLineNo">148</span> timedQuotaBuilder.build()).build();<a name="line.148"></a>
+<span class="sourceLineNo">149</span> return new ThrottleSettings(getUserName(), getTableName(), getNamespace(), mergedReq);<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> return this;<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span><a name="line.154"></a>
+<span class="sourceLineNo">155</span> private void validateTimedQuota(final TimedQuota timedQuota) throws IOException {<a name="line.155"></a>
+<span class="sourceLineNo">156</span> if (timedQuota.getSoftLimit() < 1) {<a name="line.156"></a>
+<span class="sourceLineNo">157</span> throw new DoNotRetryIOException(new UnsupportedOperationException(<a name="line.157"></a>
+<span class="sourceLineNo">158</span> "The throttle limit must be greater then 0, got " + timedQuota.getSoftLimit()));<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><a name="line.161"></a>
+<span class="sourceLineNo">162</span> static ThrottleSettings fromTimedQuota(final String userName,<a name="line.162"></a>
+<span class="sourceLineNo">163</span> final TableName tableName, final String namespace,<a name="line.163"></a>
+<span class="sourceLineNo">164</span> ThrottleType type, QuotaProtos.TimedQuota timedQuota) {<a name="line.164"></a>
+<span class="sourceLineNo">165</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.165"></a>
+<span class="sourceLineNo">166</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.166"></a>
+<span class="sourceLineNo">167</span> builder.setTimedQuota(timedQuota);<a name="line.167"></a>
+<span class="sourceLineNo">168</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<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>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
index 152155d..ba1bd79 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
@@ -49,7 +49,16 @@
<span class="sourceLineNo">041</span><a name="line.41"></a>
<span class="sourceLineNo">042</span> /** Throttling based on the read data size */<a name="line.42"></a>
<span class="sourceLineNo">043</span> READ_SIZE,<a name="line.43"></a>
-<span class="sourceLineNo">044</span>}<a name="line.44"></a>
+<span class="sourceLineNo">044</span><a name="line.44"></a>
+<span class="sourceLineNo">045</span> /** Throttling based on the read+write capacity unit */<a name="line.45"></a>
+<span class="sourceLineNo">046</span> REQUEST_CAPACITY_UNIT,<a name="line.46"></a>
+<span class="sourceLineNo">047</span><a name="line.47"></a>
+<span class="sourceLineNo">048</span> /** Throttling based on the write data capacity unit */<a name="line.48"></a>
+<span class="sourceLineNo">049</span> WRITE_CAPACITY_UNIT,<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span> /** Throttling based on the read data capacity unit */<a name="line.51"></a>
+<span class="sourceLineNo">052</span> READ_CAPACITY_UNIT,<a name="line.52"></a>
+<span class="sourceLineNo">053</span>}<a name="line.53"></a>
[05/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html b/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
index 88afb3f..6171b5d 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
@@ -32,523 +32,537 @@
<span class="sourceLineNo">024</span>import java.util.List;<a name="line.24"></a>
<span class="sourceLineNo">025</span>import java.util.Objects;<a name="line.25"></a>
<span class="sourceLineNo">026</span>import java.util.concurrent.atomic.AtomicBoolean;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import java.util.regex.Matcher;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import java.util.regex.Pattern;<a name="line.28"></a>
-<span class="sourceLineNo">029</span><a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.conf.Configuration;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.hadoop.fs.FileSystem;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.apache.hadoop.fs.Path;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.HConstants;<a name="line.34"></a>
-<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.ServerName;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.36"></a>
-<span class="sourceLineNo">037</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.38"></a>
-<span class="sourceLineNo">039</span>import org.slf4j.Logger;<a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.slf4j.LoggerFactory;<a name="line.40"></a>
-<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.41"></a>
-<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.regionserver.wal.WALActionsListener;<a name="line.42"></a>
-<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.util.CancelableProgressable;<a name="line.43"></a>
-<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.util.FSUtils;<a name="line.44"></a>
-<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.LeaseNotRecoveredException;<a name="line.45"></a>
-<span class="sourceLineNo">046</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.46"></a>
-<span class="sourceLineNo">047</span><a name="line.47"></a>
-<span class="sourceLineNo">048</span>/**<a name="line.48"></a>
-<span class="sourceLineNo">049</span> * Base class of a WAL Provider that returns a single thread safe WAL that writes to Hadoop FS. By<a name="line.49"></a>
-<span class="sourceLineNo">050</span> * default, this implementation picks a directory in Hadoop FS based on a combination of<a name="line.50"></a>
-<span class="sourceLineNo">051</span> * <ul><a name="line.51"></a>
-<span class="sourceLineNo">052</span> * <li>the HBase root directory<a name="line.52"></a>
-<span class="sourceLineNo">053</span> * <li>HConstants.HREGION_LOGDIR_NAME<a name="line.53"></a>
-<span class="sourceLineNo">054</span> * <li>the given factory's factoryId (usually identifying the regionserver by host:port)<a name="line.54"></a>
-<span class="sourceLineNo">055</span> * </ul><a name="line.55"></a>
-<span class="sourceLineNo">056</span> * It also uses the providerId to differentiate among files.<a name="line.56"></a>
-<span class="sourceLineNo">057</span> */<a name="line.57"></a>
-<span class="sourceLineNo">058</span>@InterfaceAudience.Private<a name="line.58"></a>
-<span class="sourceLineNo">059</span>@InterfaceStability.Evolving<a name="line.59"></a>
-<span class="sourceLineNo">060</span>public abstract class AbstractFSWALProvider<T extends AbstractFSWAL<?>> implements WALProvider {<a name="line.60"></a>
-<span class="sourceLineNo">061</span><a name="line.61"></a>
-<span class="sourceLineNo">062</span> private static final Logger LOG = LoggerFactory.getLogger(AbstractFSWALProvider.class);<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span> /** Separate old log into different dir by regionserver name **/<a name="line.64"></a>
-<span class="sourceLineNo">065</span> public static final String SEPARATE_OLDLOGDIR = "hbase.separate.oldlogdir.by.regionserver";<a name="line.65"></a>
-<span class="sourceLineNo">066</span> public static final boolean DEFAULT_SEPARATE_OLDLOGDIR = false;<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span> // Only public so classes back in regionserver.wal can access<a name="line.68"></a>
-<span class="sourceLineNo">069</span> public interface Reader extends WAL.Reader {<a name="line.69"></a>
-<span class="sourceLineNo">070</span> /**<a name="line.70"></a>
-<span class="sourceLineNo">071</span> * @param fs File system.<a name="line.71"></a>
-<span class="sourceLineNo">072</span> * @param path Path.<a name="line.72"></a>
-<span class="sourceLineNo">073</span> * @param c Configuration.<a name="line.73"></a>
-<span class="sourceLineNo">074</span> * @param s Input stream that may have been pre-opened by the caller; may be null.<a name="line.74"></a>
-<span class="sourceLineNo">075</span> */<a name="line.75"></a>
-<span class="sourceLineNo">076</span> void init(FileSystem fs, Path path, Configuration c, FSDataInputStream s) throws IOException;<a name="line.76"></a>
-<span class="sourceLineNo">077</span> }<a name="line.77"></a>
-<span class="sourceLineNo">078</span><a name="line.78"></a>
-<span class="sourceLineNo">079</span> protected volatile T wal;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> protected WALFactory factory;<a name="line.80"></a>
-<span class="sourceLineNo">081</span> protected Configuration conf;<a name="line.81"></a>
-<span class="sourceLineNo">082</span> protected List<WALActionsListener> listeners = new ArrayList<>();<a name="line.82"></a>
-<span class="sourceLineNo">083</span> protected String providerId;<a name="line.83"></a>
-<span class="sourceLineNo">084</span> protected AtomicBoolean initialized = new AtomicBoolean(false);<a name="line.84"></a>
-<span class="sourceLineNo">085</span> // for default wal provider, logPrefix won't change<a name="line.85"></a>
-<span class="sourceLineNo">086</span> protected String logPrefix;<a name="line.86"></a>
-<span class="sourceLineNo">087</span><a name="line.87"></a>
-<span class="sourceLineNo">088</span> /**<a name="line.88"></a>
-<span class="sourceLineNo">089</span> * we synchronized on walCreateLock to prevent wal recreation in different threads<a name="line.89"></a>
-<span class="sourceLineNo">090</span> */<a name="line.90"></a>
-<span class="sourceLineNo">091</span> private final Object walCreateLock = new Object();<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> * @param factory factory that made us, identity used for FS layout. may not be null<a name="line.94"></a>
-<span class="sourceLineNo">095</span> * @param conf may not be null<a name="line.95"></a>
-<span class="sourceLineNo">096</span> * @param providerId differentiate between providers from one factory, used for FS layout. may be<a name="line.96"></a>
-<span class="sourceLineNo">097</span> * null<a name="line.97"></a>
-<span class="sourceLineNo">098</span> */<a name="line.98"></a>
-<span class="sourceLineNo">099</span> @Override<a name="line.99"></a>
-<span class="sourceLineNo">100</span> public void init(WALFactory factory, Configuration conf, String providerId) throws IOException {<a name="line.100"></a>
-<span class="sourceLineNo">101</span> if (!initialized.compareAndSet(false, true)) {<a name="line.101"></a>
-<span class="sourceLineNo">102</span> throw new IllegalStateException("WALProvider.init should only be called once.");<a name="line.102"></a>
-<span class="sourceLineNo">103</span> }<a name="line.103"></a>
-<span class="sourceLineNo">104</span> this.factory = factory;<a name="line.104"></a>
-<span class="sourceLineNo">105</span> this.conf = conf;<a name="line.105"></a>
-<span class="sourceLineNo">106</span> this.providerId = providerId;<a name="line.106"></a>
-<span class="sourceLineNo">107</span> // get log prefix<a name="line.107"></a>
-<span class="sourceLineNo">108</span> StringBuilder sb = new StringBuilder().append(factory.factoryId);<a name="line.108"></a>
-<span class="sourceLineNo">109</span> if (providerId != null) {<a name="line.109"></a>
-<span class="sourceLineNo">110</span> if (providerId.startsWith(WAL_FILE_NAME_DELIMITER)) {<a name="line.110"></a>
-<span class="sourceLineNo">111</span> sb.append(providerId);<a name="line.111"></a>
-<span class="sourceLineNo">112</span> } else {<a name="line.112"></a>
-<span class="sourceLineNo">113</span> sb.append(WAL_FILE_NAME_DELIMITER).append(providerId);<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> logPrefix = sb.toString();<a name="line.116"></a>
-<span class="sourceLineNo">117</span> doInit(conf);<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> @Override<a name="line.120"></a>
-<span class="sourceLineNo">121</span> public List<WAL> getWALs() {<a name="line.121"></a>
-<span class="sourceLineNo">122</span> if (wal == null) {<a name="line.122"></a>
-<span class="sourceLineNo">123</span> return Collections.emptyList();<a name="line.123"></a>
-<span class="sourceLineNo">124</span> }<a name="line.124"></a>
-<span class="sourceLineNo">125</span> List<WAL> wals = new ArrayList<>(1);<a name="line.125"></a>
-<span class="sourceLineNo">126</span> wals.add(wal);<a name="line.126"></a>
-<span class="sourceLineNo">127</span> return wals;<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> @Override<a name="line.130"></a>
-<span class="sourceLineNo">131</span> public T getWAL(RegionInfo region) throws IOException {<a name="line.131"></a>
-<span class="sourceLineNo">132</span> T walCopy = wal;<a name="line.132"></a>
-<span class="sourceLineNo">133</span> if (walCopy == null) {<a name="line.133"></a>
-<span class="sourceLineNo">134</span> // only lock when need to create wal, and need to lock since<a name="line.134"></a>
-<span class="sourceLineNo">135</span> // creating hlog on fs is time consuming<a name="line.135"></a>
-<span class="sourceLineNo">136</span> synchronized (walCreateLock) {<a name="line.136"></a>
-<span class="sourceLineNo">137</span> walCopy = wal;<a name="line.137"></a>
-<span class="sourceLineNo">138</span> if (walCopy == null) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span> walCopy = createWAL();<a name="line.139"></a>
-<span class="sourceLineNo">140</span> boolean succ = false;<a name="line.140"></a>
-<span class="sourceLineNo">141</span> try {<a name="line.141"></a>
-<span class="sourceLineNo">142</span> walCopy.init();<a name="line.142"></a>
-<span class="sourceLineNo">143</span> succ = true;<a name="line.143"></a>
-<span class="sourceLineNo">144</span> } finally {<a name="line.144"></a>
-<span class="sourceLineNo">145</span> if (!succ) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> walCopy.close();<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> wal = walCopy;<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> }<a name="line.152"></a>
-<span class="sourceLineNo">153</span> return walCopy;<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> protected abstract T createWAL() throws IOException;<a name="line.156"></a>
-<span class="sourceLineNo">157</span><a name="line.157"></a>
-<span class="sourceLineNo">158</span> protected abstract void doInit(Configuration conf) throws IOException;<a name="line.158"></a>
-<span class="sourceLineNo">159</span><a name="line.159"></a>
-<span class="sourceLineNo">160</span> @Override<a name="line.160"></a>
-<span class="sourceLineNo">161</span> public void shutdown() throws IOException {<a name="line.161"></a>
-<span class="sourceLineNo">162</span> T log = this.wal;<a name="line.162"></a>
-<span class="sourceLineNo">163</span> if (log != null) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span> log.shutdown();<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span> }<a name="line.166"></a>
-<span class="sourceLineNo">167</span><a name="line.167"></a>
-<span class="sourceLineNo">168</span> @Override<a name="line.168"></a>
-<span class="sourceLineNo">169</span> public void close() throws IOException {<a name="line.169"></a>
-<span class="sourceLineNo">170</span> T log = this.wal;<a name="line.170"></a>
-<span class="sourceLineNo">171</span> if (log != null) {<a name="line.171"></a>
-<span class="sourceLineNo">172</span> log.close();<a name="line.172"></a>
-<span class="sourceLineNo">173</span> }<a name="line.173"></a>
-<span class="sourceLineNo">174</span> }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> /**<a name="line.176"></a>
-<span class="sourceLineNo">177</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * number of files (rolled and active). if either of them aren't, count 0 for that provider.<a name="line.178"></a>
-<span class="sourceLineNo">179</span> */<a name="line.179"></a>
-<span class="sourceLineNo">180</span> @Override<a name="line.180"></a>
-<span class="sourceLineNo">181</span> public long getNumLogFiles() {<a name="line.181"></a>
-<span class="sourceLineNo">182</span> T log = this.wal;<a name="line.182"></a>
-<span class="sourceLineNo">183</span> return log == null ? 0 : log.getNumLogFiles();<a name="line.183"></a>
-<span class="sourceLineNo">184</span> }<a name="line.184"></a>
-<span class="sourceLineNo">185</span><a name="line.185"></a>
-<span class="sourceLineNo">186</span> /**<a name="line.186"></a>
-<span class="sourceLineNo">187</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.187"></a>
-<span class="sourceLineNo">188</span> * size of files (only rolled). if either of them aren't, count 0 for that provider.<a name="line.188"></a>
-<span class="sourceLineNo">189</span> */<a name="line.189"></a>
-<span class="sourceLineNo">190</span> @Override<a name="line.190"></a>
-<span class="sourceLineNo">191</span> public long getLogFileSize() {<a name="line.191"></a>
-<span class="sourceLineNo">192</span> T log = this.wal;<a name="line.192"></a>
-<span class="sourceLineNo">193</span> return log == null ? 0 : log.getLogFileSize();<a name="line.193"></a>
-<span class="sourceLineNo">194</span> }<a name="line.194"></a>
-<span class="sourceLineNo">195</span><a name="line.195"></a>
-<span class="sourceLineNo">196</span> /**<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * returns the number of rolled WAL files.<a name="line.197"></a>
-<span class="sourceLineNo">198</span> */<a name="line.198"></a>
-<span class="sourceLineNo">199</span> @VisibleForTesting<a name="line.199"></a>
-<span class="sourceLineNo">200</span> public static int getNumRolledLogFiles(WAL wal) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span> return ((AbstractFSWAL<?>) wal).getNumRolledLogFiles();<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span> /**<a name="line.204"></a>
-<span class="sourceLineNo">205</span> * returns the size of rolled WAL files.<a name="line.205"></a>
-<span class="sourceLineNo">206</span> */<a name="line.206"></a>
-<span class="sourceLineNo">207</span> @VisibleForTesting<a name="line.207"></a>
-<span class="sourceLineNo">208</span> public static long getLogFileSize(WAL wal) {<a name="line.208"></a>
-<span class="sourceLineNo">209</span> return ((AbstractFSWAL<?>) wal).getLogFileSize();<a name="line.209"></a>
-<span class="sourceLineNo">210</span> }<a name="line.210"></a>
-<span class="sourceLineNo">211</span><a name="line.211"></a>
-<span class="sourceLineNo">212</span> /**<a name="line.212"></a>
-<span class="sourceLineNo">213</span> * return the current filename from the current wal.<a name="line.213"></a>
-<span class="sourceLineNo">214</span> */<a name="line.214"></a>
-<span class="sourceLineNo">215</span> @VisibleForTesting<a name="line.215"></a>
-<span class="sourceLineNo">216</span> public static Path getCurrentFileName(final WAL wal) {<a name="line.216"></a>
-<span class="sourceLineNo">217</span> return ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.217"></a>
-<span class="sourceLineNo">218</span> }<a name="line.218"></a>
-<span class="sourceLineNo">219</span><a name="line.219"></a>
-<span class="sourceLineNo">220</span> /**<a name="line.220"></a>
-<span class="sourceLineNo">221</span> * request a log roll, but don't actually do it.<a name="line.221"></a>
-<span class="sourceLineNo">222</span> */<a name="line.222"></a>
-<span class="sourceLineNo">223</span> @VisibleForTesting<a name="line.223"></a>
-<span class="sourceLineNo">224</span> static void requestLogRoll(final WAL wal) {<a name="line.224"></a>
-<span class="sourceLineNo">225</span> ((AbstractFSWAL<?>) wal).requestLogRoll();<a name="line.225"></a>
-<span class="sourceLineNo">226</span> }<a name="line.226"></a>
-<span class="sourceLineNo">227</span><a name="line.227"></a>
-<span class="sourceLineNo">228</span> // should be package private; more visible for use in AbstractFSWAL<a name="line.228"></a>
-<span class="sourceLineNo">229</span> public static final String WAL_FILE_NAME_DELIMITER = ".";<a name="line.229"></a>
-<span class="sourceLineNo">230</span> /** The hbase:meta region's WAL filename extension */<a name="line.230"></a>
-<span class="sourceLineNo">231</span> @VisibleForTesting<a name="line.231"></a>
-<span class="sourceLineNo">232</span> public static final String META_WAL_PROVIDER_ID = ".meta";<a name="line.232"></a>
-<span class="sourceLineNo">233</span> static final String DEFAULT_PROVIDER_ID = "default";<a name="line.233"></a>
-<span class="sourceLineNo">234</span><a name="line.234"></a>
-<span class="sourceLineNo">235</span> // Implementation details that currently leak in tests or elsewhere follow<a name="line.235"></a>
-<span class="sourceLineNo">236</span> /** File Extension used while splitting an WAL into regions (HBASE-2312) */<a name="line.236"></a>
-<span class="sourceLineNo">237</span> public static final String SPLITTING_EXT = "-splitting";<a name="line.237"></a>
-<span class="sourceLineNo">238</span><a name="line.238"></a>
-<span class="sourceLineNo">239</span> /**<a name="line.239"></a>
-<span class="sourceLineNo">240</span> * It returns the file create timestamp from the file name. For name format see<a name="line.240"></a>
-<span class="sourceLineNo">241</span> * {@link #validateWALFilename(String)} public until remaining tests move to o.a.h.h.wal<a name="line.241"></a>
-<span class="sourceLineNo">242</span> * @param wal must not be null<a name="line.242"></a>
-<span class="sourceLineNo">243</span> * @return the file number that is part of the WAL file name<a name="line.243"></a>
-<span class="sourceLineNo">244</span> */<a name="line.244"></a>
+<span class="sourceLineNo">027</span>import java.util.concurrent.locks.ReadWriteLock;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import java.util.concurrent.locks.ReentrantReadWriteLock;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import java.util.regex.Matcher;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import java.util.regex.Pattern;<a name="line.30"></a>
+<span class="sourceLineNo">031</span><a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.conf.Configuration;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hadoop.fs.FileSystem;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.apache.hadoop.fs.Path;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.HConstants;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.ServerName;<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.yetus.audience.InterfaceAudience;<a name="line.39"></a>
+<span class="sourceLineNo">040</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.40"></a>
+<span class="sourceLineNo">041</span>import org.slf4j.Logger;<a name="line.41"></a>
+<span class="sourceLineNo">042</span>import org.slf4j.LoggerFactory;<a name="line.42"></a>
+<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.43"></a>
+<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.regionserver.wal.WALActionsListener;<a name="line.44"></a>
+<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.CancelableProgressable;<a name="line.45"></a>
+<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.util.FSUtils;<a name="line.46"></a>
+<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.util.LeaseNotRecoveredException;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.48"></a>
+<span class="sourceLineNo">049</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span>/**<a name="line.51"></a>
+<span class="sourceLineNo">052</span> * Base class of a WAL Provider that returns a single thread safe WAL that writes to Hadoop FS. By<a name="line.52"></a>
+<span class="sourceLineNo">053</span> * default, this implementation picks a directory in Hadoop FS based on a combination of<a name="line.53"></a>
+<span class="sourceLineNo">054</span> * <ul><a name="line.54"></a>
+<span class="sourceLineNo">055</span> * <li>the HBase root directory<a name="line.55"></a>
+<span class="sourceLineNo">056</span> * <li>HConstants.HREGION_LOGDIR_NAME<a name="line.56"></a>
+<span class="sourceLineNo">057</span> * <li>the given factory's factoryId (usually identifying the regionserver by host:port)<a name="line.57"></a>
+<span class="sourceLineNo">058</span> * </ul><a name="line.58"></a>
+<span class="sourceLineNo">059</span> * It also uses the providerId to differentiate among files.<a name="line.59"></a>
+<span class="sourceLineNo">060</span> */<a name="line.60"></a>
+<span class="sourceLineNo">061</span>@InterfaceAudience.Private<a name="line.61"></a>
+<span class="sourceLineNo">062</span>@InterfaceStability.Evolving<a name="line.62"></a>
+<span class="sourceLineNo">063</span>public abstract class AbstractFSWALProvider<T extends AbstractFSWAL<?>> implements WALProvider {<a name="line.63"></a>
+<span class="sourceLineNo">064</span><a name="line.64"></a>
+<span class="sourceLineNo">065</span> private static final Logger LOG = LoggerFactory.getLogger(AbstractFSWALProvider.class);<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span> /** Separate old log into different dir by regionserver name **/<a name="line.67"></a>
+<span class="sourceLineNo">068</span> public static final String SEPARATE_OLDLOGDIR = "hbase.separate.oldlogdir.by.regionserver";<a name="line.68"></a>
+<span class="sourceLineNo">069</span> public static final boolean DEFAULT_SEPARATE_OLDLOGDIR = false;<a name="line.69"></a>
+<span class="sourceLineNo">070</span><a name="line.70"></a>
+<span class="sourceLineNo">071</span> // Only public so classes back in regionserver.wal can access<a name="line.71"></a>
+<span class="sourceLineNo">072</span> public interface Reader extends WAL.Reader {<a name="line.72"></a>
+<span class="sourceLineNo">073</span> /**<a name="line.73"></a>
+<span class="sourceLineNo">074</span> * @param fs File system.<a name="line.74"></a>
+<span class="sourceLineNo">075</span> * @param path Path.<a name="line.75"></a>
+<span class="sourceLineNo">076</span> * @param c Configuration.<a name="line.76"></a>
+<span class="sourceLineNo">077</span> * @param s Input stream that may have been pre-opened by the caller; may be null.<a name="line.77"></a>
+<span class="sourceLineNo">078</span> */<a name="line.78"></a>
+<span class="sourceLineNo">079</span> void init(FileSystem fs, Path path, Configuration c, FSDataInputStream s) throws IOException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span> }<a name="line.80"></a>
+<span class="sourceLineNo">081</span><a name="line.81"></a>
+<span class="sourceLineNo">082</span> protected volatile T wal;<a name="line.82"></a>
+<span class="sourceLineNo">083</span> protected WALFactory factory;<a name="line.83"></a>
+<span class="sourceLineNo">084</span> protected Configuration conf;<a name="line.84"></a>
+<span class="sourceLineNo">085</span> protected List<WALActionsListener> listeners = new ArrayList<>();<a name="line.85"></a>
+<span class="sourceLineNo">086</span> protected String providerId;<a name="line.86"></a>
+<span class="sourceLineNo">087</span> protected AtomicBoolean initialized = new AtomicBoolean(false);<a name="line.87"></a>
+<span class="sourceLineNo">088</span> // for default wal provider, logPrefix won't change<a name="line.88"></a>
+<span class="sourceLineNo">089</span> protected String logPrefix;<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> * We use walCreateLock to prevent wal recreation in different threads, and also prevent getWALs<a name="line.92"></a>
+<span class="sourceLineNo">093</span> * missing the newly created WAL, see HBASE-21503 for more details.<a name="line.93"></a>
+<span class="sourceLineNo">094</span> */<a name="line.94"></a>
+<span class="sourceLineNo">095</span> private final ReadWriteLock walCreateLock = new ReentrantReadWriteLock();<a name="line.95"></a>
+<span class="sourceLineNo">096</span><a name="line.96"></a>
+<span class="sourceLineNo">097</span> /**<a name="line.97"></a>
+<span class="sourceLineNo">098</span> * @param factory factory that made us, identity used for FS layout. may not be null<a name="line.98"></a>
+<span class="sourceLineNo">099</span> * @param conf may not be null<a name="line.99"></a>
+<span class="sourceLineNo">100</span> * @param providerId differentiate between providers from one factory, used for FS layout. may be<a name="line.100"></a>
+<span class="sourceLineNo">101</span> * null<a name="line.101"></a>
+<span class="sourceLineNo">102</span> */<a name="line.102"></a>
+<span class="sourceLineNo">103</span> @Override<a name="line.103"></a>
+<span class="sourceLineNo">104</span> public void init(WALFactory factory, Configuration conf, String providerId) throws IOException {<a name="line.104"></a>
+<span class="sourceLineNo">105</span> if (!initialized.compareAndSet(false, true)) {<a name="line.105"></a>
+<span class="sourceLineNo">106</span> throw new IllegalStateException("WALProvider.init should only be called once.");<a name="line.106"></a>
+<span class="sourceLineNo">107</span> }<a name="line.107"></a>
+<span class="sourceLineNo">108</span> this.factory = factory;<a name="line.108"></a>
+<span class="sourceLineNo">109</span> this.conf = conf;<a name="line.109"></a>
+<span class="sourceLineNo">110</span> this.providerId = providerId;<a name="line.110"></a>
+<span class="sourceLineNo">111</span> // get log prefix<a name="line.111"></a>
+<span class="sourceLineNo">112</span> StringBuilder sb = new StringBuilder().append(factory.factoryId);<a name="line.112"></a>
+<span class="sourceLineNo">113</span> if (providerId != null) {<a name="line.113"></a>
+<span class="sourceLineNo">114</span> if (providerId.startsWith(WAL_FILE_NAME_DELIMITER)) {<a name="line.114"></a>
+<span class="sourceLineNo">115</span> sb.append(providerId);<a name="line.115"></a>
+<span class="sourceLineNo">116</span> } else {<a name="line.116"></a>
+<span class="sourceLineNo">117</span> sb.append(WAL_FILE_NAME_DELIMITER).append(providerId);<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> logPrefix = sb.toString();<a name="line.120"></a>
+<span class="sourceLineNo">121</span> doInit(conf);<a name="line.121"></a>
+<span class="sourceLineNo">122</span> }<a name="line.122"></a>
+<span class="sourceLineNo">123</span><a name="line.123"></a>
+<span class="sourceLineNo">124</span> @Override<a name="line.124"></a>
+<span class="sourceLineNo">125</span> public List<WAL> getWALs() {<a name="line.125"></a>
+<span class="sourceLineNo">126</span> if (wal != null) {<a name="line.126"></a>
+<span class="sourceLineNo">127</span> return Lists.newArrayList(wal);<a name="line.127"></a>
+<span class="sourceLineNo">128</span> }<a name="line.128"></a>
+<span class="sourceLineNo">129</span> walCreateLock.readLock().lock();<a name="line.129"></a>
+<span class="sourceLineNo">130</span> try {<a name="line.130"></a>
+<span class="sourceLineNo">131</span> if (wal == null) {<a name="line.131"></a>
+<span class="sourceLineNo">132</span> return Collections.emptyList();<a name="line.132"></a>
+<span class="sourceLineNo">133</span> } else {<a name="line.133"></a>
+<span class="sourceLineNo">134</span> return Lists.newArrayList(wal);<a name="line.134"></a>
+<span class="sourceLineNo">135</span> }<a name="line.135"></a>
+<span class="sourceLineNo">136</span> } finally {<a name="line.136"></a>
+<span class="sourceLineNo">137</span> walCreateLock.readLock().unlock();<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><a name="line.140"></a>
+<span class="sourceLineNo">141</span> @Override<a name="line.141"></a>
+<span class="sourceLineNo">142</span> public T getWAL(RegionInfo region) throws IOException {<a name="line.142"></a>
+<span class="sourceLineNo">143</span> T walCopy = wal;<a name="line.143"></a>
+<span class="sourceLineNo">144</span> if (walCopy != null) {<a name="line.144"></a>
+<span class="sourceLineNo">145</span> return walCopy;<a name="line.145"></a>
+<span class="sourceLineNo">146</span> }<a name="line.146"></a>
+<span class="sourceLineNo">147</span> walCreateLock.writeLock().lock();<a name="line.147"></a>
+<span class="sourceLineNo">148</span> try {<a name="line.148"></a>
+<span class="sourceLineNo">149</span> walCopy = wal;<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (walCopy != null) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> return walCopy;<a name="line.151"></a>
+<span class="sourceLineNo">152</span> }<a name="line.152"></a>
+<span class="sourceLineNo">153</span> walCopy = createWAL();<a name="line.153"></a>
+<span class="sourceLineNo">154</span> boolean succ = false;<a name="line.154"></a>
+<span class="sourceLineNo">155</span> try {<a name="line.155"></a>
+<span class="sourceLineNo">156</span> walCopy.init();<a name="line.156"></a>
+<span class="sourceLineNo">157</span> succ = true;<a name="line.157"></a>
+<span class="sourceLineNo">158</span> } finally {<a name="line.158"></a>
+<span class="sourceLineNo">159</span> if (!succ) {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> walCopy.close();<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> wal = walCopy;<a name="line.163"></a>
+<span class="sourceLineNo">164</span> return walCopy;<a name="line.164"></a>
+<span class="sourceLineNo">165</span> } finally {<a name="line.165"></a>
+<span class="sourceLineNo">166</span> walCreateLock.writeLock().unlock();<a name="line.166"></a>
+<span class="sourceLineNo">167</span> }<a name="line.167"></a>
+<span class="sourceLineNo">168</span> }<a name="line.168"></a>
+<span class="sourceLineNo">169</span><a name="line.169"></a>
+<span class="sourceLineNo">170</span> protected abstract T createWAL() throws IOException;<a name="line.170"></a>
+<span class="sourceLineNo">171</span><a name="line.171"></a>
+<span class="sourceLineNo">172</span> protected abstract void doInit(Configuration conf) throws IOException;<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span> @Override<a name="line.174"></a>
+<span class="sourceLineNo">175</span> public void shutdown() throws IOException {<a name="line.175"></a>
+<span class="sourceLineNo">176</span> T log = this.wal;<a name="line.176"></a>
+<span class="sourceLineNo">177</span> if (log != null) {<a name="line.177"></a>
+<span class="sourceLineNo">178</span> log.shutdown();<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><a name="line.181"></a>
+<span class="sourceLineNo">182</span> @Override<a name="line.182"></a>
+<span class="sourceLineNo">183</span> public void close() throws IOException {<a name="line.183"></a>
+<span class="sourceLineNo">184</span> T log = this.wal;<a name="line.184"></a>
+<span class="sourceLineNo">185</span> if (log != null) {<a name="line.185"></a>
+<span class="sourceLineNo">186</span> log.close();<a name="line.186"></a>
+<span class="sourceLineNo">187</span> }<a name="line.187"></a>
+<span class="sourceLineNo">188</span> }<a name="line.188"></a>
+<span class="sourceLineNo">189</span><a name="line.189"></a>
+<span class="sourceLineNo">190</span> /**<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * number of files (rolled and active). if either of them aren't, count 0 for that provider.<a name="line.192"></a>
+<span class="sourceLineNo">193</span> */<a name="line.193"></a>
+<span class="sourceLineNo">194</span> @Override<a name="line.194"></a>
+<span class="sourceLineNo">195</span> public long getNumLogFiles() {<a name="line.195"></a>
+<span class="sourceLineNo">196</span> T log = this.wal;<a name="line.196"></a>
+<span class="sourceLineNo">197</span> return log == null ? 0 : log.getNumLogFiles();<a name="line.197"></a>
+<span class="sourceLineNo">198</span> }<a name="line.198"></a>
+<span class="sourceLineNo">199</span><a name="line.199"></a>
+<span class="sourceLineNo">200</span> /**<a name="line.200"></a>
+<span class="sourceLineNo">201</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.201"></a>
+<span class="sourceLineNo">202</span> * size of files (only rolled). if either of them aren't, count 0 for that provider.<a name="line.202"></a>
+<span class="sourceLineNo">203</span> */<a name="line.203"></a>
+<span class="sourceLineNo">204</span> @Override<a name="line.204"></a>
+<span class="sourceLineNo">205</span> public long getLogFileSize() {<a name="line.205"></a>
+<span class="sourceLineNo">206</span> T log = this.wal;<a name="line.206"></a>
+<span class="sourceLineNo">207</span> return log == null ? 0 : log.getLogFileSize();<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> /**<a name="line.210"></a>
+<span class="sourceLineNo">211</span> * returns the number of rolled WAL files.<a name="line.211"></a>
+<span class="sourceLineNo">212</span> */<a name="line.212"></a>
+<span class="sourceLineNo">213</span> @VisibleForTesting<a name="line.213"></a>
+<span class="sourceLineNo">214</span> public static int getNumRolledLogFiles(WAL wal) {<a name="line.214"></a>
+<span class="sourceLineNo">215</span> return ((AbstractFSWAL<?>) wal).getNumRolledLogFiles();<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> /**<a name="line.218"></a>
+<span class="sourceLineNo">219</span> * returns the size of rolled WAL files.<a name="line.219"></a>
+<span class="sourceLineNo">220</span> */<a name="line.220"></a>
+<span class="sourceLineNo">221</span> @VisibleForTesting<a name="line.221"></a>
+<span class="sourceLineNo">222</span> public static long getLogFileSize(WAL wal) {<a name="line.222"></a>
+<span class="sourceLineNo">223</span> return ((AbstractFSWAL<?>) wal).getLogFileSize();<a name="line.223"></a>
+<span class="sourceLineNo">224</span> }<a name="line.224"></a>
+<span class="sourceLineNo">225</span><a name="line.225"></a>
+<span class="sourceLineNo">226</span> /**<a name="line.226"></a>
+<span class="sourceLineNo">227</span> * return the current filename from the current wal.<a name="line.227"></a>
+<span class="sourceLineNo">228</span> */<a name="line.228"></a>
+<span class="sourceLineNo">229</span> @VisibleForTesting<a name="line.229"></a>
+<span class="sourceLineNo">230</span> public static Path getCurrentFileName(final WAL wal) {<a name="line.230"></a>
+<span class="sourceLineNo">231</span> return ((AbstractFSWAL<?>) wal).getCurrentFileName();<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> /**<a name="line.234"></a>
+<span class="sourceLineNo">235</span> * request a log roll, but don't actually do it.<a name="line.235"></a>
+<span class="sourceLineNo">236</span> */<a name="line.236"></a>
+<span class="sourceLineNo">237</span> @VisibleForTesting<a name="line.237"></a>
+<span class="sourceLineNo">238</span> static void requestLogRoll(final WAL wal) {<a name="line.238"></a>
+<span class="sourceLineNo">239</span> ((AbstractFSWAL<?>) wal).requestLogRoll();<a name="line.239"></a>
+<span class="sourceLineNo">240</span> }<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span> // should be package private; more visible for use in AbstractFSWAL<a name="line.242"></a>
+<span class="sourceLineNo">243</span> public static final String WAL_FILE_NAME_DELIMITER = ".";<a name="line.243"></a>
+<span class="sourceLineNo">244</span> /** The hbase:meta region's WAL filename extension */<a name="line.244"></a>
<span class="sourceLineNo">245</span> @VisibleForTesting<a name="line.245"></a>
-<span class="sourceLineNo">246</span> public static long extractFileNumFromWAL(final WAL wal) {<a name="line.246"></a>
-<span class="sourceLineNo">247</span> final Path walName = ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.247"></a>
-<span class="sourceLineNo">248</span> if (walName == null) {<a name="line.248"></a>
-<span class="sourceLineNo">249</span> throw new IllegalArgumentException("The WAL path couldn't be null");<a name="line.249"></a>
-<span class="sourceLineNo">250</span> }<a name="line.250"></a>
-<span class="sourceLineNo">251</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(walName.getName());<a name="line.251"></a>
-<span class="sourceLineNo">252</span> if (matcher.matches()) {<a name="line.252"></a>
-<span class="sourceLineNo">253</span> return Long.parseLong(matcher.group(2));<a name="line.253"></a>
-<span class="sourceLineNo">254</span> } else {<a name="line.254"></a>
-<span class="sourceLineNo">255</span> throw new IllegalArgumentException(walName.getName() + " is not a valid wal file name");<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><a name="line.258"></a>
-<span class="sourceLineNo">259</span> /**<a name="line.259"></a>
-<span class="sourceLineNo">260</span> * Pattern used to validate a WAL file name see {@link #validateWALFilename(String)} for<a name="line.260"></a>
-<span class="sourceLineNo">261</span> * description.<a name="line.261"></a>
-<span class="sourceLineNo">262</span> */<a name="line.262"></a>
-<span class="sourceLineNo">263</span> private static final Pattern WAL_FILE_NAME_PATTERN =<a name="line.263"></a>
-<span class="sourceLineNo">264</span> Pattern.compile("(.+)\\.(\\d+)(\\.[0-9A-Za-z]+)?");<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> * A WAL file name is of the format: &lt;wal-name&gt;{@link #WAL_FILE_NAME_DELIMITER}<a name="line.267"></a>
-<span class="sourceLineNo">268</span> * &lt;file-creation-timestamp&gt;[.&lt;suffix&gt;]. provider-name is usually made up of a<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * server-name and a provider-id<a name="line.269"></a>
-<span class="sourceLineNo">270</span> * @param filename name of the file to validate<a name="line.270"></a>
-<span class="sourceLineNo">271</span> * @return <tt>true</tt> if the filename matches an WAL, <tt>false</tt> otherwise<a name="line.271"></a>
-<span class="sourceLineNo">272</span> */<a name="line.272"></a>
-<span class="sourceLineNo">273</span> public static boolean validateWALFilename(String filename) {<a name="line.273"></a>
-<span class="sourceLineNo">274</span> return WAL_FILE_NAME_PATTERN.matcher(filename).matches();<a name="line.274"></a>
-<span class="sourceLineNo">275</span> }<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> * Construct the directory name for all WALs on a given server. Dir names currently look like this<a name="line.278"></a>
-<span class="sourceLineNo">279</span> * for WALs: <code>hbase//WALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.279"></a>
-<span class="sourceLineNo">280</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.280"></a>
-<span class="sourceLineNo">281</span> * @return the relative WAL directory name, e.g. <code>.logs/1.example.org,60030,12345</code> if<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * <code>serverName</code> passed is <code>1.example.org,60030,12345</code><a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static String getWALDirectoryName(final String serverName) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_LOGDIR_NAME);<a name="line.285"></a>
-<span class="sourceLineNo">286</span> dirName.append("/");<a name="line.286"></a>
-<span class="sourceLineNo">287</span> dirName.append(serverName);<a name="line.287"></a>
-<span class="sourceLineNo">288</span> return dirName.toString();<a name="line.288"></a>
+<span class="sourceLineNo">246</span> public static final String META_WAL_PROVIDER_ID = ".meta";<a name="line.246"></a>
+<span class="sourceLineNo">247</span> static final String DEFAULT_PROVIDER_ID = "default";<a name="line.247"></a>
+<span class="sourceLineNo">248</span><a name="line.248"></a>
+<span class="sourceLineNo">249</span> // Implementation details that currently leak in tests or elsewhere follow<a name="line.249"></a>
+<span class="sourceLineNo">250</span> /** File Extension used while splitting an WAL into regions (HBASE-2312) */<a name="line.250"></a>
+<span class="sourceLineNo">251</span> public static final String SPLITTING_EXT = "-splitting";<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span> /**<a name="line.253"></a>
+<span class="sourceLineNo">254</span> * It returns the file create timestamp from the file name. For name format see<a name="line.254"></a>
+<span class="sourceLineNo">255</span> * {@link #validateWALFilename(String)} public until remaining tests move to o.a.h.h.wal<a name="line.255"></a>
+<span class="sourceLineNo">256</span> * @param wal must not be null<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * @return the file number that is part of the WAL file name<a name="line.257"></a>
+<span class="sourceLineNo">258</span> */<a name="line.258"></a>
+<span class="sourceLineNo">259</span> @VisibleForTesting<a name="line.259"></a>
+<span class="sourceLineNo">260</span> public static long extractFileNumFromWAL(final WAL wal) {<a name="line.260"></a>
+<span class="sourceLineNo">261</span> final Path walName = ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.261"></a>
+<span class="sourceLineNo">262</span> if (walName == null) {<a name="line.262"></a>
+<span class="sourceLineNo">263</span> throw new IllegalArgumentException("The WAL path couldn't be null");<a name="line.263"></a>
+<span class="sourceLineNo">264</span> }<a name="line.264"></a>
+<span class="sourceLineNo">265</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(walName.getName());<a name="line.265"></a>
+<span class="sourceLineNo">266</span> if (matcher.matches()) {<a name="line.266"></a>
+<span class="sourceLineNo">267</span> return Long.parseLong(matcher.group(2));<a name="line.267"></a>
+<span class="sourceLineNo">268</span> } else {<a name="line.268"></a>
+<span class="sourceLineNo">269</span> throw new IllegalArgumentException(walName.getName() + " is not a valid wal file name");<a name="line.269"></a>
+<span class="sourceLineNo">270</span> }<a name="line.270"></a>
+<span class="sourceLineNo">271</span> }<a name="line.271"></a>
+<span class="sourceLineNo">272</span><a name="line.272"></a>
+<span class="sourceLineNo">273</span> /**<a name="line.273"></a>
+<span class="sourceLineNo">274</span> * Pattern used to validate a WAL file name see {@link #validateWALFilename(String)} for<a name="line.274"></a>
+<span class="sourceLineNo">275</span> * description.<a name="line.275"></a>
+<span class="sourceLineNo">276</span> */<a name="line.276"></a>
+<span class="sourceLineNo">277</span> private static final Pattern WAL_FILE_NAME_PATTERN =<a name="line.277"></a>
+<span class="sourceLineNo">278</span> Pattern.compile("(.+)\\.(\\d+)(\\.[0-9A-Za-z]+)?");<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> * A WAL file name is of the format: &lt;wal-name&gt;{@link #WAL_FILE_NAME_DELIMITER}<a name="line.281"></a>
+<span class="sourceLineNo">282</span> * &lt;file-creation-timestamp&gt;[.&lt;suffix&gt;]. provider-name is usually made up of a<a name="line.282"></a>
+<span class="sourceLineNo">283</span> * server-name and a provider-id<a name="line.283"></a>
+<span class="sourceLineNo">284</span> * @param filename name of the file to validate<a name="line.284"></a>
+<span class="sourceLineNo">285</span> * @return <tt>true</tt> if the filename matches an WAL, <tt>false</tt> otherwise<a name="line.285"></a>
+<span class="sourceLineNo">286</span> */<a name="line.286"></a>
+<span class="sourceLineNo">287</span> public static boolean validateWALFilename(String filename) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span> return WAL_FILE_NAME_PATTERN.matcher(filename).matches();<a name="line.288"></a>
<span class="sourceLineNo">289</span> }<a name="line.289"></a>
<span class="sourceLineNo">290</span><a name="line.290"></a>
<span class="sourceLineNo">291</span> /**<a name="line.291"></a>
-<span class="sourceLineNo">292</span> * Construct the directory name for all old WALs on a given server. The default old WALs dir looks<a name="line.292"></a>
-<span class="sourceLineNo">293</span> * like: <code>hbase/oldWALs</code>. If you config hbase.separate.oldlogdir.by.regionserver to<a name="line.293"></a>
-<span class="sourceLineNo">294</span> * true, it looks like <code>hbase//oldWALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.294"></a>
-<span class="sourceLineNo">295</span> * @param conf<a name="line.295"></a>
-<span class="sourceLineNo">296</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.296"></a>
-<span class="sourceLineNo">297</span> * @return the relative WAL directory name<a name="line.297"></a>
-<span class="sourceLineNo">298</span> */<a name="line.298"></a>
-<span class="sourceLineNo">299</span> public static String getWALArchiveDirectoryName(Configuration conf, final String serverName) {<a name="line.299"></a>
-<span class="sourceLineNo">300</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.300"></a>
-<span class="sourceLineNo">301</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.301"></a>
-<span class="sourceLineNo">302</span> dirName.append(Path.SEPARATOR);<a name="line.302"></a>
-<span class="sourceLineNo">303</span> dirName.append(serverName);<a name="line.303"></a>
-<span class="sourceLineNo">304</span> }<a name="line.304"></a>
-<span class="sourceLineNo">305</span> return dirName.toString();<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> /**<a name="line.308"></a>
-<span class="sourceLineNo">309</span> * Pulls a ServerName out of a Path generated according to our layout rules. In the below layouts,<a name="line.309"></a>
-<span class="sourceLineNo">310</span> * this method ignores the format of the logfile component. Current format: [base directory for<a name="line.310"></a>
-<span class="sourceLineNo">311</span> * hbase]/hbase/.logs/ServerName/logfile or [base directory for<a name="line.311"></a>
-<span class="sourceLineNo">312</span> * hbase]/hbase/.logs/ServerName-splitting/logfile Expected to work for individual log files and<a name="line.312"></a>
-<span class="sourceLineNo">313</span> * server-specific directories.<a name="line.313"></a>
-<span class="sourceLineNo">314</span> * @return null if it's not a log file. Returns the ServerName of the region server that created<a name="line.314"></a>
-<span class="sourceLineNo">315</span> * this log file otherwise.<a name="line.315"></a>
-<span class="sourceLineNo">316</span> */<a name="line.316"></a>
-<span class="sourceLineNo">317</span> public static ServerName getServerNameFromWALDirectoryName(Configuration conf, String path)<a name="line.317"></a>
-<span class="sourceLineNo">318</span> throws IOException {<a name="line.318"></a>
-<span class="sourceLineNo">319</span> if (path == null || path.length() <= HConstants.HREGION_LOGDIR_NAME.length()) {<a name="line.319"></a>
-<span class="sourceLineNo">320</span> return null;<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> if (conf == null) {<a name="line.323"></a>
-<span class="sourceLineNo">324</span> throw new IllegalArgumentException("parameter conf must be set");<a name="line.324"></a>
-<span class="sourceLineNo">325</span> }<a name="line.325"></a>
-<span class="sourceLineNo">326</span><a name="line.326"></a>
-<span class="sourceLineNo">327</span> final String rootDir = conf.get(HConstants.HBASE_DIR);<a name="line.327"></a>
-<span class="sourceLineNo">328</span> if (rootDir == null || rootDir.isEmpty()) {<a name="line.328"></a>
-<span class="sourceLineNo">329</span> throw new IllegalArgumentException(HConstants.HBASE_DIR + " key not found in conf.");<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> final StringBuilder startPathSB = new StringBuilder(rootDir);<a name="line.332"></a>
-<span class="sourceLineNo">333</span> if (!rootDir.endsWith("/")) {<a name="line.333"></a>
-<span class="sourceLineNo">334</span> startPathSB.append('/');<a name="line.334"></a>
+<span class="sourceLineNo">292</span> * Construct the directory name for all WALs on a given server. Dir names currently look like this<a name="line.292"></a>
+<span class="sourceLineNo">293</span> * for WALs: <code>hbase//WALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.293"></a>
+<span class="sourceLineNo">294</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.294"></a>
+<span class="sourceLineNo">295</span> * @return the relative WAL directory name, e.g. <code>.logs/1.example.org,60030,12345</code> if<a name="line.295"></a>
+<span class="sourceLineNo">296</span> * <code>serverName</code> passed is <code>1.example.org,60030,12345</code><a name="line.296"></a>
+<span class="sourceLineNo">297</span> */<a name="line.297"></a>
+<span class="sourceLineNo">298</span> public static String getWALDirectoryName(final String serverName) {<a name="line.298"></a>
+<span class="sourceLineNo">299</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_LOGDIR_NAME);<a name="line.299"></a>
+<span class="sourceLineNo">300</span> dirName.append("/");<a name="line.300"></a>
+<span class="sourceLineNo">301</span> dirName.append(serverName);<a name="line.301"></a>
+<span class="sourceLineNo">302</span> return dirName.toString();<a name="line.302"></a>
+<span class="sourceLineNo">303</span> }<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> * Construct the directory name for all old WALs on a given server. The default old WALs dir looks<a name="line.306"></a>
+<span class="sourceLineNo">307</span> * like: <code>hbase/oldWALs</code>. If you config hbase.separate.oldlogdir.by.regionserver to<a name="line.307"></a>
+<span class="sourceLineNo">308</span> * true, it looks like <code>hbase//oldWALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.308"></a>
+<span class="sourceLineNo">309</span> * @param conf<a name="line.309"></a>
+<span class="sourceLineNo">310</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.310"></a>
+<span class="sourceLineNo">311</span> * @return the relative WAL directory name<a name="line.311"></a>
+<span class="sourceLineNo">312</span> */<a name="line.312"></a>
+<span class="sourceLineNo">313</span> public static String getWALArchiveDirectoryName(Configuration conf, final String serverName) {<a name="line.313"></a>
+<span class="sourceLineNo">314</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.314"></a>
+<span class="sourceLineNo">315</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.315"></a>
+<span class="sourceLineNo">316</span> dirName.append(Path.SEPARATOR);<a name="line.316"></a>
+<span class="sourceLineNo">317</span> dirName.append(serverName);<a name="line.317"></a>
+<span class="sourceLineNo">318</span> }<a name="line.318"></a>
+<span class="sourceLineNo">319</span> return dirName.toString();<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> * Pulls a ServerName out of a Path generated according to our layout rules. In the below layouts,<a name="line.323"></a>
+<span class="sourceLineNo">324</span> * this method ignores the format of the logfile component. Current format: [base directory for<a name="line.324"></a>
+<span class="sourceLineNo">325</span> * hbase]/hbase/.logs/ServerName/logfile or [base directory for<a name="line.325"></a>
+<span class="sourceLineNo">326</span> * hbase]/hbase/.logs/ServerName-splitting/logfile Expected to work for individual log files and<a name="line.326"></a>
+<span class="sourceLineNo">327</span> * server-specific directories.<a name="line.327"></a>
+<span class="sourceLineNo">328</span> * @return null if it's not a log file. Returns the ServerName of the region server that created<a name="line.328"></a>
+<span class="sourceLineNo">329</span> * this log file otherwise.<a name="line.329"></a>
+<span class="sourceLineNo">330</span> */<a name="line.330"></a>
+<span class="sourceLineNo">331</span> public static ServerName getServerNameFromWALDirectoryName(Configuration conf, String path)<a name="line.331"></a>
+<span class="sourceLineNo">332</span> throws IOException {<a name="line.332"></a>
+<span class="sourceLineNo">333</span> if (path == null || path.length() <= HConstants.HREGION_LOGDIR_NAME.length()) {<a name="line.333"></a>
+<span class="sourceLineNo">334</span> return null;<a name="line.334"></a>
<span class="sourceLineNo">335</span> }<a name="line.335"></a>
-<span class="sourceLineNo">336</span> startPathSB.append(HConstants.HREGION_LOGDIR_NAME);<a name="line.336"></a>
-<span class="sourceLineNo">337</span> if (!HConstants.HREGION_LOGDIR_NAME.endsWith("/")) {<a name="line.337"></a>
-<span class="sourceLineNo">338</span> startPathSB.append('/');<a name="line.338"></a>
+<span class="sourceLineNo">336</span><a name="line.336"></a>
+<span class="sourceLineNo">337</span> if (conf == null) {<a name="line.337"></a>
+<span class="sourceLineNo">338</span> throw new IllegalArgumentException("parameter conf must be set");<a name="line.338"></a>
<span class="sourceLineNo">339</span> }<a name="line.339"></a>
-<span class="sourceLineNo">340</span> final String startPath = startPathSB.toString();<a name="line.340"></a>
-<span class="sourceLineNo">341</span><a name="line.341"></a>
-<span class="sourceLineNo">342</span> String fullPath;<a name="line.342"></a>
-<span class="sourceLineNo">343</span> try {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> fullPath = FileSystem.get(conf).makeQualified(new Path(path)).toString();<a name="line.344"></a>
-<span class="sourceLineNo">345</span> } catch (IllegalArgumentException e) {<a name="line.345"></a>
-<span class="sourceLineNo">346</span> LOG.info("Call to makeQualified failed on " + path + " " + e.getMessage());<a name="line.346"></a>
-<span class="sourceLineNo">347</span> return null;<a name="line.347"></a>
-<span class="sourceLineNo">348</span> }<a name="line.348"></a>
-<span class="sourceLineNo">349</span><a name="line.349"></a>
-<span class="sourceLineNo">350</span> if (!fullPath.startsWith(startPath)) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span> return null;<a name="line.351"></a>
-<span class="sourceLineNo">352</span> }<a name="line.352"></a>
-<span class="sourceLineNo">353</span><a name="line.353"></a>
-<span class="sourceLineNo">354</span> final String serverNameAndFile = fullPath.substring(startPath.length());<a name="line.354"></a>
+<span class="sourceLineNo">340</span><a name="line.340"></a>
+<span class="sourceLineNo">341</span> final String rootDir = conf.get(HConstants.HBASE_DIR);<a name="line.341"></a>
+<span class="sourceLineNo">342</span> if (rootDir == null || rootDir.isEmpty()) {<a name="line.342"></a>
+<span class="sourceLineNo">343</span> throw new IllegalArgumentException(HConstants.HBASE_DIR + " key not found in conf.");<a name="line.343"></a>
+<span class="sourceLineNo">344</span> }<a name="line.344"></a>
+<span class="sourceLineNo">345</span><a name="line.345"></a>
+<span class="sourceLineNo">346</span> final StringBuilder startPathSB = new StringBuilder(rootDir);<a name="line.346"></a>
+<span class="sourceLineNo">347</span> if (!rootDir.endsWith("/")) {<a name="line.347"></a>
+<span class="sourceLineNo">348</span> startPathSB.append('/');<a name="line.348"></a>
+<span class="sourceLineNo">349</span> }<a name="line.349"></a>
+<span class="sourceLineNo">350</span> startPathSB.append(HConstants.HREGION_LOGDIR_NAME);<a name="line.350"></a>
+<span class="sourceLineNo">351</span> if (!HConstants.HREGION_LOGDIR_NAME.endsWith("/")) {<a name="line.351"></a>
+<span class="sourceLineNo">352</span> startPathSB.append('/');<a name="line.352"></a>
+<span class="sourceLineNo">353</span> }<a name="line.353"></a>
+<span class="sourceLineNo">354</span> final String startPath = startPathSB.toString();<a name="line.354"></a>
<span class="sourceLineNo">355</span><a name="line.355"></a>
-<span class="sourceLineNo">356</span> if (serverNameAndFile.indexOf('/') < "a,0,0".length()) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span> // Either it's a file (not a directory) or it's not a ServerName format<a name="line.357"></a>
-<span class="sourceLineNo">358</span> return null;<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> Path p = new Path(path);<a name="line.361"></a>
-<span class="sourceLineNo">362</span> return getServerNameFromWALDirectoryName(p);<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> /**<a name="line.365"></a>
-<span class="sourceLineNo">366</span> * This function returns region server name from a log file name which is in one of the following<a name="line.366"></a>
-<span class="sourceLineNo">367</span> * formats:<a name="line.367"></a>
-<span class="sourceLineNo">368</span> * <ul><a name="line.368"></a>
-<span class="sourceLineNo">369</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;-splitting/...</li><a name="line.369"></a>
-<span class="sourceLineNo">370</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;/...</li><a name="line.370"></a>
-<span class="sourceLineNo">371</span> * </ul><a name="line.371"></a>
-<span class="sourceLineNo">372</span> * @return null if the passed in logFile isn't a valid WAL file path<a name="line.372"></a>
-<span class="sourceLineNo">373</span> */<a name="line.373"></a>
-<span class="sourceLineNo">374</span> public static ServerName getServerNameFromWALDirectoryName(Path logFile) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span> String logDirName = logFile.getParent().getName();<a name="line.375"></a>
-<span class="sourceLineNo">376</span> // We were passed the directory and not a file in it.<a name="line.376"></a>
-<span class="sourceLineNo">377</span> if (logDirName.equals(HConstants.HREGION_LOGDIR_NAME)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span> logDirName = logFile.getName();<a name="line.378"></a>
-<span class="sourceLineNo">379</span> }<a name="line.379"></a>
-<span class="sourceLineNo">380</span> ServerName serverName = null;<a name="line.380"></a>
-<span class="sourceLineNo">381</span> if (logDirName.endsWith(SPLITTING_EXT)) {<a name="line.381"></a>
-<span class="sourceLineNo">382</span> logDirName = logDirName.substring(0, logDirName.length() - SPLITTING_EXT.length());<a name="line.382"></a>
-<span class="sourceLineNo">383</span> }<a name="line.383"></a>
-<span class="sourceLineNo">384</span> try {<a name="line.384"></a>
-<span class="sourceLineNo">385</span> serverName = ServerName.parseServerName(logDirName);<a name="line.385"></a>
-<span class="sourceLineNo">386</span> } catch (IllegalArgumentException | IllegalStateException ex) {<a name="line.386"></a>
-<span class="sourceLineNo">387</span> serverName = null;<a name="line.387"></a>
-<span class="sourceLineNo">388</span> LOG.warn("Cannot parse a server name from path=" + logFile + "; " + ex.getMessage());<a name="line.388"></a>
-<span class="sourceLineNo">389</span> }<a name="line.389"></a>
-<span class="sourceLineNo">390</span> if (serverName != null && serverName.getStartcode() < 0) {<a name="line.390"></a>
-<span class="sourceLineNo">391</span> LOG.warn("Invalid log file path=" + logFile);<a name="line.391"></a>
-<span class="sourceLineNo">392</span> serverName = null;<a name="line.392"></a>
+<span class="sourceLineNo">356</span> String fullPath;<a name="line.356"></a>
+<span class="sourceLineNo">357</span> try {<a name="line.357"></a>
+<span class="sourceLineNo">358</span> fullPath = FileSystem.get(conf).makeQualified(new Path(path)).toString();<a name="line.358"></a>
+<span class="sourceLineNo">359</span> } catch (IllegalArgumentException e) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span> LOG.info("Call to makeQualified failed on " + path + " " + e.getMessage());<a name="line.360"></a>
+<span class="sourceLineNo">361</span> return null;<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> if (!fullPath.startsWith(startPath)) {<a name="line.364"></a>
+<span class="sourceLineNo">365</span> return null;<a name="line.365"></a>
+<span class="sourceLineNo">366</span> }<a name="line.366"></a>
+<span class="sourceLineNo">367</span><a name="line.367"></a>
+<span class="sourceLineNo">368</span> final String serverNameAndFile = fullPath.substring(startPath.length());<a name="line.368"></a>
+<span class="sourceLineNo">369</span><a name="line.369"></a>
+<span class="sourceLineNo">370</span> if (serverNameAndFile.indexOf('/') < "a,0,0".length()) {<a name="line.370"></a>
+<span class="sourceLineNo">371</span> // Either it's a file (not a directory) or it's not a ServerName format<a name="line.371"></a>
+<span class="sourceLineNo">372</span> return null;<a name="line.372"></a>
+<span class="sourceLineNo">373</span> }<a name="line.373"></a>
+<span class="sourceLineNo">374</span><a name="line.374"></a>
+<span class="sourceLineNo">375</span> Path p = new Path(path);<a name="line.375"></a>
+<span class="sourceLineNo">376</span> return getServerNameFromWALDirectoryName(p);<a name="line.376"></a>
+<span class="sourceLineNo">377</span> }<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> * This function returns region server name from a log file name which is in one of the following<a name="line.380"></a>
+<span class="sourceLineNo">381</span> * formats:<a name="line.381"></a>
+<span class="sourceLineNo">382</span> * <ul><a name="line.382"></a>
+<span class="sourceLineNo">383</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;-splitting/...</li><a name="line.383"></a>
+<span class="sourceLineNo">384</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;/...</li><a name="line.384"></a>
+<span class="sourceLineNo">385</span> * </ul><a name="line.385"></a>
+<span class="sourceLineNo">386</span> * @return null if the passed in logFile isn't a valid WAL file path<a name="line.386"></a>
+<span class="sourceLineNo">387</span> */<a name="line.387"></a>
+<span class="sourceLineNo">388</span> public static ServerName getServerNameFromWALDirectoryName(Path logFile) {<a name="line.388"></a>
+<span class="sourceLineNo">389</span> String logDirName = logFile.getParent().getName();<a name="line.389"></a>
+<span class="sourceLineNo">390</span> // We were passed the directory and not a file in it.<a name="line.390"></a>
+<span class="sourceLineNo">391</span> if (logDirName.equals(HConstants.HREGION_LOGDIR_NAME)) {<a name="line.391"></a>
+<span class="sourceLineNo">392</span> logDirName = logFile.getName();<a name="line.392"></a>
<span class="sourceLineNo">393</span> }<a name="line.393"></a>
-<span class="sourceLineNo">394</span> return serverName;<a name="line.394"></a>
-<span class="sourceLineNo">395</span> }<a name="line.395"></a>
-<span class="sourceLineNo">396</span><a name="line.396"></a>
-<span class="sourceLineNo">397</span> public static boolean isMetaFile(Path p) {<a name="line.397"></a>
-<span class="sourceLineNo">398</span> return isMetaFile(p.getName());<a name="line.398"></a>
-<span class="sourceLineNo">399</span> }<a name="line.399"></a>
-<span class="sourceLineNo">400</span><a name="line.400"></a>
-<span class="sourceLineNo">401</span> public static boolean isMetaFile(String p) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span> if (p != null && p.endsWith(META_WAL_PROVIDER_ID)) {<a name="line.402"></a>
-<span class="sourceLineNo">403</span> return true;<a name="line.403"></a>
-<span class="sourceLineNo">404</span> }<a name="line.404"></a>
-<span class="sourceLineNo">405</span> return false;<a name="line.405"></a>
-<span class="sourceLineNo">406</span> }<a name="line.406"></a>
-<span class="sourceLineNo">407</span><a name="line.407"></a>
-<span class="sourceLineNo">408</span> public static boolean isArchivedLogFile(Path p) {<a name="line.408"></a>
-<span class="sourceLineNo">409</span> String oldLog = Path.SEPARATOR + HConstants.HREGION_OLDLOGDIR_NAME + Path.SEPARATOR;<a name="line.409"></a>
-<span class="sourceLineNo">410</span> return p.toString().contains(oldLog);<a name="line.410"></a>
-<span class="sourceLineNo">411</span> }<a name="line.411"></a>
-<span class="sourceLineNo">412</span><a name="line.412"></a>
-<span class="sourceLineNo">413</span> /**<a name="line.413"></a>
-<span class="sourceLineNo">414</span> * Get the archived WAL file path<a name="line.414"></a>
-<span class="sourceLineNo">415</span> * @param path - active WAL file path<a name="line.415"></a>
-<span class="sourceLineNo">416</span> * @param conf - configuration<a name="line.416"></a>
-<span class="sourceLineNo">417</span> * @return archived path if exists, path - otherwise<a name="line.417"></a>
-<span class="sourceLineNo">418</span> * @throws IOException exception<a name="line.418"></a>
-<span class="sourceLineNo">419</span> */<a name="line.419"></a>
-<span class="sourceLineNo">420</span> public static Path getArchivedLogPath(Path path, Configuration conf) throws IOException {<a name="line.420"></a>
-<span class="sourceLineNo">421</span> Path rootDir = FSUtils.getRootDir(conf);<a name="line.421"></a>
-<span class="sourceLineNo">422</span> Path oldLogDir = new Path(rootDir, HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.422"></a>
-<span class="sourceLineNo">423</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.423"></a>
-<span class="sourceLineNo">424</span> ServerName serverName = getServerNameFromWALDirectoryName(path);<a name="line.424"></a>
-<span class="sourceLineNo">425</span> if (serverName == null) {<a name="line.425"></a>
-<span class="sourceLineNo">426</span> LOG.error("Couldn't locate log: " + path);<a name="line.426"></a>
-<span class="sourceLineNo">427</span> return path;<a name="line.427"></a>
-<span class="sourceLineNo">428</span> }<a name="line.428"></a>
-<span class="sourceLineNo">429</span> oldLogDir = new Path(oldLogDir, serverName.getServerName());<a name="line.429"></a>
-<span class="sourceLineNo">430</span> }<a name="line.430"></a>
-<span class="sourceLineNo">431</span> Path archivedLogLocation = new Path(oldLogDir, path.getName());<a name="line.431"></a>
-<span class="sourceLineNo">432</span> final FileSystem fs = FSUtils.getCurrentFileSystem(conf);<a name="line.432"></a>
-<span class="sourceLineNo">433</span><a name="line.433"></a>
-<span class="sourceLineNo">434</span> if (fs.exists(archivedLogLocation)) {<a name="line.434"></a>
-<span class="sourceLineNo">435</span> LOG.info("Log " + path + " was moved to " + archivedLogLocation);<a name="line.435"></a>
-<span class="sourceLineNo">436</span> return archivedLogLocation;<a name="line.436"></a>
-<span class="sourceLineNo">437</span> } else {<a name="line.437"></a>
-<span class="sourceLineNo">438</span> LOG.error("Couldn't locate log: " + path);<a name="line.438"></a>
-<span class="sourceLineNo">439</span> return path;<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> /**<a name="line.443"></a>
-<span class="sourceLineNo">444</span> * Opens WAL reader with retries and additional exception handling<a name="line.444"></a>
-<span class="sourceLineNo">445</span> * @param path path to WAL file<a name="line.445"></a>
-<span class="sourceLineNo">446</span> * @param conf configuration<a name="line.446"></a>
-<span class="sourceLineNo">447</span> * @return WAL Reader instance<a name="line.447"></a>
-<span class="sourceLineNo">448</span> * @throws IOException<a name="line.448"></a>
-<span class="sourceLineNo">449</span> */<a name="line.449"></a>
-<span class="sourceLineNo">450</span> public static org.apache.hadoop.hbase.wal.WAL.Reader openReader(Path path, Configuration conf)<a name="line.450"></a>
-<span class="sourceLineNo">451</span> throws IOException<a name="line.451"></a>
-<span class="sourceLineNo">452</span><a name="line.452"></a>
-<span class="sourceLineNo">453</span> {<a name="line.453"></a>
-<span class="sourceLineNo">454</span> long retryInterval = 2000; // 2 sec<a name="line.454"></a>
-<span class="sourceLineNo">455</span> int maxAttempts = 30;<a name="line.455"></a>
-<span class="sourceLineNo">456</span> int attempt = 0;<a name="line.456"></a>
-<span class="sourceLineNo">457</span> Exception ee = null;<a name="line.457"></a>
-<span class="sourceLineNo">458</span> org.apache.hadoop.hbase.wal.WAL.Reader reader = null;<a name="line.458"></a>
-<span class="sourceLineNo">459</span> while (reader == null && attempt++ < maxAttempts) {<a name="line.459"></a>
-<span class="sourceLineNo">460</span> try {<a name="line.460"></a>
-<span class="sourceLineNo">461</span> // Detect if this is a new file, if so get a new reader else<a name="line.461"></a>
-<span class="sourceLineNo">462</span> // reset the current reader so that we see the new data<a name="line.462"></a>
-<span class="sourceLineNo">463</span> reader = WALFactory.createReader(path.getFileSystem(conf), path, conf);<a name="line.463"></a>
-<span class="sourceLineNo">464</span> return reader;<a name="line.464"></a>
-<span class="sourceLineNo">465</span> } catch (FileNotFoundException fnfe) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span> // If the log was archived, continue reading from there<a name="line.466"></a>
-<span class="sourceLineNo">467</span> Path archivedLog = AbstractFSWALProvider.getArchivedLogPath(path, conf);<a name="line.467"></a>
-<span class="sourceLineNo">468</span> if (!Objects.equals(path, archivedLog)) {<a name="line.468"></a>
-<span class="sourceLineNo">469</span> return openReader(archivedLog, conf);<a name="line.469"></a>
-<span class="sourceLineNo">470</span> } else {<a name="line.470"></a>
-<span class="sourceLineNo">471</span> throw fnfe;<a name="line.471"></a>
-<span class="sourceLineNo">472</span> }<a name="line.472"></a>
-<span class="sourceLineNo">473</span> } catch (LeaseNotRecoveredException lnre) {<a name="line.473"></a>
-<span class="sourceLineNo">474</span> // HBASE-15019 the WAL was not closed due to some hiccup.<a name="line.474"></a>
-<span class="sourceLineNo">475</span> LOG.warn("Try to recover the WAL lease " + path, lnre);<a name="line.475"></a>
-<span class="sourceLineNo">476</span> recoverLease(conf, path);<a name="line.476"></a>
-<span class="sourceLineNo">477</span> reader = null;<a name="line.477"></a>
-<span class="sourceLineNo">478</span> ee = lnre;<a name="line.478"></a>
-<span class="sourceLineNo">479</span> } catch (NullPointerException npe) {<a name="line.479"></a>
-<span class="sourceLineNo">480</span> // Workaround for race condition in HDFS-4380<a name="line.480"></a>
-<span class="sourceLineNo">481</span> // which throws a NPE if we open a file before any data node has the most recent block<a name="line.481"></a>
-<span class="sourceLineNo">482</span> // Just sleep and retry. Will require re-reading compressed WALs for compressionContext.<a name="line.482"></a>
-<span class="sourceLineNo">483</span> LOG.warn("Got NPE opening reader, will retry.");<a name="line.483"></a>
-<span class="sourceLineNo">484</span> reader = null;<a name="line.484"></a>
-<span class="sourceLineNo">485</span> ee = npe;<a name="line.485"></a>
-<span class="sourceLineNo">486</span> }<a name="line.486"></a>
-<span class="sourceLineNo">487</span> if (reader == null) {<a name="line.487"></a>
-<span class="sourceLineNo">488</span> // sleep before next attempt<a name="line.488"></a>
-<span class="sourceLineNo">489</span> try {<a name="line.489"></a>
-<span class="sourceLineNo">490</span> Thread.sleep(retryInterval);<a name="line.490"></a>
-<span class="sourceLineNo">491</span> } catch (InterruptedException e) {<a name="line.491"></a>
-<span class="sourceLineNo">492</span> }<a name="line.492"></a>
-<span class="sourceLineNo">493</span> }<a name="line.493"></a>
-<span class="sourceLineNo">494</span> }<a name="line.494"></a>
-<span class="sourceLineNo">495</span> throw new IOException("Could not open reader", ee);<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> // For HBASE-15019<a name="line.498"></a>
-<span class="sourceLineNo">499</span> private static void recoverLease(final Configuration conf, final Path path) {<a name="line.499"></a>
-<span class="sourceLineNo">500</span> try {<a name="line.500"></a>
-<span class="sourceLineNo">501</span> final FileSystem dfs = FSUtils.getCurrentFileSystem(conf);<a name="line.501"></a>
-<span class="sourceLineNo">502</span> FSUtils fsUtils = FSUtils.getInstance(dfs, conf);<a name="line.502"></a>
-<span class="sourceLineNo">503</span> fsUtils.recoverFileLease(dfs, path, conf, new CancelableProgressable() {<a name="line.503"></a>
-<span class="sourceLineNo">504</span> @Override<a name="line.504"></a>
-<span class="sourceLineNo">505</span> public boolean progress() {<a name="line.505"></a>
-<span class="sourceLineNo">506</span> LOG.debug("Still trying to recover WAL lease: " + path);<a name="line.506"></a>
-<span class="sourceLineNo">507</span> return true;<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> } catch (IOException e) {<a name="line.510"></a>
-<span class="sourceLineNo">511</span> LOG.warn("unable to recover lease for WAL: " + path, e);<a name="line.511"></a>
-<span class="sourceLineNo">512</span> }<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span><a name="line.514"></a>
-<span class="sourceLineNo">515</span> @Override<a name="line.515"></a>
-<span class="sourceLineNo">516</span> public void addWALActionsListener(WALActionsListener listener) {<a name="line.516"></a>
-<span class="sourceLineNo">517</span> listeners.add(listener);<a name="line.517"></a>
-<span class="sourceLineNo">518</span> }<a name="line.518"></a>
-<span class="sourceLineNo">519</span><a name="line.519"></a>
-<span class="sourceLineNo">520</span> private static String getWALNameGroupFromWALName(String name, int group) {<a name="line.520"></a>
-<span class="sourceLineNo">521</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(name);<a name="line.521"></a>
-<span class="sourceLineNo">522</span> if (matcher.matches()) {<a name="line.522"></a>
-<span class="sourceLineNo">523</span> return matcher.group(group);<a name="line.523"></a>
-<span class="sourceLineNo">524</span> } else {<a name="line.524"></a>
-<span class="sourceLineNo">525</span> throw new IllegalArgumentException(name + " is not a valid wal file name");<a name="line.525"></a>
+<span class="sourceLineNo">394</span> ServerName serverName = null;<a name="line.394"></a>
+<span class="sourceLineNo">395</span> if (logDirName.endsWith(SPLITTING_EXT)) {<a name="line.395"></a>
+<span class="sourceLineNo">396</span> logDirName = logDirName.substring(0, logDirName.length() - SPLITTING_EXT.length());<a name="line.396"></a>
+<span class="sourceLineNo">397</span> }<a name="line.397"></a>
+<span class="sourceLineNo">398</span> try {<a name="line.398"></a>
+<span class="sourceLineNo">399</span> serverName = ServerName.parseServerName(logDirName);<a name="line.399"></a>
+<span class="sourceLineNo">400</span> } catch (IllegalArgumentException | IllegalStateException ex) {<a name="line.400"></a>
+<span class="sourceLineNo">401</span> serverName = null;<a name="line.401"></a>
+<span class="sourceLineNo">402</span> LOG.warn("Cannot parse a server name from path=" + logFile + "; " + ex.getMessage());<a name="line.402"></a>
+<span class="sourceLineNo">403</span> }<a name="line.403"></a>
+<span class="sourceLineNo">404</span> if (serverName != null && serverName.getStartcode() < 0) {<a name="line.404"></a>
+<span class="sourceLineNo">405</span> LOG.warn("Invalid log file path=" + logFile);<a name="line.405"></a>
+<span class="sourceLineNo">406</span> serverName = null;<a name="line.406"></a>
+<span class="sourceLineNo">407</span> }<a name="line.407"></a>
+<span class="sourceLineNo">408</span> return serverName;<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> public static boolean isMetaFile(Path p) {<a name="line.411"></a>
+<span class="sourceLineNo">412</span> return isMetaFile(p.getName());<a name="line.412"></a>
+<span class="sourceLineNo">413</span> }<a name="line.413"></a>
+<span class="sourceLineNo">414</span><a name="line.414"></a>
+<span class="sourceLineNo">415</span> public static boolean isMetaFile(String p) {<a name="line.415"></a>
+<span class="sourceLineNo">416</span> if (p != null && p.endsWith(META_WAL_PROVIDER_ID)) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span> return true;<a name="line.417"></a>
+<span class="sourceLineNo">418</span> }<a name="line.418"></a>
+<span class="sourceLineNo">419</span> return false;<a name="line.419"></a>
+<span class="sourceLineNo">420</span> }<a name="line.420"></a>
+<span class="sourceLineNo">421</span><a name="line.421"></a>
+<span class="sourceLineNo">422</span> public static boolean isArchivedLogFile(Path p) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span> String oldLog = Path.SEPARATOR + HConstants.HREGION_OLDLOGDIR_NAME + Path.SEPARATOR;<a name="line.423"></a>
+<span class="sourceLineNo">424</span> return p.toString().contains(oldLog);<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> * Get the archived WAL file path<a name="line.428"></a>
+<span class="sourceLineNo">429</span> * @param path - active WAL file path<a name="line.429"></a>
+<span class="sourceLineNo">430</span> * @param conf - configuration<a name="line.430"></a>
+<span class="sourceLineNo">431</span> * @return archived path if exists, path - otherwise<a name="line.431"></a>
+<span class="sourceLineNo">432</span> * @throws IOException exception<a name="line.432"></a>
+<span class="sourceLineNo">433</span> */<a name="line.433"></a>
+<span class="sourceLineNo">434</span> public static Path getArchivedLogPath(Path path, Configuration conf) throws IOException {<a name="line.434"></a>
+<span class="sourceLineNo">435</span> Path rootDir = FSUtils.getRootDir(conf);<a name="line.435"></a>
+<span class="sourceLineNo">436</span> Path oldLogDir = new Path(rootDir, HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.436"></a>
+<span class="sourceLineNo">437</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.437"></a>
+<span class="sourceLineNo">438</span> ServerName serverName = getServerNameFromWALDirectoryName(path);<a name="line.438"></a>
+<span class="sourceLineNo">439</span> if (serverName == null) {<a name="line.439"></a>
+<span class="sourceLineNo">440</span> LOG.error("Couldn't locate log: " + path);<a name="line.440"></a>
+<span class="sourceLineNo">441</span> return path;<a name="line.441"></a>
+<span class="sourceLineNo">442</span> }<a name="line.442"></a>
+<span class="sourceLineNo">443</span> oldLogDir = new Path(oldLogDir, serverName.getServerName());<a name="line.443"></a>
+<span class="sourceLineNo">444</span> }<a name="line.444"></a>
+<span class="sourceLineNo">445</sp
<TRUNCATED>
[15/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/checkstyle.rss
----------------------------------------------------------------------
diff --git a/checkstyle.rss b/checkstyle.rss
index bbe0bd1..3281d20 100644
--- a/checkstyle.rss
+++ b/checkstyle.rss
@@ -25,8 +25,8 @@ under the License.
<language>en-us</language>
<copyright>©2007 - 2018 The Apache Software Foundation</copyright>
<item>
- <title>File: 3812,
- Errors: 14996,
+ <title>File: 3813,
+ Errors: 14984,
Warnings: 0,
Infos: 0
</title>
@@ -7895,7 +7895,7 @@ under the License.
0
</td>
<td>
- 3
+ 1
</td>
</tr>
<tr>
@@ -8637,7 +8637,7 @@ under the License.
0
</td>
<td>
- 7
+ 1
</td>
</tr>
<tr>
@@ -13948,6 +13948,20 @@ under the License.
</tr>
<tr>
<td>
+ <a href="http://hbase.apache.org/checkstyle.html#org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.java">org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.java</a>
+ </td>
+ <td>
+ 0
+ </td>
+ <td>
+ 0
+ </td>
+ <td>
+ 0
+ </td>
+ </tr>
+ <tr>
+ <td>
<a href="http://hbase.apache.org/checkstyle.html#org.apache.hadoop.hbase.master.locking.TestLockProcedure.java">org/apache/hadoop/hbase/master/locking/TestLockProcedure.java</a>
</td>
<td>
@@ -32969,7 +32983,7 @@ under the License.
0
</td>
<td>
- 4
+ 2
</td>
</tr>
<tr>
@@ -38471,7 +38485,7 @@ under the License.
0
</td>
<td>
- 2
+ 0
</td>
</tr>
<tr>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/coc.html
----------------------------------------------------------------------
diff --git a/coc.html b/coc.html
index 2cf874b..c16dea3 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Code of Conduct Policy
@@ -385,7 +385,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/dependencies.html
----------------------------------------------------------------------
diff --git a/dependencies.html b/dependencies.html
index da88b26..6113d23 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Dependencies</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -450,7 +450,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/dependency-convergence.html
----------------------------------------------------------------------
diff --git a/dependency-convergence.html b/dependency-convergence.html
index ea3ce81..801c3c0 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Reactor Dependency Convergence</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -680,7 +680,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/dependency-info.html
----------------------------------------------------------------------
diff --git a/dependency-info.html b/dependency-info.html
index e40faa7..ab50b95 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Dependency Information</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -323,7 +323,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/dependency-management.html
----------------------------------------------------------------------
diff --git a/dependency-management.html b/dependency-management.html
index f5ddf99..04a76b6 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase – Project Dependency Management</title>
<link rel="stylesheet" href="./css/apache-maven-fluido-1.4-HBase.min.css" />
@@ -1009,7 +1009,7 @@
<a href="https://www.apache.org/">The Apache Software Foundation</a>.
All rights reserved.
- <li id="publishDate" class="pull-right">Last Published: 2018-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/constant-values.html
----------------------------------------------------------------------
diff --git a/devapidocs/constant-values.html b/devapidocs/constant-values.html
index b5207a8..bc36bfa 100644
--- a/devapidocs/constant-values.html
+++ b/devapidocs/constant-values.html
@@ -3824,7 +3824,7 @@
<!-- -->
</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>"Tue Nov 20 14:44:19 UTC 2018"</code></td>
+<td class="colLast"><code>"Wed Nov 21 14:44:11 UTC 2018"</code></td>
</tr>
<tr class="rowColor">
<td class="colFirst"><a name="org.apache.hadoop.hbase.Version.revision">
@@ -3838,7 +3838,7 @@
<!-- -->
</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>"05b800e0fa4b560f4e9c387e4d35888d"</code></td>
+<td class="colLast"><code>"1f80a990a945d9efd6b2cf79bf4adb13"</code></td>
</tr>
<tr class="rowColor">
<td class="colFirst"><a name="org.apache.hadoop.hbase.Version.url">
@@ -17524,6 +17524,20 @@
</tr>
<tbody>
<tr class="altColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.quotas.QuotaUtil.DEFAULT_READ_CAPACITY_UNIT">
+<!-- -->
+</a><code>public static final long</code></td>
+<td><code><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_READ_CAPACITY_UNIT">DEFAULT_READ_CAPACITY_UNIT</a></code></td>
+<td class="colLast"><code>1024L</code></td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.quotas.QuotaUtil.DEFAULT_WRITE_CAPACITY_UNIT">
+<!-- -->
+</a><code>public static final long</code></td>
+<td><code><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_WRITE_CAPACITY_UNIT">DEFAULT_WRITE_CAPACITY_UNIT</a></code></td>
+<td class="colLast"><code>1024L</code></td>
+</tr>
+<tr class="altColor">
<td class="colFirst"><a name="org.apache.hadoop.hbase.quotas.QuotaUtil.QUOTA_CONF_KEY">
<!-- -->
</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>
@@ -17537,6 +17551,20 @@
<td><code><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#QUOTA_ENABLED_DEFAULT">QUOTA_ENABLED_DEFAULT</a></code></td>
<td class="colLast"><code>false</code></td>
</tr>
+<tr class="altColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.quotas.QuotaUtil.READ_CAPACITY_UNIT_CONF_KEY">
+<!-- -->
+</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/quotas/QuotaUtil.html#READ_CAPACITY_UNIT_CONF_KEY">READ_CAPACITY_UNIT_CONF_KEY</a></code></td>
+<td class="colLast"><code>"hbase.quota.read.capacity.unit"</code></td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><a name="org.apache.hadoop.hbase.quotas.QuotaUtil.WRITE_CAPACITY_UNIT_CONF_KEY">
+<!-- -->
+</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/quotas/QuotaUtil.html#WRITE_CAPACITY_UNIT_CONF_KEY">WRITE_CAPACITY_UNIT_CONF_KEY</a></code></td>
+<td class="colLast"><code>"hbase.quota.write.capacity.unit"</code></td>
+</tr>
</tbody>
</table>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/index-all.html
----------------------------------------------------------------------
diff --git a/devapidocs/index-all.html b/devapidocs/index-all.html
index 3958ac3..11dc849 100644
--- a/devapidocs/index-all.html
+++ b/devapidocs/index-all.html
@@ -8521,6 +8521,10 @@
<dd>
<div class="block">Calculate size for cleaner pool.</div>
</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateReadCapacityUnit-long-">calculateReadCapacityUnit(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateReadCapacityUnitDiff-long-long-">calculateReadCapacityUnitDiff(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/replication/regionserver/ReplicationLoad.html#calculateReplicationDelay-long-long-int-">calculateReplicationDelay(long, long, int)</a></span> - Static method in class org.apache.hadoop.hbase.replication.regionserver.<a href="org/apache/hadoop/hbase/replication/regionserver/ReplicationLoad.html" title="class in org.apache.hadoop.hbase.replication.regionserver">ReplicationLoad</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#calculateResultSize-org.apache.hadoop.hbase.client.Result-">calculateResultSize(Result)</a></span> - Static method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html" title="class in org.apache.hadoop.hbase.quotas">QuotaUtil</a></dt>
@@ -8532,6 +8536,10 @@
<div class="block">When scanning for a prefix the scan should stop immediately after the the last row that
has the specified prefix.</div>
</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateWriteCapacityUnit-long-">calculateWriteCapacityUnit(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#calculateWriteCapacityUnitDiff-long-long-">calculateWriteCapacityUnitDiff(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/backup/regionserver/LogRollBackupSubprocedure.RSRollLogTask.html#call--">call()</a></span> - Method in class org.apache.hadoop.hbase.backup.regionserver.<a href="org/apache/hadoop/hbase/backup/regionserver/LogRollBackupSubprocedure.RSRollLogTask.html" title="class in org.apache.hadoop.hbase.backup.regionserver">LogRollBackupSubprocedure.RSRollLogTask</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/client/AsyncAdminRequestRetryingCaller.html#call--">call()</a></span> - Method in class org.apache.hadoop.hbase.client.<a href="org/apache/hadoop/hbase/client/AsyncAdminRequestRetryingCaller.html" title="class in org.apache.hadoop.hbase.client">AsyncAdminRequestRetryingCaller</a></dt>
@@ -10974,13 +10982,13 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopOperationQuota.html#checkQuota-int-int-int-">checkQuota(int, int, int)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">NoopOperationQuota</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota(long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota(long, long, long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/OperationQuota.html#checkQuota-int-int-int-">checkQuota(int, int, int)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/OperationQuota.html" title="interface in org.apache.hadoop.hbase.quotas">OperationQuota</a></dt>
<dd>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-">checkQuota(long, long, long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota(long, long, long, long, long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
<dd>
<div class="block">Checks if it is possible to execute the specified operation.</div>
</dd>
@@ -10996,7 +11004,7 @@
<dd>
<div class="block">Check the quota for the current (rpc-context) user.</div>
</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-">checkQuota(long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#checkQuota-long-long-long-long-long-long-">checkQuota(long, long, long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceWALReader.html#checkQuota--">checkQuota()</a></span> - Method in class org.apache.hadoop.hbase.replication.regionserver.<a href="org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceWALReader.html" title="class in org.apache.hadoop.hbase.replication.regionserver">ReplicationSourceWALReader</a></dt>
<dd> </dd>
@@ -17478,25 +17486,25 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/wal/AsyncFSWAL.html#consumer">consumer</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.wal.<a href="org/apache/hadoop/hbase/regionserver/wal/AsyncFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AsyncFSWAL</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeRead-long-">consumeRead(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeRead-long-long-">consumeRead(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-">consumeRead(long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeRead-long-long-">consumeRead(long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
<dd>
<div class="block">Removes or add back some read amount to the quota.</div>
</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeRead-long-">consumeRead(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeRead-long-long-">consumeRead(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html#consumerLoop-java.util.concurrent.BlockingQueue-">consumerLoop(BlockingQueue<HFileCleaner.HFileDeleteTask>)</a></span> - Method in class org.apache.hadoop.hbase.master.cleaner.<a href="org/apache/hadoop/hbase/master/cleaner/HFileCleaner.html" title="class in org.apache.hadoop.hbase.master.cleaner">HFileCleaner</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/regionserver/wal/AsyncFSWAL.html#consumerScheduled">consumerScheduled</a></span> - Variable in class org.apache.hadoop.hbase.regionserver.wal.<a href="org/apache/hadoop/hbase/regionserver/wal/AsyncFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AsyncFSWAL</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeWrite-long-">consumeWrite(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#consumeWrite-long-long-">consumeWrite(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-">consumeWrite(long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#consumeWrite-long-long-">consumeWrite(long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
<dd>
<div class="block">Removes or add back some write amount to the quota.</div>
</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeWrite-long-">consumeWrite(long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#consumeWrite-long-long-">consumeWrite(long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/util/LRUDictionary.BidirectionalLRUMap.ByteArrayBackedNode.html#container">container</a></span> - Variable in class org.apache.hadoop.hbase.io.util.<a href="org/apache/hadoop/hbase/io/util/LRUDictionary.BidirectionalLRUMap.ByteArrayBackedNode.html" title="class in org.apache.hadoop.hbase.io.util">LRUDictionary.BidirectionalLRUMap.ByteArrayBackedNode</a></dt>
<dd> </dd>
@@ -23866,6 +23874,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.RackLocalityCostFunction.html#DEFAULT_RACK_LOCALITY_COST">DEFAULT_RACK_LOCALITY_COST</a></span> - Static variable in class org.apache.hadoop.hbase.master.balancer.<a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.RackLocalityCostFunction.html" title="class in org.apache.hadoop.hbase.master.balancer">StochasticLoadBalancer.RackLocalityCostFunction</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_READ_CAPACITY_UNIT">DEFAULT_READ_CAPACITY_UNIT</a></span> - Static variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html" title="class in org.apache.hadoop.hbase.quotas">QuotaUtil</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.ReadRequestCostFunction.html#DEFAULT_READ_REQUEST_COST">DEFAULT_READ_REQUEST_COST</a></span> - Static variable in class org.apache.hadoop.hbase.master.balancer.<a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.ReadRequestCostFunction.html" title="class in org.apache.hadoop.hbase.master.balancer">StochasticLoadBalancer.ReadRequestCostFunction</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/client/TableDescriptorBuilder.html#DEFAULT_READONLY">DEFAULT_READONLY</a></span> - Static variable in class org.apache.hadoop.hbase.client.<a href="org/apache/hadoop/hbase/client/TableDescriptorBuilder.html" title="class in org.apache.hadoop.hbase.client">TableDescriptorBuilder</a></dt>
@@ -24189,6 +24199,8 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/procedure2/ProcedureExecutor.WorkerMonitor.html#DEFAULT_WORKER_STUCK_THRESHOLD">DEFAULT_WORKER_STUCK_THRESHOLD</a></span> - Static variable in class org.apache.hadoop.hbase.procedure2.<a href="org/apache/hadoop/hbase/procedure2/ProcedureExecutor.WorkerMonitor.html" title="class in org.apache.hadoop.hbase.procedure2">ProcedureExecutor.WorkerMonitor</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#DEFAULT_WRITE_CAPACITY_UNIT">DEFAULT_WRITE_CAPACITY_UNIT</a></span> - Static variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html" title="class in org.apache.hadoop.hbase.quotas">QuotaUtil</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/tool/Canary.RegionMonitor.html#DEFAULT_WRITE_DATA_TTL">DEFAULT_WRITE_DATA_TTL</a></span> - Static variable in class org.apache.hadoop.hbase.tool.<a href="org/apache/hadoop/hbase/tool/Canary.RegionMonitor.html" title="class in org.apache.hadoop.hbase.tool">Canary.RegionMonitor</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.WriteRequestCostFunction.html#DEFAULT_WRITE_REQUEST_COST">DEFAULT_WRITE_REQUEST_COST</a></span> - Static variable in class org.apache.hadoop.hbase.master.balancer.<a href="org/apache/hadoop/hbase/master/balancer/StochasticLoadBalancer.WriteRequestCostFunction.html" title="class in org.apache.hadoop.hbase.master.balancer">StochasticLoadBalancer.WriteRequestCostFunction</a></dt>
@@ -24309,9 +24321,9 @@
<dd> </dd>
<dt><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">DefaultOperationQuota</span></a> - Class in <a href="org/apache/hadoop/hbase/quotas/package-summary.html">org.apache.hadoop.hbase.quotas</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota(QuotaLimiter...)</a></span> - Constructor for class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-org.apache.hadoop.hbase.quotas.QuotaLimiter...-">DefaultOperationQuota(Configuration, QuotaLimiter...)</a></span> - Constructor for class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-java.util.List-">DefaultOperationQuota(List<QuotaLimiter>)</a></span> - Constructor for class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#DefaultOperationQuota-org.apache.hadoop.conf.Configuration-java.util.List-">DefaultOperationQuota(Configuration, List<QuotaLimiter>)</a></span> - Constructor for class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
<dd>
<div class="block">NOTE: The order matters.</div>
</dd>
@@ -55204,13 +55216,13 @@
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/io/hfile/bucket/BucketAllocator.html#grabGlobalCompletelyFreeBucket--">grabGlobalCompletelyFreeBucket()</a></span> - Method in class org.apache.hadoop.hbase.io.hfile.bucket.<a href="org/apache/hadoop/hbase/io/hfile/bucket/BucketAllocator.html" title="class in org.apache.hadoop.hbase.io.hfile.bucket">BucketAllocator</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota(long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota(long, long, long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/NoopQuotaLimiter.html" title="class in org.apache.hadoop.hbase.quotas">NoopQuotaLimiter</a></dt>
<dd> </dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-">grabQuota(long, long, long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota(long, long, long, long, long, long)</a></span> - Method in interface org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaLimiter.html" title="interface in org.apache.hadoop.hbase.quotas">QuotaLimiter</a></dt>
<dd>
<div class="block">Removes the specified write and read amount from the quota.</div>
</dd>
-<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#grabQuota-long-long-long-long-">grabQuota(long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#grabQuota-long-long-long-long-long-long-">grabQuota(long, long, long, long, long, long)</a></span> - Method in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/coordination/ZkSplitLogWorkerCoordination.html#grabTask-java.lang.String-">grabTask(String)</a></span> - Method in class org.apache.hadoop.hbase.coordination.<a href="org/apache/hadoop/hbase/coordination/ZkSplitLogWorkerCoordination.html" title="class in org.apache.hadoop.hbase.coordination">ZkSplitLogWorkerCoordination</a></dt>
<dd>
@@ -89280,6 +89292,8 @@ service.</div>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/ipc/SimpleServerRpcConnection.html#read4Bytes--">read4Bytes()</a></span> - Method in class org.apache.hadoop.hbase.ipc.<a href="org/apache/hadoop/hbase/ipc/SimpleServerRpcConnection.html" title="class in org.apache.hadoop.hbase.ipc">SimpleServerRpcConnection</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#READ_CAPACITY_UNIT_CONF_KEY">READ_CAPACITY_UNIT_CONF_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html" title="class in org.apache.hadoop.hbase.quotas">QuotaUtil</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html#READ_OPERATION_LATENCY_DESC">READ_OPERATION_LATENCY_DESC</a></span> - Static variable in interface org.apache.hadoop.hbase.zookeeper.<a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html" title="interface in org.apache.hadoop.hbase.zookeeper">MetricsZooKeeperSource</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html#READ_OPERATION_LATENCY_NAME">READ_OPERATION_LATENCY_NAME</a></span> - Static variable in interface org.apache.hadoop.hbase.zookeeper.<a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html" title="interface in org.apache.hadoop.hbase.zookeeper">MetricsZooKeeperSource</a></dt>
@@ -89407,6 +89421,12 @@ service.</div>
</dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/util/Bytes.html#readBytes-java.nio.ByteBuffer-">readBytes(ByteBuffer)</a></span> - Static method in class org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/Bytes.html" title="class in org.apache.hadoop.hbase.util">Bytes</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#readCapacityUnit">readCapacityUnit</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#readCapacityUnitConsumed">readCapacityUnitConsumed</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#readCapacityUnitLimiter">readCapacityUnitLimiter</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/mob/MobFile.html#readCell-org.apache.hadoop.hbase.Cell-boolean-">readCell(Cell, boolean)</a></span> - Method in class org.apache.hadoop.hbase.mob.<a href="org/apache/hadoop/hbase/mob/MobFile.html" title="class in org.apache.hadoop.hbase.mob">MobFile</a></dt>
<dd>
<div class="block">Reads a cell from the mob file.</div>
@@ -94738,6 +94758,8 @@ service.</div>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/client/MetricsConnection.html#REQ_BASE">REQ_BASE</a></span> - Static variable in class org.apache.hadoop.hbase.client.<a href="org/apache/hadoop/hbase/client/MetricsConnection.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#reqCapacityUnitLimiter">reqCapacityUnitLimiter</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/ipc/ServerCall.html#reqCleanup">reqCleanup</a></span> - Variable in class org.apache.hadoop.hbase.ipc.<a href="org/apache/hadoop/hbase/ipc/ServerCall.html" title="class in org.apache.hadoop.hbase.ipc">ServerCall</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/client/MetricsConnection.CallTracker.html#reqHist">reqHist</a></span> - Variable in class org.apache.hadoop.hbase.client.<a href="org/apache/hadoop/hbase/client/MetricsConnection.CallTracker.html" title="class in org.apache.hadoop.hbase.client">MetricsConnection.CallTracker</a></dt>
@@ -123458,7 +123480,8 @@ the order they are declared.</div>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#walCreateLock">walCreateLock</a></span> - Variable in class org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">AbstractFSWALProvider</a></dt>
<dd>
-<div class="block">we synchronized on walCreateLock to prevent wal recreation in different threads</div>
+<div class="block">We use walCreateLock to prevent wal recreation in different threads, and also prevent getWALs
+ missing the newly created WAL, see HBASE-21503 for more details.</div>
</dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.html#walDir">walDir</a></span> - Variable in class org.apache.hadoop.hbase.procedure2.store.wal.<a href="org/apache/hadoop/hbase/procedure2/store/wal/WALProcedureStore.html" title="class in org.apache.hadoop.hbase.procedure2.store.wal">WALProcedureStore</a></dt>
<dd> </dd>
@@ -124682,6 +124705,8 @@ the order they are declared.</div>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/client/ConnectionConfiguration.html#WRITE_BUFFER_SIZE_KEY">WRITE_BUFFER_SIZE_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.client.<a href="org/apache/hadoop/hbase/client/ConnectionConfiguration.html" title="class in org.apache.hadoop.hbase.client">ConnectionConfiguration</a></dt>
<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html#WRITE_CAPACITY_UNIT_CONF_KEY">WRITE_CAPACITY_UNIT_CONF_KEY</a></span> - Static variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/QuotaUtil.html" title="class in org.apache.hadoop.hbase.quotas">QuotaUtil</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html#WRITE_OPERATION_LATENCY_DESC">WRITE_OPERATION_LATENCY_DESC</a></span> - Static variable in interface org.apache.hadoop.hbase.zookeeper.<a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html" title="interface in org.apache.hadoop.hbase.zookeeper">MetricsZooKeeperSource</a></dt>
<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html#WRITE_OPERATION_LATENCY_NAME">WRITE_OPERATION_LATENCY_NAME</a></span> - Static variable in interface org.apache.hadoop.hbase.zookeeper.<a href="org/apache/hadoop/hbase/zookeeper/MetricsZooKeeperSource.html" title="interface in org.apache.hadoop.hbase.zookeeper">MetricsZooKeeperSource</a></dt>
@@ -124798,6 +124823,12 @@ the order they are declared.</div>
<dd>
<div class="block">Write byte-array from src to tgt with a vint length prefix.</div>
</dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#writeCapacityUnit">writeCapacityUnit</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html#writeCapacityUnitConsumed">writeCapacityUnitConsumed</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/DefaultOperationQuota.html" title="class in org.apache.hadoop.hbase.quotas">DefaultOperationQuota</a></dt>
+<dd> </dd>
+<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html#writeCapacityUnitLimiter">writeCapacityUnitLimiter</a></span> - Variable in class org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html" title="class in org.apache.hadoop.hbase.quotas">TimeBasedLimiter</a></dt>
+<dd> </dd>
<dt><span class="memberNameLink"><a href="org/apache/hadoop/hbase/PrivateCellUtil.html#writeCell-org.apache.hadoop.hbase.Cell-java.io.OutputStream-boolean-">writeCell(Cell, OutputStream, boolean)</a></span> - Static method in class org.apache.hadoop.hbase.<a href="org/apache/hadoop/hbase/PrivateCellUtil.html" title="class in org.apache.hadoop.hbase">PrivateCellUtil</a></dt>
<dd>
<div class="block">Writes the cell to the given OutputStream</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 44aeebe..06e7f45 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/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.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/BackupInfo.BackupState.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupInfo.BackupState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupType.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.backup.<a href="../../../../../org/apache/hadoop/hbase/backup/BackupRestoreConstants.BackupCommand.html" title="enum in org.apache.hadoop.hbase.backup"><span class="typeNameLink">BackupRestoreConstants.BackupCommand</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 2f02fa5..e802a67 100644
--- a/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/client/package-tree.html
@@ -555,24 +555,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/SnapshotType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">SnapshotType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/Durability.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Durability</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RequestController.ReturnCode.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RequestController.ReturnCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/CompactionState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">CompactionState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/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/MobCompactPartitionPolicy.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">MobCompactPartitionPolicy</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">AsyncScanSingleRegionRpcRetryingCaller.ScanControllerState</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.client.<a href="../../../../../org/apache/hadoop/hbase/client/RegionLocateType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">RegionLocateType</span></a></li>
-<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/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/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/Scan.ReadType.html" title="enum in org.apache.hadoop.hbase.client"><span class="typeNameLink">Scan.ReadType</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
index e67b778..329f62f 100644
--- a/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/coprocessor/package-tree.html
@@ -201,8 +201,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/MetaTableMetrics.MetaTableOps.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">MetaTableMetrics.MetaTableOps</span></a></li>
<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/RegionObserver.MutationType.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">RegionObserver.MutationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.coprocessor.<a href="../../../../../org/apache/hadoop/hbase/coprocessor/MetaTableMetrics.MetaTableOps.html" title="enum in org.apache.hadoop.hbase.coprocessor"><span class="typeNameLink">MetaTableMetrics.MetaTableOps</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 a4b54d0..9508e4f 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.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/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/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/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/RegexStringComparator.EngineType.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">RegexStringComparator.EngineType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/Filter.ReturnCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">Filter.ReturnCode</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.Order.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.Order</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FuzzyRowFilter.SatisfiesCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FuzzyRowFilter.SatisfiesCode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/BitComparator.BitwiseOp.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">BitComparator.BitwiseOp</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/RegexStringComparator.EngineType.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">RegexStringComparator.EngineType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterWrapper.FilterRowRetCode.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterWrapper.FilterRowRetCode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.filter.<a href="../../../../../org/apache/hadoop/hbase/filter/FilterList.Operator.html" title="enum in org.apache.hadoop.hbase.filter"><span class="typeNameLink">FilterList.Operator</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 7a95ff6..0a5f717 100644
--- a/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/io/hfile/package-tree.html
@@ -275,11 +275,11 @@
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/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/BlockType.BlockCategory.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockType.BlockCategory</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/BlockPriority.html" title="enum in org.apache.hadoop.hbase.io.hfile"><span class="typeNameLink">BlockPriority</span></a></li>
<li type="circle">org.apache.hadoop.hbase.io.hfile.<a href="../../../../../../org/apache/hadoop/hbase/io/hfile/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/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/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/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/de8c44eb/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 91a2ed4..427b9f5 100644
--- a/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/ipc/package-tree.html
@@ -354,8 +354,8 @@
<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/CallEvent.Type.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">CallEvent.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/BufferCallBeforeInitHandler.BufferCallAction.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">BufferCallBeforeInitHandler.BufferCallAction</span></a></li>
<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/MetricsHBaseServerSourceFactoryImpl.SourceStorage.html" title="enum in org.apache.hadoop.hbase.ipc"><span class="typeNameLink">MetricsHBaseServerSourceFactoryImpl.SourceStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.ipc.<a href="../../../../../org/apache/hadoop/hbase/ipc/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/de8c44eb/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 2e21581..c069040 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/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/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>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
index 1799704..abd92a9 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/balancer/package-tree.html
@@ -198,8 +198,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.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.LocalityType.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.LocalityType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.balancer.<a href="../../../../../../org/apache/hadoop/hbase/master/balancer/BaseLoadBalancer.Cluster.Action.Type.html" title="enum in org.apache.hadoop.hbase.master.balancer"><span class="typeNameLink">BaseLoadBalancer.Cluster.Action.Type</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 8184df1..8ec7e45 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/package-tree.html
@@ -347,11 +347,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/MasterRpcServices.BalanceSwitchMode.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MasterRpcServices.BalanceSwitchMode</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/MetricsMasterSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">MetricsMasterSourceFactoryImpl.FactoryStorage</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/SplitLogManager.ResubmitDirective.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.ResubmitDirective</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/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/SplitLogManager.TerminationStatus.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">SplitLogManager.TerminationStatus</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.<a href="../../../../../org/apache/hadoop/hbase/master/RegionState.State.html" title="enum in org.apache.hadoop.hbase.master"><span class="typeNameLink">RegionState.State</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 0bc680d..2991c16 100644
--- a/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/master/procedure/package-tree.html
@@ -215,10 +215,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.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MetaProcedureInterface.MetaOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">MetaProcedureInterface.MetaOperationType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/TableProcedureInterface.TableOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">TableProcedureInterface.TableOperationType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/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/PeerProcedureInterface.PeerOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">PeerProcedureInterface.PeerOperationType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.master.procedure.<a href="../../../../../../org/apache/hadoop/hbase/master/procedure/MetaProcedureInterface.MetaOperationType.html" title="enum in org.apache.hadoop.hbase.master.procedure"><span class="typeNameLink">MetaProcedureInterface.MetaOperationType</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 4b549da..7b435d2 100644
--- a/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/monitoring/package-tree.html
@@ -127,8 +127,8 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/de8c44eb/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 124a172..00dbbad 100644
--- a/devapidocs/org/apache/hadoop/hbase/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/package-tree.html
@@ -437,19 +437,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/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/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/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/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/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/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/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/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/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/CellBuilderType.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CellBuilderType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/Cell.Type.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Cell.Type</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/CompareOperator.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">CompareOperator</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/HealthChecker.HealthCheckerExitStatus.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">HealthChecker.HealthCheckerExitStatus</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.<a href="../../../../org/apache/hadoop/hbase/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/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/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/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/Coprocessor.State.html" title="enum in org.apache.hadoop.hbase"><span class="typeNameLink">Coprocessor.State</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 1c10e27..f6e32b6 100644
--- a/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/procedure2/package-tree.html
@@ -217,10 +217,10 @@
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/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>
[02/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html b/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
index e860fef..b648526 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html
@@ -18,7 +18,7 @@
catch(err) {
}
//-->
-var methods = {"i0":10,"i1":10,"i2":9,"i3":10,"i4":9,"i5":10,"i6":10,"i7":10,"i8":10,"i9":10,"i10":10,"i11":10,"i12":10,"i13":10,"i14":10,"i15":10,"i16":10,"i17":10,"i18":10,"i19":10,"i20":10,"i21":10};
+var methods = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":9,"i5":10,"i6":9,"i7":10,"i8":10,"i9":10,"i10":10,"i11":10,"i12":10,"i13":10,"i14":10,"i15":10,"i16":10,"i17":10,"i18":10,"i19":10,"i20":10,"i21":10,"i22":10,"i23":10,"i24":10,"i25":10};
var tabs = {65535:["t0","All Methods"],1:["t1","Static Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
@@ -204,70 +204,88 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>private int</code></td>
-<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#doPuts-int-org.apache.hadoop.hbase.client.Table...-">doPuts</a></span>(int maxOps,
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#doPuts-int-int-org.apache.hadoop.hbase.client.Table...-">doPuts</a></span>(int maxOps,
+ int valueSize,
org.apache.hadoop.hbase.client.Table... tables)</code> </td>
</tr>
<tr id="i2" class="altColor">
+<td class="colFirst"><code>private int</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#doPuts-int-org.apache.hadoop.hbase.client.Table...-">doPuts</a></span>(int maxOps,
+ org.apache.hadoop.hbase.client.Table... tables)</code> </td>
+</tr>
+<tr id="i3" class="rowColor">
+<td class="colFirst"><code>private byte[]</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#generateValue-int-">generateValue</a></span>(int valueSize)</code> </td>
+</tr>
+<tr id="i4" class="altColor">
<td class="colFirst"><code>static void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#setUpBeforeClass--">setUpBeforeClass</a></span>()</code> </td>
</tr>
-<tr id="i3" class="rowColor">
+<tr id="i5" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#tearDown--">tearDown</a></span>()</code> </td>
</tr>
-<tr id="i4" class="altColor">
+<tr id="i6" class="altColor">
<td class="colFirst"><code>static void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#tearDownAfterClass--">tearDownAfterClass</a></span>()</code> </td>
</tr>
-<tr id="i5" class="rowColor">
+<tr id="i7" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testNamespaceGlobalReadAndWriteThrottle--">testNamespaceGlobalReadAndWriteThrottle</a></span>()</code> </td>
</tr>
-<tr id="i6" class="altColor">
+<tr id="i8" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testNamespaceGlobalThrottle--">testNamespaceGlobalThrottle</a></span>()</code> </td>
</tr>
-<tr id="i7" class="rowColor">
+<tr id="i9" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableGlobalReadAndWriteThrottle--">testTableGlobalReadAndWriteThrottle</a></span>()</code> </td>
</tr>
-<tr id="i8" class="altColor">
+<tr id="i10" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableGlobalThrottle--">testTableGlobalThrottle</a></span>()</code> </td>
</tr>
-<tr id="i9" class="rowColor">
+<tr id="i11" class="rowColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableReadCapacityUnitThrottle--">testTableReadCapacityUnitThrottle</a></span>()</code> </td>
+</tr>
+<tr id="i12" class="altColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testTableWriteCapacityUnitThrottle--">testTableWriteCapacityUnitThrottle</a></span>()</code> </td>
+</tr>
+<tr id="i13" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserAndTableThrottle--">testUserAndTableThrottle</a></span>()</code> </td>
</tr>
-<tr id="i10" class="altColor">
+<tr id="i14" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserGlobalBypassThrottle--">testUserGlobalBypassThrottle</a></span>()</code> </td>
</tr>
-<tr id="i11" class="rowColor">
+<tr id="i15" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserGlobalReadAndWriteThrottle--">testUserGlobalReadAndWriteThrottle</a></span>()</code> </td>
</tr>
-<tr id="i12" class="altColor">
+<tr id="i16" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserGlobalThrottle--">testUserGlobalThrottle</a></span>()</code> </td>
</tr>
-<tr id="i13" class="rowColor">
+<tr id="i17" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserNamespaceReadAndWriteThrottle--">testUserNamespaceReadAndWriteThrottle</a></span>()</code> </td>
</tr>
-<tr id="i14" class="altColor">
+<tr id="i18" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserNamespaceThrottle--">testUserNamespaceThrottle</a></span>()</code> </td>
</tr>
-<tr id="i15" class="rowColor">
+<tr id="i19" class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserTableReadAndWriteThrottle--">testUserTableReadAndWriteThrottle</a></span>()</code> </td>
</tr>
-<tr id="i16" class="altColor">
+<tr id="i20" class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#testUserTableThrottle--">testUserTableThrottle</a></span>()</code> </td>
</tr>
-<tr id="i17" class="rowColor">
+<tr id="i21" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#triggerCacheRefresh-boolean-boolean-boolean-boolean-org.apache.hadoop.hbase.TableName...-">triggerCacheRefresh</a></span>(boolean bypass,
boolean userLimiter,
@@ -275,22 +293,22 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
boolean nsLimiter,
org.apache.hadoop.hbase.TableName... tables)</code> </td>
</tr>
-<tr id="i18" class="altColor">
+<tr id="i22" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#triggerNamespaceCacheRefresh-boolean-org.apache.hadoop.hbase.TableName...-">triggerNamespaceCacheRefresh</a></span>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)</code> </td>
</tr>
-<tr id="i19" class="rowColor">
+<tr id="i23" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#triggerTableCacheRefresh-boolean-org.apache.hadoop.hbase.TableName...-">triggerTableCacheRefresh</a></span>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)</code> </td>
</tr>
-<tr id="i20" class="altColor">
+<tr id="i24" class="altColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#triggerUserCacheRefresh-boolean-org.apache.hadoop.hbase.TableName...-">triggerUserCacheRefresh</a></span>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)</code> </td>
</tr>
-<tr id="i21" class="rowColor">
+<tr id="i25" class="rowColor">
<td class="colFirst"><code>private void</code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#waitMinuteQuota--">waitMinuteQuota</a></span>()</code> </td>
</tr>
@@ -636,13 +654,57 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</dl>
</li>
</ul>
+<a name="testTableWriteCapacityUnitThrottle--">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>testTableWriteCapacityUnitThrottle</h4>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.513">testTableWriteCapacityUnitThrottle</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>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
+<a name="testTableReadCapacityUnitThrottle--">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>testTableReadCapacityUnitThrottle</h4>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.534">testTableReadCapacityUnitThrottle</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>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
<a name="doPuts-int-org.apache.hadoop.hbase.client.Table...-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>doPuts</h4>
-<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.512">doPuts</a>(int maxOps,
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.556">doPuts</a>(int maxOps,
+ org.apache.hadoop.hbase.client.Table... tables)
+ 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>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
+<a name="doPuts-int-int-org.apache.hadoop.hbase.client.Table...-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>doPuts</h4>
+<pre>private int <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.560">doPuts</a>(int maxOps,
+ int valueSize,
org.apache.hadoop.hbase.client.Table... tables)
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>
@@ -651,13 +713,22 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</dl>
</li>
</ul>
+<a name="generateValue-int-">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>generateValue</h4>
+<pre>private byte[] <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.583">generateValue</a>(int valueSize)</pre>
+</li>
+</ul>
<a name="doGets-int-org.apache.hadoop.hbase.client.Table...-">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>doGets</h4>
-<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.529">doGets</a>(int maxOps,
+<pre>private long <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.591">doGets</a>(int maxOps,
org.apache.hadoop.hbase.client.Table... tables)
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>
@@ -672,7 +743,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>triggerUserCacheRefresh</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.545">triggerUserCacheRefresh</a>(boolean bypass,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.607">triggerUserCacheRefresh</a>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)
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>
@@ -687,7 +758,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>triggerTableCacheRefresh</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.549">triggerTableCacheRefresh</a>(boolean bypass,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.611">triggerTableCacheRefresh</a>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)
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>
@@ -702,7 +773,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>triggerNamespaceCacheRefresh</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.553">triggerNamespaceCacheRefresh</a>(boolean bypass,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.615">triggerNamespaceCacheRefresh</a>(boolean bypass,
org.apache.hadoop.hbase.TableName... tables)
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>
@@ -717,7 +788,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>triggerCacheRefresh</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.557">triggerCacheRefresh</a>(boolean bypass,
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.619">triggerCacheRefresh</a>(boolean bypass,
boolean userLimiter,
boolean tableLimiter,
boolean nsLimiter,
@@ -735,7 +806,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>waitMinuteQuota</h4>
-<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.602">waitMinuteQuota</a>()</pre>
+<pre>private void <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html#line.664">waitMinuteQuota</a>()</pre>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html b/testdevapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
index f85d0ea..7c63b00 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -701,11 +701,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.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestMultiLogThreshold.ActionType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestMultiLogThreshold.ActionType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestAtomicOperation.TestStep.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestAtomicOperation.TestStep</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestRegionServerReadRequestMetrics.Metric.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestRegionServerReadRequestMetrics.Metric</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestCacheOnWriteInSchema.CacheOnWriteType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestCacheOnWriteInSchema.CacheOnWriteType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestMultiLogThreshold.ActionType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestMultiLogThreshold.ActionType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/DataBlockEncodingTool.Manipulation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">DataBlockEncodingTool.Manipulation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestRegionServerReadRequestMetrics.Metric.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestRegionServerReadRequestMetrics.Metric</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/TestAtomicOperation.TestStep.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">TestAtomicOperation.TestStep</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/test/package-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/test/package-tree.html b/testdevapidocs/org/apache/hadoop/hbase/test/package-tree.html
index a45e794..1bd5f18 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/test/package-tree.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/test/package-tree.html
@@ -253,10 +253,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.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestBigLinkedList.Verify.Counts.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestBigLinkedList.Verify.Counts</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestBigLinkedList.Generator.Counts.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestBigLinkedList.Generator.Counts</span></a></li>
<li type="circle">org.apache.hadoop.hbase.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestWithCellVisibilityLoadAndVerify.Counters.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestWithCellVisibilityLoadAndVerify.Counters</span></a></li>
<li type="circle">org.apache.hadoop.hbase.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestLoadAndVerify.Counters.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestLoadAndVerify.Counters</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestBigLinkedList.Generator.Counts.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestBigLinkedList.Generator.Counts</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.test.<a href="../../../../../org/apache/hadoop/hbase/test/IntegrationTestBigLinkedList.Verify.Counts.html" title="enum in org.apache.hadoop.hbase.test"><span class="typeNameLink">IntegrationTestBigLinkedList.Verify.Counts</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/TestFSHLogProvider.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/TestFSHLogProvider.html b/testdevapidocs/org/apache/hadoop/hbase/wal/TestFSHLogProvider.html
index 8b78d88..eb75cbb 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/wal/TestFSHLogProvider.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/TestFSHLogProvider.html
@@ -50,7 +50,7 @@ var activeTableTab = "activeTableTab";
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestDisabledWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
-<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" target="_top">Frames</a></li>
@@ -580,7 +580,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<div class="subNav">
<ul class="navList">
<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestDisabledWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
-<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" target="_top">Frames</a></li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html b/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
new file mode 100644
index 0000000..e0e06fc
--- /dev/null
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
@@ -0,0 +1,365 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc -->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>TestRaceBetweenGetWALAndGetWALs.FSWALProvider (Apache HBase 3.0.0-SNAPSHOT Test API)</title>
+<link rel="stylesheet" type="text/css" href="../../../../../stylesheet.css" title="Style">
+<script type="text/javascript" src="../../../../../script.js"></script>
+</head>
+<body>
+<script type="text/javascript"><!--
+ try {
+ if (location.href.indexOf('is-external=true') == -1) {
+ parent.document.title="TestRaceBetweenGetWALAndGetWALs.FSWALProvider (Apache HBase 3.0.0-SNAPSHOT Test API)";
+ }
+ }
+ catch(err) {
+ }
+//-->
+var methods = {"i0":10,"i1":10};
+var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
+var altColor = "altColor";
+var rowColor = "rowColor";
+var tableTab = "tableTab";
+var activeTableTab = "activeTableTab";
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar.top">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.top.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_top");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary: </li>
+<li><a href="#nested.classes.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">Nested</a> | </li>
+<li><a href="#fields.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">Field</a> | </li>
+<li><a href="#constructor.summary">Constr</a> | </li>
+<li><a href="#method.summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail: </li>
+<li>Field | </li>
+<li><a href="#constructor.detail">Constr</a> | </li>
+<li><a href="#method.detail">Method</a></li>
+</ul>
+</div>
+<a name="skip.navbar.top">
+<!-- -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.hadoop.hbase.wal</div>
+<h2 title="Class TestRaceBetweenGetWALAndGetWALs.FSWALProvider" class="title">Class TestRaceBetweenGetWALAndGetWALs.FSWALProvider</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.hadoop.hbase.wal.AbstractFSWALProvider<org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?>></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<dl>
+<dt>All Implemented Interfaces:</dt>
+<dd>org.apache.hadoop.hbase.wal.WALProvider</dd>
+</dl>
+<dl>
+<dt>Enclosing class:</dt>
+<dd><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></dd>
+</dl>
+<hr>
+<br>
+<pre>private static final class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.53">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a>
+extends org.apache.hadoop.hbase.wal.AbstractFSWALProvider<org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?>></pre>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== NESTED CLASS SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="nested.class.summary">
+<!-- -->
+</a>
+<h3>Nested Class Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a name="nested.classes.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">
+<!-- -->
+</a>
+<h3>Nested classes/interfaces inherited from class org.apache.hadoop.hbase.wal.AbstractFSWALProvider</h3>
+<code>org.apache.hadoop.hbase.wal.AbstractFSWALProvider.Reader</code></li>
+</ul>
+<ul class="blockList">
+<li class="blockList"><a name="nested.classes.inherited.from.class.org.apache.hadoop.hbase.wal.WALProvider">
+<!-- -->
+</a>
+<h3>Nested classes/interfaces inherited from interface org.apache.hadoop.hbase.wal.WALProvider</h3>
+<code>org.apache.hadoop.hbase.wal.WALProvider.AsyncWriter, org.apache.hadoop.hbase.wal.WALProvider.Writer, org.apache.hadoop.hbase.wal.WALProvider.WriterBase</code></li>
+</ul>
+</li>
+</ul>
+<!-- =========== FIELD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="field.summary">
+<!-- -->
+</a>
+<h3>Field Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a name="fields.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">
+<!-- -->
+</a>
+<h3>Fields inherited from class org.apache.hadoop.hbase.wal.AbstractFSWALProvider</h3>
+<code>conf, DEFAULT_PROVIDER_ID, DEFAULT_SEPARATE_OLDLOGDIR, factory, initialized, listeners, logPrefix, META_WAL_PROVIDER_ID, providerId, SEPARATE_OLDLOGDIR, SPLITTING_EXT, wal, WAL_FILE_NAME_DELIMITER</code></li>
+</ul>
+</li>
+</ul>
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor.summary">
+<!-- -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd"> </span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier</th>
+<th class="colLast" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private </code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#FSWALProvider--">FSWALProvider</a></span>()</code> </td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method.summary">
+<!-- -->
+</a>
+<h3>Method Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
+<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd"> </span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd"> </span></span><span id="t4" class="tableTab"><span><a href="javascript:show(8);">Concrete Methods</a></span><span class="tabEnd"> </span></span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr id="i0" class="altColor">
+<td class="colFirst"><code>protected org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#createWAL--">createWAL</a></span>()</code> </td>
+</tr>
+<tr id="i1" class="rowColor">
+<td class="colFirst"><code>protected void</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#doInit-org.apache.hadoop.conf.Configuration-">doInit</a></span>(org.apache.hadoop.conf.Configuration conf)</code> </td>
+</tr>
+</table>
+<ul class="blockList">
+<li class="blockList"><a name="methods.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">
+<!-- -->
+</a>
+<h3>Methods inherited from class org.apache.hadoop.hbase.wal.AbstractFSWALProvider</h3>
+<code>addWALActionsListener, close, extractFileNumFromWAL, getArchivedLogPath, getCurrentFileName, getLogFileSize, getLogFileSize, getNumLogFiles, getNumRolledLogFiles, getServerNameFromWALDirectoryName, getServerNameFromWALDirectoryName, getWAL, getWALArchiveDirectoryName, getWALDirectoryName, getWALPrefixFromWALName, getWALs, getWALStartTimeFromWALName, init, isArchivedLogFile, isMetaFile, isMetaFile, openReader, requestLogRoll, shutdown, validateWALFilename</code></li>
+</ul>
+<ul class="blockList">
+<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
+<!-- -->
+</a>
+<h3>Methods inherited from class java.lang.<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></h3>
+<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#clone--" title="class or interface in java.lang">clone</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#equals-java.lang.Object-" title="class or interface in java.lang">equals</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#finalize--" title="class or interface in java.lang">finalize</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#getClass--" title="class or interface in java.lang">getClass</a>, <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>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notify--" title="class or interface in java.lang">notify</a>, <a href="https://docs.oracle.com/javase/8/docs/api/ja
va/lang/Object.html?is-external=true#notifyAll--" title="class or interface in java.lang">notifyAll</a>, <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>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait--" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-int-" title="class or interface in java.lang">wait</a></code></li>
+</ul>
+<ul class="blockList">
+<li class="blockList"><a name="methods.inherited.from.class.org.apache.hadoop.hbase.wal.WALProvider">
+<!-- -->
+</a>
+<h3>Methods inherited from interface org.apache.hadoop.hbase.wal.WALProvider</h3>
+<code>getWALFileLengthProvider</code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor.detail">
+<!-- -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="FSWALProvider--">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>FSWALProvider</h4>
+<pre>private <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#line.53">FSWALProvider</a>()</pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method.detail">
+<!-- -->
+</a>
+<h3>Method Detail</h3>
+<a name="createWAL--">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>createWAL</h4>
+<pre>protected org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#line.56">createWAL</a>()
+ throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
+<dl>
+<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
+<dd><code>createWAL</code> in class <code>org.apache.hadoop.hbase.wal.AbstractFSWALProvider<org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?>></code></dd>
+<dt><span class="throwsLabel">Throws:</span></dt>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
+<a name="doInit-org.apache.hadoop.conf.Configuration-">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>doInit</h4>
+<pre>protected void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html#line.66">doInit</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="overrideSpecifyLabel">Specified by:</span></dt>
+<dd><code>doInit</code> in class <code>org.apache.hadoop.hbase.wal.AbstractFSWALProvider<org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL<?>></code></dd>
+<dt><span class="throwsLabel">Throws:</span></dt>
+<dd><code><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></code></dd>
+</dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar.bottom">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.bottom.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_bottom");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary: </li>
+<li><a href="#nested.classes.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">Nested</a> | </li>
+<li><a href="#fields.inherited.from.class.org.apache.hadoop.hbase.wal.AbstractFSWALProvider">Field</a> | </li>
+<li><a href="#constructor.summary">Constr</a> | </li>
+<li><a href="#method.summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail: </li>
+<li>Field | </li>
+<li><a href="#constructor.detail">Constr</a> | </li>
+<li><a href="#method.detail">Method</a></li>
+</ul>
+</div>
+<a name="skip.navbar.bottom">
+<!-- -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright © 2007–2018 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
+</body>
+</html>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html b/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
new file mode 100644
index 0000000..fda26ba
--- /dev/null
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html
@@ -0,0 +1,350 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc -->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>TestRaceBetweenGetWALAndGetWALs (Apache HBase 3.0.0-SNAPSHOT Test API)</title>
+<link rel="stylesheet" type="text/css" href="../../../../../stylesheet.css" title="Style">
+<script type="text/javascript" src="../../../../../script.js"></script>
+</head>
+<body>
+<script type="text/javascript"><!--
+ try {
+ if (location.href.indexOf('is-external=true') == -1) {
+ parent.document.title="TestRaceBetweenGetWALAndGetWALs (Apache HBase 3.0.0-SNAPSHOT Test API)";
+ }
+ }
+ catch(err) {
+ }
+//-->
+var methods = {"i0":10};
+var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete Methods"]};
+var altColor = "altColor";
+var rowColor = "rowColor";
+var tableTab = "tableTab";
+var activeTableTab = "activeTableTab";
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar.top">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.top.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/TestRaceBetweenGetWALAndGetWALs.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_top");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary: </li>
+<li><a href="#nested.class.summary">Nested</a> | </li>
+<li><a href="#field.summary">Field</a> | </li>
+<li><a href="#constructor.summary">Constr</a> | </li>
+<li><a href="#method.summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail: </li>
+<li><a href="#field.detail">Field</a> | </li>
+<li><a href="#constructor.detail">Constr</a> | </li>
+<li><a href="#method.detail">Method</a></li>
+</ul>
+</div>
+<a name="skip.navbar.top">
+<!-- -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.hadoop.hbase.wal</div>
+<h2 title="Class TestRaceBetweenGetWALAndGetWALs" class="title">Class TestRaceBetweenGetWALAndGetWALs</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<hr>
+<br>
+<pre>public class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.45">TestRaceBetweenGetWALAndGetWALs</a>
+extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a></pre>
+<div class="block">Testcase for HBASE-21503.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== NESTED CLASS SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="nested.class.summary">
+<!-- -->
+</a>
+<h3>Nested Class Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Nested Class Summary table, listing nested classes, and an explanation">
+<caption><span>Nested Classes</span><span class="tabEnd"> </span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Class and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>private static class </code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></span></code> </td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- =========== FIELD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="field.summary">
+<!-- -->
+</a>
+<h3>Field Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Field Summary table, listing fields, and an explanation">
+<caption><span>Fields</span><span class="tabEnd"> </span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Field and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>static <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#CLASS_RULE">CLASS_RULE</a></span></code> </td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Future.html?is-external=true" title="class or interface in java.util.concurrent">Future</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.wal.WAL>></code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#GET_WALS_FUTURE">GET_WALS_FUTURE</a></span></code> </td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor.summary">
+<!-- -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd"> </span></caption>
+<tr>
+<th class="colOne" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#TestRaceBetweenGetWALAndGetWALs--">TestRaceBetweenGetWALAndGetWALs</a></span>()</code> </td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method.summary">
+<!-- -->
+</a>
+<h3>Method Summary</h3>
+<table class="memberSummary" border="0" cellpadding="3" cellspacing="0" summary="Method Summary table, listing methods, and an explanation">
+<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd"> </span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd"> </span></span><span id="t4" class="tableTab"><span><a href="javascript:show(8);">Concrete Methods</a></span><span class="tabEnd"> </span></span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr id="i0" class="altColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#testRace--">testRace</a></span>()</code> </td>
+</tr>
+</table>
+<ul class="blockList">
+<li class="blockList"><a name="methods.inherited.from.class.java.lang.Object">
+<!-- -->
+</a>
+<h3>Methods inherited from class java.lang.<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></h3>
+<code><a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#clone--" title="class or interface in java.lang">clone</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#equals-java.lang.Object-" title="class or interface in java.lang">equals</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#finalize--" title="class or interface in java.lang">finalize</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#getClass--" title="class or interface in java.lang">getClass</a>, <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>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#notify--" title="class or interface in java.lang">notify</a>, <a href="https://docs.oracle.com/javase/8/docs/api/ja
va/lang/Object.html?is-external=true#notifyAll--" title="class or interface in java.lang">notifyAll</a>, <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>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait--" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-" title="class or interface in java.lang">wait</a>, <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true#wait-long-int-" title="class or interface in java.lang">wait</a></code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ============ FIELD DETAIL =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="field.detail">
+<!-- -->
+</a>
+<h3>Field Detail</h3>
+<a name="CLASS_RULE">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>CLASS_RULE</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/HBaseClassTestRule.html" title="class in org.apache.hadoop.hbase">HBaseClassTestRule</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.48">CLASS_RULE</a></pre>
+</li>
+</ul>
+<a name="GET_WALS_FUTURE">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>GET_WALS_FUTURE</h4>
+<pre>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Future.html?is-external=true" title="class or interface in java.util.concurrent">Future</a><<a href="https://docs.oracle.com/javase/8/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a><org.apache.hadoop.hbase.wal.WAL>> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.51">GET_WALS_FUTURE</a></pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor.detail">
+<!-- -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="TestRaceBetweenGetWALAndGetWALs--">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>TestRaceBetweenGetWALAndGetWALs</h4>
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.45">TestRaceBetweenGetWALAndGetWALs</a>()</pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method.detail">
+<!-- -->
+</a>
+<h3>Method Detail</h3>
+<a name="testRace--">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>testRace</h4>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html#line.71">testRace</a>()
+ throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a>,
+ <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/InterruptedException.html?is-external=true" title="class or interface in java.lang">InterruptedException</a>,
+ <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutionException.html?is-external=true" title="class or interface in java.util.concurrent">ExecutionException</a></pre>
+<dl>
+<dt><span class="throwsLabel">Throws:</span></dt>
+<dd><code><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></code></dd>
+<dd><code><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></code></dd>
+<dd><code><a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ExecutionException.html?is-external=true" title="class or interface in java.util.concurrent">ExecutionException</a></code></dd>
+</dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar.bottom">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.bottom.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/TestRaceBetweenGetWALAndGetWALs.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../index.html?org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_bottom");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary: </li>
+<li><a href="#nested.class.summary">Nested</a> | </li>
+<li><a href="#field.summary">Field</a> | </li>
+<li><a href="#constructor.summary">Constr</a> | </li>
+<li><a href="#method.summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail: </li>
+<li><a href="#field.detail">Field</a> | </li>
+<li><a href="#constructor.detail">Constr</a> | </li>
+<li><a href="#method.detail">Method</a></li>
+</ul>
+</div>
+<a name="skip.navbar.bottom">
+<!-- -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright © 2007–2018 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
+</body>
+</html>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html b/testdevapidocs/org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html
index fa914af..de2977d 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html
@@ -49,7 +49,7 @@ var activeTableTab = "activeTableTab";
</div>
<div class="subNav">
<ul class="navList">
-<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestSecureWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
</ul>
<ul class="navList">
@@ -355,7 +355,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
</div>
<div class="subNav">
<ul class="navList">
-<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
+<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Prev Class</span></a></li>
<li><a href="../../../../../org/apache/hadoop/hbase/wal/TestSecureWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">Next Class</span></a></li>
</ul>
<ul class="navList">
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html b/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
new file mode 100644
index 0000000..b560e62
--- /dev/null
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html
@@ -0,0 +1,125 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc -->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider (Apache HBase 3.0.0-SNAPSHOT Test API)</title>
+<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
+<script type="text/javascript" src="../../../../../../script.js"></script>
+</head>
+<body>
+<script type="text/javascript"><!--
+ try {
+ if (location.href.indexOf('is-external=true') == -1) {
+ parent.document.title="Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider (Apache HBase 3.0.0-SNAPSHOT Test API)";
+ }
+ }
+ catch(err) {
+ }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar.top">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.top.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../../overview-summary.html">Overview</a></li>
+<li><a href="../package-summary.html">Package</a></li>
+<li><a href="../../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">Class</a></li>
+<li class="navBarCell1Rev">Use</li>
+<li><a href="../../../../../../overview-tree.html">Tree</a></li>
+<li><a href="../../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li>Prev</li>
+<li>Next</li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../../index.html?org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_top");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<a name="skip.navbar.top">
+<!-- -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<div class="header">
+<h2 title="Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider" class="title">Uses of Class<br>org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider</h2>
+</div>
+<div class="classUseContainer">No usage of org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs.FSWALProvider</div>
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar.bottom">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.bottom.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../../overview-summary.html">Overview</a></li>
+<li><a href="../package-summary.html">Package</a></li>
+<li><a href="../../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">Class</a></li>
+<li class="navBarCell1Rev">Use</li>
+<li><a href="../../../../../../overview-tree.html">Tree</a></li>
+<li><a href="../../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li>Prev</li>
+<li>Next</li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../../index.html?org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_bottom");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<a name="skip.navbar.bottom">
+<!-- -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright © 2007–2018 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
+</body>
+</html>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html b/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html
new file mode 100644
index 0000000..ec983d1
--- /dev/null
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html
@@ -0,0 +1,125 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc -->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs (Apache HBase 3.0.0-SNAPSHOT Test API)</title>
+<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
+<script type="text/javascript" src="../../../../../../script.js"></script>
+</head>
+<body>
+<script type="text/javascript"><!--
+ try {
+ if (location.href.indexOf('is-external=true') == -1) {
+ parent.document.title="Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs (Apache HBase 3.0.0-SNAPSHOT Test API)";
+ }
+ }
+ catch(err) {
+ }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar.top">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.top.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../../overview-summary.html">Overview</a></li>
+<li><a href="../package-summary.html">Package</a></li>
+<li><a href="../../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">Class</a></li>
+<li class="navBarCell1Rev">Use</li>
+<li><a href="../../../../../../overview-tree.html">Tree</a></li>
+<li><a href="../../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li>Prev</li>
+<li>Next</li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../../index.html?org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_top");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<a name="skip.navbar.top">
+<!-- -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<div class="header">
+<h2 title="Uses of Class org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs" class="title">Uses of Class<br>org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs</h2>
+</div>
+<div class="classUseContainer">No usage of org.apache.hadoop.hbase.wal.TestRaceBetweenGetWALAndGetWALs</div>
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar.bottom">
+<!-- -->
+</a>
+<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
+<a name="navbar.bottom.firstrow">
+<!-- -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../../../overview-summary.html">Overview</a></li>
+<li><a href="../package-summary.html">Package</a></li>
+<li><a href="../../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">Class</a></li>
+<li class="navBarCell1Rev">Use</li>
+<li><a href="../../../../../../overview-tree.html">Tree</a></li>
+<li><a href="../../../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../../../index-all.html">Index</a></li>
+<li><a href="../../../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li>Prev</li>
+<li>Next</li>
+</ul>
+<ul class="navList">
+<li><a href="../../../../../../index.html?org/apache/hadoop/hbase/wal/class-use/TestRaceBetweenGetWALAndGetWALs.html" target="_top">Frames</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+ allClassesLink = document.getElementById("allclasses_navbar_bottom");
+ if(window==top) {
+ allClassesLink.style.display = "block";
+ }
+ else {
+ allClassesLink.style.display = "none";
+ }
+ //-->
+</script>
+</div>
+<a name="skip.navbar.bottom">
+<!-- -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright © 2007–2018 <a href="https://www.apache.org/">The Apache Software Foundation</a>. All rights reserved.</small></p>
+</body>
+</html>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/package-frame.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/package-frame.html b/testdevapidocs/org/apache/hadoop/hbase/wal/package-frame.html
index 84f805d..a7a433e 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/wal/package-frame.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/package-frame.html
@@ -20,6 +20,8 @@
<li><a href="TestBoundedRegionGroupingStrategy.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestBoundedRegionGroupingStrategy</a></li>
<li><a href="TestDisabledWAL.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestDisabledWAL</a></li>
<li><a href="TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestFSHLogProvider</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestRaceBetweenGetWALAndGetWALs</a></li>
+<li><a href="TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></li>
<li><a href="TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestReadWriteSeqIdFiles</a></li>
<li><a href="TestSecureWAL.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestSecureWAL</a></li>
<li><a href="TestSyncReplicationWALProvider.html" title="class in org.apache.hadoop.hbase.wal" target="classFrame">TestSyncReplicationWALProvider</a></li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/package-summary.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/package-summary.html b/testdevapidocs/org/apache/hadoop/hbase/wal/package-summary.html
index 053376b..adaea9e 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/wal/package-summary.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/package-summary.html
@@ -118,6 +118,16 @@
<td class="colLast"> </td>
</tr>
<tr class="rowColor">
+<td class="colFirst"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs</a></td>
+<td class="colLast">
+<div class="block">Testcase for HBASE-21503.</div>
+</td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</a></td>
+<td class="colLast"> </td>
+</tr>
+<tr class="rowColor">
<td class="colFirst"><a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal">TestReadWriteSeqIdFiles</a></td>
<td class="colLast"> </td>
</tr>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/org/apache/hadoop/hbase/wal/package-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/org/apache/hadoop/hbase/wal/package-tree.html b/testdevapidocs/org/apache/hadoop/hbase/wal/package-tree.html
index fa9e769..f62b3ca 100644
--- a/testdevapidocs/org/apache/hadoop/hbase/wal/package-tree.html
+++ b/testdevapidocs/org/apache/hadoop/hbase/wal/package-tree.html
@@ -91,6 +91,11 @@
</li>
</ul>
</li>
+<li type="circle">org.apache.hadoop.hbase.wal.AbstractFSWALProvider<T> (implements org.apache.hadoop.hbase.wal.WALProvider)
+<ul>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</span></a></li>
+</ul>
+</li>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.AbstractProtobufLogWriter
<ul>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.ProtobufLogWriter (implements org.apache.hadoop.hbase.wal.FSHLogProvider.Writer)
@@ -109,6 +114,7 @@
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestBoundedRegionGroupingStrategy.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestBoundedRegionGroupingStrategy</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestDisabledWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestDisabledWAL</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestFSHLogProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestFSHLogProvider</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestReadWriteSeqIdFiles.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestReadWriteSeqIdFiles</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestSecureWAL.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestSecureWAL</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestSyncReplicationWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestSyncReplicationWALProvider</span></a></li>
@@ -141,9 +147,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.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplit.Corruptions.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestWALSplit.Corruptions</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/IOTestProvider.AllowedOperations.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">IOTestProvider.AllowedOperations</span></a></li>
<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/FaultyFSLog.FailureType.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">FaultyFSLog.FailureType</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/IOTestProvider.AllowedOperations.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">IOTestProvider.AllowedOperations</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="../../../../../org/apache/hadoop/hbase/wal/TestWALSplit.Corruptions.html" title="enum in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestWALSplit.Corruptions</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/testdevapidocs/overview-tree.html
----------------------------------------------------------------------
diff --git a/testdevapidocs/overview-tree.html b/testdevapidocs/overview-tree.html
index b891855..bc9a9cb 100644
--- a/testdevapidocs/overview-tree.html
+++ b/testdevapidocs/overview-tree.html
@@ -228,6 +228,11 @@
</li>
</ul>
</li>
+<li type="circle">org.apache.hadoop.hbase.wal.AbstractFSWALProvider<T> (implements org.apache.hadoop.hbase.wal.WALProvider)
+<ul>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.FSWALProvider.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs.FSWALProvider</span></a></li>
+</ul>
+</li>
<li type="circle">org.apache.hadoop.hbase.util.AbstractHBaseTool (implements org.apache.hadoop.util.Tool)
<ul>
<li type="circle">org.apache.hadoop.hbase.util.<a href="org/apache/hadoop/hbase/util/AbstractHBaseToolTest.TestTool.html" title="class in org.apache.hadoop.hbase.util"><span class="typeNameLink">AbstractHBaseToolTest.TestTool</span></a></li>
@@ -3375,6 +3380,7 @@
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaStatusRPCs.html" title="class in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">TestQuotaStatusRPCs</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaTableUtil.html" title="class in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">TestQuotaTableUtil</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestQuotaThrottle.html" title="class in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">TestQuotaThrottle</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.wal.<a href="org/apache/hadoop/hbase/wal/TestRaceBetweenGetWALAndGetWALs.html" title="class in org.apache.hadoop.hbase.wal"><span class="typeNameLink">TestRaceBetweenGetWALAndGetWALs</span></a></li>
<li type="circle">org.apache.hadoop.hbase.replication.regionserver.<a href="org/apache/hadoop/hbase/replication/regionserver/TestRaceWhenCreatingReplicationSource.html" title="class in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">TestRaceWhenCreatingReplicationSource</span></a></li>
<li type="circle">org.apache.hadoop.hbase.filter.<a href="org/apache/hadoop/hbase/filter/TestRandomRowFilter.html" title="class in org.apache.hadoop.hbase.filter"><span class="typeNameLink">TestRandomRowFilter</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="org/apache/hadoop/hbase/quotas/TestRateLimiter.html" title="class in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">TestRateLimiter</span></a></li>
[12/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 d65da67..8125dd3 100644
--- a/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/quotas/package-tree.html
@@ -229,13 +229,13 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/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/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/RpcThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">RpcThrottlingException.Type</span></a></li>
-<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/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/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/QuotaType.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaScope.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">QuotaScope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.quotas.<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottlingException.Type.html" title="enum in org.apache.hadoop.hbase.quotas"><span class="typeNameLink">ThrottlingException.Type</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 d5fccc6..f6fc132 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/package-tree.html
@@ -716,20 +716,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/MetricsRegionServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MetricsRegionServerSourceFactoryImpl.FactoryStorage</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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/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/BloomType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">BloomType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ChunkCreator.ChunkType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ChunkCreator.ChunkType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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.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/Region.Operation.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">Region.Operation</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/ScanType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">ScanType</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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>
<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/CompactingMemStore.IndexType.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">CompactingMemStore.IndexType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/SplitLogWorker.TaskExecutor.Status.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">SplitLogWorker.TaskExecutor.Status</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.<a href="../../../../../org/apache/hadoop/hbase/regionserver/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/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/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/MetricsRegionServerSourceFactoryImpl.FactoryStorage.html" title="enum in org.apache.hadoop.hbase.regionserver"><span class="typeNameLink">MetricsRegionServerSourceFactoryImpl.FactoryStorage</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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..b377318 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/querymatcher/package-tree.html
@@ -130,9 +130,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/ScanQueryMatcher.MatchCode.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">ScanQueryMatcher.MatchCode</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/DeleteTracker.DeleteResult.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">DeleteTracker.DeleteResult</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.regionserver.querymatcher.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/querymatcher/StripeCompactionScanQueryMatcher.DropDeletesInOutput.html" title="enum in org.apache.hadoop.hbase.regionserver.querymatcher"><span class="typeNameLink">StripeCompactionScanQueryMatcher.DropDeletesInOutput</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
index 19354d1..7eedc5c 100644
--- a/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/regionserver/wal/package-tree.html
@@ -247,9 +247,9 @@
<ul>
<li type="circle">java.lang.<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?is-external=true" title="class or interface in java.lang"><span class="typeNameLink">Enum</span></a><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.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/ProtobufLogReader.WALHdrResult.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">ProtobufLogReader.WALHdrResult</span></a></li>
<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/RingBufferTruck.Type.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">RingBufferTruck.Type</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.regionserver.wal.<a href="../../../../../../org/apache/hadoop/hbase/regionserver/wal/CompressionContext.DictionaryIndex.html" title="enum in org.apache.hadoop.hbase.regionserver.wal"><span class="typeNameLink">CompressionContext.DictionaryIndex</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html b/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
index 30c4e73..cd3870f 100644
--- a/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/replication/regionserver/package-tree.html
@@ -207,8 +207,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.replication.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/MetricsReplicationSourceFactoryImpl.SourceHolder.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">MetricsReplicationSourceFactoryImpl.SourceHolder</span></a></li>
<li type="circle">org.apache.hadoop.hbase.replication.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/ReplicationSourceShipper.WorkerState.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">ReplicationSourceShipper.WorkerState</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.replication.regionserver.<a href="../../../../../../org/apache/hadoop/hbase/replication/regionserver/MetricsReplicationSourceFactoryImpl.SourceHolder.html" title="enum in org.apache.hadoop.hbase.replication.regionserver"><span class="typeNameLink">MetricsReplicationSourceFactoryImpl.SourceHolder</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
index 7ec20da..f56fa93 100644
--- a/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/security/access/package-tree.html
@@ -141,10 +141,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.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
+<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Action.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Action</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessControlFilter.Strategy.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessControlFilter.Strategy</span></a></li>
<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/AccessController.OpType.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">AccessController.OpType</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Action.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Action</span></a></li>
-<li type="circle">org.apache.hadoop.hbase.security.access.<a href="../../../../../../org/apache/hadoop/hbase/security/access/Permission.Scope.html" title="enum in org.apache.hadoop.hbase.security.access"><span class="typeNameLink">Permission.Scope</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 a7046e6..feca11f 100644
--- a/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
+++ b/devapidocs/org/apache/hadoop/hbase/util/package-tree.html
@@ -540,14 +540,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.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/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/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/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/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/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/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/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/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/HBaseFsck.ErrorReporter.ERROR_CODE.html" title="enum in org.apache.hadoop.hbase.util"><span class="typeNameLink">HBaseFsck.ErrorReporter.ERROR_CODE</span></a></li>
</ul>
</li>
</ul>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html b/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
index f0dcbfd..b935d91 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html
@@ -113,7 +113,7 @@ var activeTableTab = "activeTableTab";
</dl>
<hr>
<br>
-<pre>public static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.69">AbstractFSWALProvider.Reader</a>
+<pre>public static interface <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.72">AbstractFSWALProvider.Reader</a>
extends <a href="../../../../../org/apache/hadoop/hbase/wal/WAL.Reader.html" title="interface in org.apache.hadoop.hbase.wal">WAL.Reader</a></pre>
</li>
</ul>
@@ -175,7 +175,7 @@ extends <a href="../../../../../org/apache/hadoop/hbase/wal/WAL.Reader.html" tit
<ul class="blockListLast">
<li class="blockList">
<h4>init</h4>
-<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html#line.76">init</a>(org.apache.hadoop.fs.FileSystem fs,
+<pre>void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.Reader.html#line.79">init</a>(org.apache.hadoop.fs.FileSystem fs,
org.apache.hadoop.fs.Path path,
org.apache.hadoop.conf.Configuration c,
org.apache.hadoop.fs.FSDataInputStream s)
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
----------------------------------------------------------------------
diff --git a/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html b/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
index 7b42b91..c81ca37 100644
--- a/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
+++ b/devapidocs/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
@@ -119,7 +119,7 @@ var activeTableTab = "activeTableTab";
<br>
<pre>@InterfaceAudience.Private
@InterfaceStability.Evolving
-public abstract class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.60">AbstractFSWALProvider</a><T extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a><?>>
+public abstract class <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.63">AbstractFSWALProvider</a><T extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a><?>>
extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html?is-external=true" title="class or interface in java.lang">Object</a>
implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html" title="interface in org.apache.hadoop.hbase.wal">WALProvider</a></pre>
<div class="block">Base class of a WAL Provider that returns a single thread safe WAL that writes to Hadoop FS. By
@@ -244,9 +244,10 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
</td>
</tr>
<tr class="rowColor">
-<td class="colFirst"><code>private <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></td>
+<td class="colFirst"><code>private <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/locks/ReadWriteLock.html?is-external=true" title="class or interface in java.util.concurrent.locks">ReadWriteLock</a></code></td>
<td class="colLast"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#walCreateLock">walCreateLock</a></span></code>
-<div class="block">we synchronized on walCreateLock to prevent wal recreation in different threads</div>
+<div class="block">We use walCreateLock to prevent wal recreation in different threads, and also prevent getWALs
+ missing the newly created WAL, see HBASE-21503 for more details.</div>
</td>
</tr>
</table>
@@ -487,7 +488,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>LOG</h4>
-<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.62">LOG</a></pre>
+<pre>private static final org.slf4j.Logger <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.65">LOG</a></pre>
</li>
</ul>
<a name="SEPARATE_OLDLOGDIR">
@@ -496,7 +497,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>SEPARATE_OLDLOGDIR</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/wal/AbstractFSWALProvider.html#line.65">SEPARATE_OLDLOGDIR</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/wal/AbstractFSWALProvider.html#line.68">SEPARATE_OLDLOGDIR</a></pre>
<div class="block">Separate old log into different dir by regionserver name</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -510,7 +511,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_SEPARATE_OLDLOGDIR</h4>
-<pre>public static final boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.66">DEFAULT_SEPARATE_OLDLOGDIR</a></pre>
+<pre>public static final boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.69">DEFAULT_SEPARATE_OLDLOGDIR</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.wal.AbstractFSWALProvider.DEFAULT_SEPARATE_OLDLOGDIR">Constant Field Values</a></dd>
@@ -523,7 +524,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>wal</h4>
-<pre>protected volatile <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a><?> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.79">wal</a></pre>
+<pre>protected volatile <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> extends <a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/AbstractFSWAL.html" title="class in org.apache.hadoop.hbase.regionserver.wal">AbstractFSWAL</a><?> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.82">wal</a></pre>
</li>
</ul>
<a name="factory">
@@ -532,7 +533,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>factory</h4>
-<pre>protected <a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.html" title="class in org.apache.hadoop.hbase.wal">WALFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.80">factory</a></pre>
+<pre>protected <a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.html" title="class in org.apache.hadoop.hbase.wal">WALFactory</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.83">factory</a></pre>
</li>
</ul>
<a name="conf">
@@ -541,7 +542,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>conf</h4>
-<pre>protected org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.81">conf</a></pre>
+<pre>protected org.apache.hadoop.conf.Configuration <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.84">conf</a></pre>
</li>
</ul>
<a name="listeners">
@@ -550,7 +551,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>listeners</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><<a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.html" title="interface in org.apache.hadoop.hbase.regionserver.wal">WALActionsListener</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.82">listeners</a></pre>
+<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><<a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.html" title="interface in org.apache.hadoop.hbase.regionserver.wal">WALActionsListener</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.85">listeners</a></pre>
</li>
</ul>
<a name="providerId">
@@ -559,7 +560,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>providerId</h4>
-<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.83">providerId</a></pre>
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.86">providerId</a></pre>
</li>
</ul>
<a name="initialized">
@@ -568,7 +569,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>initialized</h4>
-<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.84">initialized</a></pre>
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicBoolean.html?is-external=true" title="class or interface in java.util.concurrent.atomic">AtomicBoolean</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.87">initialized</a></pre>
</li>
</ul>
<a name="logPrefix">
@@ -577,7 +578,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>logPrefix</h4>
-<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.86">logPrefix</a></pre>
+<pre>protected <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.89">logPrefix</a></pre>
</li>
</ul>
<a name="walCreateLock">
@@ -586,8 +587,9 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>walCreateLock</h4>
-<pre>private final <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> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.91">walCreateLock</a></pre>
-<div class="block">we synchronized on walCreateLock to prevent wal recreation in different threads</div>
+<pre>private final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/locks/ReadWriteLock.html?is-external=true" title="class or interface in java.util.concurrent.locks">ReadWriteLock</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.95">walCreateLock</a></pre>
+<div class="block">We use walCreateLock to prevent wal recreation in different threads, and also prevent getWALs
+ missing the newly created WAL, see HBASE-21503 for more details.</div>
</li>
</ul>
<a name="WAL_FILE_NAME_DELIMITER">
@@ -596,7 +598,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>WAL_FILE_NAME_DELIMITER</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/wal/AbstractFSWALProvider.html#line.229">WAL_FILE_NAME_DELIMITER</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/wal/AbstractFSWALProvider.html#line.243">WAL_FILE_NAME_DELIMITER</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.wal.AbstractFSWALProvider.WAL_FILE_NAME_DELIMITER">Constant Field Values</a></dd>
@@ -609,7 +611,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>META_WAL_PROVIDER_ID</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/wal/AbstractFSWALProvider.html#line.232">META_WAL_PROVIDER_ID</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/wal/AbstractFSWALProvider.html#line.246">META_WAL_PROVIDER_ID</a></pre>
<div class="block">The hbase:meta region's WAL filename extension</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -623,7 +625,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>DEFAULT_PROVIDER_ID</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/wal/AbstractFSWALProvider.html#line.233">DEFAULT_PROVIDER_ID</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/wal/AbstractFSWALProvider.html#line.247">DEFAULT_PROVIDER_ID</a></pre>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
<dd><a href="../../../../../constant-values.html#org.apache.hadoop.hbase.wal.AbstractFSWALProvider.DEFAULT_PROVIDER_ID">Constant Field Values</a></dd>
@@ -636,7 +638,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>SPLITTING_EXT</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/wal/AbstractFSWALProvider.html#line.237">SPLITTING_EXT</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/wal/AbstractFSWALProvider.html#line.251">SPLITTING_EXT</a></pre>
<div class="block">File Extension used while splitting an WAL into regions (HBASE-2312)</div>
<dl>
<dt><span class="seeLabel">See Also:</span></dt>
@@ -650,7 +652,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockListLast">
<li class="blockList">
<h4>WAL_FILE_NAME_PATTERN</h4>
-<pre>private static final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html?is-external=true" title="class or interface in java.util.regex">Pattern</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.263">WAL_FILE_NAME_PATTERN</a></pre>
+<pre>private static final <a href="https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html?is-external=true" title="class or interface in java.util.regex">Pattern</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.277">WAL_FILE_NAME_PATTERN</a></pre>
<div class="block">Pattern used to validate a WAL file name see <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#validateWALFilename-java.lang.String-"><code>validateWALFilename(String)</code></a> for
description.</div>
</li>
@@ -669,7 +671,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockListLast">
<li class="blockList">
<h4>AbstractFSWALProvider</h4>
-<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.60">AbstractFSWALProvider</a>()</pre>
+<pre>public <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.63">AbstractFSWALProvider</a>()</pre>
</li>
</ul>
</li>
@@ -686,7 +688,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>init</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.100">init</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.html" title="class in org.apache.hadoop.hbase.wal">WALFactory</a> factory,
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.104">init</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WALFactory.html" title="class in org.apache.hadoop.hbase.wal">WALFactory</a> factory,
org.apache.hadoop.conf.Configuration conf,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> providerId)
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>
@@ -711,7 +713,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWALs</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="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.121">getWALs</a>()</pre>
+<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="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a>> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.125">getWALs</a>()</pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
<dd><code><a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html#getWALs--">getWALs</a></code> in interface <code><a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html" title="interface in org.apache.hadoop.hbase.wal">WALProvider</a></code></dd>
@@ -726,7 +728,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWAL</h4>
-<pre>public <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.131">getWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a> region)
+<pre>public <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.142">getWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/client/RegionInfo.html" title="interface in org.apache.hadoop.hbase.client">RegionInfo</a> region)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<dl>
<dt><span class="overrideSpecifyLabel">Specified by:</span></dt>
@@ -746,7 +748,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>createWAL</h4>
-<pre>protected abstract <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.156">createWAL</a>()
+<pre>protected abstract <a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html" title="type parameter in AbstractFSWALProvider">T</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.170">createWAL</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>
@@ -760,7 +762,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>doInit</h4>
-<pre>protected abstract void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.158">doInit</a>(org.apache.hadoop.conf.Configuration conf)
+<pre>protected abstract void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.172">doInit</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>
@@ -774,7 +776,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>shutdown</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.161">shutdown</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.175">shutdown</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html#shutdown--">WALProvider</a></code></span></div>
<div class="block">persist outstanding WALs to storage and stop accepting new appends. This method serves as
@@ -794,7 +796,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>close</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.169">close</a>()
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.183">close</a>()
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html#close--">WALProvider</a></code></span></div>
<div class="block">shutdown utstanding WALs and clean up any persisted state. Call this method only when you will
@@ -814,7 +816,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getNumLogFiles</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.181">getNumLogFiles</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.195">getNumLogFiles</a>()</pre>
<div class="block">iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the
number of files (rolled and active). if either of them aren't, count 0 for that provider.</div>
<dl>
@@ -829,7 +831,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getLogFileSize</h4>
-<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.191">getLogFileSize</a>()</pre>
+<pre>public long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.205">getLogFileSize</a>()</pre>
<div class="block">iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the
size of files (only rolled). if either of them aren't, count 0 for that provider.</div>
<dl>
@@ -844,7 +846,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getNumRolledLogFiles</h4>
-<pre>public static int <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.200">getNumRolledLogFiles</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
+<pre>public static int <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.214">getNumRolledLogFiles</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
<div class="block">returns the number of rolled WAL files.</div>
</li>
</ul>
@@ -854,7 +856,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getLogFileSize</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.208">getLogFileSize</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
+<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.222">getLogFileSize</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
<div class="block">returns the size of rolled WAL files.</div>
</li>
</ul>
@@ -864,7 +866,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getCurrentFileName</h4>
-<pre>public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.216">getCurrentFileName</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
+<pre>public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.230">getCurrentFileName</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
<div class="block">return the current filename from the current wal.</div>
</li>
</ul>
@@ -874,7 +876,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>requestLogRoll</h4>
-<pre>static void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.224">requestLogRoll</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
+<pre>static void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.238">requestLogRoll</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
<div class="block">request a log roll, but don't actually do it.</div>
</li>
</ul>
@@ -884,7 +886,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>extractFileNumFromWAL</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.246">extractFileNumFromWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
+<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.260">extractFileNumFromWAL</a>(<a href="../../../../../org/apache/hadoop/hbase/wal/WAL.html" title="interface in org.apache.hadoop.hbase.wal">WAL</a> wal)</pre>
<div class="block">It returns the file create timestamp from the file name. For name format see
<a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#validateWALFilename-java.lang.String-"><code>validateWALFilename(String)</code></a> public until remaining tests move to o.a.h.h.wal</div>
<dl>
@@ -901,7 +903,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>validateWALFilename</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.273">validateWALFilename</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> filename)</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.287">validateWALFilename</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> filename)</pre>
<div class="block">A WAL file name is of the format: <wal-name><a href="../../../../../org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#WAL_FILE_NAME_DELIMITER"><code>WAL_FILE_NAME_DELIMITER</code></a>
<file-creation-timestamp>[.<suffix>]. provider-name is usually made up of a
server-name and a provider-id</div>
@@ -919,7 +921,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWALDirectoryName</h4>
-<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.284">getWALDirectoryName</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> serverName)</pre>
+<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.298">getWALDirectoryName</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> serverName)</pre>
<div class="block">Construct the directory name for all WALs on a given server. Dir names currently look like this
for WALs: <code>hbase//WALs/kalashnikov.att.net,61634,1486865297088</code>.</div>
<dl>
@@ -937,7 +939,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWALArchiveDirectoryName</h4>
-<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.299">getWALArchiveDirectoryName</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.313">getWALArchiveDirectoryName</a>(org.apache.hadoop.conf.Configuration conf,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> serverName)</pre>
<div class="block">Construct the directory name for all old WALs on a given server. The default old WALs dir looks
like: <code>hbase/oldWALs</code>. If you config hbase.separate.oldlogdir.by.regionserver to
@@ -957,7 +959,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getServerNameFromWALDirectoryName</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.317">getServerNameFromWALDirectoryName</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.331">getServerNameFromWALDirectoryName</a>(org.apache.hadoop.conf.Configuration conf,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> path)
throws <a href="https://docs.oracle.com/javase/8/docs/api/java/io/IOException.html?is-external=true" title="class or interface in java.io">IOException</a></pre>
<div class="block">Pulls a ServerName out of a Path generated according to our layout rules. In the below layouts,
@@ -980,7 +982,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getServerNameFromWALDirectoryName</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.374">getServerNameFromWALDirectoryName</a>(org.apache.hadoop.fs.Path logFile)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/ServerName.html" title="class in org.apache.hadoop.hbase">ServerName</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.388">getServerNameFromWALDirectoryName</a>(org.apache.hadoop.fs.Path logFile)</pre>
<div class="block">This function returns region server name from a log file name which is in one of the following
formats:
<ul>
@@ -999,7 +1001,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>isMetaFile</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.397">isMetaFile</a>(org.apache.hadoop.fs.Path p)</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.411">isMetaFile</a>(org.apache.hadoop.fs.Path p)</pre>
</li>
</ul>
<a name="isMetaFile-java.lang.String-">
@@ -1008,7 +1010,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>isMetaFile</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.401">isMetaFile</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> p)</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.415">isMetaFile</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> p)</pre>
</li>
</ul>
<a name="isArchivedLogFile-org.apache.hadoop.fs.Path-">
@@ -1017,7 +1019,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>isArchivedLogFile</h4>
-<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.408">isArchivedLogFile</a>(org.apache.hadoop.fs.Path p)</pre>
+<pre>public static boolean <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.422">isArchivedLogFile</a>(org.apache.hadoop.fs.Path p)</pre>
</li>
</ul>
<a name="getArchivedLogPath-org.apache.hadoop.fs.Path-org.apache.hadoop.conf.Configuration-">
@@ -1026,7 +1028,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getArchivedLogPath</h4>
-<pre>public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.420">getArchivedLogPath</a>(org.apache.hadoop.fs.Path path,
+<pre>public static org.apache.hadoop.fs.Path <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.434">getArchivedLogPath</a>(org.apache.hadoop.fs.Path path,
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>
<div class="block">Get the archived WAL file path</div>
@@ -1047,7 +1049,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>openReader</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/wal/WAL.Reader.html" title="interface in org.apache.hadoop.hbase.wal">WAL.Reader</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.450">openReader</a>(org.apache.hadoop.fs.Path path,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/wal/WAL.Reader.html" title="interface in org.apache.hadoop.hbase.wal">WAL.Reader</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.464">openReader</a>(org.apache.hadoop.fs.Path path,
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>
<div class="block">Opens WAL reader with retries and additional exception handling</div>
@@ -1068,7 +1070,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>recoverLease</h4>
-<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.499">recoverLease</a>(org.apache.hadoop.conf.Configuration conf,
+<pre>private static void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.513">recoverLease</a>(org.apache.hadoop.conf.Configuration conf,
org.apache.hadoop.fs.Path path)</pre>
</li>
</ul>
@@ -1078,7 +1080,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>addWALActionsListener</h4>
-<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.516">addWALActionsListener</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.html" title="interface in org.apache.hadoop.hbase.regionserver.wal">WALActionsListener</a> listener)</pre>
+<pre>public void <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.530">addWALActionsListener</a>(<a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.html" title="interface in org.apache.hadoop.hbase.regionserver.wal">WALActionsListener</a> listener)</pre>
<div class="block"><span class="descfrmTypeLabel">Description copied from interface: <code><a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html#addWALActionsListener-org.apache.hadoop.hbase.regionserver.wal.WALActionsListener-">WALProvider</a></code></span></div>
<div class="block">Add a <a href="../../../../../org/apache/hadoop/hbase/regionserver/wal/WALActionsListener.html" title="interface in org.apache.hadoop.hbase.regionserver.wal"><code>WALActionsListener</code></a>.
<p>
@@ -1097,7 +1099,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWALNameGroupFromWALName</h4>
-<pre>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.520">getWALNameGroupFromWALName</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>private static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.534">getWALNameGroupFromWALName</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,
int group)</pre>
</li>
</ul>
@@ -1107,7 +1109,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockList">
<li class="blockList">
<h4>getWALPrefixFromWALName</h4>
-<pre>public static <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.536">getWALPrefixFromWALName</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="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.550">getWALPrefixFromWALName</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">Get prefix of the log from its name, assuming WAL name in format of
log_prefix.filenumber.log_suffix</div>
<dl>
@@ -1128,7 +1130,7 @@ implements <a href="../../../../../org/apache/hadoop/hbase/wal/WALProvider.html"
<ul class="blockListLast">
<li class="blockList">
<h4>getWALStartTimeFromWALName</h4>
-<pre>public static long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.540">getWALStartTimeFromWALName</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 long <a href="../../../../../src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html#line.554">getWALStartTimeFromWALName</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>
</li>
</ul>
</li>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/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 288641b..564c848 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/Version.html
@@ -18,9 +18,9 @@
<span class="sourceLineNo">010</span> public static final String version = "3.0.0-SNAPSHOT";<a name="line.10"></a>
<span class="sourceLineNo">011</span> public static final String revision = "";<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 = "Tue Nov 20 14:44:19 UTC 2018";<a name="line.13"></a>
+<span class="sourceLineNo">013</span> public static final String date = "Wed Nov 21 14:44:11 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 = "05b800e0fa4b560f4e9c387e4d35888d";<a name="line.15"></a>
+<span class="sourceLineNo">015</span> public static final String srcChecksum = "1f80a990a945d9efd6b2cf79bf4adb13";<a name="line.15"></a>
<span class="sourceLineNo">016</span>}<a name="line.16"></a>
[09/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
index 2f1d985..e55c7bd 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
@@ -151,244 +151,256 @@
<span class="sourceLineNo">143</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.143"></a>
<span class="sourceLineNo">144</span> ThrottleType.READ_SIZE, throttle.getReadSize()));<a name="line.144"></a>
<span class="sourceLineNo">145</span> }<a name="line.145"></a>
-<span class="sourceLineNo">146</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.149"></a>
-<span class="sourceLineNo">150</span> if (protoQuota == null) {<a name="line.150"></a>
-<span class="sourceLineNo">151</span> return null;<a name="line.151"></a>
-<span class="sourceLineNo">152</span> }<a name="line.152"></a>
-<span class="sourceLineNo">153</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.153"></a>
-<span class="sourceLineNo">154</span> throw new IllegalArgumentException(<a name="line.154"></a>
-<span class="sourceLineNo">155</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.155"></a>
-<span class="sourceLineNo">156</span> }<a name="line.156"></a>
-<span class="sourceLineNo">157</span> if (table != null) {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> if (protoQuota.getRemove()) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> return new SpaceLimitSettings(table);<a name="line.159"></a>
-<span class="sourceLineNo">160</span> }<a name="line.160"></a>
-<span class="sourceLineNo">161</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.161"></a>
-<span class="sourceLineNo">162</span> } else {<a name="line.162"></a>
-<span class="sourceLineNo">163</span> if (protoQuota.getRemove()) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span> return new SpaceLimitSettings(namespace);<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span> // namespace must be non-null<a name="line.166"></a>
-<span class="sourceLineNo">167</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.167"></a>
+<span class="sourceLineNo">146</span> if (throttle.hasReqCapacityUnit()) {<a name="line.146"></a>
+<span class="sourceLineNo">147</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.147"></a>
+<span class="sourceLineNo">148</span> ThrottleType.REQUEST_CAPACITY_UNIT, throttle.getReqCapacityUnit()));<a name="line.148"></a>
+<span class="sourceLineNo">149</span> }<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (throttle.hasReadCapacityUnit()) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.151"></a>
+<span class="sourceLineNo">152</span> ThrottleType.READ_CAPACITY_UNIT, throttle.getReadCapacityUnit()));<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span> if (throttle.hasWriteCapacityUnit()) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.155"></a>
+<span class="sourceLineNo">156</span> ThrottleType.WRITE_CAPACITY_UNIT, throttle.getWriteCapacityUnit()));<a name="line.156"></a>
+<span class="sourceLineNo">157</span> }<a name="line.157"></a>
+<span class="sourceLineNo">158</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.161"></a>
+<span class="sourceLineNo">162</span> if (protoQuota == null) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span> return null;<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.165"></a>
+<span class="sourceLineNo">166</span> throw new IllegalArgumentException(<a name="line.166"></a>
+<span class="sourceLineNo">167</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.167"></a>
<span class="sourceLineNo">168</span> }<a name="line.168"></a>
-<span class="sourceLineNo">169</span> }<a name="line.169"></a>
-<span class="sourceLineNo">170</span><a name="line.170"></a>
-<span class="sourceLineNo">171</span> /* ==========================================================================<a name="line.171"></a>
-<span class="sourceLineNo">172</span> * RPC Throttle<a name="line.172"></a>
-<span class="sourceLineNo">173</span> */<a name="line.173"></a>
-<span class="sourceLineNo">174</span><a name="line.174"></a>
-<span class="sourceLineNo">175</span> /**<a name="line.175"></a>
-<span class="sourceLineNo">176</span> * Throttle the specified user.<a name="line.176"></a>
-<span class="sourceLineNo">177</span> *<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * @param userName the user to throttle<a name="line.178"></a>
-<span class="sourceLineNo">179</span> * @param type the type of throttling<a name="line.179"></a>
-<span class="sourceLineNo">180</span> * @param limit the allowed number of request/data per timeUnit<a name="line.180"></a>
-<span class="sourceLineNo">181</span> * @param timeUnit the limit time unit<a name="line.181"></a>
-<span class="sourceLineNo">182</span> * @return the quota settings<a name="line.182"></a>
-<span class="sourceLineNo">183</span> */<a name="line.183"></a>
-<span class="sourceLineNo">184</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.184"></a>
-<span class="sourceLineNo">185</span> final long limit, final TimeUnit timeUnit) {<a name="line.185"></a>
-<span class="sourceLineNo">186</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.186"></a>
-<span class="sourceLineNo">187</span> }<a name="line.187"></a>
-<span class="sourceLineNo">188</span><a name="line.188"></a>
-<span class="sourceLineNo">189</span> /**<a name="line.189"></a>
-<span class="sourceLineNo">190</span> * Throttle the specified user on the specified table.<a name="line.190"></a>
-<span class="sourceLineNo">191</span> *<a name="line.191"></a>
-<span class="sourceLineNo">192</span> * @param userName the user to throttle<a name="line.192"></a>
-<span class="sourceLineNo">193</span> * @param tableName the table to throttle<a name="line.193"></a>
-<span class="sourceLineNo">194</span> * @param type the type of throttling<a name="line.194"></a>
-<span class="sourceLineNo">195</span> * @param limit the allowed number of request/data per timeUnit<a name="line.195"></a>
-<span class="sourceLineNo">196</span> * @param timeUnit the limit time unit<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * @return the quota settings<a name="line.197"></a>
-<span class="sourceLineNo">198</span> */<a name="line.198"></a>
-<span class="sourceLineNo">199</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.199"></a>
-<span class="sourceLineNo">200</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span> /**<a name="line.204"></a>
-<span class="sourceLineNo">205</span> * Throttle the specified user on the specified namespace.<a name="line.205"></a>
-<span class="sourceLineNo">206</span> *<a name="line.206"></a>
-<span class="sourceLineNo">207</span> * @param userName the user to throttle<a name="line.207"></a>
-<span class="sourceLineNo">208</span> * @param namespace the namespace to throttle<a name="line.208"></a>
-<span class="sourceLineNo">209</span> * @param type the type of throttling<a name="line.209"></a>
-<span class="sourceLineNo">210</span> * @param limit the allowed number of request/data per timeUnit<a name="line.210"></a>
-<span class="sourceLineNo">211</span> * @param timeUnit the limit time unit<a name="line.211"></a>
-<span class="sourceLineNo">212</span> * @return the quota settings<a name="line.212"></a>
-<span class="sourceLineNo">213</span> */<a name="line.213"></a>
-<span class="sourceLineNo">214</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.214"></a>
-<span class="sourceLineNo">215</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.215"></a>
-<span class="sourceLineNo">216</span> return throttle(userName, null, namespace, type, limit, timeUnit);<a name="line.216"></a>
-<span class="sourceLineNo">217</span> }<a name="line.217"></a>
-<span class="sourceLineNo">218</span><a name="line.218"></a>
-<span class="sourceLineNo">219</span> /**<a name="line.219"></a>
-<span class="sourceLineNo">220</span> * Remove the throttling for the specified user.<a name="line.220"></a>
-<span class="sourceLineNo">221</span> *<a name="line.221"></a>
-<span class="sourceLineNo">222</span> * @param userName the user<a name="line.222"></a>
-<span class="sourceLineNo">223</span> * @return the quota settings<a name="line.223"></a>
-<span class="sourceLineNo">224</span> */<a name="line.224"></a>
-<span class="sourceLineNo">225</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.225"></a>
-<span class="sourceLineNo">226</span> return throttle(userName, null, null, null, 0, null);<a name="line.226"></a>
-<span class="sourceLineNo">227</span> }<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span> /**<a name="line.229"></a>
-<span class="sourceLineNo">230</span> * Remove the throttling for the specified user on the specified table.<a name="line.230"></a>
-<span class="sourceLineNo">231</span> *<a name="line.231"></a>
-<span class="sourceLineNo">232</span> * @param userName the user<a name="line.232"></a>
-<span class="sourceLineNo">233</span> * @param tableName the table<a name="line.233"></a>
-<span class="sourceLineNo">234</span> * @return the quota settings<a name="line.234"></a>
-<span class="sourceLineNo">235</span> */<a name="line.235"></a>
-<span class="sourceLineNo">236</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.237"></a>
-<span class="sourceLineNo">238</span> }<a name="line.238"></a>
-<span class="sourceLineNo">239</span><a name="line.239"></a>
-<span class="sourceLineNo">240</span> /**<a name="line.240"></a>
-<span class="sourceLineNo">241</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.241"></a>
-<span class="sourceLineNo">242</span> *<a name="line.242"></a>
-<span class="sourceLineNo">243</span> * @param userName the user<a name="line.243"></a>
-<span class="sourceLineNo">244</span> * @param namespace the namespace<a name="line.244"></a>
-<span class="sourceLineNo">245</span> * @return the quota settings<a name="line.245"></a>
-<span class="sourceLineNo">246</span> */<a name="line.246"></a>
-<span class="sourceLineNo">247</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.247"></a>
-<span class="sourceLineNo">248</span> return throttle(userName, null, namespace, null, 0, null);<a name="line.248"></a>
-<span class="sourceLineNo">249</span> }<a name="line.249"></a>
-<span class="sourceLineNo">250</span><a name="line.250"></a>
-<span class="sourceLineNo">251</span> /**<a name="line.251"></a>
-<span class="sourceLineNo">252</span> * Throttle the specified table.<a name="line.252"></a>
-<span class="sourceLineNo">253</span> *<a name="line.253"></a>
-<span class="sourceLineNo">254</span> * @param tableName the table to throttle<a name="line.254"></a>
-<span class="sourceLineNo">255</span> * @param type the type of throttling<a name="line.255"></a>
-<span class="sourceLineNo">256</span> * @param limit the allowed number of request/data per timeUnit<a name="line.256"></a>
-<span class="sourceLineNo">257</span> * @param timeUnit the limit time unit<a name="line.257"></a>
-<span class="sourceLineNo">258</span> * @return the quota settings<a name="line.258"></a>
-<span class="sourceLineNo">259</span> */<a name="line.259"></a>
-<span class="sourceLineNo">260</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.260"></a>
-<span class="sourceLineNo">261</span> final long limit, final TimeUnit timeUnit) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.262"></a>
-<span class="sourceLineNo">263</span> }<a name="line.263"></a>
-<span class="sourceLineNo">264</span><a name="line.264"></a>
-<span class="sourceLineNo">265</span> /**<a name="line.265"></a>
-<span class="sourceLineNo">266</span> * Remove the throttling for the specified table.<a name="line.266"></a>
-<span class="sourceLineNo">267</span> *<a name="line.267"></a>
-<span class="sourceLineNo">268</span> * @param tableName the table<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * @return the quota settings<a name="line.269"></a>
-<span class="sourceLineNo">270</span> */<a name="line.270"></a>
-<span class="sourceLineNo">271</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.271"></a>
-<span class="sourceLineNo">272</span> return throttle(null, tableName, null, null, 0, null);<a name="line.272"></a>
-<span class="sourceLineNo">273</span> }<a name="line.273"></a>
-<span class="sourceLineNo">274</span><a name="line.274"></a>
-<span class="sourceLineNo">275</span> /**<a name="line.275"></a>
-<span class="sourceLineNo">276</span> * Throttle the specified namespace.<a name="line.276"></a>
-<span class="sourceLineNo">277</span> *<a name="line.277"></a>
-<span class="sourceLineNo">278</span> * @param namespace the namespace to throttle<a name="line.278"></a>
-<span class="sourceLineNo">279</span> * @param type the type of throttling<a name="line.279"></a>
-<span class="sourceLineNo">280</span> * @param limit the allowed number of request/data per timeUnit<a name="line.280"></a>
-<span class="sourceLineNo">281</span> * @param timeUnit the limit time unit<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * @return the quota settings<a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.284"></a>
-<span class="sourceLineNo">285</span> final long limit, final TimeUnit timeUnit) {<a name="line.285"></a>
-<span class="sourceLineNo">286</span> return throttle(null, null, namespace, type, limit, timeUnit);<a name="line.286"></a>
-<span class="sourceLineNo">287</span> }<a name="line.287"></a>
-<span class="sourceLineNo">288</span><a name="line.288"></a>
-<span class="sourceLineNo">289</span> /**<a name="line.289"></a>
-<span class="sourceLineNo">290</span> * Remove the throttling for the specified namespace.<a name="line.290"></a>
-<span class="sourceLineNo">291</span> *<a name="line.291"></a>
-<span class="sourceLineNo">292</span> * @param namespace the namespace<a name="line.292"></a>
-<span class="sourceLineNo">293</span> * @return the quota settings<a name="line.293"></a>
-<span class="sourceLineNo">294</span> */<a name="line.294"></a>
-<span class="sourceLineNo">295</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span> return throttle(null, null, namespace, null, 0, null);<a name="line.296"></a>
-<span class="sourceLineNo">297</span> }<a name="line.297"></a>
-<span class="sourceLineNo">298</span><a name="line.298"></a>
-<span class="sourceLineNo">299</span> /* Throttle helper */<a name="line.299"></a>
-<span class="sourceLineNo">300</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.300"></a>
-<span class="sourceLineNo">301</span> final String namespace, final ThrottleType type, final long limit,<a name="line.301"></a>
-<span class="sourceLineNo">302</span> final TimeUnit timeUnit) {<a name="line.302"></a>
-<span class="sourceLineNo">303</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.303"></a>
-<span class="sourceLineNo">304</span> if (type != null) {<a name="line.304"></a>
-<span class="sourceLineNo">305</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.305"></a>
-<span class="sourceLineNo">306</span> }<a name="line.306"></a>
-<span class="sourceLineNo">307</span> if (timeUnit != null) {<a name="line.307"></a>
-<span class="sourceLineNo">308</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.308"></a>
-<span class="sourceLineNo">309</span> }<a name="line.309"></a>
-<span class="sourceLineNo">310</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<a name="line.310"></a>
-<span class="sourceLineNo">311</span> }<a name="line.311"></a>
-<span class="sourceLineNo">312</span><a name="line.312"></a>
-<span class="sourceLineNo">313</span> /* ==========================================================================<a name="line.313"></a>
-<span class="sourceLineNo">314</span> * Global Settings<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> /**<a name="line.317"></a>
-<span class="sourceLineNo">318</span> * Set the "bypass global settings" for the specified user<a name="line.318"></a>
-<span class="sourceLineNo">319</span> *<a name="line.319"></a>
-<span class="sourceLineNo">320</span> * @param userName the user to throttle<a name="line.320"></a>
-<span class="sourceLineNo">321</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.321"></a>
-<span class="sourceLineNo">322</span> * @return the quota settings<a name="line.322"></a>
-<span class="sourceLineNo">323</span> */<a name="line.323"></a>
-<span class="sourceLineNo">324</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.324"></a>
-<span class="sourceLineNo">325</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<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> /* ==========================================================================<a name="line.328"></a>
-<span class="sourceLineNo">329</span> * FileSystem Space Settings<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> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.333"></a>
-<span class="sourceLineNo">334</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.334"></a>
-<span class="sourceLineNo">335</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.335"></a>
-<span class="sourceLineNo">336</span> *<a name="line.336"></a>
-<span class="sourceLineNo">337</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.337"></a>
-<span class="sourceLineNo">338</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.338"></a>
-<span class="sourceLineNo">339</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.339"></a>
-<span class="sourceLineNo">340</span> * @return An {@link QuotaSettings} object.<a name="line.340"></a>
-<span class="sourceLineNo">341</span> */<a name="line.341"></a>
-<span class="sourceLineNo">342</span> public static QuotaSettings limitTableSpace(<a name="line.342"></a>
-<span class="sourceLineNo">343</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.344"></a>
-<span class="sourceLineNo">345</span> }<a name="line.345"></a>
-<span class="sourceLineNo">346</span><a name="line.346"></a>
-<span class="sourceLineNo">347</span> /**<a name="line.347"></a>
-<span class="sourceLineNo">348</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.348"></a>
-<span class="sourceLineNo">349</span> * table.<a name="line.349"></a>
-<span class="sourceLineNo">350</span> *<a name="line.350"></a>
-<span class="sourceLineNo">351</span> * @param tableName The name of the table to remove the quota for.<a name="line.351"></a>
-<span class="sourceLineNo">352</span> * @return A {@link QuotaSettings} object.<a name="line.352"></a>
+<span class="sourceLineNo">169</span> if (table != null) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (protoQuota.getRemove()) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> return new SpaceLimitSettings(table);<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.173"></a>
+<span class="sourceLineNo">174</span> } else {<a name="line.174"></a>
+<span class="sourceLineNo">175</span> if (protoQuota.getRemove()) {<a name="line.175"></a>
+<span class="sourceLineNo">176</span> return new SpaceLimitSettings(namespace);<a name="line.176"></a>
+<span class="sourceLineNo">177</span> }<a name="line.177"></a>
+<span class="sourceLineNo">178</span> // namespace must be non-null<a name="line.178"></a>
+<span class="sourceLineNo">179</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.179"></a>
+<span class="sourceLineNo">180</span> }<a name="line.180"></a>
+<span class="sourceLineNo">181</span> }<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> /* ==========================================================================<a name="line.183"></a>
+<span class="sourceLineNo">184</span> * RPC Throttle<a name="line.184"></a>
+<span class="sourceLineNo">185</span> */<a name="line.185"></a>
+<span class="sourceLineNo">186</span><a name="line.186"></a>
+<span class="sourceLineNo">187</span> /**<a name="line.187"></a>
+<span class="sourceLineNo">188</span> * Throttle the specified user.<a name="line.188"></a>
+<span class="sourceLineNo">189</span> *<a name="line.189"></a>
+<span class="sourceLineNo">190</span> * @param userName the user to throttle<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * @param type the type of throttling<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * @param limit the allowed number of request/data per timeUnit<a name="line.192"></a>
+<span class="sourceLineNo">193</span> * @param timeUnit the limit time unit<a name="line.193"></a>
+<span class="sourceLineNo">194</span> * @return the quota settings<a name="line.194"></a>
+<span class="sourceLineNo">195</span> */<a name="line.195"></a>
+<span class="sourceLineNo">196</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.196"></a>
+<span class="sourceLineNo">197</span> final long limit, final TimeUnit timeUnit) {<a name="line.197"></a>
+<span class="sourceLineNo">198</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span><a name="line.200"></a>
+<span class="sourceLineNo">201</span> /**<a name="line.201"></a>
+<span class="sourceLineNo">202</span> * Throttle the specified user on the specified table.<a name="line.202"></a>
+<span class="sourceLineNo">203</span> *<a name="line.203"></a>
+<span class="sourceLineNo">204</span> * @param userName the user to throttle<a name="line.204"></a>
+<span class="sourceLineNo">205</span> * @param tableName the table to throttle<a name="line.205"></a>
+<span class="sourceLineNo">206</span> * @param type the type of throttling<a name="line.206"></a>
+<span class="sourceLineNo">207</span> * @param limit the allowed number of request/data per timeUnit<a name="line.207"></a>
+<span class="sourceLineNo">208</span> * @param timeUnit the limit time unit<a name="line.208"></a>
+<span class="sourceLineNo">209</span> * @return the quota settings<a name="line.209"></a>
+<span class="sourceLineNo">210</span> */<a name="line.210"></a>
+<span class="sourceLineNo">211</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.211"></a>
+<span class="sourceLineNo">212</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.212"></a>
+<span class="sourceLineNo">213</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.213"></a>
+<span class="sourceLineNo">214</span> }<a name="line.214"></a>
+<span class="sourceLineNo">215</span><a name="line.215"></a>
+<span class="sourceLineNo">216</span> /**<a name="line.216"></a>
+<span class="sourceLineNo">217</span> * Throttle the specified user on the specified namespace.<a name="line.217"></a>
+<span class="sourceLineNo">218</span> *<a name="line.218"></a>
+<span class="sourceLineNo">219</span> * @param userName the user to throttle<a name="line.219"></a>
+<span class="sourceLineNo">220</span> * @param namespace the namespace to throttle<a name="line.220"></a>
+<span class="sourceLineNo">221</span> * @param type the type of throttling<a name="line.221"></a>
+<span class="sourceLineNo">222</span> * @param limit the allowed number of request/data per timeUnit<a name="line.222"></a>
+<span class="sourceLineNo">223</span> * @param timeUnit the limit time unit<a name="line.223"></a>
+<span class="sourceLineNo">224</span> * @return the quota settings<a name="line.224"></a>
+<span class="sourceLineNo">225</span> */<a name="line.225"></a>
+<span class="sourceLineNo">226</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.226"></a>
+<span class="sourceLineNo">227</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> return throttle(userName, null, namespace, type, limit, timeUnit);<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> /**<a name="line.231"></a>
+<span class="sourceLineNo">232</span> * Remove the throttling for the specified user.<a name="line.232"></a>
+<span class="sourceLineNo">233</span> *<a name="line.233"></a>
+<span class="sourceLineNo">234</span> * @param userName the user<a name="line.234"></a>
+<span class="sourceLineNo">235</span> * @return the quota settings<a name="line.235"></a>
+<span class="sourceLineNo">236</span> */<a name="line.236"></a>
+<span class="sourceLineNo">237</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.237"></a>
+<span class="sourceLineNo">238</span> return throttle(userName, null, null, null, 0, null);<a name="line.238"></a>
+<span class="sourceLineNo">239</span> }<a name="line.239"></a>
+<span class="sourceLineNo">240</span><a name="line.240"></a>
+<span class="sourceLineNo">241</span> /**<a name="line.241"></a>
+<span class="sourceLineNo">242</span> * Remove the throttling for the specified user on the specified table.<a name="line.242"></a>
+<span class="sourceLineNo">243</span> *<a name="line.243"></a>
+<span class="sourceLineNo">244</span> * @param userName the user<a name="line.244"></a>
+<span class="sourceLineNo">245</span> * @param tableName the table<a name="line.245"></a>
+<span class="sourceLineNo">246</span> * @return the quota settings<a name="line.246"></a>
+<span class="sourceLineNo">247</span> */<a name="line.247"></a>
+<span class="sourceLineNo">248</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.248"></a>
+<span class="sourceLineNo">249</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.249"></a>
+<span class="sourceLineNo">250</span> }<a name="line.250"></a>
+<span class="sourceLineNo">251</span><a name="line.251"></a>
+<span class="sourceLineNo">252</span> /**<a name="line.252"></a>
+<span class="sourceLineNo">253</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.253"></a>
+<span class="sourceLineNo">254</span> *<a name="line.254"></a>
+<span class="sourceLineNo">255</span> * @param userName the user<a name="line.255"></a>
+<span class="sourceLineNo">256</span> * @param namespace the namespace<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * @return the quota settings<a name="line.257"></a>
+<span class="sourceLineNo">258</span> */<a name="line.258"></a>
+<span class="sourceLineNo">259</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> return throttle(userName, null, namespace, null, 0, null);<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> /**<a name="line.263"></a>
+<span class="sourceLineNo">264</span> * Throttle the specified table.<a name="line.264"></a>
+<span class="sourceLineNo">265</span> *<a name="line.265"></a>
+<span class="sourceLineNo">266</span> * @param tableName the table to throttle<a name="line.266"></a>
+<span class="sourceLineNo">267</span> * @param type the type of throttling<a name="line.267"></a>
+<span class="sourceLineNo">268</span> * @param limit the allowed number of request/data per timeUnit<a name="line.268"></a>
+<span class="sourceLineNo">269</span> * @param timeUnit the limit time unit<a name="line.269"></a>
+<span class="sourceLineNo">270</span> * @return the quota settings<a name="line.270"></a>
+<span class="sourceLineNo">271</span> */<a name="line.271"></a>
+<span class="sourceLineNo">272</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.272"></a>
+<span class="sourceLineNo">273</span> final long limit, final TimeUnit timeUnit) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.274"></a>
+<span class="sourceLineNo">275</span> }<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> * Remove the throttling for the specified table.<a name="line.278"></a>
+<span class="sourceLineNo">279</span> *<a name="line.279"></a>
+<span class="sourceLineNo">280</span> * @param tableName the table<a name="line.280"></a>
+<span class="sourceLineNo">281</span> * @return the quota settings<a name="line.281"></a>
+<span class="sourceLineNo">282</span> */<a name="line.282"></a>
+<span class="sourceLineNo">283</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> return throttle(null, tableName, null, null, 0, null);<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> /**<a name="line.287"></a>
+<span class="sourceLineNo">288</span> * Throttle the specified namespace.<a name="line.288"></a>
+<span class="sourceLineNo">289</span> *<a name="line.289"></a>
+<span class="sourceLineNo">290</span> * @param namespace the namespace to throttle<a name="line.290"></a>
+<span class="sourceLineNo">291</span> * @param type the type of throttling<a name="line.291"></a>
+<span class="sourceLineNo">292</span> * @param limit the allowed number of request/data per timeUnit<a name="line.292"></a>
+<span class="sourceLineNo">293</span> * @param timeUnit the limit time unit<a name="line.293"></a>
+<span class="sourceLineNo">294</span> * @return the quota settings<a name="line.294"></a>
+<span class="sourceLineNo">295</span> */<a name="line.295"></a>
+<span class="sourceLineNo">296</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.296"></a>
+<span class="sourceLineNo">297</span> final long limit, final TimeUnit timeUnit) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span> return throttle(null, null, namespace, type, limit, timeUnit);<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> /**<a name="line.301"></a>
+<span class="sourceLineNo">302</span> * Remove the throttling for the specified namespace.<a name="line.302"></a>
+<span class="sourceLineNo">303</span> *<a name="line.303"></a>
+<span class="sourceLineNo">304</span> * @param namespace the namespace<a name="line.304"></a>
+<span class="sourceLineNo">305</span> * @return the quota settings<a name="line.305"></a>
+<span class="sourceLineNo">306</span> */<a name="line.306"></a>
+<span class="sourceLineNo">307</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.307"></a>
+<span class="sourceLineNo">308</span> return throttle(null, null, namespace, null, 0, null);<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> /* Throttle helper */<a name="line.311"></a>
+<span class="sourceLineNo">312</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.312"></a>
+<span class="sourceLineNo">313</span> final String namespace, final ThrottleType type, final long limit,<a name="line.313"></a>
+<span class="sourceLineNo">314</span> final TimeUnit timeUnit) {<a name="line.314"></a>
+<span class="sourceLineNo">315</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.315"></a>
+<span class="sourceLineNo">316</span> if (type != null) {<a name="line.316"></a>
+<span class="sourceLineNo">317</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.317"></a>
+<span class="sourceLineNo">318</span> }<a name="line.318"></a>
+<span class="sourceLineNo">319</span> if (timeUnit != null) {<a name="line.319"></a>
+<span class="sourceLineNo">320</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.320"></a>
+<span class="sourceLineNo">321</span> }<a name="line.321"></a>
+<span class="sourceLineNo">322</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<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> /* ==========================================================================<a name="line.325"></a>
+<span class="sourceLineNo">326</span> * Global Settings<a name="line.326"></a>
+<span class="sourceLineNo">327</span> */<a name="line.327"></a>
+<span class="sourceLineNo">328</span><a name="line.328"></a>
+<span class="sourceLineNo">329</span> /**<a name="line.329"></a>
+<span class="sourceLineNo">330</span> * Set the "bypass global settings" for the specified user<a name="line.330"></a>
+<span class="sourceLineNo">331</span> *<a name="line.331"></a>
+<span class="sourceLineNo">332</span> * @param userName the user to throttle<a name="line.332"></a>
+<span class="sourceLineNo">333</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.333"></a>
+<span class="sourceLineNo">334</span> * @return the quota settings<a name="line.334"></a>
+<span class="sourceLineNo">335</span> */<a name="line.335"></a>
+<span class="sourceLineNo">336</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.336"></a>
+<span class="sourceLineNo">337</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<a name="line.337"></a>
+<span class="sourceLineNo">338</span> }<a name="line.338"></a>
+<span class="sourceLineNo">339</span><a name="line.339"></a>
+<span class="sourceLineNo">340</span> /* ==========================================================================<a name="line.340"></a>
+<span class="sourceLineNo">341</span> * FileSystem Space Settings<a name="line.341"></a>
+<span class="sourceLineNo">342</span> */<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span> /**<a name="line.344"></a>
+<span class="sourceLineNo">345</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.345"></a>
+<span class="sourceLineNo">346</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.346"></a>
+<span class="sourceLineNo">347</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.347"></a>
+<span class="sourceLineNo">348</span> *<a name="line.348"></a>
+<span class="sourceLineNo">349</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.349"></a>
+<span class="sourceLineNo">350</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.350"></a>
+<span class="sourceLineNo">351</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.351"></a>
+<span class="sourceLineNo">352</span> * @return An {@link QuotaSettings} object.<a name="line.352"></a>
<span class="sourceLineNo">353</span> */<a name="line.353"></a>
-<span class="sourceLineNo">354</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.354"></a>
-<span class="sourceLineNo">355</span> return new SpaceLimitSettings(tableName);<a name="line.355"></a>
-<span class="sourceLineNo">356</span> }<a name="line.356"></a>
-<span class="sourceLineNo">357</span><a name="line.357"></a>
-<span class="sourceLineNo">358</span> /**<a name="line.358"></a>
-<span class="sourceLineNo">359</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.359"></a>
-<span class="sourceLineNo">360</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.360"></a>
-<span class="sourceLineNo">361</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.361"></a>
+<span class="sourceLineNo">354</span> public static QuotaSettings limitTableSpace(<a name="line.354"></a>
+<span class="sourceLineNo">355</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.356"></a>
+<span class="sourceLineNo">357</span> }<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.360"></a>
+<span class="sourceLineNo">361</span> * table.<a name="line.361"></a>
<span class="sourceLineNo">362</span> *<a name="line.362"></a>
-<span class="sourceLineNo">363</span> * @param namespace The namespace on which the quota should be applied.<a name="line.363"></a>
-<span class="sourceLineNo">364</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.364"></a>
-<span class="sourceLineNo">365</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.365"></a>
-<span class="sourceLineNo">366</span> * @return An {@link QuotaSettings} object.<a name="line.366"></a>
-<span class="sourceLineNo">367</span> */<a name="line.367"></a>
-<span class="sourceLineNo">368</span> public static QuotaSettings limitNamespaceSpace(<a name="line.368"></a>
-<span class="sourceLineNo">369</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.369"></a>
-<span class="sourceLineNo">370</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.374"></a>
-<span class="sourceLineNo">375</span> * namespace.<a name="line.375"></a>
-<span class="sourceLineNo">376</span> *<a name="line.376"></a>
-<span class="sourceLineNo">377</span> * @param namespace The namespace to remove the quota on.<a name="line.377"></a>
-<span class="sourceLineNo">378</span> * @return A {@link QuotaSettings} object.<a name="line.378"></a>
+<span class="sourceLineNo">363</span> * @param tableName The name of the table to remove the quota for.<a name="line.363"></a>
+<span class="sourceLineNo">364</span> * @return A {@link QuotaSettings} object.<a name="line.364"></a>
+<span class="sourceLineNo">365</span> */<a name="line.365"></a>
+<span class="sourceLineNo">366</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.366"></a>
+<span class="sourceLineNo">367</span> return new SpaceLimitSettings(tableName);<a name="line.367"></a>
+<span class="sourceLineNo">368</span> }<a name="line.368"></a>
+<span class="sourceLineNo">369</span><a name="line.369"></a>
+<span class="sourceLineNo">370</span> /**<a name="line.370"></a>
+<span class="sourceLineNo">371</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.371"></a>
+<span class="sourceLineNo">372</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.372"></a>
+<span class="sourceLineNo">373</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.373"></a>
+<span class="sourceLineNo">374</span> *<a name="line.374"></a>
+<span class="sourceLineNo">375</span> * @param namespace The namespace on which the quota should be applied.<a name="line.375"></a>
+<span class="sourceLineNo">376</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.376"></a>
+<span class="sourceLineNo">377</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.377"></a>
+<span class="sourceLineNo">378</span> * @return An {@link QuotaSettings} object.<a name="line.378"></a>
<span class="sourceLineNo">379</span> */<a name="line.379"></a>
-<span class="sourceLineNo">380</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.380"></a>
-<span class="sourceLineNo">381</span> return new SpaceLimitSettings(namespace);<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">380</span> public static QuotaSettings limitNamespaceSpace(<a name="line.380"></a>
+<span class="sourceLineNo">381</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.381"></a>
+<span class="sourceLineNo">382</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<a name="line.382"></a>
+<span class="sourceLineNo">383</span> }<a name="line.383"></a>
+<span class="sourceLineNo">384</span><a name="line.384"></a>
+<span class="sourceLineNo">385</span> /**<a name="line.385"></a>
+<span class="sourceLineNo">386</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.386"></a>
+<span class="sourceLineNo">387</span> * namespace.<a name="line.387"></a>
+<span class="sourceLineNo">388</span> *<a name="line.388"></a>
+<span class="sourceLineNo">389</span> * @param namespace The namespace to remove the quota on.<a name="line.389"></a>
+<span class="sourceLineNo">390</span> * @return A {@link QuotaSettings} object.<a name="line.390"></a>
+<span class="sourceLineNo">391</span> */<a name="line.391"></a>
+<span class="sourceLineNo">392</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span> return new SpaceLimitSettings(namespace);<a name="line.393"></a>
+<span class="sourceLineNo">394</span> }<a name="line.394"></a>
+<span class="sourceLineNo">395</span>}<a name="line.395"></a>
[06/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
index 7e6dad2..418733e 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/TimeBasedLimiter.html
@@ -48,165 +48,239 @@
<span class="sourceLineNo">040</span> private RateLimiter writeSizeLimiter = null;<a name="line.40"></a>
<span class="sourceLineNo">041</span> private RateLimiter readReqsLimiter = null;<a name="line.41"></a>
<span class="sourceLineNo">042</span> private RateLimiter readSizeLimiter = null;<a name="line.42"></a>
-<span class="sourceLineNo">043</span><a name="line.43"></a>
-<span class="sourceLineNo">044</span> private TimeBasedLimiter() {<a name="line.44"></a>
-<span class="sourceLineNo">045</span> if (FixedIntervalRateLimiter.class.getName().equals(<a name="line.45"></a>
-<span class="sourceLineNo">046</span> conf.getClass(RateLimiter.QUOTA_RATE_LIMITER_CONF_KEY, AverageIntervalRateLimiter.class)<a name="line.46"></a>
-<span class="sourceLineNo">047</span> .getName())) {<a name="line.47"></a>
-<span class="sourceLineNo">048</span> reqsLimiter = new FixedIntervalRateLimiter();<a name="line.48"></a>
-<span class="sourceLineNo">049</span> reqSizeLimiter = new FixedIntervalRateLimiter();<a name="line.49"></a>
-<span class="sourceLineNo">050</span> writeReqsLimiter = new FixedIntervalRateLimiter();<a name="line.50"></a>
-<span class="sourceLineNo">051</span> writeSizeLimiter = new FixedIntervalRateLimiter();<a name="line.51"></a>
-<span class="sourceLineNo">052</span> readReqsLimiter = new FixedIntervalRateLimiter();<a name="line.52"></a>
-<span class="sourceLineNo">053</span> readSizeLimiter = new FixedIntervalRateLimiter();<a name="line.53"></a>
-<span class="sourceLineNo">054</span> } else {<a name="line.54"></a>
-<span class="sourceLineNo">055</span> reqsLimiter = new AverageIntervalRateLimiter();<a name="line.55"></a>
-<span class="sourceLineNo">056</span> reqSizeLimiter = new AverageIntervalRateLimiter();<a name="line.56"></a>
-<span class="sourceLineNo">057</span> writeReqsLimiter = new AverageIntervalRateLimiter();<a name="line.57"></a>
-<span class="sourceLineNo">058</span> writeSizeLimiter = new AverageIntervalRateLimiter();<a name="line.58"></a>
-<span class="sourceLineNo">059</span> readReqsLimiter = new AverageIntervalRateLimiter();<a name="line.59"></a>
-<span class="sourceLineNo">060</span> readSizeLimiter = new AverageIntervalRateLimiter();<a name="line.60"></a>
-<span class="sourceLineNo">061</span> }<a name="line.61"></a>
-<span class="sourceLineNo">062</span> }<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span> static QuotaLimiter fromThrottle(final Throttle throttle) {<a name="line.64"></a>
-<span class="sourceLineNo">065</span> TimeBasedLimiter limiter = new TimeBasedLimiter();<a name="line.65"></a>
-<span class="sourceLineNo">066</span> boolean isBypass = true;<a name="line.66"></a>
-<span class="sourceLineNo">067</span> if (throttle.hasReqNum()) {<a name="line.67"></a>
-<span class="sourceLineNo">068</span> setFromTimedQuota(limiter.reqsLimiter, throttle.getReqNum());<a name="line.68"></a>
-<span class="sourceLineNo">069</span> isBypass = false;<a name="line.69"></a>
+<span class="sourceLineNo">043</span> private RateLimiter reqCapacityUnitLimiter = null;<a name="line.43"></a>
+<span class="sourceLineNo">044</span> private RateLimiter writeCapacityUnitLimiter = null;<a name="line.44"></a>
+<span class="sourceLineNo">045</span> private RateLimiter readCapacityUnitLimiter = null;<a name="line.45"></a>
+<span class="sourceLineNo">046</span><a name="line.46"></a>
+<span class="sourceLineNo">047</span> private TimeBasedLimiter() {<a name="line.47"></a>
+<span class="sourceLineNo">048</span> if (FixedIntervalRateLimiter.class.getName().equals(<a name="line.48"></a>
+<span class="sourceLineNo">049</span> conf.getClass(RateLimiter.QUOTA_RATE_LIMITER_CONF_KEY, AverageIntervalRateLimiter.class)<a name="line.49"></a>
+<span class="sourceLineNo">050</span> .getName())) {<a name="line.50"></a>
+<span class="sourceLineNo">051</span> reqsLimiter = new FixedIntervalRateLimiter();<a name="line.51"></a>
+<span class="sourceLineNo">052</span> reqSizeLimiter = new FixedIntervalRateLimiter();<a name="line.52"></a>
+<span class="sourceLineNo">053</span> writeReqsLimiter = new FixedIntervalRateLimiter();<a name="line.53"></a>
+<span class="sourceLineNo">054</span> writeSizeLimiter = new FixedIntervalRateLimiter();<a name="line.54"></a>
+<span class="sourceLineNo">055</span> readReqsLimiter = new FixedIntervalRateLimiter();<a name="line.55"></a>
+<span class="sourceLineNo">056</span> readSizeLimiter = new FixedIntervalRateLimiter();<a name="line.56"></a>
+<span class="sourceLineNo">057</span> reqCapacityUnitLimiter = new FixedIntervalRateLimiter();<a name="line.57"></a>
+<span class="sourceLineNo">058</span> writeCapacityUnitLimiter = new FixedIntervalRateLimiter();<a name="line.58"></a>
+<span class="sourceLineNo">059</span> readCapacityUnitLimiter = new FixedIntervalRateLimiter();<a name="line.59"></a>
+<span class="sourceLineNo">060</span> } else {<a name="line.60"></a>
+<span class="sourceLineNo">061</span> reqsLimiter = new AverageIntervalRateLimiter();<a name="line.61"></a>
+<span class="sourceLineNo">062</span> reqSizeLimiter = new AverageIntervalRateLimiter();<a name="line.62"></a>
+<span class="sourceLineNo">063</span> writeReqsLimiter = new AverageIntervalRateLimiter();<a name="line.63"></a>
+<span class="sourceLineNo">064</span> writeSizeLimiter = new AverageIntervalRateLimiter();<a name="line.64"></a>
+<span class="sourceLineNo">065</span> readReqsLimiter = new AverageIntervalRateLimiter();<a name="line.65"></a>
+<span class="sourceLineNo">066</span> readSizeLimiter = new AverageIntervalRateLimiter();<a name="line.66"></a>
+<span class="sourceLineNo">067</span> reqCapacityUnitLimiter = new AverageIntervalRateLimiter();<a name="line.67"></a>
+<span class="sourceLineNo">068</span> writeCapacityUnitLimiter = new AverageIntervalRateLimiter();<a name="line.68"></a>
+<span class="sourceLineNo">069</span> readCapacityUnitLimiter = new AverageIntervalRateLimiter();<a name="line.69"></a>
<span class="sourceLineNo">070</span> }<a name="line.70"></a>
-<span class="sourceLineNo">071</span><a name="line.71"></a>
-<span class="sourceLineNo">072</span> if (throttle.hasReqSize()) {<a name="line.72"></a>
-<span class="sourceLineNo">073</span> setFromTimedQuota(limiter.reqSizeLimiter, throttle.getReqSize());<a name="line.73"></a>
-<span class="sourceLineNo">074</span> isBypass = false;<a name="line.74"></a>
-<span class="sourceLineNo">075</span> }<a name="line.75"></a>
-<span class="sourceLineNo">076</span><a name="line.76"></a>
-<span class="sourceLineNo">077</span> if (throttle.hasWriteNum()) {<a name="line.77"></a>
-<span class="sourceLineNo">078</span> setFromTimedQuota(limiter.writeReqsLimiter, throttle.getWriteNum());<a name="line.78"></a>
-<span class="sourceLineNo">079</span> isBypass = false;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> }<a name="line.80"></a>
-<span class="sourceLineNo">081</span><a name="line.81"></a>
-<span class="sourceLineNo">082</span> if (throttle.hasWriteSize()) {<a name="line.82"></a>
-<span class="sourceLineNo">083</span> setFromTimedQuota(limiter.writeSizeLimiter, throttle.getWriteSize());<a name="line.83"></a>
-<span class="sourceLineNo">084</span> isBypass = false;<a name="line.84"></a>
-<span class="sourceLineNo">085</span> }<a name="line.85"></a>
-<span class="sourceLineNo">086</span><a name="line.86"></a>
-<span class="sourceLineNo">087</span> if (throttle.hasReadNum()) {<a name="line.87"></a>
-<span class="sourceLineNo">088</span> setFromTimedQuota(limiter.readReqsLimiter, throttle.getReadNum());<a name="line.88"></a>
-<span class="sourceLineNo">089</span> isBypass = false;<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> if (throttle.hasReadSize()) {<a name="line.92"></a>
-<span class="sourceLineNo">093</span> setFromTimedQuota(limiter.readSizeLimiter, throttle.getReadSize());<a name="line.93"></a>
-<span class="sourceLineNo">094</span> isBypass = false;<a name="line.94"></a>
-<span class="sourceLineNo">095</span> }<a name="line.95"></a>
-<span class="sourceLineNo">096</span> return isBypass ? NoopQuotaLimiter.get() : limiter;<a name="line.96"></a>
-<span class="sourceLineNo">097</span> }<a name="line.97"></a>
-<span class="sourceLineNo">098</span><a name="line.98"></a>
-<span class="sourceLineNo">099</span> public void update(final TimeBasedLimiter other) {<a name="line.99"></a>
-<span class="sourceLineNo">100</span> reqsLimiter.update(other.reqsLimiter);<a name="line.100"></a>
-<span class="sourceLineNo">101</span> reqSizeLimiter.update(other.reqSizeLimiter);<a name="line.101"></a>
-<span class="sourceLineNo">102</span> writeReqsLimiter.update(other.writeReqsLimiter);<a name="line.102"></a>
-<span class="sourceLineNo">103</span> writeSizeLimiter.update(other.writeSizeLimiter);<a name="line.103"></a>
-<span class="sourceLineNo">104</span> readReqsLimiter.update(other.readReqsLimiter);<a name="line.104"></a>
-<span class="sourceLineNo">105</span> readSizeLimiter.update(other.readSizeLimiter);<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> private static void setFromTimedQuota(final RateLimiter limiter, final TimedQuota timedQuota) {<a name="line.108"></a>
-<span class="sourceLineNo">109</span> limiter.set(timedQuota.getSoftLimit(), ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit()));<a name="line.109"></a>
-<span class="sourceLineNo">110</span> }<a name="line.110"></a>
-<span class="sourceLineNo">111</span><a name="line.111"></a>
-<span class="sourceLineNo">112</span> @Override<a name="line.112"></a>
-<span class="sourceLineNo">113</span> public void checkQuota(long writeReqs, long estimateWriteSize, long readReqs,<a name="line.113"></a>
-<span class="sourceLineNo">114</span> long estimateReadSize) throws RpcThrottlingException {<a name="line.114"></a>
-<span class="sourceLineNo">115</span> if (!reqsLimiter.canExecute(writeReqs + readReqs)) {<a name="line.115"></a>
-<span class="sourceLineNo">116</span> RpcThrottlingException.throwNumRequestsExceeded(reqsLimiter.waitInterval());<a name="line.116"></a>
-<span class="sourceLineNo">117</span> }<a name="line.117"></a>
-<span class="sourceLineNo">118</span> if (!reqSizeLimiter.canExecute(estimateWriteSize + estimateReadSize)) {<a name="line.118"></a>
-<span class="sourceLineNo">119</span> RpcThrottlingException.throwRequestSizeExceeded(<a name="line.119"></a>
-<span class="sourceLineNo">120</span> reqSizeLimiter.waitInterval(estimateWriteSize + estimateReadSize));<a name="line.120"></a>
-<span class="sourceLineNo">121</span> }<a name="line.121"></a>
+<span class="sourceLineNo">071</span> }<a name="line.71"></a>
+<span class="sourceLineNo">072</span><a name="line.72"></a>
+<span class="sourceLineNo">073</span> static QuotaLimiter fromThrottle(final Throttle throttle) {<a name="line.73"></a>
+<span class="sourceLineNo">074</span> TimeBasedLimiter limiter = new TimeBasedLimiter();<a name="line.74"></a>
+<span class="sourceLineNo">075</span> boolean isBypass = true;<a name="line.75"></a>
+<span class="sourceLineNo">076</span> if (throttle.hasReqNum()) {<a name="line.76"></a>
+<span class="sourceLineNo">077</span> setFromTimedQuota(limiter.reqsLimiter, throttle.getReqNum());<a name="line.77"></a>
+<span class="sourceLineNo">078</span> isBypass = false;<a name="line.78"></a>
+<span class="sourceLineNo">079</span> }<a name="line.79"></a>
+<span class="sourceLineNo">080</span><a name="line.80"></a>
+<span class="sourceLineNo">081</span> if (throttle.hasReqSize()) {<a name="line.81"></a>
+<span class="sourceLineNo">082</span> setFromTimedQuota(limiter.reqSizeLimiter, throttle.getReqSize());<a name="line.82"></a>
+<span class="sourceLineNo">083</span> isBypass = false;<a name="line.83"></a>
+<span class="sourceLineNo">084</span> }<a name="line.84"></a>
+<span class="sourceLineNo">085</span><a name="line.85"></a>
+<span class="sourceLineNo">086</span> if (throttle.hasWriteNum()) {<a name="line.86"></a>
+<span class="sourceLineNo">087</span> setFromTimedQuota(limiter.writeReqsLimiter, throttle.getWriteNum());<a name="line.87"></a>
+<span class="sourceLineNo">088</span> isBypass = false;<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> if (throttle.hasWriteSize()) {<a name="line.91"></a>
+<span class="sourceLineNo">092</span> setFromTimedQuota(limiter.writeSizeLimiter, throttle.getWriteSize());<a name="line.92"></a>
+<span class="sourceLineNo">093</span> isBypass = false;<a name="line.93"></a>
+<span class="sourceLineNo">094</span> }<a name="line.94"></a>
+<span class="sourceLineNo">095</span><a name="line.95"></a>
+<span class="sourceLineNo">096</span> if (throttle.hasReadNum()) {<a name="line.96"></a>
+<span class="sourceLineNo">097</span> setFromTimedQuota(limiter.readReqsLimiter, throttle.getReadNum());<a name="line.97"></a>
+<span class="sourceLineNo">098</span> isBypass = false;<a name="line.98"></a>
+<span class="sourceLineNo">099</span> }<a name="line.99"></a>
+<span class="sourceLineNo">100</span><a name="line.100"></a>
+<span class="sourceLineNo">101</span> if (throttle.hasReadSize()) {<a name="line.101"></a>
+<span class="sourceLineNo">102</span> setFromTimedQuota(limiter.readSizeLimiter, throttle.getReadSize());<a name="line.102"></a>
+<span class="sourceLineNo">103</span> isBypass = false;<a name="line.103"></a>
+<span class="sourceLineNo">104</span> }<a name="line.104"></a>
+<span class="sourceLineNo">105</span><a name="line.105"></a>
+<span class="sourceLineNo">106</span> if (throttle.hasReqCapacityUnit()) {<a name="line.106"></a>
+<span class="sourceLineNo">107</span> setFromTimedQuota(limiter.reqCapacityUnitLimiter, throttle.getReqCapacityUnit());<a name="line.107"></a>
+<span class="sourceLineNo">108</span> isBypass = false;<a name="line.108"></a>
+<span class="sourceLineNo">109</span> }<a name="line.109"></a>
+<span class="sourceLineNo">110</span><a name="line.110"></a>
+<span class="sourceLineNo">111</span> if (throttle.hasWriteCapacityUnit()) {<a name="line.111"></a>
+<span class="sourceLineNo">112</span> setFromTimedQuota(limiter.writeCapacityUnitLimiter, throttle.getWriteCapacityUnit());<a name="line.112"></a>
+<span class="sourceLineNo">113</span> isBypass = false;<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> if (throttle.hasReadCapacityUnit()) {<a name="line.116"></a>
+<span class="sourceLineNo">117</span> setFromTimedQuota(limiter.readCapacityUnitLimiter, throttle.getReadCapacityUnit());<a name="line.117"></a>
+<span class="sourceLineNo">118</span> isBypass = false;<a name="line.118"></a>
+<span class="sourceLineNo">119</span> }<a name="line.119"></a>
+<span class="sourceLineNo">120</span> return isBypass ? NoopQuotaLimiter.get() : limiter;<a name="line.120"></a>
+<span class="sourceLineNo">121</span> }<a name="line.121"></a>
<span class="sourceLineNo">122</span><a name="line.122"></a>
-<span class="sourceLineNo">123</span> if (estimateWriteSize > 0) {<a name="line.123"></a>
-<span class="sourceLineNo">124</span> if (!writeReqsLimiter.canExecute(writeReqs)) {<a name="line.124"></a>
-<span class="sourceLineNo">125</span> RpcThrottlingException.throwNumWriteRequestsExceeded(writeReqsLimiter.waitInterval());<a name="line.125"></a>
-<span class="sourceLineNo">126</span> }<a name="line.126"></a>
-<span class="sourceLineNo">127</span> if (!writeSizeLimiter.canExecute(estimateWriteSize)) {<a name="line.127"></a>
-<span class="sourceLineNo">128</span> RpcThrottlingException.throwWriteSizeExceeded(<a name="line.128"></a>
-<span class="sourceLineNo">129</span> writeSizeLimiter.waitInterval(estimateWriteSize));<a name="line.129"></a>
-<span class="sourceLineNo">130</span> }<a name="line.130"></a>
-<span class="sourceLineNo">131</span> }<a name="line.131"></a>
-<span class="sourceLineNo">132</span><a name="line.132"></a>
-<span class="sourceLineNo">133</span> if (estimateReadSize > 0) {<a name="line.133"></a>
-<span class="sourceLineNo">134</span> if (!readReqsLimiter.canExecute(readReqs)) {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> RpcThrottlingException.throwNumReadRequestsExceeded(readReqsLimiter.waitInterval());<a name="line.135"></a>
-<span class="sourceLineNo">136</span> }<a name="line.136"></a>
-<span class="sourceLineNo">137</span> if (!readSizeLimiter.canExecute(estimateReadSize)) {<a name="line.137"></a>
-<span class="sourceLineNo">138</span> RpcThrottlingException.throwReadSizeExceeded(<a name="line.138"></a>
-<span class="sourceLineNo">139</span> readSizeLimiter.waitInterval(estimateReadSize));<a name="line.139"></a>
-<span class="sourceLineNo">140</span> }<a name="line.140"></a>
-<span class="sourceLineNo">141</span> }<a name="line.141"></a>
-<span class="sourceLineNo">142</span> }<a name="line.142"></a>
-<span class="sourceLineNo">143</span><a name="line.143"></a>
-<span class="sourceLineNo">144</span> @Override<a name="line.144"></a>
-<span class="sourceLineNo">145</span> public void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> assert writeSize != 0 || readSize != 0;<a name="line.146"></a>
-<span class="sourceLineNo">147</span><a name="line.147"></a>
-<span class="sourceLineNo">148</span> reqsLimiter.consume(writeReqs + readReqs);<a name="line.148"></a>
-<span class="sourceLineNo">149</span> reqSizeLimiter.consume(writeSize + readSize);<a name="line.149"></a>
-<span class="sourceLineNo">150</span><a name="line.150"></a>
-<span class="sourceLineNo">151</span> if (writeSize > 0) {<a name="line.151"></a>
-<span class="sourceLineNo">152</span> writeReqsLimiter.consume(writeReqs);<a name="line.152"></a>
-<span class="sourceLineNo">153</span> writeSizeLimiter.consume(writeSize);<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span> if (readSize > 0) {<a name="line.155"></a>
-<span class="sourceLineNo">156</span> readReqsLimiter.consume(readReqs);<a name="line.156"></a>
-<span class="sourceLineNo">157</span> readSizeLimiter.consume(readSize);<a name="line.157"></a>
-<span class="sourceLineNo">158</span> }<a name="line.158"></a>
-<span class="sourceLineNo">159</span> }<a name="line.159"></a>
-<span class="sourceLineNo">160</span><a name="line.160"></a>
-<span class="sourceLineNo">161</span> @Override<a name="line.161"></a>
-<span class="sourceLineNo">162</span> public void consumeWrite(final long size) {<a name="line.162"></a>
-<span class="sourceLineNo">163</span> reqSizeLimiter.consume(size);<a name="line.163"></a>
-<span class="sourceLineNo">164</span> writeSizeLimiter.consume(size);<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span><a name="line.166"></a>
-<span class="sourceLineNo">167</span> @Override<a name="line.167"></a>
-<span class="sourceLineNo">168</span> public void consumeRead(final long size) {<a name="line.168"></a>
-<span class="sourceLineNo">169</span> reqSizeLimiter.consume(size);<a name="line.169"></a>
-<span class="sourceLineNo">170</span> readSizeLimiter.consume(size);<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> @Override<a name="line.173"></a>
-<span class="sourceLineNo">174</span> public boolean isBypass() {<a name="line.174"></a>
-<span class="sourceLineNo">175</span> return false;<a name="line.175"></a>
-<span class="sourceLineNo">176</span> }<a name="line.176"></a>
-<span class="sourceLineNo">177</span><a name="line.177"></a>
-<span class="sourceLineNo">178</span> @Override<a name="line.178"></a>
-<span class="sourceLineNo">179</span> public long getWriteAvailable() {<a name="line.179"></a>
-<span class="sourceLineNo">180</span> return writeSizeLimiter.getAvailable();<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> @Override<a name="line.183"></a>
-<span class="sourceLineNo">184</span> public long getReadAvailable() {<a name="line.184"></a>
-<span class="sourceLineNo">185</span> return readSizeLimiter.getAvailable();<a name="line.185"></a>
-<span class="sourceLineNo">186</span> }<a name="line.186"></a>
-<span class="sourceLineNo">187</span><a name="line.187"></a>
-<span class="sourceLineNo">188</span> @Override<a name="line.188"></a>
-<span class="sourceLineNo">189</span> public String toString() {<a name="line.189"></a>
-<span class="sourceLineNo">190</span> StringBuilder builder = new StringBuilder();<a name="line.190"></a>
-<span class="sourceLineNo">191</span> builder.append("TimeBasedLimiter(");<a name="line.191"></a>
-<span class="sourceLineNo">192</span> if (!reqsLimiter.isBypass()) builder.append("reqs=" + reqsLimiter);<a name="line.192"></a>
-<span class="sourceLineNo">193</span> if (!reqSizeLimiter.isBypass()) builder.append(" resSize=" + reqSizeLimiter);<a name="line.193"></a>
-<span class="sourceLineNo">194</span> if (!writeReqsLimiter.isBypass()) builder.append(" writeReqs=" + writeReqsLimiter);<a name="line.194"></a>
-<span class="sourceLineNo">195</span> if (!writeSizeLimiter.isBypass()) builder.append(" writeSize=" + writeSizeLimiter);<a name="line.195"></a>
-<span class="sourceLineNo">196</span> if (!readReqsLimiter.isBypass()) builder.append(" readReqs=" + readReqsLimiter);<a name="line.196"></a>
-<span class="sourceLineNo">197</span> if (!readSizeLimiter.isBypass()) builder.append(" readSize=" + readSizeLimiter);<a name="line.197"></a>
-<span class="sourceLineNo">198</span> builder.append(')');<a name="line.198"></a>
-<span class="sourceLineNo">199</span> return builder.toString();<a name="line.199"></a>
-<span class="sourceLineNo">200</span> }<a name="line.200"></a>
-<span class="sourceLineNo">201</span>}<a name="line.201"></a>
+<span class="sourceLineNo">123</span> public void update(final TimeBasedLimiter other) {<a name="line.123"></a>
+<span class="sourceLineNo">124</span> reqsLimiter.update(other.reqsLimiter);<a name="line.124"></a>
+<span class="sourceLineNo">125</span> reqSizeLimiter.update(other.reqSizeLimiter);<a name="line.125"></a>
+<span class="sourceLineNo">126</span> writeReqsLimiter.update(other.writeReqsLimiter);<a name="line.126"></a>
+<span class="sourceLineNo">127</span> writeSizeLimiter.update(other.writeSizeLimiter);<a name="line.127"></a>
+<span class="sourceLineNo">128</span> readReqsLimiter.update(other.readReqsLimiter);<a name="line.128"></a>
+<span class="sourceLineNo">129</span> readSizeLimiter.update(other.readSizeLimiter);<a name="line.129"></a>
+<span class="sourceLineNo">130</span> reqCapacityUnitLimiter.update(other.reqCapacityUnitLimiter);<a name="line.130"></a>
+<span class="sourceLineNo">131</span> writeCapacityUnitLimiter.update(other.writeCapacityUnitLimiter);<a name="line.131"></a>
+<span class="sourceLineNo">132</span> readCapacityUnitLimiter.update(other.readCapacityUnitLimiter);<a name="line.132"></a>
+<span class="sourceLineNo">133</span> }<a name="line.133"></a>
+<span class="sourceLineNo">134</span><a name="line.134"></a>
+<span class="sourceLineNo">135</span> private static void setFromTimedQuota(final RateLimiter limiter, final TimedQuota timedQuota) {<a name="line.135"></a>
+<span class="sourceLineNo">136</span> limiter.set(timedQuota.getSoftLimit(), ProtobufUtil.toTimeUnit(timedQuota.getTimeUnit()));<a name="line.136"></a>
+<span class="sourceLineNo">137</span> }<a name="line.137"></a>
+<span class="sourceLineNo">138</span><a name="line.138"></a>
+<span class="sourceLineNo">139</span> @Override<a name="line.139"></a>
+<span class="sourceLineNo">140</span> public void checkQuota(long writeReqs, long estimateWriteSize, long readReqs,<a name="line.140"></a>
+<span class="sourceLineNo">141</span> long estimateReadSize, long estimateWriteCapacityUnit, long estimateReadCapacityUnit)<a name="line.141"></a>
+<span class="sourceLineNo">142</span> throws RpcThrottlingException {<a name="line.142"></a>
+<span class="sourceLineNo">143</span> if (!reqsLimiter.canExecute(writeReqs + readReqs)) {<a name="line.143"></a>
+<span class="sourceLineNo">144</span> RpcThrottlingException.throwNumRequestsExceeded(reqsLimiter.waitInterval());<a name="line.144"></a>
+<span class="sourceLineNo">145</span> }<a name="line.145"></a>
+<span class="sourceLineNo">146</span> if (!reqSizeLimiter.canExecute(estimateWriteSize + estimateReadSize)) {<a name="line.146"></a>
+<span class="sourceLineNo">147</span> RpcThrottlingException.throwRequestSizeExceeded(<a name="line.147"></a>
+<span class="sourceLineNo">148</span> reqSizeLimiter.waitInterval(estimateWriteSize + estimateReadSize));<a name="line.148"></a>
+<span class="sourceLineNo">149</span> }<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (!reqCapacityUnitLimiter.canExecute(estimateWriteCapacityUnit + estimateReadCapacityUnit)) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> RpcThrottlingException.throwRequestSizeExceeded(<a name="line.151"></a>
+<span class="sourceLineNo">152</span> reqCapacityUnitLimiter.waitInterval(estimateWriteCapacityUnit + estimateReadCapacityUnit));<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span><a name="line.154"></a>
+<span class="sourceLineNo">155</span> if (estimateWriteSize > 0) {<a name="line.155"></a>
+<span class="sourceLineNo">156</span> if (!writeReqsLimiter.canExecute(writeReqs)) {<a name="line.156"></a>
+<span class="sourceLineNo">157</span> RpcThrottlingException.throwNumWriteRequestsExceeded(writeReqsLimiter.waitInterval());<a name="line.157"></a>
+<span class="sourceLineNo">158</span> }<a name="line.158"></a>
+<span class="sourceLineNo">159</span> if (!writeSizeLimiter.canExecute(estimateWriteSize)) {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> RpcThrottlingException.throwWriteSizeExceeded(<a name="line.160"></a>
+<span class="sourceLineNo">161</span> writeSizeLimiter.waitInterval(estimateWriteSize));<a name="line.161"></a>
+<span class="sourceLineNo">162</span> }<a name="line.162"></a>
+<span class="sourceLineNo">163</span> if (!writeCapacityUnitLimiter.canExecute(estimateWriteCapacityUnit)) {<a name="line.163"></a>
+<span class="sourceLineNo">164</span> RpcThrottlingException.throwWriteSizeExceeded(<a name="line.164"></a>
+<span class="sourceLineNo">165</span> writeCapacityUnitLimiter.waitInterval(estimateWriteCapacityUnit));<a name="line.165"></a>
+<span class="sourceLineNo">166</span> }<a name="line.166"></a>
+<span class="sourceLineNo">167</span> }<a name="line.167"></a>
+<span class="sourceLineNo">168</span><a name="line.168"></a>
+<span class="sourceLineNo">169</span> if (estimateReadSize > 0) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (!readReqsLimiter.canExecute(readReqs)) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> RpcThrottlingException.throwNumReadRequestsExceeded(readReqsLimiter.waitInterval());<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> if (!readSizeLimiter.canExecute(estimateReadSize)) {<a name="line.173"></a>
+<span class="sourceLineNo">174</span> RpcThrottlingException.throwReadSizeExceeded(<a name="line.174"></a>
+<span class="sourceLineNo">175</span> readSizeLimiter.waitInterval(estimateReadSize));<a name="line.175"></a>
+<span class="sourceLineNo">176</span> }<a name="line.176"></a>
+<span class="sourceLineNo">177</span> if (!readCapacityUnitLimiter.canExecute(estimateReadCapacityUnit)) {<a name="line.177"></a>
+<span class="sourceLineNo">178</span> RpcThrottlingException<a name="line.178"></a>
+<span class="sourceLineNo">179</span> .throwWriteSizeExceeded(readCapacityUnitLimiter.waitInterval(estimateReadCapacityUnit));<a name="line.179"></a>
+<span class="sourceLineNo">180</span> }<a name="line.180"></a>
+<span class="sourceLineNo">181</span> }<a name="line.181"></a>
+<span class="sourceLineNo">182</span> }<a name="line.182"></a>
+<span class="sourceLineNo">183</span><a name="line.183"></a>
+<span class="sourceLineNo">184</span> @Override<a name="line.184"></a>
+<span class="sourceLineNo">185</span> public void grabQuota(long writeReqs, long writeSize, long readReqs, long readSize,<a name="line.185"></a>
+<span class="sourceLineNo">186</span> long writeCapacityUnit, long readCapacityUnit) {<a name="line.186"></a>
+<span class="sourceLineNo">187</span> assert writeSize != 0 || readSize != 0;<a name="line.187"></a>
+<span class="sourceLineNo">188</span><a name="line.188"></a>
+<span class="sourceLineNo">189</span> reqsLimiter.consume(writeReqs + readReqs);<a name="line.189"></a>
+<span class="sourceLineNo">190</span> reqSizeLimiter.consume(writeSize + readSize);<a name="line.190"></a>
+<span class="sourceLineNo">191</span><a name="line.191"></a>
+<span class="sourceLineNo">192</span> if (writeSize > 0) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span> writeReqsLimiter.consume(writeReqs);<a name="line.193"></a>
+<span class="sourceLineNo">194</span> writeSizeLimiter.consume(writeSize);<a name="line.194"></a>
+<span class="sourceLineNo">195</span> }<a name="line.195"></a>
+<span class="sourceLineNo">196</span> if (readSize > 0) {<a name="line.196"></a>
+<span class="sourceLineNo">197</span> readReqsLimiter.consume(readReqs);<a name="line.197"></a>
+<span class="sourceLineNo">198</span> readSizeLimiter.consume(readSize);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span> if (writeCapacityUnit > 0) {<a name="line.200"></a>
+<span class="sourceLineNo">201</span> reqCapacityUnitLimiter.consume(writeCapacityUnit);<a name="line.201"></a>
+<span class="sourceLineNo">202</span> writeCapacityUnitLimiter.consume(writeCapacityUnit);<a name="line.202"></a>
+<span class="sourceLineNo">203</span> }<a name="line.203"></a>
+<span class="sourceLineNo">204</span> if (readCapacityUnit > 0) {<a name="line.204"></a>
+<span class="sourceLineNo">205</span> reqCapacityUnitLimiter.consume(readCapacityUnit);<a name="line.205"></a>
+<span class="sourceLineNo">206</span> readCapacityUnitLimiter.consume(readCapacityUnit);<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> @Override<a name="line.210"></a>
+<span class="sourceLineNo">211</span> public void consumeWrite(final long size, long capacityUnit) {<a name="line.211"></a>
+<span class="sourceLineNo">212</span> reqSizeLimiter.consume(size);<a name="line.212"></a>
+<span class="sourceLineNo">213</span> writeSizeLimiter.consume(size);<a name="line.213"></a>
+<span class="sourceLineNo">214</span> reqCapacityUnitLimiter.consume(capacityUnit);<a name="line.214"></a>
+<span class="sourceLineNo">215</span> writeCapacityUnitLimiter.consume(capacityUnit);<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> @Override<a name="line.218"></a>
+<span class="sourceLineNo">219</span> public void consumeRead(final long size, long capacityUnit) {<a name="line.219"></a>
+<span class="sourceLineNo">220</span> reqSizeLimiter.consume(size);<a name="line.220"></a>
+<span class="sourceLineNo">221</span> readSizeLimiter.consume(size);<a name="line.221"></a>
+<span class="sourceLineNo">222</span> reqCapacityUnitLimiter.consume(capacityUnit);<a name="line.222"></a>
+<span class="sourceLineNo">223</span> readCapacityUnitLimiter.consume(capacityUnit);<a name="line.223"></a>
+<span class="sourceLineNo">224</span> }<a name="line.224"></a>
+<span class="sourceLineNo">225</span><a name="line.225"></a>
+<span class="sourceLineNo">226</span> @Override<a name="line.226"></a>
+<span class="sourceLineNo">227</span> public boolean isBypass() {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> return false;<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> @Override<a name="line.231"></a>
+<span class="sourceLineNo">232</span> public long getWriteAvailable() {<a name="line.232"></a>
+<span class="sourceLineNo">233</span> return writeSizeLimiter.getAvailable();<a name="line.233"></a>
+<span class="sourceLineNo">234</span> }<a name="line.234"></a>
+<span class="sourceLineNo">235</span><a name="line.235"></a>
+<span class="sourceLineNo">236</span> @Override<a name="line.236"></a>
+<span class="sourceLineNo">237</span> public long getReadAvailable() {<a name="line.237"></a>
+<span class="sourceLineNo">238</span> return readSizeLimiter.getAvailable();<a name="line.238"></a>
+<span class="sourceLineNo">239</span> }<a name="line.239"></a>
+<span class="sourceLineNo">240</span><a name="line.240"></a>
+<span class="sourceLineNo">241</span> @Override<a name="line.241"></a>
+<span class="sourceLineNo">242</span> public String toString() {<a name="line.242"></a>
+<span class="sourceLineNo">243</span> StringBuilder builder = new StringBuilder();<a name="line.243"></a>
+<span class="sourceLineNo">244</span> builder.append("TimeBasedLimiter(");<a name="line.244"></a>
+<span class="sourceLineNo">245</span> if (!reqsLimiter.isBypass()) {<a name="line.245"></a>
+<span class="sourceLineNo">246</span> builder.append("reqs=" + reqsLimiter);<a name="line.246"></a>
+<span class="sourceLineNo">247</span> }<a name="line.247"></a>
+<span class="sourceLineNo">248</span> if (!reqSizeLimiter.isBypass()) {<a name="line.248"></a>
+<span class="sourceLineNo">249</span> builder.append(" resSize=" + reqSizeLimiter);<a name="line.249"></a>
+<span class="sourceLineNo">250</span> }<a name="line.250"></a>
+<span class="sourceLineNo">251</span> if (!writeReqsLimiter.isBypass()) {<a name="line.251"></a>
+<span class="sourceLineNo">252</span> builder.append(" writeReqs=" + writeReqsLimiter);<a name="line.252"></a>
+<span class="sourceLineNo">253</span> }<a name="line.253"></a>
+<span class="sourceLineNo">254</span> if (!writeSizeLimiter.isBypass()) {<a name="line.254"></a>
+<span class="sourceLineNo">255</span> builder.append(" writeSize=" + writeSizeLimiter);<a name="line.255"></a>
+<span class="sourceLineNo">256</span> }<a name="line.256"></a>
+<span class="sourceLineNo">257</span> if (!readReqsLimiter.isBypass()) {<a name="line.257"></a>
+<span class="sourceLineNo">258</span> builder.append(" readReqs=" + readReqsLimiter);<a name="line.258"></a>
+<span class="sourceLineNo">259</span> }<a name="line.259"></a>
+<span class="sourceLineNo">260</span> if (!readSizeLimiter.isBypass()) {<a name="line.260"></a>
+<span class="sourceLineNo">261</span> builder.append(" readSize=" + readSizeLimiter);<a name="line.261"></a>
+<span class="sourceLineNo">262</span> }<a name="line.262"></a>
+<span class="sourceLineNo">263</span> if (!reqCapacityUnitLimiter.isBypass()) {<a name="line.263"></a>
+<span class="sourceLineNo">264</span> builder.append(" reqCapacityUnit=" + reqCapacityUnitLimiter);<a name="line.264"></a>
+<span class="sourceLineNo">265</span> }<a name="line.265"></a>
+<span class="sourceLineNo">266</span> if (!writeCapacityUnitLimiter.isBypass()) {<a name="line.266"></a>
+<span class="sourceLineNo">267</span> builder.append(" writeCapacityUnit=" + writeCapacityUnitLimiter);<a name="line.267"></a>
+<span class="sourceLineNo">268</span> }<a name="line.268"></a>
+<span class="sourceLineNo">269</span> if (!readCapacityUnitLimiter.isBypass()) {<a name="line.269"></a>
+<span class="sourceLineNo">270</span> builder.append(" readCapacityUnit=" + readCapacityUnitLimiter);<a name="line.270"></a>
+<span class="sourceLineNo">271</span> }<a name="line.271"></a>
+<span class="sourceLineNo">272</span> builder.append(')');<a name="line.272"></a>
+<span class="sourceLineNo">273</span> return builder.toString();<a name="line.273"></a>
+<span class="sourceLineNo">274</span> }<a name="line.274"></a>
+<span class="sourceLineNo">275</span>}<a name="line.275"></a>
[17/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
Published site at 5cc845b713853645f1e25b29caa556d79cfdc551.
Project: http://git-wip-us.apache.org/repos/asf/hbase-site/repo
Commit: http://git-wip-us.apache.org/repos/asf/hbase-site/commit/de8c44eb
Tree: http://git-wip-us.apache.org/repos/asf/hbase-site/tree/de8c44eb
Diff: http://git-wip-us.apache.org/repos/asf/hbase-site/diff/de8c44eb
Branch: refs/heads/asf-site
Commit: de8c44eb3cc9e754761ea430548b5f7346463c38
Parents: af942cc
Author: jenkins <bu...@apache.org>
Authored: Wed Nov 21 14:53:04 2018 +0000
Committer: jenkins <bu...@apache.org>
Committed: Wed Nov 21 14:53:04 2018 +0000
----------------------------------------------------------------------
acid-semantics.html | 4 +-
apache_hbase_reference_guide.pdf | 4 +-
.../hbase/quotas/QuotaSettingsFactory.html | 30 +-
.../hadoop/hbase/quotas/ThrottleType.html | 51 +-
.../hbase/quotas/QuotaSettingsFactory.html | 480 +-
.../hadoop/hbase/quotas/ThrottleType.html | 11 +-
book.html | 2 +-
bulk-loads.html | 4 +-
checkstyle-aggregate.html | 21932 ++++++++---------
checkstyle.rss | 26 +-
coc.html | 4 +-
dependencies.html | 4 +-
dependency-convergence.html | 4 +-
dependency-info.html | 4 +-
dependency-management.html | 4 +-
devapidocs/constant-values.html | 32 +-
devapidocs/index-all.html | 61 +-
.../hadoop/hbase/backup/package-tree.html | 4 +-
.../hadoop/hbase/client/package-tree.html | 28 +-
.../hadoop/hbase/coprocessor/package-tree.html | 2 +-
.../hadoop/hbase/filter/package-tree.html | 10 +-
.../hadoop/hbase/io/hfile/package-tree.html | 4 +-
.../apache/hadoop/hbase/ipc/package-tree.html | 2 +-
.../hadoop/hbase/mapreduce/package-tree.html | 4 +-
.../hbase/master/balancer/package-tree.html | 2 +-
.../hadoop/hbase/master/package-tree.html | 6 +-
.../hbase/master/procedure/package-tree.html | 4 +-
.../hadoop/hbase/monitoring/package-tree.html | 2 +-
.../org/apache/hadoop/hbase/package-tree.html | 16 +-
.../hadoop/hbase/procedure2/package-tree.html | 2 +-
.../hbase/quotas/DefaultOperationQuota.html | 168 +-
.../hbase/quotas/GlobalQuotaSettingsImpl.html | 8 +-
.../hadoop/hbase/quotas/NoopQuotaLimiter.html | 80 +-
.../hadoop/hbase/quotas/QuotaLimiter.html | 58 +-
.../hbase/quotas/QuotaSettingsFactory.html | 34 +-
.../hbase/quotas/QuotaUtil.KeyFromRow.html | 4 +-
.../apache/hadoop/hbase/quotas/QuotaUtil.html | 118 +-
.../quotas/RegionServerRpcQuotaManager.html | 6 +-
.../hadoop/hbase/quotas/ThrottleSettings.html | 6 +-
.../hadoop/hbase/quotas/ThrottleType.html | 51 +-
.../hadoop/hbase/quotas/TimeBasedLimiter.html | 127 +-
.../hbase/quotas/class-use/QuotaLimiter.html | 6 +-
.../hbase/quotas/class-use/RateLimiter.html | 16 +-
.../class-use/RpcThrottlingException.html | 18 +-
.../hadoop/hbase/quotas/package-tree.html | 6 +-
.../hadoop/hbase/regionserver/package-tree.html | 16 +-
.../regionserver/querymatcher/package-tree.html | 2 +-
.../hbase/regionserver/wal/package-tree.html | 2 +-
.../replication/regionserver/package-tree.html | 2 +-
.../hbase/security/access/package-tree.html | 4 +-
.../apache/hadoop/hbase/util/package-tree.html | 6 +-
.../hbase/wal/AbstractFSWALProvider.Reader.html | 4 +-
.../hadoop/hbase/wal/AbstractFSWALProvider.html | 102 +-
.../org/apache/hadoop/hbase/Version.html | 4 +-
.../hbase/quotas/DefaultOperationQuota.html | 245 +-
.../hbase/quotas/GlobalQuotaSettingsImpl.html | 325 +-
.../hadoop/hbase/quotas/NoopQuotaLimiter.html | 111 +-
.../hadoop/hbase/quotas/QuotaLimiter.html | 100 +-
...tingsFactory.QuotaGlobalsSettingsBypass.html | 480 +-
.../hbase/quotas/QuotaSettingsFactory.html | 480 +-
.../hbase/quotas/QuotaUtil.KeyFromRow.html | 495 +-
.../apache/hadoop/hbase/quotas/QuotaUtil.html | 495 +-
.../quotas/RegionServerRpcQuotaManager.html | 173 +-
.../hadoop/hbase/quotas/ThrottleSettings.html | 134 +-
.../hadoop/hbase/quotas/ThrottleType.html | 11 +-
.../hadoop/hbase/quotas/TimeBasedLimiter.html | 388 +-
.../hbase/wal/AbstractFSWALProvider.Reader.html | 1028 +-
.../hadoop/hbase/wal/AbstractFSWALProvider.html | 1028 +-
downloads.html | 4 +-
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 +-
testdevapidocs/allclasses-frame.html | 2 +
testdevapidocs/allclasses-noframe.html | 2 +
testdevapidocs/index-all.html | 30 +
.../hbase/class-use/HBaseClassTestRule.html | 22 +-
.../org/apache/hadoop/hbase/package-tree.html | 14 +-
.../hadoop/hbase/procedure2/package-tree.html | 4 +-
.../hadoop/hbase/quotas/TestQuotaAdmin.html | 56 +-
.../hadoop/hbase/quotas/TestQuotaThrottle.html | 127 +-
.../hadoop/hbase/regionserver/package-tree.html | 6 +-
.../apache/hadoop/hbase/test/package-tree.html | 4 +-
.../hadoop/hbase/wal/TestFSHLogProvider.html | 4 +-
...ceBetweenGetWALAndGetWALs.FSWALProvider.html | 365 +
.../wal/TestRaceBetweenGetWALAndGetWALs.html | 350 +
.../hbase/wal/TestReadWriteSeqIdFiles.html | 4 +-
...ceBetweenGetWALAndGetWALs.FSWALProvider.html | 125 +
.../TestRaceBetweenGetWALAndGetWALs.html | 125 +
.../apache/hadoop/hbase/wal/package-frame.html | 2 +
.../hadoop/hbase/wal/package-summary.html | 10 +
.../apache/hadoop/hbase/wal/package-tree.html | 10 +-
testdevapidocs/overview-tree.html | 6 +
.../hadoop/hbase/quotas/TestQuotaAdmin.html | 374 +-
.../hadoop/hbase/quotas/TestQuotaState.html | 8 +-
.../hadoop/hbase/quotas/TestQuotaThrottle.html | 248 +-
...ceBetweenGetWALAndGetWALs.FSWALProvider.html | 150 +
.../wal/TestRaceBetweenGetWALAndGetWALs.html | 150 +
115 files changed, 16744 insertions(+), 14626 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/acid-semantics.html
----------------------------------------------------------------------
diff --git a/acid-semantics.html b/acid-semantics.html
index 5bf6014..09e024c 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Apache HBase (TM) ACID Properties
@@ -611,7 +611,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/apache_hbase_reference_guide.pdf
----------------------------------------------------------------------
diff --git a/apache_hbase_reference_guide.pdf b/apache_hbase_reference_guide.pdf
index 2665718..9d56cd7 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:20181120143320+00'00')
-/CreationDate (D:20181120144912+00'00')
+/ModDate (D:20181121143253+00'00')
+/CreationDate (D:20181121144917+00'00')
>>
endobj
2 0 obj
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/apidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
----------------------------------------------------------------------
diff --git a/apidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html b/apidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
index db339f6..5c6397e 100644
--- a/apidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
+++ b/apidocs/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
@@ -329,7 +329,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.184">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.196">throttleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -351,7 +351,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.199">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.211">throttleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
@@ -375,7 +375,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.214">throttleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.226">throttleUser</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> userName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
@@ -399,7 +399,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.225">unthrottleUser</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> userName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.237">unthrottleUser</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> userName)</pre>
<div class="block">Remove the throttling for the specified user.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -415,7 +415,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.236">unthrottleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.248">unthrottleUser</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> userName,
<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Remove the throttling for the specified user on the specified table.</div>
<dl>
@@ -433,7 +433,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleUser</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.247">unthrottleUser</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.259">unthrottleUser</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> userName,
<a href="https://docs.oracle.com/javase/8/docs/api/java/lang/String.html?is-external=true" title="class or interface in java.lang">String</a> namespace)</pre>
<div class="block">Remove the throttling for the specified user on the specified namespace.</div>
<dl>
@@ -451,7 +451,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleTable</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.260">throttleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.272">throttleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -473,7 +473,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleTable</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.271">unthrottleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.283">unthrottleTable</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Remove the throttling for the specified table.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -489,7 +489,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>throttleNamespace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.284">throttleNamespace</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> namespace,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.296">throttleNamespace</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> namespace,
<a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> type,
long limit,
<a href="https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/TimeUnit.html?is-external=true" title="class or interface in java.util.concurrent">TimeUnit</a> timeUnit)</pre>
@@ -511,7 +511,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>unthrottleNamespace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.295">unthrottleNamespace</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> namespace)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.307">unthrottleNamespace</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> namespace)</pre>
<div class="block">Remove the throttling for the specified namespace.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
@@ -527,7 +527,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>bypassGlobals</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.324">bypassGlobals</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> userName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.336">bypassGlobals</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> userName,
boolean bypassGlobals)</pre>
<div class="block">Set the "bypass global settings" for the specified user</div>
<dl>
@@ -545,7 +545,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>limitTableSpace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.342">limitTableSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.354">limitTableSpace</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName,
long sizeLimit,
<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas">SpaceViolationPolicy</a> violationPolicy)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to limit the FileSystem space usage for the given table
@@ -567,7 +567,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>removeTableSpaceLimit</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.354">removeTableSpaceLimit</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.366">removeTableSpaceLimit</a>(<a href="../../../../../org/apache/hadoop/hbase/TableName.html" title="class in org.apache.hadoop.hbase">TableName</a> tableName)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to remove the FileSystem space quota for the given
table.</div>
<dl>
@@ -584,7 +584,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockList">
<li class="blockList">
<h4>limitNamespaceSpace</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.368">limitNamespaceSpace</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> namespace,
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.380">limitNamespaceSpace</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> namespace,
long sizeLimit,
<a href="../../../../../org/apache/hadoop/hbase/quotas/SpaceViolationPolicy.html" title="enum in org.apache.hadoop.hbase.quotas">SpaceViolationPolicy</a> violationPolicy)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to limit the FileSystem space usage for the given
@@ -606,7 +606,7 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html
<ul class="blockListLast">
<li class="blockList">
<h4>removeNamespaceSpaceLimit</h4>
-<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.380">removeNamespaceSpaceLimit</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> namespace)</pre>
+<pre>public static <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas">QuotaSettings</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html#line.392">removeNamespaceSpaceLimit</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> namespace)</pre>
<div class="block">Creates a <a href="../../../../../org/apache/hadoop/hbase/quotas/QuotaSettings.html" title="class in org.apache.hadoop.hbase.quotas"><code>QuotaSettings</code></a> object to remove the FileSystem space quota for the given
namespace.</div>
<dl>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/apidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
----------------------------------------------------------------------
diff --git a/apidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html b/apidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
index 488ba7e..a9bddf5 100644
--- a/apidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
+++ b/apidocs/org/apache/hadoop/hbase/quotas/ThrottleType.html
@@ -140,15 +140,25 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?i
<th class="colOne" scope="col">Enum Constant and Description</th>
</tr>
<tr class="altColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_CAPACITY_UNIT">READ_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the read data capacity unit</div>
+</td>
+</tr>
+<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_NUMBER">READ_NUMBER</a></span></code>
<div class="block">Throttling based on the number of read requests per time-unit</div>
</td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#READ_SIZE">READ_SIZE</a></span></code>
<div class="block">Throttling based on the read data size</div>
</td>
</tr>
+<tr class="rowColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#REQUEST_CAPACITY_UNIT">REQUEST_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the read+write capacity unit</div>
+</td>
+</tr>
<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#REQUEST_NUMBER">REQUEST_NUMBER</a></span></code>
<div class="block">Throttling based on the number of requests per time-unit</div>
@@ -160,11 +170,16 @@ extends <a href="https://docs.oracle.com/javase/8/docs/api/java/lang/Enum.html?i
</td>
</tr>
<tr class="altColor">
+<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_CAPACITY_UNIT">WRITE_CAPACITY_UNIT</a></span></code>
+<div class="block">Throttling based on the write data capacity unit</div>
+</td>
+</tr>
+<tr class="rowColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_NUMBER">WRITE_NUMBER</a></span></code>
<div class="block">Throttling based on the number of write requests per time-unit</div>
</td>
</tr>
-<tr class="rowColor">
+<tr class="altColor">
<td class="colOne"><code><span class="memberNameLink"><a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html#WRITE_SIZE">WRITE_SIZE</a></span></code>
<div class="block">Throttling based on the write data size</div>
</td>
@@ -279,13 +294,43 @@ the order they are declared.</div>
<a name="READ_SIZE">
<!-- -->
</a>
-<ul class="blockListLast">
+<ul class="blockList">
<li class="blockList">
<h4>READ_SIZE</h4>
<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.43">READ_SIZE</a></pre>
<div class="block">Throttling based on the read data size</div>
</li>
</ul>
+<a name="REQUEST_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>REQUEST_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.46">REQUEST_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the read+write capacity unit</div>
+</li>
+</ul>
+<a name="WRITE_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>WRITE_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.49">WRITE_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the write data capacity unit</div>
+</li>
+</ul>
+<a name="READ_CAPACITY_UNIT">
+<!-- -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>READ_CAPACITY_UNIT</h4>
+<pre>public static final <a href="../../../../../org/apache/hadoop/hbase/quotas/ThrottleType.html" title="enum in org.apache.hadoop.hbase.quotas">ThrottleType</a> <a href="../../../../../src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html#line.52">READ_CAPACITY_UNIT</a></pre>
+<div class="block">Throttling based on the read data capacity unit</div>
+</li>
+</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/apidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
----------------------------------------------------------------------
diff --git a/apidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html b/apidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
index 2f1d985..e55c7bd 100644
--- a/apidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
+++ b/apidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaSettingsFactory.html
@@ -151,244 +151,256 @@
<span class="sourceLineNo">143</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.143"></a>
<span class="sourceLineNo">144</span> ThrottleType.READ_SIZE, throttle.getReadSize()));<a name="line.144"></a>
<span class="sourceLineNo">145</span> }<a name="line.145"></a>
-<span class="sourceLineNo">146</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.149"></a>
-<span class="sourceLineNo">150</span> if (protoQuota == null) {<a name="line.150"></a>
-<span class="sourceLineNo">151</span> return null;<a name="line.151"></a>
-<span class="sourceLineNo">152</span> }<a name="line.152"></a>
-<span class="sourceLineNo">153</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.153"></a>
-<span class="sourceLineNo">154</span> throw new IllegalArgumentException(<a name="line.154"></a>
-<span class="sourceLineNo">155</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.155"></a>
-<span class="sourceLineNo">156</span> }<a name="line.156"></a>
-<span class="sourceLineNo">157</span> if (table != null) {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> if (protoQuota.getRemove()) {<a name="line.158"></a>
-<span class="sourceLineNo">159</span> return new SpaceLimitSettings(table);<a name="line.159"></a>
-<span class="sourceLineNo">160</span> }<a name="line.160"></a>
-<span class="sourceLineNo">161</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.161"></a>
-<span class="sourceLineNo">162</span> } else {<a name="line.162"></a>
-<span class="sourceLineNo">163</span> if (protoQuota.getRemove()) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span> return new SpaceLimitSettings(namespace);<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span> // namespace must be non-null<a name="line.166"></a>
-<span class="sourceLineNo">167</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.167"></a>
+<span class="sourceLineNo">146</span> if (throttle.hasReqCapacityUnit()) {<a name="line.146"></a>
+<span class="sourceLineNo">147</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.147"></a>
+<span class="sourceLineNo">148</span> ThrottleType.REQUEST_CAPACITY_UNIT, throttle.getReqCapacityUnit()));<a name="line.148"></a>
+<span class="sourceLineNo">149</span> }<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (throttle.hasReadCapacityUnit()) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.151"></a>
+<span class="sourceLineNo">152</span> ThrottleType.READ_CAPACITY_UNIT, throttle.getReadCapacityUnit()));<a name="line.152"></a>
+<span class="sourceLineNo">153</span> }<a name="line.153"></a>
+<span class="sourceLineNo">154</span> if (throttle.hasWriteCapacityUnit()) {<a name="line.154"></a>
+<span class="sourceLineNo">155</span> settings.add(ThrottleSettings.fromTimedQuota(userName, tableName, namespace,<a name="line.155"></a>
+<span class="sourceLineNo">156</span> ThrottleType.WRITE_CAPACITY_UNIT, throttle.getWriteCapacityUnit()));<a name="line.156"></a>
+<span class="sourceLineNo">157</span> }<a name="line.157"></a>
+<span class="sourceLineNo">158</span> return settings;<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> static QuotaSettings fromSpace(TableName table, String namespace, SpaceQuota protoQuota) {<a name="line.161"></a>
+<span class="sourceLineNo">162</span> if (protoQuota == null) {<a name="line.162"></a>
+<span class="sourceLineNo">163</span> return null;<a name="line.163"></a>
+<span class="sourceLineNo">164</span> }<a name="line.164"></a>
+<span class="sourceLineNo">165</span> if ((table == null && namespace == null) || (table != null && namespace != null)) {<a name="line.165"></a>
+<span class="sourceLineNo">166</span> throw new IllegalArgumentException(<a name="line.166"></a>
+<span class="sourceLineNo">167</span> "Can only construct SpaceLimitSettings for a table or namespace.");<a name="line.167"></a>
<span class="sourceLineNo">168</span> }<a name="line.168"></a>
-<span class="sourceLineNo">169</span> }<a name="line.169"></a>
-<span class="sourceLineNo">170</span><a name="line.170"></a>
-<span class="sourceLineNo">171</span> /* ==========================================================================<a name="line.171"></a>
-<span class="sourceLineNo">172</span> * RPC Throttle<a name="line.172"></a>
-<span class="sourceLineNo">173</span> */<a name="line.173"></a>
-<span class="sourceLineNo">174</span><a name="line.174"></a>
-<span class="sourceLineNo">175</span> /**<a name="line.175"></a>
-<span class="sourceLineNo">176</span> * Throttle the specified user.<a name="line.176"></a>
-<span class="sourceLineNo">177</span> *<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * @param userName the user to throttle<a name="line.178"></a>
-<span class="sourceLineNo">179</span> * @param type the type of throttling<a name="line.179"></a>
-<span class="sourceLineNo">180</span> * @param limit the allowed number of request/data per timeUnit<a name="line.180"></a>
-<span class="sourceLineNo">181</span> * @param timeUnit the limit time unit<a name="line.181"></a>
-<span class="sourceLineNo">182</span> * @return the quota settings<a name="line.182"></a>
-<span class="sourceLineNo">183</span> */<a name="line.183"></a>
-<span class="sourceLineNo">184</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.184"></a>
-<span class="sourceLineNo">185</span> final long limit, final TimeUnit timeUnit) {<a name="line.185"></a>
-<span class="sourceLineNo">186</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.186"></a>
-<span class="sourceLineNo">187</span> }<a name="line.187"></a>
-<span class="sourceLineNo">188</span><a name="line.188"></a>
-<span class="sourceLineNo">189</span> /**<a name="line.189"></a>
-<span class="sourceLineNo">190</span> * Throttle the specified user on the specified table.<a name="line.190"></a>
-<span class="sourceLineNo">191</span> *<a name="line.191"></a>
-<span class="sourceLineNo">192</span> * @param userName the user to throttle<a name="line.192"></a>
-<span class="sourceLineNo">193</span> * @param tableName the table to throttle<a name="line.193"></a>
-<span class="sourceLineNo">194</span> * @param type the type of throttling<a name="line.194"></a>
-<span class="sourceLineNo">195</span> * @param limit the allowed number of request/data per timeUnit<a name="line.195"></a>
-<span class="sourceLineNo">196</span> * @param timeUnit the limit time unit<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * @return the quota settings<a name="line.197"></a>
-<span class="sourceLineNo">198</span> */<a name="line.198"></a>
-<span class="sourceLineNo">199</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.199"></a>
-<span class="sourceLineNo">200</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span> /**<a name="line.204"></a>
-<span class="sourceLineNo">205</span> * Throttle the specified user on the specified namespace.<a name="line.205"></a>
-<span class="sourceLineNo">206</span> *<a name="line.206"></a>
-<span class="sourceLineNo">207</span> * @param userName the user to throttle<a name="line.207"></a>
-<span class="sourceLineNo">208</span> * @param namespace the namespace to throttle<a name="line.208"></a>
-<span class="sourceLineNo">209</span> * @param type the type of throttling<a name="line.209"></a>
-<span class="sourceLineNo">210</span> * @param limit the allowed number of request/data per timeUnit<a name="line.210"></a>
-<span class="sourceLineNo">211</span> * @param timeUnit the limit time unit<a name="line.211"></a>
-<span class="sourceLineNo">212</span> * @return the quota settings<a name="line.212"></a>
-<span class="sourceLineNo">213</span> */<a name="line.213"></a>
-<span class="sourceLineNo">214</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.214"></a>
-<span class="sourceLineNo">215</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.215"></a>
-<span class="sourceLineNo">216</span> return throttle(userName, null, namespace, type, limit, timeUnit);<a name="line.216"></a>
-<span class="sourceLineNo">217</span> }<a name="line.217"></a>
-<span class="sourceLineNo">218</span><a name="line.218"></a>
-<span class="sourceLineNo">219</span> /**<a name="line.219"></a>
-<span class="sourceLineNo">220</span> * Remove the throttling for the specified user.<a name="line.220"></a>
-<span class="sourceLineNo">221</span> *<a name="line.221"></a>
-<span class="sourceLineNo">222</span> * @param userName the user<a name="line.222"></a>
-<span class="sourceLineNo">223</span> * @return the quota settings<a name="line.223"></a>
-<span class="sourceLineNo">224</span> */<a name="line.224"></a>
-<span class="sourceLineNo">225</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.225"></a>
-<span class="sourceLineNo">226</span> return throttle(userName, null, null, null, 0, null);<a name="line.226"></a>
-<span class="sourceLineNo">227</span> }<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span> /**<a name="line.229"></a>
-<span class="sourceLineNo">230</span> * Remove the throttling for the specified user on the specified table.<a name="line.230"></a>
-<span class="sourceLineNo">231</span> *<a name="line.231"></a>
-<span class="sourceLineNo">232</span> * @param userName the user<a name="line.232"></a>
-<span class="sourceLineNo">233</span> * @param tableName the table<a name="line.233"></a>
-<span class="sourceLineNo">234</span> * @return the quota settings<a name="line.234"></a>
-<span class="sourceLineNo">235</span> */<a name="line.235"></a>
-<span class="sourceLineNo">236</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.237"></a>
-<span class="sourceLineNo">238</span> }<a name="line.238"></a>
-<span class="sourceLineNo">239</span><a name="line.239"></a>
-<span class="sourceLineNo">240</span> /**<a name="line.240"></a>
-<span class="sourceLineNo">241</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.241"></a>
-<span class="sourceLineNo">242</span> *<a name="line.242"></a>
-<span class="sourceLineNo">243</span> * @param userName the user<a name="line.243"></a>
-<span class="sourceLineNo">244</span> * @param namespace the namespace<a name="line.244"></a>
-<span class="sourceLineNo">245</span> * @return the quota settings<a name="line.245"></a>
-<span class="sourceLineNo">246</span> */<a name="line.246"></a>
-<span class="sourceLineNo">247</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.247"></a>
-<span class="sourceLineNo">248</span> return throttle(userName, null, namespace, null, 0, null);<a name="line.248"></a>
-<span class="sourceLineNo">249</span> }<a name="line.249"></a>
-<span class="sourceLineNo">250</span><a name="line.250"></a>
-<span class="sourceLineNo">251</span> /**<a name="line.251"></a>
-<span class="sourceLineNo">252</span> * Throttle the specified table.<a name="line.252"></a>
-<span class="sourceLineNo">253</span> *<a name="line.253"></a>
-<span class="sourceLineNo">254</span> * @param tableName the table to throttle<a name="line.254"></a>
-<span class="sourceLineNo">255</span> * @param type the type of throttling<a name="line.255"></a>
-<span class="sourceLineNo">256</span> * @param limit the allowed number of request/data per timeUnit<a name="line.256"></a>
-<span class="sourceLineNo">257</span> * @param timeUnit the limit time unit<a name="line.257"></a>
-<span class="sourceLineNo">258</span> * @return the quota settings<a name="line.258"></a>
-<span class="sourceLineNo">259</span> */<a name="line.259"></a>
-<span class="sourceLineNo">260</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.260"></a>
-<span class="sourceLineNo">261</span> final long limit, final TimeUnit timeUnit) {<a name="line.261"></a>
-<span class="sourceLineNo">262</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.262"></a>
-<span class="sourceLineNo">263</span> }<a name="line.263"></a>
-<span class="sourceLineNo">264</span><a name="line.264"></a>
-<span class="sourceLineNo">265</span> /**<a name="line.265"></a>
-<span class="sourceLineNo">266</span> * Remove the throttling for the specified table.<a name="line.266"></a>
-<span class="sourceLineNo">267</span> *<a name="line.267"></a>
-<span class="sourceLineNo">268</span> * @param tableName the table<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * @return the quota settings<a name="line.269"></a>
-<span class="sourceLineNo">270</span> */<a name="line.270"></a>
-<span class="sourceLineNo">271</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.271"></a>
-<span class="sourceLineNo">272</span> return throttle(null, tableName, null, null, 0, null);<a name="line.272"></a>
-<span class="sourceLineNo">273</span> }<a name="line.273"></a>
-<span class="sourceLineNo">274</span><a name="line.274"></a>
-<span class="sourceLineNo">275</span> /**<a name="line.275"></a>
-<span class="sourceLineNo">276</span> * Throttle the specified namespace.<a name="line.276"></a>
-<span class="sourceLineNo">277</span> *<a name="line.277"></a>
-<span class="sourceLineNo">278</span> * @param namespace the namespace to throttle<a name="line.278"></a>
-<span class="sourceLineNo">279</span> * @param type the type of throttling<a name="line.279"></a>
-<span class="sourceLineNo">280</span> * @param limit the allowed number of request/data per timeUnit<a name="line.280"></a>
-<span class="sourceLineNo">281</span> * @param timeUnit the limit time unit<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * @return the quota settings<a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.284"></a>
-<span class="sourceLineNo">285</span> final long limit, final TimeUnit timeUnit) {<a name="line.285"></a>
-<span class="sourceLineNo">286</span> return throttle(null, null, namespace, type, limit, timeUnit);<a name="line.286"></a>
-<span class="sourceLineNo">287</span> }<a name="line.287"></a>
-<span class="sourceLineNo">288</span><a name="line.288"></a>
-<span class="sourceLineNo">289</span> /**<a name="line.289"></a>
-<span class="sourceLineNo">290</span> * Remove the throttling for the specified namespace.<a name="line.290"></a>
-<span class="sourceLineNo">291</span> *<a name="line.291"></a>
-<span class="sourceLineNo">292</span> * @param namespace the namespace<a name="line.292"></a>
-<span class="sourceLineNo">293</span> * @return the quota settings<a name="line.293"></a>
-<span class="sourceLineNo">294</span> */<a name="line.294"></a>
-<span class="sourceLineNo">295</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.295"></a>
-<span class="sourceLineNo">296</span> return throttle(null, null, namespace, null, 0, null);<a name="line.296"></a>
-<span class="sourceLineNo">297</span> }<a name="line.297"></a>
-<span class="sourceLineNo">298</span><a name="line.298"></a>
-<span class="sourceLineNo">299</span> /* Throttle helper */<a name="line.299"></a>
-<span class="sourceLineNo">300</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.300"></a>
-<span class="sourceLineNo">301</span> final String namespace, final ThrottleType type, final long limit,<a name="line.301"></a>
-<span class="sourceLineNo">302</span> final TimeUnit timeUnit) {<a name="line.302"></a>
-<span class="sourceLineNo">303</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.303"></a>
-<span class="sourceLineNo">304</span> if (type != null) {<a name="line.304"></a>
-<span class="sourceLineNo">305</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.305"></a>
-<span class="sourceLineNo">306</span> }<a name="line.306"></a>
-<span class="sourceLineNo">307</span> if (timeUnit != null) {<a name="line.307"></a>
-<span class="sourceLineNo">308</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.308"></a>
-<span class="sourceLineNo">309</span> }<a name="line.309"></a>
-<span class="sourceLineNo">310</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<a name="line.310"></a>
-<span class="sourceLineNo">311</span> }<a name="line.311"></a>
-<span class="sourceLineNo">312</span><a name="line.312"></a>
-<span class="sourceLineNo">313</span> /* ==========================================================================<a name="line.313"></a>
-<span class="sourceLineNo">314</span> * Global Settings<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> /**<a name="line.317"></a>
-<span class="sourceLineNo">318</span> * Set the "bypass global settings" for the specified user<a name="line.318"></a>
-<span class="sourceLineNo">319</span> *<a name="line.319"></a>
-<span class="sourceLineNo">320</span> * @param userName the user to throttle<a name="line.320"></a>
-<span class="sourceLineNo">321</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.321"></a>
-<span class="sourceLineNo">322</span> * @return the quota settings<a name="line.322"></a>
-<span class="sourceLineNo">323</span> */<a name="line.323"></a>
-<span class="sourceLineNo">324</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.324"></a>
-<span class="sourceLineNo">325</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<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> /* ==========================================================================<a name="line.328"></a>
-<span class="sourceLineNo">329</span> * FileSystem Space Settings<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> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.333"></a>
-<span class="sourceLineNo">334</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.334"></a>
-<span class="sourceLineNo">335</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.335"></a>
-<span class="sourceLineNo">336</span> *<a name="line.336"></a>
-<span class="sourceLineNo">337</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.337"></a>
-<span class="sourceLineNo">338</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.338"></a>
-<span class="sourceLineNo">339</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.339"></a>
-<span class="sourceLineNo">340</span> * @return An {@link QuotaSettings} object.<a name="line.340"></a>
-<span class="sourceLineNo">341</span> */<a name="line.341"></a>
-<span class="sourceLineNo">342</span> public static QuotaSettings limitTableSpace(<a name="line.342"></a>
-<span class="sourceLineNo">343</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.344"></a>
-<span class="sourceLineNo">345</span> }<a name="line.345"></a>
-<span class="sourceLineNo">346</span><a name="line.346"></a>
-<span class="sourceLineNo">347</span> /**<a name="line.347"></a>
-<span class="sourceLineNo">348</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.348"></a>
-<span class="sourceLineNo">349</span> * table.<a name="line.349"></a>
-<span class="sourceLineNo">350</span> *<a name="line.350"></a>
-<span class="sourceLineNo">351</span> * @param tableName The name of the table to remove the quota for.<a name="line.351"></a>
-<span class="sourceLineNo">352</span> * @return A {@link QuotaSettings} object.<a name="line.352"></a>
+<span class="sourceLineNo">169</span> if (table != null) {<a name="line.169"></a>
+<span class="sourceLineNo">170</span> if (protoQuota.getRemove()) {<a name="line.170"></a>
+<span class="sourceLineNo">171</span> return new SpaceLimitSettings(table);<a name="line.171"></a>
+<span class="sourceLineNo">172</span> }<a name="line.172"></a>
+<span class="sourceLineNo">173</span> return SpaceLimitSettings.fromSpaceQuota(table, protoQuota);<a name="line.173"></a>
+<span class="sourceLineNo">174</span> } else {<a name="line.174"></a>
+<span class="sourceLineNo">175</span> if (protoQuota.getRemove()) {<a name="line.175"></a>
+<span class="sourceLineNo">176</span> return new SpaceLimitSettings(namespace);<a name="line.176"></a>
+<span class="sourceLineNo">177</span> }<a name="line.177"></a>
+<span class="sourceLineNo">178</span> // namespace must be non-null<a name="line.178"></a>
+<span class="sourceLineNo">179</span> return SpaceLimitSettings.fromSpaceQuota(namespace, protoQuota);<a name="line.179"></a>
+<span class="sourceLineNo">180</span> }<a name="line.180"></a>
+<span class="sourceLineNo">181</span> }<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> /* ==========================================================================<a name="line.183"></a>
+<span class="sourceLineNo">184</span> * RPC Throttle<a name="line.184"></a>
+<span class="sourceLineNo">185</span> */<a name="line.185"></a>
+<span class="sourceLineNo">186</span><a name="line.186"></a>
+<span class="sourceLineNo">187</span> /**<a name="line.187"></a>
+<span class="sourceLineNo">188</span> * Throttle the specified user.<a name="line.188"></a>
+<span class="sourceLineNo">189</span> *<a name="line.189"></a>
+<span class="sourceLineNo">190</span> * @param userName the user to throttle<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * @param type the type of throttling<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * @param limit the allowed number of request/data per timeUnit<a name="line.192"></a>
+<span class="sourceLineNo">193</span> * @param timeUnit the limit time unit<a name="line.193"></a>
+<span class="sourceLineNo">194</span> * @return the quota settings<a name="line.194"></a>
+<span class="sourceLineNo">195</span> */<a name="line.195"></a>
+<span class="sourceLineNo">196</span> public static QuotaSettings throttleUser(final String userName, final ThrottleType type,<a name="line.196"></a>
+<span class="sourceLineNo">197</span> final long limit, final TimeUnit timeUnit) {<a name="line.197"></a>
+<span class="sourceLineNo">198</span> return throttle(userName, null, null, type, limit, timeUnit);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span><a name="line.200"></a>
+<span class="sourceLineNo">201</span> /**<a name="line.201"></a>
+<span class="sourceLineNo">202</span> * Throttle the specified user on the specified table.<a name="line.202"></a>
+<span class="sourceLineNo">203</span> *<a name="line.203"></a>
+<span class="sourceLineNo">204</span> * @param userName the user to throttle<a name="line.204"></a>
+<span class="sourceLineNo">205</span> * @param tableName the table to throttle<a name="line.205"></a>
+<span class="sourceLineNo">206</span> * @param type the type of throttling<a name="line.206"></a>
+<span class="sourceLineNo">207</span> * @param limit the allowed number of request/data per timeUnit<a name="line.207"></a>
+<span class="sourceLineNo">208</span> * @param timeUnit the limit time unit<a name="line.208"></a>
+<span class="sourceLineNo">209</span> * @return the quota settings<a name="line.209"></a>
+<span class="sourceLineNo">210</span> */<a name="line.210"></a>
+<span class="sourceLineNo">211</span> public static QuotaSettings throttleUser(final String userName, final TableName tableName,<a name="line.211"></a>
+<span class="sourceLineNo">212</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.212"></a>
+<span class="sourceLineNo">213</span> return throttle(userName, tableName, null, type, limit, timeUnit);<a name="line.213"></a>
+<span class="sourceLineNo">214</span> }<a name="line.214"></a>
+<span class="sourceLineNo">215</span><a name="line.215"></a>
+<span class="sourceLineNo">216</span> /**<a name="line.216"></a>
+<span class="sourceLineNo">217</span> * Throttle the specified user on the specified namespace.<a name="line.217"></a>
+<span class="sourceLineNo">218</span> *<a name="line.218"></a>
+<span class="sourceLineNo">219</span> * @param userName the user to throttle<a name="line.219"></a>
+<span class="sourceLineNo">220</span> * @param namespace the namespace to throttle<a name="line.220"></a>
+<span class="sourceLineNo">221</span> * @param type the type of throttling<a name="line.221"></a>
+<span class="sourceLineNo">222</span> * @param limit the allowed number of request/data per timeUnit<a name="line.222"></a>
+<span class="sourceLineNo">223</span> * @param timeUnit the limit time unit<a name="line.223"></a>
+<span class="sourceLineNo">224</span> * @return the quota settings<a name="line.224"></a>
+<span class="sourceLineNo">225</span> */<a name="line.225"></a>
+<span class="sourceLineNo">226</span> public static QuotaSettings throttleUser(final String userName, final String namespace,<a name="line.226"></a>
+<span class="sourceLineNo">227</span> final ThrottleType type, final long limit, final TimeUnit timeUnit) {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> return throttle(userName, null, namespace, type, limit, timeUnit);<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> /**<a name="line.231"></a>
+<span class="sourceLineNo">232</span> * Remove the throttling for the specified user.<a name="line.232"></a>
+<span class="sourceLineNo">233</span> *<a name="line.233"></a>
+<span class="sourceLineNo">234</span> * @param userName the user<a name="line.234"></a>
+<span class="sourceLineNo">235</span> * @return the quota settings<a name="line.235"></a>
+<span class="sourceLineNo">236</span> */<a name="line.236"></a>
+<span class="sourceLineNo">237</span> public static QuotaSettings unthrottleUser(final String userName) {<a name="line.237"></a>
+<span class="sourceLineNo">238</span> return throttle(userName, null, null, null, 0, null);<a name="line.238"></a>
+<span class="sourceLineNo">239</span> }<a name="line.239"></a>
+<span class="sourceLineNo">240</span><a name="line.240"></a>
+<span class="sourceLineNo">241</span> /**<a name="line.241"></a>
+<span class="sourceLineNo">242</span> * Remove the throttling for the specified user on the specified table.<a name="line.242"></a>
+<span class="sourceLineNo">243</span> *<a name="line.243"></a>
+<span class="sourceLineNo">244</span> * @param userName the user<a name="line.244"></a>
+<span class="sourceLineNo">245</span> * @param tableName the table<a name="line.245"></a>
+<span class="sourceLineNo">246</span> * @return the quota settings<a name="line.246"></a>
+<span class="sourceLineNo">247</span> */<a name="line.247"></a>
+<span class="sourceLineNo">248</span> public static QuotaSettings unthrottleUser(final String userName, final TableName tableName) {<a name="line.248"></a>
+<span class="sourceLineNo">249</span> return throttle(userName, tableName, null, null, 0, null);<a name="line.249"></a>
+<span class="sourceLineNo">250</span> }<a name="line.250"></a>
+<span class="sourceLineNo">251</span><a name="line.251"></a>
+<span class="sourceLineNo">252</span> /**<a name="line.252"></a>
+<span class="sourceLineNo">253</span> * Remove the throttling for the specified user on the specified namespace.<a name="line.253"></a>
+<span class="sourceLineNo">254</span> *<a name="line.254"></a>
+<span class="sourceLineNo">255</span> * @param userName the user<a name="line.255"></a>
+<span class="sourceLineNo">256</span> * @param namespace the namespace<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * @return the quota settings<a name="line.257"></a>
+<span class="sourceLineNo">258</span> */<a name="line.258"></a>
+<span class="sourceLineNo">259</span> public static QuotaSettings unthrottleUser(final String userName, final String namespace) {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> return throttle(userName, null, namespace, null, 0, null);<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> /**<a name="line.263"></a>
+<span class="sourceLineNo">264</span> * Throttle the specified table.<a name="line.264"></a>
+<span class="sourceLineNo">265</span> *<a name="line.265"></a>
+<span class="sourceLineNo">266</span> * @param tableName the table to throttle<a name="line.266"></a>
+<span class="sourceLineNo">267</span> * @param type the type of throttling<a name="line.267"></a>
+<span class="sourceLineNo">268</span> * @param limit the allowed number of request/data per timeUnit<a name="line.268"></a>
+<span class="sourceLineNo">269</span> * @param timeUnit the limit time unit<a name="line.269"></a>
+<span class="sourceLineNo">270</span> * @return the quota settings<a name="line.270"></a>
+<span class="sourceLineNo">271</span> */<a name="line.271"></a>
+<span class="sourceLineNo">272</span> public static QuotaSettings throttleTable(final TableName tableName, final ThrottleType type,<a name="line.272"></a>
+<span class="sourceLineNo">273</span> final long limit, final TimeUnit timeUnit) {<a name="line.273"></a>
+<span class="sourceLineNo">274</span> return throttle(null, tableName, null, type, limit, timeUnit);<a name="line.274"></a>
+<span class="sourceLineNo">275</span> }<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> * Remove the throttling for the specified table.<a name="line.278"></a>
+<span class="sourceLineNo">279</span> *<a name="line.279"></a>
+<span class="sourceLineNo">280</span> * @param tableName the table<a name="line.280"></a>
+<span class="sourceLineNo">281</span> * @return the quota settings<a name="line.281"></a>
+<span class="sourceLineNo">282</span> */<a name="line.282"></a>
+<span class="sourceLineNo">283</span> public static QuotaSettings unthrottleTable(final TableName tableName) {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> return throttle(null, tableName, null, null, 0, null);<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> /**<a name="line.287"></a>
+<span class="sourceLineNo">288</span> * Throttle the specified namespace.<a name="line.288"></a>
+<span class="sourceLineNo">289</span> *<a name="line.289"></a>
+<span class="sourceLineNo">290</span> * @param namespace the namespace to throttle<a name="line.290"></a>
+<span class="sourceLineNo">291</span> * @param type the type of throttling<a name="line.291"></a>
+<span class="sourceLineNo">292</span> * @param limit the allowed number of request/data per timeUnit<a name="line.292"></a>
+<span class="sourceLineNo">293</span> * @param timeUnit the limit time unit<a name="line.293"></a>
+<span class="sourceLineNo">294</span> * @return the quota settings<a name="line.294"></a>
+<span class="sourceLineNo">295</span> */<a name="line.295"></a>
+<span class="sourceLineNo">296</span> public static QuotaSettings throttleNamespace(final String namespace, final ThrottleType type,<a name="line.296"></a>
+<span class="sourceLineNo">297</span> final long limit, final TimeUnit timeUnit) {<a name="line.297"></a>
+<span class="sourceLineNo">298</span> return throttle(null, null, namespace, type, limit, timeUnit);<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> /**<a name="line.301"></a>
+<span class="sourceLineNo">302</span> * Remove the throttling for the specified namespace.<a name="line.302"></a>
+<span class="sourceLineNo">303</span> *<a name="line.303"></a>
+<span class="sourceLineNo">304</span> * @param namespace the namespace<a name="line.304"></a>
+<span class="sourceLineNo">305</span> * @return the quota settings<a name="line.305"></a>
+<span class="sourceLineNo">306</span> */<a name="line.306"></a>
+<span class="sourceLineNo">307</span> public static QuotaSettings unthrottleNamespace(final String namespace) {<a name="line.307"></a>
+<span class="sourceLineNo">308</span> return throttle(null, null, namespace, null, 0, null);<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> /* Throttle helper */<a name="line.311"></a>
+<span class="sourceLineNo">312</span> private static QuotaSettings throttle(final String userName, final TableName tableName,<a name="line.312"></a>
+<span class="sourceLineNo">313</span> final String namespace, final ThrottleType type, final long limit,<a name="line.313"></a>
+<span class="sourceLineNo">314</span> final TimeUnit timeUnit) {<a name="line.314"></a>
+<span class="sourceLineNo">315</span> QuotaProtos.ThrottleRequest.Builder builder = QuotaProtos.ThrottleRequest.newBuilder();<a name="line.315"></a>
+<span class="sourceLineNo">316</span> if (type != null) {<a name="line.316"></a>
+<span class="sourceLineNo">317</span> builder.setType(ProtobufUtil.toProtoThrottleType(type));<a name="line.317"></a>
+<span class="sourceLineNo">318</span> }<a name="line.318"></a>
+<span class="sourceLineNo">319</span> if (timeUnit != null) {<a name="line.319"></a>
+<span class="sourceLineNo">320</span> builder.setTimedQuota(ProtobufUtil.toTimedQuota(limit, timeUnit, QuotaScope.MACHINE));<a name="line.320"></a>
+<span class="sourceLineNo">321</span> }<a name="line.321"></a>
+<span class="sourceLineNo">322</span> return new ThrottleSettings(userName, tableName, namespace, builder.build());<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> /* ==========================================================================<a name="line.325"></a>
+<span class="sourceLineNo">326</span> * Global Settings<a name="line.326"></a>
+<span class="sourceLineNo">327</span> */<a name="line.327"></a>
+<span class="sourceLineNo">328</span><a name="line.328"></a>
+<span class="sourceLineNo">329</span> /**<a name="line.329"></a>
+<span class="sourceLineNo">330</span> * Set the "bypass global settings" for the specified user<a name="line.330"></a>
+<span class="sourceLineNo">331</span> *<a name="line.331"></a>
+<span class="sourceLineNo">332</span> * @param userName the user to throttle<a name="line.332"></a>
+<span class="sourceLineNo">333</span> * @param bypassGlobals true if the global settings should be bypassed<a name="line.333"></a>
+<span class="sourceLineNo">334</span> * @return the quota settings<a name="line.334"></a>
+<span class="sourceLineNo">335</span> */<a name="line.335"></a>
+<span class="sourceLineNo">336</span> public static QuotaSettings bypassGlobals(final String userName, final boolean bypassGlobals) {<a name="line.336"></a>
+<span class="sourceLineNo">337</span> return new QuotaGlobalsSettingsBypass(userName, null, null, bypassGlobals);<a name="line.337"></a>
+<span class="sourceLineNo">338</span> }<a name="line.338"></a>
+<span class="sourceLineNo">339</span><a name="line.339"></a>
+<span class="sourceLineNo">340</span> /* ==========================================================================<a name="line.340"></a>
+<span class="sourceLineNo">341</span> * FileSystem Space Settings<a name="line.341"></a>
+<span class="sourceLineNo">342</span> */<a name="line.342"></a>
+<span class="sourceLineNo">343</span><a name="line.343"></a>
+<span class="sourceLineNo">344</span> /**<a name="line.344"></a>
+<span class="sourceLineNo">345</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given table<a name="line.345"></a>
+<span class="sourceLineNo">346</span> * to the given size in bytes. When the space usage is exceeded by the table, the provided<a name="line.346"></a>
+<span class="sourceLineNo">347</span> * {@link SpaceViolationPolicy} is enacted on the table.<a name="line.347"></a>
+<span class="sourceLineNo">348</span> *<a name="line.348"></a>
+<span class="sourceLineNo">349</span> * @param tableName The name of the table on which the quota should be applied.<a name="line.349"></a>
+<span class="sourceLineNo">350</span> * @param sizeLimit The limit of a table's size in bytes.<a name="line.350"></a>
+<span class="sourceLineNo">351</span> * @param violationPolicy The action to take when the quota is exceeded.<a name="line.351"></a>
+<span class="sourceLineNo">352</span> * @return An {@link QuotaSettings} object.<a name="line.352"></a>
<span class="sourceLineNo">353</span> */<a name="line.353"></a>
-<span class="sourceLineNo">354</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.354"></a>
-<span class="sourceLineNo">355</span> return new SpaceLimitSettings(tableName);<a name="line.355"></a>
-<span class="sourceLineNo">356</span> }<a name="line.356"></a>
-<span class="sourceLineNo">357</span><a name="line.357"></a>
-<span class="sourceLineNo">358</span> /**<a name="line.358"></a>
-<span class="sourceLineNo">359</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.359"></a>
-<span class="sourceLineNo">360</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.360"></a>
-<span class="sourceLineNo">361</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.361"></a>
+<span class="sourceLineNo">354</span> public static QuotaSettings limitTableSpace(<a name="line.354"></a>
+<span class="sourceLineNo">355</span> final TableName tableName, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.355"></a>
+<span class="sourceLineNo">356</span> return new SpaceLimitSettings(tableName, sizeLimit, violationPolicy);<a name="line.356"></a>
+<span class="sourceLineNo">357</span> }<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.360"></a>
+<span class="sourceLineNo">361</span> * table.<a name="line.361"></a>
<span class="sourceLineNo">362</span> *<a name="line.362"></a>
-<span class="sourceLineNo">363</span> * @param namespace The namespace on which the quota should be applied.<a name="line.363"></a>
-<span class="sourceLineNo">364</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.364"></a>
-<span class="sourceLineNo">365</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.365"></a>
-<span class="sourceLineNo">366</span> * @return An {@link QuotaSettings} object.<a name="line.366"></a>
-<span class="sourceLineNo">367</span> */<a name="line.367"></a>
-<span class="sourceLineNo">368</span> public static QuotaSettings limitNamespaceSpace(<a name="line.368"></a>
-<span class="sourceLineNo">369</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.369"></a>
-<span class="sourceLineNo">370</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<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> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.374"></a>
-<span class="sourceLineNo">375</span> * namespace.<a name="line.375"></a>
-<span class="sourceLineNo">376</span> *<a name="line.376"></a>
-<span class="sourceLineNo">377</span> * @param namespace The namespace to remove the quota on.<a name="line.377"></a>
-<span class="sourceLineNo">378</span> * @return A {@link QuotaSettings} object.<a name="line.378"></a>
+<span class="sourceLineNo">363</span> * @param tableName The name of the table to remove the quota for.<a name="line.363"></a>
+<span class="sourceLineNo">364</span> * @return A {@link QuotaSettings} object.<a name="line.364"></a>
+<span class="sourceLineNo">365</span> */<a name="line.365"></a>
+<span class="sourceLineNo">366</span> public static QuotaSettings removeTableSpaceLimit(TableName tableName) {<a name="line.366"></a>
+<span class="sourceLineNo">367</span> return new SpaceLimitSettings(tableName);<a name="line.367"></a>
+<span class="sourceLineNo">368</span> }<a name="line.368"></a>
+<span class="sourceLineNo">369</span><a name="line.369"></a>
+<span class="sourceLineNo">370</span> /**<a name="line.370"></a>
+<span class="sourceLineNo">371</span> * Creates a {@link QuotaSettings} object to limit the FileSystem space usage for the given<a name="line.371"></a>
+<span class="sourceLineNo">372</span> * namespace to the given size in bytes. When the space usage is exceeded by all tables in the<a name="line.372"></a>
+<span class="sourceLineNo">373</span> * namespace, the provided {@link SpaceViolationPolicy} is enacted on all tables in the namespace.<a name="line.373"></a>
+<span class="sourceLineNo">374</span> *<a name="line.374"></a>
+<span class="sourceLineNo">375</span> * @param namespace The namespace on which the quota should be applied.<a name="line.375"></a>
+<span class="sourceLineNo">376</span> * @param sizeLimit The limit of the namespace's size in bytes.<a name="line.376"></a>
+<span class="sourceLineNo">377</span> * @param violationPolicy The action to take when the the quota is exceeded.<a name="line.377"></a>
+<span class="sourceLineNo">378</span> * @return An {@link QuotaSettings} object.<a name="line.378"></a>
<span class="sourceLineNo">379</span> */<a name="line.379"></a>
-<span class="sourceLineNo">380</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.380"></a>
-<span class="sourceLineNo">381</span> return new SpaceLimitSettings(namespace);<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">380</span> public static QuotaSettings limitNamespaceSpace(<a name="line.380"></a>
+<span class="sourceLineNo">381</span> final String namespace, long sizeLimit, final SpaceViolationPolicy violationPolicy) {<a name="line.381"></a>
+<span class="sourceLineNo">382</span> return new SpaceLimitSettings(namespace, sizeLimit, violationPolicy);<a name="line.382"></a>
+<span class="sourceLineNo">383</span> }<a name="line.383"></a>
+<span class="sourceLineNo">384</span><a name="line.384"></a>
+<span class="sourceLineNo">385</span> /**<a name="line.385"></a>
+<span class="sourceLineNo">386</span> * Creates a {@link QuotaSettings} object to remove the FileSystem space quota for the given<a name="line.386"></a>
+<span class="sourceLineNo">387</span> * namespace.<a name="line.387"></a>
+<span class="sourceLineNo">388</span> *<a name="line.388"></a>
+<span class="sourceLineNo">389</span> * @param namespace The namespace to remove the quota on.<a name="line.389"></a>
+<span class="sourceLineNo">390</span> * @return A {@link QuotaSettings} object.<a name="line.390"></a>
+<span class="sourceLineNo">391</span> */<a name="line.391"></a>
+<span class="sourceLineNo">392</span> public static QuotaSettings removeNamespaceSpaceLimit(String namespace) {<a name="line.392"></a>
+<span class="sourceLineNo">393</span> return new SpaceLimitSettings(namespace);<a name="line.393"></a>
+<span class="sourceLineNo">394</span> }<a name="line.394"></a>
+<span class="sourceLineNo">395</span>}<a name="line.395"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/apidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
----------------------------------------------------------------------
diff --git a/apidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html b/apidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
index 152155d..ba1bd79 100644
--- a/apidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
+++ b/apidocs/src-html/org/apache/hadoop/hbase/quotas/ThrottleType.html
@@ -49,7 +49,16 @@
<span class="sourceLineNo">041</span><a name="line.41"></a>
<span class="sourceLineNo">042</span> /** Throttling based on the read data size */<a name="line.42"></a>
<span class="sourceLineNo">043</span> READ_SIZE,<a name="line.43"></a>
-<span class="sourceLineNo">044</span>}<a name="line.44"></a>
+<span class="sourceLineNo">044</span><a name="line.44"></a>
+<span class="sourceLineNo">045</span> /** Throttling based on the read+write capacity unit */<a name="line.45"></a>
+<span class="sourceLineNo">046</span> REQUEST_CAPACITY_UNIT,<a name="line.46"></a>
+<span class="sourceLineNo">047</span><a name="line.47"></a>
+<span class="sourceLineNo">048</span> /** Throttling based on the write data capacity unit */<a name="line.48"></a>
+<span class="sourceLineNo">049</span> WRITE_CAPACITY_UNIT,<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span> /** Throttling based on the read data capacity unit */<a name="line.51"></a>
+<span class="sourceLineNo">052</span> READ_CAPACITY_UNIT,<a name="line.52"></a>
+<span class="sourceLineNo">053</span>}<a name="line.53"></a>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/book.html
----------------------------------------------------------------------
diff --git a/book.html b/book.html
index 7e3cdf8..58b2425 100644
--- a/book.html
+++ b/book.html
@@ -41318,7 +41318,7 @@ org/apache/hadoop/hbase/security/access/AccessControlClient.revoke:(Lorg/apache/
<div id="footer">
<div id="footer-text">
Version 3.0.0-SNAPSHOT<br>
-Last updated 2018-11-20 14:33:20 UTC
+Last updated 2018-11-21 14:32:53 UTC
</div>
</div>
</body>
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/bulk-loads.html
----------------------------------------------------------------------
diff --git a/bulk-loads.html b/bulk-loads.html
index e1b2c16..45d6cc9 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="20181120" />
+ <meta name="Date-Revision-yyyymmdd" content="20181121" />
<meta http-equiv="Content-Language" content="en" />
<title>Apache HBase –
Bulk Loads in Apache HBase (TM)
@@ -316,7 +316,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-11-20</li>
+ <li id="publishDate" class="pull-right">Last Published: 2018-11-21</li>
</p>
</div>
[08/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
index 455d344..ed0431e 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/quotas/QuotaUtil.KeyFromRow.html
@@ -65,258 +65,265 @@
<span class="sourceLineNo">057</span> public static final String QUOTA_CONF_KEY = "hbase.quota.enabled";<a name="line.57"></a>
<span class="sourceLineNo">058</span> private static final boolean QUOTA_ENABLED_DEFAULT = false;<a name="line.58"></a>
<span class="sourceLineNo">059</span><a name="line.59"></a>
-<span class="sourceLineNo">060</span> /** Table descriptor for Quota internal table */<a name="line.60"></a>
-<span class="sourceLineNo">061</span> public static final HTableDescriptor QUOTA_TABLE_DESC =<a name="line.61"></a>
-<span class="sourceLineNo">062</span> new HTableDescriptor(QUOTA_TABLE_NAME);<a name="line.62"></a>
-<span class="sourceLineNo">063</span> static {<a name="line.63"></a>
-<span class="sourceLineNo">064</span> QUOTA_TABLE_DESC.addFamily(<a name="line.64"></a>
-<span class="sourceLineNo">065</span> new HColumnDescriptor(QUOTA_FAMILY_INFO)<a name="line.65"></a>
-<span class="sourceLineNo">066</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.66"></a>
-<span class="sourceLineNo">067</span> .setBloomFilterType(BloomType.ROW)<a name="line.67"></a>
-<span class="sourceLineNo">068</span> .setMaxVersions(1)<a name="line.68"></a>
-<span class="sourceLineNo">069</span> );<a name="line.69"></a>
-<span class="sourceLineNo">070</span> QUOTA_TABLE_DESC.addFamily(<a name="line.70"></a>
-<span class="sourceLineNo">071</span> new HColumnDescriptor(QUOTA_FAMILY_USAGE)<a name="line.71"></a>
-<span class="sourceLineNo">072</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.72"></a>
-<span class="sourceLineNo">073</span> .setBloomFilterType(BloomType.ROW)<a name="line.73"></a>
-<span class="sourceLineNo">074</span> .setMaxVersions(1)<a name="line.74"></a>
-<span class="sourceLineNo">075</span> );<a name="line.75"></a>
-<span class="sourceLineNo">076</span> }<a name="line.76"></a>
-<span class="sourceLineNo">077</span><a name="line.77"></a>
-<span class="sourceLineNo">078</span> /** Returns true if the support for quota is enabled */<a name="line.78"></a>
-<span class="sourceLineNo">079</span> public static boolean isQuotaEnabled(final Configuration conf) {<a name="line.79"></a>
-<span class="sourceLineNo">080</span> return conf.getBoolean(QUOTA_CONF_KEY, QUOTA_ENABLED_DEFAULT);<a name="line.80"></a>
-<span class="sourceLineNo">081</span> }<a name="line.81"></a>
-<span class="sourceLineNo">082</span><a name="line.82"></a>
-<span class="sourceLineNo">083</span> /* =========================================================================<a name="line.83"></a>
-<span class="sourceLineNo">084</span> * Quota "settings" helpers<a name="line.84"></a>
-<span class="sourceLineNo">085</span> */<a name="line.85"></a>
-<span class="sourceLineNo">086</span> public static void addTableQuota(final Connection connection, final TableName table,<a name="line.86"></a>
-<span class="sourceLineNo">087</span> final Quotas data) throws IOException {<a name="line.87"></a>
-<span class="sourceLineNo">088</span> addQuotas(connection, getTableRowKey(table), data);<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> public static void deleteTableQuota(final Connection connection, final TableName table)<a name="line.91"></a>
-<span class="sourceLineNo">092</span> throws IOException {<a name="line.92"></a>
-<span class="sourceLineNo">093</span> deleteQuotas(connection, getTableRowKey(table));<a name="line.93"></a>
-<span class="sourceLineNo">094</span> }<a name="line.94"></a>
-<span class="sourceLineNo">095</span><a name="line.95"></a>
-<span class="sourceLineNo">096</span> public static void addNamespaceQuota(final Connection connection, final String namespace,<a name="line.96"></a>
-<span class="sourceLineNo">097</span> final Quotas data) throws IOException {<a name="line.97"></a>
-<span class="sourceLineNo">098</span> addQuotas(connection, getNamespaceRowKey(namespace), data);<a name="line.98"></a>
-<span class="sourceLineNo">099</span> }<a name="line.99"></a>
-<span class="sourceLineNo">100</span><a name="line.100"></a>
-<span class="sourceLineNo">101</span> public static void deleteNamespaceQuota(final Connection connection, final String namespace)<a name="line.101"></a>
-<span class="sourceLineNo">102</span> throws IOException {<a name="line.102"></a>
-<span class="sourceLineNo">103</span> deleteQuotas(connection, getNamespaceRowKey(namespace));<a name="line.103"></a>
-<span class="sourceLineNo">104</span> }<a name="line.104"></a>
-<span class="sourceLineNo">105</span><a name="line.105"></a>
-<span class="sourceLineNo">106</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.106"></a>
-<span class="sourceLineNo">107</span> final Quotas data) throws IOException {<a name="line.107"></a>
-<span class="sourceLineNo">108</span> addQuotas(connection, getUserRowKey(user), data);<a name="line.108"></a>
-<span class="sourceLineNo">109</span> }<a name="line.109"></a>
-<span class="sourceLineNo">110</span><a name="line.110"></a>
-<span class="sourceLineNo">111</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.111"></a>
-<span class="sourceLineNo">112</span> final TableName table, final Quotas data) throws IOException {<a name="line.112"></a>
-<span class="sourceLineNo">113</span> addQuotas(connection, getUserRowKey(user), getSettingsQualifierForUserTable(table), data);<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> public static void addUserQuota(final Connection connection, final String user,<a name="line.116"></a>
-<span class="sourceLineNo">117</span> final String namespace, final Quotas data) throws IOException {<a name="line.117"></a>
-<span class="sourceLineNo">118</span> addQuotas(connection, getUserRowKey(user),<a name="line.118"></a>
-<span class="sourceLineNo">119</span> getSettingsQualifierForUserNamespace(namespace), data);<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> public static void deleteUserQuota(final Connection connection, final String user)<a name="line.122"></a>
-<span class="sourceLineNo">123</span> throws IOException {<a name="line.123"></a>
-<span class="sourceLineNo">124</span> deleteQuotas(connection, getUserRowKey(user));<a name="line.124"></a>
-<span class="sourceLineNo">125</span> }<a name="line.125"></a>
-<span class="sourceLineNo">126</span><a name="line.126"></a>
-<span class="sourceLineNo">127</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.127"></a>
-<span class="sourceLineNo">128</span> final TableName table) throws IOException {<a name="line.128"></a>
-<span class="sourceLineNo">129</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.129"></a>
-<span class="sourceLineNo">130</span> getSettingsQualifierForUserTable(table));<a name="line.130"></a>
-<span class="sourceLineNo">131</span> }<a name="line.131"></a>
-<span class="sourceLineNo">132</span><a name="line.132"></a>
-<span class="sourceLineNo">133</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.133"></a>
-<span class="sourceLineNo">134</span> final String namespace) throws IOException {<a name="line.134"></a>
-<span class="sourceLineNo">135</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.135"></a>
-<span class="sourceLineNo">136</span> getSettingsQualifierForUserNamespace(namespace));<a name="line.136"></a>
-<span class="sourceLineNo">137</span> }<a name="line.137"></a>
-<span class="sourceLineNo">138</span><a name="line.138"></a>
-<span class="sourceLineNo">139</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.139"></a>
-<span class="sourceLineNo">140</span> final Quotas data) throws IOException {<a name="line.140"></a>
-<span class="sourceLineNo">141</span> addQuotas(connection, rowKey, QUOTA_QUALIFIER_SETTINGS, data);<a name="line.141"></a>
-<span class="sourceLineNo">142</span> }<a name="line.142"></a>
-<span class="sourceLineNo">143</span><a name="line.143"></a>
-<span class="sourceLineNo">144</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.144"></a>
-<span class="sourceLineNo">145</span> final byte[] qualifier, final Quotas data) throws IOException {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> Put put = new Put(rowKey);<a name="line.146"></a>
-<span class="sourceLineNo">147</span> put.addColumn(QUOTA_FAMILY_INFO, qualifier, quotasToData(data));<a name="line.147"></a>
-<span class="sourceLineNo">148</span> doPut(connection, put);<a name="line.148"></a>
+<span class="sourceLineNo">060</span> public static final String READ_CAPACITY_UNIT_CONF_KEY = "hbase.quota.read.capacity.unit";<a name="line.60"></a>
+<span class="sourceLineNo">061</span> // the default one read capacity unit is 1024 bytes (1KB)<a name="line.61"></a>
+<span class="sourceLineNo">062</span> public static final long DEFAULT_READ_CAPACITY_UNIT = 1024;<a name="line.62"></a>
+<span class="sourceLineNo">063</span> public static final String WRITE_CAPACITY_UNIT_CONF_KEY = "hbase.quota.write.capacity.unit";<a name="line.63"></a>
+<span class="sourceLineNo">064</span> // the default one write capacity unit is 1024 bytes (1KB)<a name="line.64"></a>
+<span class="sourceLineNo">065</span> public static final long DEFAULT_WRITE_CAPACITY_UNIT = 1024;<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span> /** Table descriptor for Quota internal table */<a name="line.67"></a>
+<span class="sourceLineNo">068</span> public static final HTableDescriptor QUOTA_TABLE_DESC =<a name="line.68"></a>
+<span class="sourceLineNo">069</span> new HTableDescriptor(QUOTA_TABLE_NAME);<a name="line.69"></a>
+<span class="sourceLineNo">070</span> static {<a name="line.70"></a>
+<span class="sourceLineNo">071</span> QUOTA_TABLE_DESC.addFamily(<a name="line.71"></a>
+<span class="sourceLineNo">072</span> new HColumnDescriptor(QUOTA_FAMILY_INFO)<a name="line.72"></a>
+<span class="sourceLineNo">073</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.73"></a>
+<span class="sourceLineNo">074</span> .setBloomFilterType(BloomType.ROW)<a name="line.74"></a>
+<span class="sourceLineNo">075</span> .setMaxVersions(1)<a name="line.75"></a>
+<span class="sourceLineNo">076</span> );<a name="line.76"></a>
+<span class="sourceLineNo">077</span> QUOTA_TABLE_DESC.addFamily(<a name="line.77"></a>
+<span class="sourceLineNo">078</span> new HColumnDescriptor(QUOTA_FAMILY_USAGE)<a name="line.78"></a>
+<span class="sourceLineNo">079</span> .setScope(HConstants.REPLICATION_SCOPE_LOCAL)<a name="line.79"></a>
+<span class="sourceLineNo">080</span> .setBloomFilterType(BloomType.ROW)<a name="line.80"></a>
+<span class="sourceLineNo">081</span> .setMaxVersions(1)<a name="line.81"></a>
+<span class="sourceLineNo">082</span> );<a name="line.82"></a>
+<span class="sourceLineNo">083</span> }<a name="line.83"></a>
+<span class="sourceLineNo">084</span><a name="line.84"></a>
+<span class="sourceLineNo">085</span> /** Returns true if the support for quota is enabled */<a name="line.85"></a>
+<span class="sourceLineNo">086</span> public static boolean isQuotaEnabled(final Configuration conf) {<a name="line.86"></a>
+<span class="sourceLineNo">087</span> return conf.getBoolean(QUOTA_CONF_KEY, QUOTA_ENABLED_DEFAULT);<a name="line.87"></a>
+<span class="sourceLineNo">088</span> }<a name="line.88"></a>
+<span class="sourceLineNo">089</span><a name="line.89"></a>
+<span class="sourceLineNo">090</span> /* =========================================================================<a name="line.90"></a>
+<span class="sourceLineNo">091</span> * Quota "settings" helpers<a name="line.91"></a>
+<span class="sourceLineNo">092</span> */<a name="line.92"></a>
+<span class="sourceLineNo">093</span> public static void addTableQuota(final Connection connection, final TableName table,<a name="line.93"></a>
+<span class="sourceLineNo">094</span> final Quotas data) throws IOException {<a name="line.94"></a>
+<span class="sourceLineNo">095</span> addQuotas(connection, getTableRowKey(table), data);<a name="line.95"></a>
+<span class="sourceLineNo">096</span> }<a name="line.96"></a>
+<span class="sourceLineNo">097</span><a name="line.97"></a>
+<span class="sourceLineNo">098</span> public static void deleteTableQuota(final Connection connection, final TableName table)<a name="line.98"></a>
+<span class="sourceLineNo">099</span> throws IOException {<a name="line.99"></a>
+<span class="sourceLineNo">100</span> deleteQuotas(connection, getTableRowKey(table));<a name="line.100"></a>
+<span class="sourceLineNo">101</span> }<a name="line.101"></a>
+<span class="sourceLineNo">102</span><a name="line.102"></a>
+<span class="sourceLineNo">103</span> public static void addNamespaceQuota(final Connection connection, final String namespace,<a name="line.103"></a>
+<span class="sourceLineNo">104</span> final Quotas data) throws IOException {<a name="line.104"></a>
+<span class="sourceLineNo">105</span> addQuotas(connection, getNamespaceRowKey(namespace), data);<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> public static void deleteNamespaceQuota(final Connection connection, final String namespace)<a name="line.108"></a>
+<span class="sourceLineNo">109</span> throws IOException {<a name="line.109"></a>
+<span class="sourceLineNo">110</span> deleteQuotas(connection, getNamespaceRowKey(namespace));<a name="line.110"></a>
+<span class="sourceLineNo">111</span> }<a name="line.111"></a>
+<span class="sourceLineNo">112</span><a name="line.112"></a>
+<span class="sourceLineNo">113</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.113"></a>
+<span class="sourceLineNo">114</span> final Quotas data) throws IOException {<a name="line.114"></a>
+<span class="sourceLineNo">115</span> addQuotas(connection, getUserRowKey(user), data);<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> public static void addUserQuota(final Connection connection, final String user,<a name="line.118"></a>
+<span class="sourceLineNo">119</span> final TableName table, final Quotas data) throws IOException {<a name="line.119"></a>
+<span class="sourceLineNo">120</span> addQuotas(connection, getUserRowKey(user), getSettingsQualifierForUserTable(table), data);<a name="line.120"></a>
+<span class="sourceLineNo">121</span> }<a name="line.121"></a>
+<span class="sourceLineNo">122</span><a name="line.122"></a>
+<span class="sourceLineNo">123</span> public static void addUserQuota(final Connection connection, final String user,<a name="line.123"></a>
+<span class="sourceLineNo">124</span> final String namespace, final Quotas data) throws IOException {<a name="line.124"></a>
+<span class="sourceLineNo">125</span> addQuotas(connection, getUserRowKey(user),<a name="line.125"></a>
+<span class="sourceLineNo">126</span> getSettingsQualifierForUserNamespace(namespace), data);<a name="line.126"></a>
+<span class="sourceLineNo">127</span> }<a name="line.127"></a>
+<span class="sourceLineNo">128</span><a name="line.128"></a>
+<span class="sourceLineNo">129</span> public static void deleteUserQuota(final Connection connection, final String user)<a name="line.129"></a>
+<span class="sourceLineNo">130</span> throws IOException {<a name="line.130"></a>
+<span class="sourceLineNo">131</span> deleteQuotas(connection, getUserRowKey(user));<a name="line.131"></a>
+<span class="sourceLineNo">132</span> }<a name="line.132"></a>
+<span class="sourceLineNo">133</span><a name="line.133"></a>
+<span class="sourceLineNo">134</span> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.134"></a>
+<span class="sourceLineNo">135</span> final TableName table) throws IOException {<a name="line.135"></a>
+<span class="sourceLineNo">136</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.136"></a>
+<span class="sourceLineNo">137</span> getSettingsQualifierForUserTable(table));<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> public static void deleteUserQuota(final Connection connection, final String user,<a name="line.140"></a>
+<span class="sourceLineNo">141</span> final String namespace) throws IOException {<a name="line.141"></a>
+<span class="sourceLineNo">142</span> deleteQuotas(connection, getUserRowKey(user),<a name="line.142"></a>
+<span class="sourceLineNo">143</span> getSettingsQualifierForUserNamespace(namespace));<a name="line.143"></a>
+<span class="sourceLineNo">144</span> }<a name="line.144"></a>
+<span class="sourceLineNo">145</span><a name="line.145"></a>
+<span class="sourceLineNo">146</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.146"></a>
+<span class="sourceLineNo">147</span> final Quotas data) throws IOException {<a name="line.147"></a>
+<span class="sourceLineNo">148</span> addQuotas(connection, rowKey, QUOTA_QUALIFIER_SETTINGS, data);<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> private static void deleteQuotas(final Connection connection, final byte[] rowKey)<a name="line.151"></a>
-<span class="sourceLineNo">152</span> throws IOException {<a name="line.152"></a>
-<span class="sourceLineNo">153</span> deleteQuotas(connection, rowKey, null);<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> private static void deleteQuotas(final Connection connection, final byte[] rowKey,<a name="line.156"></a>
-<span class="sourceLineNo">157</span> final byte[] qualifier) throws IOException {<a name="line.157"></a>
-<span class="sourceLineNo">158</span> Delete delete = new Delete(rowKey);<a name="line.158"></a>
-<span class="sourceLineNo">159</span> if (qualifier != null) {<a name="line.159"></a>
-<span class="sourceLineNo">160</span> delete.addColumns(QUOTA_FAMILY_INFO, qualifier);<a name="line.160"></a>
-<span class="sourceLineNo">161</span> }<a name="line.161"></a>
-<span class="sourceLineNo">162</span> doDelete(connection, delete);<a name="line.162"></a>
-<span class="sourceLineNo">163</span> }<a name="line.163"></a>
-<span class="sourceLineNo">164</span><a name="line.164"></a>
-<span class="sourceLineNo">165</span> public static Map<String, UserQuotaState> fetchUserQuotas(final Connection connection,<a name="line.165"></a>
-<span class="sourceLineNo">166</span> final List<Get> gets) throws IOException {<a name="line.166"></a>
-<span class="sourceLineNo">167</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.167"></a>
-<span class="sourceLineNo">168</span> Result[] results = doGet(connection, gets);<a name="line.168"></a>
-<span class="sourceLineNo">169</span><a name="line.169"></a>
-<span class="sourceLineNo">170</span> Map<String, UserQuotaState> userQuotas = new HashMap<>(results.length);<a name="line.170"></a>
-<span class="sourceLineNo">171</span> for (int i = 0; i < results.length; ++i) {<a name="line.171"></a>
-<span class="sourceLineNo">172</span> byte[] key = gets.get(i).getRow();<a name="line.172"></a>
-<span class="sourceLineNo">173</span> assert isUserRowKey(key);<a name="line.173"></a>
-<span class="sourceLineNo">174</span> String user = getUserFromRowKey(key);<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> final UserQuotaState quotaInfo = new UserQuotaState(nowTs);<a name="line.176"></a>
-<span class="sourceLineNo">177</span> userQuotas.put(user, quotaInfo);<a name="line.177"></a>
-<span class="sourceLineNo">178</span><a name="line.178"></a>
-<span class="sourceLineNo">179</span> if (results[i].isEmpty()) continue;<a name="line.179"></a>
-<span class="sourceLineNo">180</span> assert Bytes.equals(key, results[i].getRow());<a name="line.180"></a>
-<span class="sourceLineNo">181</span><a name="line.181"></a>
-<span class="sourceLineNo">182</span> try {<a name="line.182"></a>
-<span class="sourceLineNo">183</span> parseUserResult(user, results[i], new UserQuotasVisitor() {<a name="line.183"></a>
-<span class="sourceLineNo">184</span> @Override<a name="line.184"></a>
-<span class="sourceLineNo">185</span> public void visitUserQuotas(String userName, String namespace, Quotas quotas) {<a name="line.185"></a>
-<span class="sourceLineNo">186</span> quotaInfo.setQuotas(namespace, quotas);<a name="line.186"></a>
-<span class="sourceLineNo">187</span> }<a name="line.187"></a>
+<span class="sourceLineNo">151</span> private static void addQuotas(final Connection connection, final byte[] rowKey,<a name="line.151"></a>
+<span class="sourceLineNo">152</span> final byte[] qualifier, final Quotas data) throws IOException {<a name="line.152"></a>
+<span class="sourceLineNo">153</span> Put put = new Put(rowKey);<a name="line.153"></a>
+<span class="sourceLineNo">154</span> put.addColumn(QUOTA_FAMILY_INFO, qualifier, quotasToData(data));<a name="line.154"></a>
+<span class="sourceLineNo">155</span> doPut(connection, put);<a name="line.155"></a>
+<span class="sourceLineNo">156</span> }<a name="line.156"></a>
+<span class="sourceLineNo">157</span><a name="line.157"></a>
+<span class="sourceLineNo">158</span> private static void deleteQuotas(final Connection connection, final byte[] rowKey)<a name="line.158"></a>
+<span class="sourceLineNo">159</span> throws IOException {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> deleteQuotas(connection, rowKey, null);<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> private static void deleteQuotas(final Connection connection, final byte[] rowKey,<a name="line.163"></a>
+<span class="sourceLineNo">164</span> final byte[] qualifier) throws IOException {<a name="line.164"></a>
+<span class="sourceLineNo">165</span> Delete delete = new Delete(rowKey);<a name="line.165"></a>
+<span class="sourceLineNo">166</span> if (qualifier != null) {<a name="line.166"></a>
+<span class="sourceLineNo">167</span> delete.addColumns(QUOTA_FAMILY_INFO, qualifier);<a name="line.167"></a>
+<span class="sourceLineNo">168</span> }<a name="line.168"></a>
+<span class="sourceLineNo">169</span> doDelete(connection, delete);<a name="line.169"></a>
+<span class="sourceLineNo">170</span> }<a name="line.170"></a>
+<span class="sourceLineNo">171</span><a name="line.171"></a>
+<span class="sourceLineNo">172</span> public static Map<String, UserQuotaState> fetchUserQuotas(final Connection connection,<a name="line.172"></a>
+<span class="sourceLineNo">173</span> final List<Get> gets) throws IOException {<a name="line.173"></a>
+<span class="sourceLineNo">174</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.174"></a>
+<span class="sourceLineNo">175</span> Result[] results = doGet(connection, gets);<a name="line.175"></a>
+<span class="sourceLineNo">176</span><a name="line.176"></a>
+<span class="sourceLineNo">177</span> Map<String, UserQuotaState> userQuotas = new HashMap<>(results.length);<a name="line.177"></a>
+<span class="sourceLineNo">178</span> for (int i = 0; i < results.length; ++i) {<a name="line.178"></a>
+<span class="sourceLineNo">179</span> byte[] key = gets.get(i).getRow();<a name="line.179"></a>
+<span class="sourceLineNo">180</span> assert isUserRowKey(key);<a name="line.180"></a>
+<span class="sourceLineNo">181</span> String user = getUserFromRowKey(key);<a name="line.181"></a>
+<span class="sourceLineNo">182</span><a name="line.182"></a>
+<span class="sourceLineNo">183</span> final UserQuotaState quotaInfo = new UserQuotaState(nowTs);<a name="line.183"></a>
+<span class="sourceLineNo">184</span> userQuotas.put(user, quotaInfo);<a name="line.184"></a>
+<span class="sourceLineNo">185</span><a name="line.185"></a>
+<span class="sourceLineNo">186</span> if (results[i].isEmpty()) continue;<a name="line.186"></a>
+<span class="sourceLineNo">187</span> assert Bytes.equals(key, results[i].getRow());<a name="line.187"></a>
<span class="sourceLineNo">188</span><a name="line.188"></a>
-<span class="sourceLineNo">189</span> @Override<a name="line.189"></a>
-<span class="sourceLineNo">190</span> public void visitUserQuotas(String userName, TableName table, Quotas quotas) {<a name="line.190"></a>
-<span class="sourceLineNo">191</span> quotaInfo.setQuotas(table, quotas);<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> @Override<a name="line.194"></a>
-<span class="sourceLineNo">195</span> public void visitUserQuotas(String userName, Quotas quotas) {<a name="line.195"></a>
-<span class="sourceLineNo">196</span> quotaInfo.setQuotas(quotas);<a name="line.196"></a>
-<span class="sourceLineNo">197</span> }<a name="line.197"></a>
-<span class="sourceLineNo">198</span> });<a name="line.198"></a>
-<span class="sourceLineNo">199</span> } catch (IOException e) {<a name="line.199"></a>
-<span class="sourceLineNo">200</span> LOG.error("Unable to parse user '" + user + "' quotas", e);<a name="line.200"></a>
-<span class="sourceLineNo">201</span> userQuotas.remove(user);<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span> }<a name="line.203"></a>
-<span class="sourceLineNo">204</span> return userQuotas;<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> public static Map<TableName, QuotaState> fetchTableQuotas(final Connection connection,<a name="line.207"></a>
-<span class="sourceLineNo">208</span> final List<Get> gets) throws IOException {<a name="line.208"></a>
-<span class="sourceLineNo">209</span> return fetchGlobalQuotas("table", connection, gets, new KeyFromRow<TableName>() {<a name="line.209"></a>
-<span class="sourceLineNo">210</span> @Override<a name="line.210"></a>
-<span class="sourceLineNo">211</span> public TableName getKeyFromRow(final byte[] row) {<a name="line.211"></a>
-<span class="sourceLineNo">212</span> assert isTableRowKey(row);<a name="line.212"></a>
-<span class="sourceLineNo">213</span> return getTableFromRowKey(row);<a name="line.213"></a>
-<span class="sourceLineNo">214</span> }<a name="line.214"></a>
-<span class="sourceLineNo">215</span> });<a name="line.215"></a>
-<span class="sourceLineNo">216</span> }<a name="line.216"></a>
-<span class="sourceLineNo">217</span><a name="line.217"></a>
-<span class="sourceLineNo">218</span> public static Map<String, QuotaState> fetchNamespaceQuotas(final Connection connection,<a name="line.218"></a>
-<span class="sourceLineNo">219</span> final List<Get> gets) throws IOException {<a name="line.219"></a>
-<span class="sourceLineNo">220</span> return fetchGlobalQuotas("namespace", connection, gets, new KeyFromRow<String>() {<a name="line.220"></a>
-<span class="sourceLineNo">221</span> @Override<a name="line.221"></a>
-<span class="sourceLineNo">222</span> public String getKeyFromRow(final byte[] row) {<a name="line.222"></a>
-<span class="sourceLineNo">223</span> assert isNamespaceRowKey(row);<a name="line.223"></a>
-<span class="sourceLineNo">224</span> return getNamespaceFromRowKey(row);<a name="line.224"></a>
-<span class="sourceLineNo">225</span> }<a name="line.225"></a>
-<span class="sourceLineNo">226</span> });<a name="line.226"></a>
-<span class="sourceLineNo">227</span> }<a name="line.227"></a>
-<span class="sourceLineNo">228</span><a name="line.228"></a>
-<span class="sourceLineNo">229</span> public static <K> Map<K, QuotaState> fetchGlobalQuotas(final String type,<a name="line.229"></a>
-<span class="sourceLineNo">230</span> final Connection connection, final List<Get> gets, final KeyFromRow<K> kfr)<a name="line.230"></a>
-<span class="sourceLineNo">231</span> throws IOException {<a name="line.231"></a>
-<span class="sourceLineNo">232</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.232"></a>
-<span class="sourceLineNo">233</span> Result[] results = doGet(connection, gets);<a name="line.233"></a>
-<span class="sourceLineNo">234</span><a name="line.234"></a>
-<span class="sourceLineNo">235</span> Map<K, QuotaState> globalQuotas = new HashMap<>(results.length);<a name="line.235"></a>
-<span class="sourceLineNo">236</span> for (int i = 0; i < results.length; ++i) {<a name="line.236"></a>
-<span class="sourceLineNo">237</span> byte[] row = gets.get(i).getRow();<a name="line.237"></a>
-<span class="sourceLineNo">238</span> K key = kfr.getKeyFromRow(row);<a name="line.238"></a>
-<span class="sourceLineNo">239</span><a name="line.239"></a>
-<span class="sourceLineNo">240</span> QuotaState quotaInfo = new QuotaState(nowTs);<a name="line.240"></a>
-<span class="sourceLineNo">241</span> globalQuotas.put(key, quotaInfo);<a name="line.241"></a>
-<span class="sourceLineNo">242</span><a name="line.242"></a>
-<span class="sourceLineNo">243</span> if (results[i].isEmpty()) continue;<a name="line.243"></a>
-<span class="sourceLineNo">244</span> assert Bytes.equals(row, results[i].getRow());<a name="line.244"></a>
-<span class="sourceLineNo">245</span><a name="line.245"></a>
-<span class="sourceLineNo">246</span> byte[] data = results[i].getValue(QUOTA_FAMILY_INFO, QUOTA_QUALIFIER_SETTINGS);<a name="line.246"></a>
-<span class="sourceLineNo">247</span> if (data == null) continue;<a name="line.247"></a>
-<span class="sourceLineNo">248</span><a name="line.248"></a>
-<span class="sourceLineNo">249</span> try {<a name="line.249"></a>
-<span class="sourceLineNo">250</span> Quotas quotas = quotasFromData(data);<a name="line.250"></a>
-<span class="sourceLineNo">251</span> quotaInfo.setQuotas(quotas);<a name="line.251"></a>
-<span class="sourceLineNo">252</span> } catch (IOException e) {<a name="line.252"></a>
-<span class="sourceLineNo">253</span> LOG.error("Unable to parse " + type + " '" + key + "' quotas", e);<a name="line.253"></a>
-<span class="sourceLineNo">254</span> globalQuotas.remove(key);<a name="line.254"></a>
-<span class="sourceLineNo">255</span> }<a name="line.255"></a>
-<span class="sourceLineNo">256</span> }<a name="line.256"></a>
-<span class="sourceLineNo">257</span> return globalQuotas;<a name="line.257"></a>
-<span class="sourceLineNo">258</span> }<a name="line.258"></a>
-<span class="sourceLineNo">259</span><a name="line.259"></a>
-<span class="sourceLineNo">260</span> private static interface KeyFromRow<T> {<a name="line.260"></a>
-<span class="sourceLineNo">261</span> T getKeyFromRow(final byte[] row);<a name="line.261"></a>
-<span class="sourceLineNo">262</span> }<a name="line.262"></a>
-<span class="sourceLineNo">263</span><a name="line.263"></a>
-<span class="sourceLineNo">264</span> /* =========================================================================<a name="line.264"></a>
-<span class="sourceLineNo">265</span> * HTable helpers<a name="line.265"></a>
-<span class="sourceLineNo">266</span> */<a name="line.266"></a>
-<span class="sourceLineNo">267</span> private static void doPut(final Connection connection, final Put put)<a name="line.267"></a>
-<span class="sourceLineNo">268</span> throws IOException {<a name="line.268"></a>
-<span class="sourceLineNo">269</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.269"></a>
-<span class="sourceLineNo">270</span> table.put(put);<a name="line.270"></a>
-<span class="sourceLineNo">271</span> }<a name="line.271"></a>
-<span class="sourceLineNo">272</span> }<a name="line.272"></a>
-<span class="sourceLineNo">273</span><a name="line.273"></a>
-<span class="sourceLineNo">274</span> private static void doDelete(final Connection connection, final Delete delete)<a name="line.274"></a>
+<span class="sourceLineNo">189</span> try {<a name="line.189"></a>
+<span class="sourceLineNo">190</span> parseUserResult(user, results[i], new UserQuotasVisitor() {<a name="line.190"></a>
+<span class="sourceLineNo">191</span> @Override<a name="line.191"></a>
+<span class="sourceLineNo">192</span> public void visitUserQuotas(String userName, String namespace, Quotas quotas) {<a name="line.192"></a>
+<span class="sourceLineNo">193</span> quotaInfo.setQuotas(namespace, quotas);<a name="line.193"></a>
+<span class="sourceLineNo">194</span> }<a name="line.194"></a>
+<span class="sourceLineNo">195</span><a name="line.195"></a>
+<span class="sourceLineNo">196</span> @Override<a name="line.196"></a>
+<span class="sourceLineNo">197</span> public void visitUserQuotas(String userName, TableName table, Quotas quotas) {<a name="line.197"></a>
+<span class="sourceLineNo">198</span> quotaInfo.setQuotas(table, quotas);<a name="line.198"></a>
+<span class="sourceLineNo">199</span> }<a name="line.199"></a>
+<span class="sourceLineNo">200</span><a name="line.200"></a>
+<span class="sourceLineNo">201</span> @Override<a name="line.201"></a>
+<span class="sourceLineNo">202</span> public void visitUserQuotas(String userName, Quotas quotas) {<a name="line.202"></a>
+<span class="sourceLineNo">203</span> quotaInfo.setQuotas(quotas);<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> } catch (IOException e) {<a name="line.206"></a>
+<span class="sourceLineNo">207</span> LOG.error("Unable to parse user '" + user + "' quotas", e);<a name="line.207"></a>
+<span class="sourceLineNo">208</span> userQuotas.remove(user);<a name="line.208"></a>
+<span class="sourceLineNo">209</span> }<a name="line.209"></a>
+<span class="sourceLineNo">210</span> }<a name="line.210"></a>
+<span class="sourceLineNo">211</span> return userQuotas;<a name="line.211"></a>
+<span class="sourceLineNo">212</span> }<a name="line.212"></a>
+<span class="sourceLineNo">213</span><a name="line.213"></a>
+<span class="sourceLineNo">214</span> public static Map<TableName, QuotaState> fetchTableQuotas(final Connection connection,<a name="line.214"></a>
+<span class="sourceLineNo">215</span> final List<Get> gets) throws IOException {<a name="line.215"></a>
+<span class="sourceLineNo">216</span> return fetchGlobalQuotas("table", connection, gets, new KeyFromRow<TableName>() {<a name="line.216"></a>
+<span class="sourceLineNo">217</span> @Override<a name="line.217"></a>
+<span class="sourceLineNo">218</span> public TableName getKeyFromRow(final byte[] row) {<a name="line.218"></a>
+<span class="sourceLineNo">219</span> assert isTableRowKey(row);<a name="line.219"></a>
+<span class="sourceLineNo">220</span> return getTableFromRowKey(row);<a name="line.220"></a>
+<span class="sourceLineNo">221</span> }<a name="line.221"></a>
+<span class="sourceLineNo">222</span> });<a name="line.222"></a>
+<span class="sourceLineNo">223</span> }<a name="line.223"></a>
+<span class="sourceLineNo">224</span><a name="line.224"></a>
+<span class="sourceLineNo">225</span> public static Map<String, QuotaState> fetchNamespaceQuotas(final Connection connection,<a name="line.225"></a>
+<span class="sourceLineNo">226</span> final List<Get> gets) throws IOException {<a name="line.226"></a>
+<span class="sourceLineNo">227</span> return fetchGlobalQuotas("namespace", connection, gets, new KeyFromRow<String>() {<a name="line.227"></a>
+<span class="sourceLineNo">228</span> @Override<a name="line.228"></a>
+<span class="sourceLineNo">229</span> public String getKeyFromRow(final byte[] row) {<a name="line.229"></a>
+<span class="sourceLineNo">230</span> assert isNamespaceRowKey(row);<a name="line.230"></a>
+<span class="sourceLineNo">231</span> return getNamespaceFromRowKey(row);<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> }<a name="line.234"></a>
+<span class="sourceLineNo">235</span><a name="line.235"></a>
+<span class="sourceLineNo">236</span> public static <K> Map<K, QuotaState> fetchGlobalQuotas(final String type,<a name="line.236"></a>
+<span class="sourceLineNo">237</span> final Connection connection, final List<Get> gets, final KeyFromRow<K> kfr)<a name="line.237"></a>
+<span class="sourceLineNo">238</span> throws IOException {<a name="line.238"></a>
+<span class="sourceLineNo">239</span> long nowTs = EnvironmentEdgeManager.currentTime();<a name="line.239"></a>
+<span class="sourceLineNo">240</span> Result[] results = doGet(connection, gets);<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span> Map<K, QuotaState> globalQuotas = new HashMap<>(results.length);<a name="line.242"></a>
+<span class="sourceLineNo">243</span> for (int i = 0; i < results.length; ++i) {<a name="line.243"></a>
+<span class="sourceLineNo">244</span> byte[] row = gets.get(i).getRow();<a name="line.244"></a>
+<span class="sourceLineNo">245</span> K key = kfr.getKeyFromRow(row);<a name="line.245"></a>
+<span class="sourceLineNo">246</span><a name="line.246"></a>
+<span class="sourceLineNo">247</span> QuotaState quotaInfo = new QuotaState(nowTs);<a name="line.247"></a>
+<span class="sourceLineNo">248</span> globalQuotas.put(key, quotaInfo);<a name="line.248"></a>
+<span class="sourceLineNo">249</span><a name="line.249"></a>
+<span class="sourceLineNo">250</span> if (results[i].isEmpty()) continue;<a name="line.250"></a>
+<span class="sourceLineNo">251</span> assert Bytes.equals(row, results[i].getRow());<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span> byte[] data = results[i].getValue(QUOTA_FAMILY_INFO, QUOTA_QUALIFIER_SETTINGS);<a name="line.253"></a>
+<span class="sourceLineNo">254</span> if (data == null) continue;<a name="line.254"></a>
+<span class="sourceLineNo">255</span><a name="line.255"></a>
+<span class="sourceLineNo">256</span> try {<a name="line.256"></a>
+<span class="sourceLineNo">257</span> Quotas quotas = quotasFromData(data);<a name="line.257"></a>
+<span class="sourceLineNo">258</span> quotaInfo.setQuotas(quotas);<a name="line.258"></a>
+<span class="sourceLineNo">259</span> } catch (IOException e) {<a name="line.259"></a>
+<span class="sourceLineNo">260</span> LOG.error("Unable to parse " + type + " '" + key + "' quotas", e);<a name="line.260"></a>
+<span class="sourceLineNo">261</span> globalQuotas.remove(key);<a name="line.261"></a>
+<span class="sourceLineNo">262</span> }<a name="line.262"></a>
+<span class="sourceLineNo">263</span> }<a name="line.263"></a>
+<span class="sourceLineNo">264</span> return globalQuotas;<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> private static interface KeyFromRow<T> {<a name="line.267"></a>
+<span class="sourceLineNo">268</span> T getKeyFromRow(final byte[] row);<a name="line.268"></a>
+<span class="sourceLineNo">269</span> }<a name="line.269"></a>
+<span class="sourceLineNo">270</span><a name="line.270"></a>
+<span class="sourceLineNo">271</span> /* =========================================================================<a name="line.271"></a>
+<span class="sourceLineNo">272</span> * HTable helpers<a name="line.272"></a>
+<span class="sourceLineNo">273</span> */<a name="line.273"></a>
+<span class="sourceLineNo">274</span> private static void doPut(final Connection connection, final Put put)<a name="line.274"></a>
<span class="sourceLineNo">275</span> throws IOException {<a name="line.275"></a>
<span class="sourceLineNo">276</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.276"></a>
-<span class="sourceLineNo">277</span> table.delete(delete);<a name="line.277"></a>
+<span class="sourceLineNo">277</span> table.put(put);<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> /* =========================================================================<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * Data Size Helpers<a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static long calculateMutationSize(final Mutation mutation) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span> long size = 0;<a name="line.285"></a>
-<span class="sourceLineNo">286</span> for (Map.Entry<byte [], List<Cell>> entry : mutation.getFamilyCellMap().entrySet()) {<a name="line.286"></a>
-<span class="sourceLineNo">287</span> for (Cell cell : entry.getValue()) {<a name="line.287"></a>
-<span class="sourceLineNo">288</span> size += KeyValueUtil.length(cell);<a name="line.288"></a>
-<span class="sourceLineNo">289</span> }<a name="line.289"></a>
-<span class="sourceLineNo">290</span> }<a name="line.290"></a>
-<span class="sourceLineNo">291</span> return size;<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> public static long calculateResultSize(final Result result) {<a name="line.294"></a>
-<span class="sourceLineNo">295</span> long size = 0;<a name="line.295"></a>
-<span class="sourceLineNo">296</span> for (Cell cell : result.rawCells()) {<a name="line.296"></a>
-<span class="sourceLineNo">297</span> size += KeyValueUtil.length(cell);<a name="line.297"></a>
-<span class="sourceLineNo">298</span> }<a name="line.298"></a>
-<span class="sourceLineNo">299</span> return size;<a name="line.299"></a>
-<span class="sourceLineNo">300</span> }<a name="line.300"></a>
-<span class="sourceLineNo">301</span><a name="line.301"></a>
-<span class="sourceLineNo">302</span> public static long calculateResultSize(final List<Result> results) {<a name="line.302"></a>
-<span class="sourceLineNo">303</span> long size = 0;<a name="line.303"></a>
-<span class="sourceLineNo">304</span> for (Result result: results) {<a name="line.304"></a>
-<span class="sourceLineNo">305</span> for (Cell cell : result.rawCells()) {<a name="line.305"></a>
-<span class="sourceLineNo">306</span> size += KeyValueUtil.length(cell);<a name="line.306"></a>
-<span class="sourceLineNo">307</span> }<a name="line.307"></a>
-<span class="sourceLineNo">308</span> }<a name="line.308"></a>
-<span class="sourceLineNo">309</span> return size;<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">281</span> private static void doDelete(final Connection connection, final Delete delete)<a name="line.281"></a>
+<span class="sourceLineNo">282</span> throws IOException {<a name="line.282"></a>
+<span class="sourceLineNo">283</span> try (Table table = connection.getTable(QuotaUtil.QUOTA_TABLE_NAME)) {<a name="line.283"></a>
+<span class="sourceLineNo">284</span> table.delete(delete);<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><a name="line.287"></a>
+<span class="sourceLineNo">288</span> /* =========================================================================<a name="line.288"></a>
+<span class="sourceLineNo">289</span> * Data Size Helpers<a name="line.289"></a>
+<span class="sourceLineNo">290</span> */<a name="line.290"></a>
+<span class="sourceLineNo">291</span> public static long calculateMutationSize(final Mutation mutation) {<a name="line.291"></a>
+<span class="sourceLineNo">292</span> long size = 0;<a name="line.292"></a>
+<span class="sourceLineNo">293</span> for (Map.Entry<byte [], List<Cell>> entry : mutation.getFamilyCellMap().entrySet()) {<a name="line.293"></a>
+<span class="sourceLineNo">294</span> for (Cell cell : entry.getValue()) {<a name="line.294"></a>
+<span class="sourceLineNo">295</span> size += KeyValueUtil.length(cell);<a name="line.295"></a>
+<span class="sourceLineNo">296</span> }<a name="line.296"></a>
+<span class="sourceLineNo">297</span> }<a name="line.297"></a>
+<span class="sourceLineNo">298</span> return size;<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> public static long calculateResultSize(final Result result) {<a name="line.301"></a>
+<span class="sourceLineNo">302</span> long size = 0;<a name="line.302"></a>
+<span class="sourceLineNo">303</span> for (Cell cell : result.rawCells()) {<a name="line.303"></a>
+<span class="sourceLineNo">304</span> size += KeyValueUtil.length(cell);<a name="line.304"></a>
+<span class="sourceLineNo">305</span> }<a name="line.305"></a>
+<span class="sourceLineNo">306</span> return size;<a name="line.306"></a>
+<span class="sourceLineNo">307</span> }<a name="line.307"></a>
+<span class="sourceLineNo">308</span><a name="line.308"></a>
+<span class="sourceLineNo">309</span> public static long calculateResultSize(final List<Result> results) {<a name="line.309"></a>
+<span class="sourceLineNo">310</span> long size = 0;<a name="line.310"></a>
+<span class="sourceLineNo">311</span> for (Result result: results) {<a name="line.311"></a>
+<span class="sourceLineNo">312</span> for (Cell cell : result.rawCells()) {<a name="line.312"></a>
+<span class="sourceLineNo">313</span> size += KeyValueUtil.length(cell);<a name="line.313"></a>
+<span class="sourceLineNo">314</span> }<a name="line.314"></a>
+<span class="sourceLineNo">315</span> }<a name="line.315"></a>
+<span class="sourceLineNo">316</span> return size;<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>
[04/17] hbase-site git commit: Published site at
5cc845b713853645f1e25b29caa556d79cfdc551.
Posted by gi...@apache.org.
http://git-wip-us.apache.org/repos/asf/hbase-site/blob/de8c44eb/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
----------------------------------------------------------------------
diff --git a/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html b/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
index 88afb3f..6171b5d 100644
--- a/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
+++ b/devapidocs/src-html/org/apache/hadoop/hbase/wal/AbstractFSWALProvider.html
@@ -32,523 +32,537 @@
<span class="sourceLineNo">024</span>import java.util.List;<a name="line.24"></a>
<span class="sourceLineNo">025</span>import java.util.Objects;<a name="line.25"></a>
<span class="sourceLineNo">026</span>import java.util.concurrent.atomic.AtomicBoolean;<a name="line.26"></a>
-<span class="sourceLineNo">027</span>import java.util.regex.Matcher;<a name="line.27"></a>
-<span class="sourceLineNo">028</span>import java.util.regex.Pattern;<a name="line.28"></a>
-<span class="sourceLineNo">029</span><a name="line.29"></a>
-<span class="sourceLineNo">030</span>import org.apache.hadoop.conf.Configuration;<a name="line.30"></a>
-<span class="sourceLineNo">031</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.31"></a>
-<span class="sourceLineNo">032</span>import org.apache.hadoop.fs.FileSystem;<a name="line.32"></a>
-<span class="sourceLineNo">033</span>import org.apache.hadoop.fs.Path;<a name="line.33"></a>
-<span class="sourceLineNo">034</span>import org.apache.hadoop.hbase.HConstants;<a name="line.34"></a>
-<span class="sourceLineNo">035</span>import org.apache.hadoop.hbase.ServerName;<a name="line.35"></a>
-<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.client.RegionInfo;<a name="line.36"></a>
-<span class="sourceLineNo">037</span>import org.apache.yetus.audience.InterfaceAudience;<a name="line.37"></a>
-<span class="sourceLineNo">038</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.38"></a>
-<span class="sourceLineNo">039</span>import org.slf4j.Logger;<a name="line.39"></a>
-<span class="sourceLineNo">040</span>import org.slf4j.LoggerFactory;<a name="line.40"></a>
-<span class="sourceLineNo">041</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.41"></a>
-<span class="sourceLineNo">042</span>import org.apache.hadoop.hbase.regionserver.wal.WALActionsListener;<a name="line.42"></a>
-<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.util.CancelableProgressable;<a name="line.43"></a>
-<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.util.FSUtils;<a name="line.44"></a>
-<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.LeaseNotRecoveredException;<a name="line.45"></a>
-<span class="sourceLineNo">046</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.46"></a>
-<span class="sourceLineNo">047</span><a name="line.47"></a>
-<span class="sourceLineNo">048</span>/**<a name="line.48"></a>
-<span class="sourceLineNo">049</span> * Base class of a WAL Provider that returns a single thread safe WAL that writes to Hadoop FS. By<a name="line.49"></a>
-<span class="sourceLineNo">050</span> * default, this implementation picks a directory in Hadoop FS based on a combination of<a name="line.50"></a>
-<span class="sourceLineNo">051</span> * <ul><a name="line.51"></a>
-<span class="sourceLineNo">052</span> * <li>the HBase root directory<a name="line.52"></a>
-<span class="sourceLineNo">053</span> * <li>HConstants.HREGION_LOGDIR_NAME<a name="line.53"></a>
-<span class="sourceLineNo">054</span> * <li>the given factory's factoryId (usually identifying the regionserver by host:port)<a name="line.54"></a>
-<span class="sourceLineNo">055</span> * </ul><a name="line.55"></a>
-<span class="sourceLineNo">056</span> * It also uses the providerId to differentiate among files.<a name="line.56"></a>
-<span class="sourceLineNo">057</span> */<a name="line.57"></a>
-<span class="sourceLineNo">058</span>@InterfaceAudience.Private<a name="line.58"></a>
-<span class="sourceLineNo">059</span>@InterfaceStability.Evolving<a name="line.59"></a>
-<span class="sourceLineNo">060</span>public abstract class AbstractFSWALProvider<T extends AbstractFSWAL<?>> implements WALProvider {<a name="line.60"></a>
-<span class="sourceLineNo">061</span><a name="line.61"></a>
-<span class="sourceLineNo">062</span> private static final Logger LOG = LoggerFactory.getLogger(AbstractFSWALProvider.class);<a name="line.62"></a>
-<span class="sourceLineNo">063</span><a name="line.63"></a>
-<span class="sourceLineNo">064</span> /** Separate old log into different dir by regionserver name **/<a name="line.64"></a>
-<span class="sourceLineNo">065</span> public static final String SEPARATE_OLDLOGDIR = "hbase.separate.oldlogdir.by.regionserver";<a name="line.65"></a>
-<span class="sourceLineNo">066</span> public static final boolean DEFAULT_SEPARATE_OLDLOGDIR = false;<a name="line.66"></a>
-<span class="sourceLineNo">067</span><a name="line.67"></a>
-<span class="sourceLineNo">068</span> // Only public so classes back in regionserver.wal can access<a name="line.68"></a>
-<span class="sourceLineNo">069</span> public interface Reader extends WAL.Reader {<a name="line.69"></a>
-<span class="sourceLineNo">070</span> /**<a name="line.70"></a>
-<span class="sourceLineNo">071</span> * @param fs File system.<a name="line.71"></a>
-<span class="sourceLineNo">072</span> * @param path Path.<a name="line.72"></a>
-<span class="sourceLineNo">073</span> * @param c Configuration.<a name="line.73"></a>
-<span class="sourceLineNo">074</span> * @param s Input stream that may have been pre-opened by the caller; may be null.<a name="line.74"></a>
-<span class="sourceLineNo">075</span> */<a name="line.75"></a>
-<span class="sourceLineNo">076</span> void init(FileSystem fs, Path path, Configuration c, FSDataInputStream s) throws IOException;<a name="line.76"></a>
-<span class="sourceLineNo">077</span> }<a name="line.77"></a>
-<span class="sourceLineNo">078</span><a name="line.78"></a>
-<span class="sourceLineNo">079</span> protected volatile T wal;<a name="line.79"></a>
-<span class="sourceLineNo">080</span> protected WALFactory factory;<a name="line.80"></a>
-<span class="sourceLineNo">081</span> protected Configuration conf;<a name="line.81"></a>
-<span class="sourceLineNo">082</span> protected List<WALActionsListener> listeners = new ArrayList<>();<a name="line.82"></a>
-<span class="sourceLineNo">083</span> protected String providerId;<a name="line.83"></a>
-<span class="sourceLineNo">084</span> protected AtomicBoolean initialized = new AtomicBoolean(false);<a name="line.84"></a>
-<span class="sourceLineNo">085</span> // for default wal provider, logPrefix won't change<a name="line.85"></a>
-<span class="sourceLineNo">086</span> protected String logPrefix;<a name="line.86"></a>
-<span class="sourceLineNo">087</span><a name="line.87"></a>
-<span class="sourceLineNo">088</span> /**<a name="line.88"></a>
-<span class="sourceLineNo">089</span> * we synchronized on walCreateLock to prevent wal recreation in different threads<a name="line.89"></a>
-<span class="sourceLineNo">090</span> */<a name="line.90"></a>
-<span class="sourceLineNo">091</span> private final Object walCreateLock = new Object();<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> * @param factory factory that made us, identity used for FS layout. may not be null<a name="line.94"></a>
-<span class="sourceLineNo">095</span> * @param conf may not be null<a name="line.95"></a>
-<span class="sourceLineNo">096</span> * @param providerId differentiate between providers from one factory, used for FS layout. may be<a name="line.96"></a>
-<span class="sourceLineNo">097</span> * null<a name="line.97"></a>
-<span class="sourceLineNo">098</span> */<a name="line.98"></a>
-<span class="sourceLineNo">099</span> @Override<a name="line.99"></a>
-<span class="sourceLineNo">100</span> public void init(WALFactory factory, Configuration conf, String providerId) throws IOException {<a name="line.100"></a>
-<span class="sourceLineNo">101</span> if (!initialized.compareAndSet(false, true)) {<a name="line.101"></a>
-<span class="sourceLineNo">102</span> throw new IllegalStateException("WALProvider.init should only be called once.");<a name="line.102"></a>
-<span class="sourceLineNo">103</span> }<a name="line.103"></a>
-<span class="sourceLineNo">104</span> this.factory = factory;<a name="line.104"></a>
-<span class="sourceLineNo">105</span> this.conf = conf;<a name="line.105"></a>
-<span class="sourceLineNo">106</span> this.providerId = providerId;<a name="line.106"></a>
-<span class="sourceLineNo">107</span> // get log prefix<a name="line.107"></a>
-<span class="sourceLineNo">108</span> StringBuilder sb = new StringBuilder().append(factory.factoryId);<a name="line.108"></a>
-<span class="sourceLineNo">109</span> if (providerId != null) {<a name="line.109"></a>
-<span class="sourceLineNo">110</span> if (providerId.startsWith(WAL_FILE_NAME_DELIMITER)) {<a name="line.110"></a>
-<span class="sourceLineNo">111</span> sb.append(providerId);<a name="line.111"></a>
-<span class="sourceLineNo">112</span> } else {<a name="line.112"></a>
-<span class="sourceLineNo">113</span> sb.append(WAL_FILE_NAME_DELIMITER).append(providerId);<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> logPrefix = sb.toString();<a name="line.116"></a>
-<span class="sourceLineNo">117</span> doInit(conf);<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> @Override<a name="line.120"></a>
-<span class="sourceLineNo">121</span> public List<WAL> getWALs() {<a name="line.121"></a>
-<span class="sourceLineNo">122</span> if (wal == null) {<a name="line.122"></a>
-<span class="sourceLineNo">123</span> return Collections.emptyList();<a name="line.123"></a>
-<span class="sourceLineNo">124</span> }<a name="line.124"></a>
-<span class="sourceLineNo">125</span> List<WAL> wals = new ArrayList<>(1);<a name="line.125"></a>
-<span class="sourceLineNo">126</span> wals.add(wal);<a name="line.126"></a>
-<span class="sourceLineNo">127</span> return wals;<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> @Override<a name="line.130"></a>
-<span class="sourceLineNo">131</span> public T getWAL(RegionInfo region) throws IOException {<a name="line.131"></a>
-<span class="sourceLineNo">132</span> T walCopy = wal;<a name="line.132"></a>
-<span class="sourceLineNo">133</span> if (walCopy == null) {<a name="line.133"></a>
-<span class="sourceLineNo">134</span> // only lock when need to create wal, and need to lock since<a name="line.134"></a>
-<span class="sourceLineNo">135</span> // creating hlog on fs is time consuming<a name="line.135"></a>
-<span class="sourceLineNo">136</span> synchronized (walCreateLock) {<a name="line.136"></a>
-<span class="sourceLineNo">137</span> walCopy = wal;<a name="line.137"></a>
-<span class="sourceLineNo">138</span> if (walCopy == null) {<a name="line.138"></a>
-<span class="sourceLineNo">139</span> walCopy = createWAL();<a name="line.139"></a>
-<span class="sourceLineNo">140</span> boolean succ = false;<a name="line.140"></a>
-<span class="sourceLineNo">141</span> try {<a name="line.141"></a>
-<span class="sourceLineNo">142</span> walCopy.init();<a name="line.142"></a>
-<span class="sourceLineNo">143</span> succ = true;<a name="line.143"></a>
-<span class="sourceLineNo">144</span> } finally {<a name="line.144"></a>
-<span class="sourceLineNo">145</span> if (!succ) {<a name="line.145"></a>
-<span class="sourceLineNo">146</span> walCopy.close();<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> wal = walCopy;<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> }<a name="line.152"></a>
-<span class="sourceLineNo">153</span> return walCopy;<a name="line.153"></a>
-<span class="sourceLineNo">154</span> }<a name="line.154"></a>
-<span class="sourceLineNo">155</span><a name="line.155"></a>
-<span class="sourceLineNo">156</span> protected abstract T createWAL() throws IOException;<a name="line.156"></a>
-<span class="sourceLineNo">157</span><a name="line.157"></a>
-<span class="sourceLineNo">158</span> protected abstract void doInit(Configuration conf) throws IOException;<a name="line.158"></a>
-<span class="sourceLineNo">159</span><a name="line.159"></a>
-<span class="sourceLineNo">160</span> @Override<a name="line.160"></a>
-<span class="sourceLineNo">161</span> public void shutdown() throws IOException {<a name="line.161"></a>
-<span class="sourceLineNo">162</span> T log = this.wal;<a name="line.162"></a>
-<span class="sourceLineNo">163</span> if (log != null) {<a name="line.163"></a>
-<span class="sourceLineNo">164</span> log.shutdown();<a name="line.164"></a>
-<span class="sourceLineNo">165</span> }<a name="line.165"></a>
-<span class="sourceLineNo">166</span> }<a name="line.166"></a>
-<span class="sourceLineNo">167</span><a name="line.167"></a>
-<span class="sourceLineNo">168</span> @Override<a name="line.168"></a>
-<span class="sourceLineNo">169</span> public void close() throws IOException {<a name="line.169"></a>
-<span class="sourceLineNo">170</span> T log = this.wal;<a name="line.170"></a>
-<span class="sourceLineNo">171</span> if (log != null) {<a name="line.171"></a>
-<span class="sourceLineNo">172</span> log.close();<a name="line.172"></a>
-<span class="sourceLineNo">173</span> }<a name="line.173"></a>
-<span class="sourceLineNo">174</span> }<a name="line.174"></a>
-<span class="sourceLineNo">175</span><a name="line.175"></a>
-<span class="sourceLineNo">176</span> /**<a name="line.176"></a>
-<span class="sourceLineNo">177</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.177"></a>
-<span class="sourceLineNo">178</span> * number of files (rolled and active). if either of them aren't, count 0 for that provider.<a name="line.178"></a>
-<span class="sourceLineNo">179</span> */<a name="line.179"></a>
-<span class="sourceLineNo">180</span> @Override<a name="line.180"></a>
-<span class="sourceLineNo">181</span> public long getNumLogFiles() {<a name="line.181"></a>
-<span class="sourceLineNo">182</span> T log = this.wal;<a name="line.182"></a>
-<span class="sourceLineNo">183</span> return log == null ? 0 : log.getNumLogFiles();<a name="line.183"></a>
-<span class="sourceLineNo">184</span> }<a name="line.184"></a>
-<span class="sourceLineNo">185</span><a name="line.185"></a>
-<span class="sourceLineNo">186</span> /**<a name="line.186"></a>
-<span class="sourceLineNo">187</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.187"></a>
-<span class="sourceLineNo">188</span> * size of files (only rolled). if either of them aren't, count 0 for that provider.<a name="line.188"></a>
-<span class="sourceLineNo">189</span> */<a name="line.189"></a>
-<span class="sourceLineNo">190</span> @Override<a name="line.190"></a>
-<span class="sourceLineNo">191</span> public long getLogFileSize() {<a name="line.191"></a>
-<span class="sourceLineNo">192</span> T log = this.wal;<a name="line.192"></a>
-<span class="sourceLineNo">193</span> return log == null ? 0 : log.getLogFileSize();<a name="line.193"></a>
-<span class="sourceLineNo">194</span> }<a name="line.194"></a>
-<span class="sourceLineNo">195</span><a name="line.195"></a>
-<span class="sourceLineNo">196</span> /**<a name="line.196"></a>
-<span class="sourceLineNo">197</span> * returns the number of rolled WAL files.<a name="line.197"></a>
-<span class="sourceLineNo">198</span> */<a name="line.198"></a>
-<span class="sourceLineNo">199</span> @VisibleForTesting<a name="line.199"></a>
-<span class="sourceLineNo">200</span> public static int getNumRolledLogFiles(WAL wal) {<a name="line.200"></a>
-<span class="sourceLineNo">201</span> return ((AbstractFSWAL<?>) wal).getNumRolledLogFiles();<a name="line.201"></a>
-<span class="sourceLineNo">202</span> }<a name="line.202"></a>
-<span class="sourceLineNo">203</span><a name="line.203"></a>
-<span class="sourceLineNo">204</span> /**<a name="line.204"></a>
-<span class="sourceLineNo">205</span> * returns the size of rolled WAL files.<a name="line.205"></a>
-<span class="sourceLineNo">206</span> */<a name="line.206"></a>
-<span class="sourceLineNo">207</span> @VisibleForTesting<a name="line.207"></a>
-<span class="sourceLineNo">208</span> public static long getLogFileSize(WAL wal) {<a name="line.208"></a>
-<span class="sourceLineNo">209</span> return ((AbstractFSWAL<?>) wal).getLogFileSize();<a name="line.209"></a>
-<span class="sourceLineNo">210</span> }<a name="line.210"></a>
-<span class="sourceLineNo">211</span><a name="line.211"></a>
-<span class="sourceLineNo">212</span> /**<a name="line.212"></a>
-<span class="sourceLineNo">213</span> * return the current filename from the current wal.<a name="line.213"></a>
-<span class="sourceLineNo">214</span> */<a name="line.214"></a>
-<span class="sourceLineNo">215</span> @VisibleForTesting<a name="line.215"></a>
-<span class="sourceLineNo">216</span> public static Path getCurrentFileName(final WAL wal) {<a name="line.216"></a>
-<span class="sourceLineNo">217</span> return ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.217"></a>
-<span class="sourceLineNo">218</span> }<a name="line.218"></a>
-<span class="sourceLineNo">219</span><a name="line.219"></a>
-<span class="sourceLineNo">220</span> /**<a name="line.220"></a>
-<span class="sourceLineNo">221</span> * request a log roll, but don't actually do it.<a name="line.221"></a>
-<span class="sourceLineNo">222</span> */<a name="line.222"></a>
-<span class="sourceLineNo">223</span> @VisibleForTesting<a name="line.223"></a>
-<span class="sourceLineNo">224</span> static void requestLogRoll(final WAL wal) {<a name="line.224"></a>
-<span class="sourceLineNo">225</span> ((AbstractFSWAL<?>) wal).requestLogRoll();<a name="line.225"></a>
-<span class="sourceLineNo">226</span> }<a name="line.226"></a>
-<span class="sourceLineNo">227</span><a name="line.227"></a>
-<span class="sourceLineNo">228</span> // should be package private; more visible for use in AbstractFSWAL<a name="line.228"></a>
-<span class="sourceLineNo">229</span> public static final String WAL_FILE_NAME_DELIMITER = ".";<a name="line.229"></a>
-<span class="sourceLineNo">230</span> /** The hbase:meta region's WAL filename extension */<a name="line.230"></a>
-<span class="sourceLineNo">231</span> @VisibleForTesting<a name="line.231"></a>
-<span class="sourceLineNo">232</span> public static final String META_WAL_PROVIDER_ID = ".meta";<a name="line.232"></a>
-<span class="sourceLineNo">233</span> static final String DEFAULT_PROVIDER_ID = "default";<a name="line.233"></a>
-<span class="sourceLineNo">234</span><a name="line.234"></a>
-<span class="sourceLineNo">235</span> // Implementation details that currently leak in tests or elsewhere follow<a name="line.235"></a>
-<span class="sourceLineNo">236</span> /** File Extension used while splitting an WAL into regions (HBASE-2312) */<a name="line.236"></a>
-<span class="sourceLineNo">237</span> public static final String SPLITTING_EXT = "-splitting";<a name="line.237"></a>
-<span class="sourceLineNo">238</span><a name="line.238"></a>
-<span class="sourceLineNo">239</span> /**<a name="line.239"></a>
-<span class="sourceLineNo">240</span> * It returns the file create timestamp from the file name. For name format see<a name="line.240"></a>
-<span class="sourceLineNo">241</span> * {@link #validateWALFilename(String)} public until remaining tests move to o.a.h.h.wal<a name="line.241"></a>
-<span class="sourceLineNo">242</span> * @param wal must not be null<a name="line.242"></a>
-<span class="sourceLineNo">243</span> * @return the file number that is part of the WAL file name<a name="line.243"></a>
-<span class="sourceLineNo">244</span> */<a name="line.244"></a>
+<span class="sourceLineNo">027</span>import java.util.concurrent.locks.ReadWriteLock;<a name="line.27"></a>
+<span class="sourceLineNo">028</span>import java.util.concurrent.locks.ReentrantReadWriteLock;<a name="line.28"></a>
+<span class="sourceLineNo">029</span>import java.util.regex.Matcher;<a name="line.29"></a>
+<span class="sourceLineNo">030</span>import java.util.regex.Pattern;<a name="line.30"></a>
+<span class="sourceLineNo">031</span><a name="line.31"></a>
+<span class="sourceLineNo">032</span>import org.apache.hadoop.conf.Configuration;<a name="line.32"></a>
+<span class="sourceLineNo">033</span>import org.apache.hadoop.fs.FSDataInputStream;<a name="line.33"></a>
+<span class="sourceLineNo">034</span>import org.apache.hadoop.fs.FileSystem;<a name="line.34"></a>
+<span class="sourceLineNo">035</span>import org.apache.hadoop.fs.Path;<a name="line.35"></a>
+<span class="sourceLineNo">036</span>import org.apache.hadoop.hbase.HConstants;<a name="line.36"></a>
+<span class="sourceLineNo">037</span>import org.apache.hadoop.hbase.ServerName;<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.yetus.audience.InterfaceAudience;<a name="line.39"></a>
+<span class="sourceLineNo">040</span>import org.apache.yetus.audience.InterfaceStability;<a name="line.40"></a>
+<span class="sourceLineNo">041</span>import org.slf4j.Logger;<a name="line.41"></a>
+<span class="sourceLineNo">042</span>import org.slf4j.LoggerFactory;<a name="line.42"></a>
+<span class="sourceLineNo">043</span>import org.apache.hadoop.hbase.regionserver.wal.AbstractFSWAL;<a name="line.43"></a>
+<span class="sourceLineNo">044</span>import org.apache.hadoop.hbase.regionserver.wal.WALActionsListener;<a name="line.44"></a>
+<span class="sourceLineNo">045</span>import org.apache.hadoop.hbase.util.CancelableProgressable;<a name="line.45"></a>
+<span class="sourceLineNo">046</span>import org.apache.hadoop.hbase.util.FSUtils;<a name="line.46"></a>
+<span class="sourceLineNo">047</span>import org.apache.hadoop.hbase.util.LeaseNotRecoveredException;<a name="line.47"></a>
+<span class="sourceLineNo">048</span>import org.apache.hbase.thirdparty.com.google.common.annotations.VisibleForTesting;<a name="line.48"></a>
+<span class="sourceLineNo">049</span>import org.apache.hbase.thirdparty.com.google.common.collect.Lists;<a name="line.49"></a>
+<span class="sourceLineNo">050</span><a name="line.50"></a>
+<span class="sourceLineNo">051</span>/**<a name="line.51"></a>
+<span class="sourceLineNo">052</span> * Base class of a WAL Provider that returns a single thread safe WAL that writes to Hadoop FS. By<a name="line.52"></a>
+<span class="sourceLineNo">053</span> * default, this implementation picks a directory in Hadoop FS based on a combination of<a name="line.53"></a>
+<span class="sourceLineNo">054</span> * <ul><a name="line.54"></a>
+<span class="sourceLineNo">055</span> * <li>the HBase root directory<a name="line.55"></a>
+<span class="sourceLineNo">056</span> * <li>HConstants.HREGION_LOGDIR_NAME<a name="line.56"></a>
+<span class="sourceLineNo">057</span> * <li>the given factory's factoryId (usually identifying the regionserver by host:port)<a name="line.57"></a>
+<span class="sourceLineNo">058</span> * </ul><a name="line.58"></a>
+<span class="sourceLineNo">059</span> * It also uses the providerId to differentiate among files.<a name="line.59"></a>
+<span class="sourceLineNo">060</span> */<a name="line.60"></a>
+<span class="sourceLineNo">061</span>@InterfaceAudience.Private<a name="line.61"></a>
+<span class="sourceLineNo">062</span>@InterfaceStability.Evolving<a name="line.62"></a>
+<span class="sourceLineNo">063</span>public abstract class AbstractFSWALProvider<T extends AbstractFSWAL<?>> implements WALProvider {<a name="line.63"></a>
+<span class="sourceLineNo">064</span><a name="line.64"></a>
+<span class="sourceLineNo">065</span> private static final Logger LOG = LoggerFactory.getLogger(AbstractFSWALProvider.class);<a name="line.65"></a>
+<span class="sourceLineNo">066</span><a name="line.66"></a>
+<span class="sourceLineNo">067</span> /** Separate old log into different dir by regionserver name **/<a name="line.67"></a>
+<span class="sourceLineNo">068</span> public static final String SEPARATE_OLDLOGDIR = "hbase.separate.oldlogdir.by.regionserver";<a name="line.68"></a>
+<span class="sourceLineNo">069</span> public static final boolean DEFAULT_SEPARATE_OLDLOGDIR = false;<a name="line.69"></a>
+<span class="sourceLineNo">070</span><a name="line.70"></a>
+<span class="sourceLineNo">071</span> // Only public so classes back in regionserver.wal can access<a name="line.71"></a>
+<span class="sourceLineNo">072</span> public interface Reader extends WAL.Reader {<a name="line.72"></a>
+<span class="sourceLineNo">073</span> /**<a name="line.73"></a>
+<span class="sourceLineNo">074</span> * @param fs File system.<a name="line.74"></a>
+<span class="sourceLineNo">075</span> * @param path Path.<a name="line.75"></a>
+<span class="sourceLineNo">076</span> * @param c Configuration.<a name="line.76"></a>
+<span class="sourceLineNo">077</span> * @param s Input stream that may have been pre-opened by the caller; may be null.<a name="line.77"></a>
+<span class="sourceLineNo">078</span> */<a name="line.78"></a>
+<span class="sourceLineNo">079</span> void init(FileSystem fs, Path path, Configuration c, FSDataInputStream s) throws IOException;<a name="line.79"></a>
+<span class="sourceLineNo">080</span> }<a name="line.80"></a>
+<span class="sourceLineNo">081</span><a name="line.81"></a>
+<span class="sourceLineNo">082</span> protected volatile T wal;<a name="line.82"></a>
+<span class="sourceLineNo">083</span> protected WALFactory factory;<a name="line.83"></a>
+<span class="sourceLineNo">084</span> protected Configuration conf;<a name="line.84"></a>
+<span class="sourceLineNo">085</span> protected List<WALActionsListener> listeners = new ArrayList<>();<a name="line.85"></a>
+<span class="sourceLineNo">086</span> protected String providerId;<a name="line.86"></a>
+<span class="sourceLineNo">087</span> protected AtomicBoolean initialized = new AtomicBoolean(false);<a name="line.87"></a>
+<span class="sourceLineNo">088</span> // for default wal provider, logPrefix won't change<a name="line.88"></a>
+<span class="sourceLineNo">089</span> protected String logPrefix;<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> * We use walCreateLock to prevent wal recreation in different threads, and also prevent getWALs<a name="line.92"></a>
+<span class="sourceLineNo">093</span> * missing the newly created WAL, see HBASE-21503 for more details.<a name="line.93"></a>
+<span class="sourceLineNo">094</span> */<a name="line.94"></a>
+<span class="sourceLineNo">095</span> private final ReadWriteLock walCreateLock = new ReentrantReadWriteLock();<a name="line.95"></a>
+<span class="sourceLineNo">096</span><a name="line.96"></a>
+<span class="sourceLineNo">097</span> /**<a name="line.97"></a>
+<span class="sourceLineNo">098</span> * @param factory factory that made us, identity used for FS layout. may not be null<a name="line.98"></a>
+<span class="sourceLineNo">099</span> * @param conf may not be null<a name="line.99"></a>
+<span class="sourceLineNo">100</span> * @param providerId differentiate between providers from one factory, used for FS layout. may be<a name="line.100"></a>
+<span class="sourceLineNo">101</span> * null<a name="line.101"></a>
+<span class="sourceLineNo">102</span> */<a name="line.102"></a>
+<span class="sourceLineNo">103</span> @Override<a name="line.103"></a>
+<span class="sourceLineNo">104</span> public void init(WALFactory factory, Configuration conf, String providerId) throws IOException {<a name="line.104"></a>
+<span class="sourceLineNo">105</span> if (!initialized.compareAndSet(false, true)) {<a name="line.105"></a>
+<span class="sourceLineNo">106</span> throw new IllegalStateException("WALProvider.init should only be called once.");<a name="line.106"></a>
+<span class="sourceLineNo">107</span> }<a name="line.107"></a>
+<span class="sourceLineNo">108</span> this.factory = factory;<a name="line.108"></a>
+<span class="sourceLineNo">109</span> this.conf = conf;<a name="line.109"></a>
+<span class="sourceLineNo">110</span> this.providerId = providerId;<a name="line.110"></a>
+<span class="sourceLineNo">111</span> // get log prefix<a name="line.111"></a>
+<span class="sourceLineNo">112</span> StringBuilder sb = new StringBuilder().append(factory.factoryId);<a name="line.112"></a>
+<span class="sourceLineNo">113</span> if (providerId != null) {<a name="line.113"></a>
+<span class="sourceLineNo">114</span> if (providerId.startsWith(WAL_FILE_NAME_DELIMITER)) {<a name="line.114"></a>
+<span class="sourceLineNo">115</span> sb.append(providerId);<a name="line.115"></a>
+<span class="sourceLineNo">116</span> } else {<a name="line.116"></a>
+<span class="sourceLineNo">117</span> sb.append(WAL_FILE_NAME_DELIMITER).append(providerId);<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> logPrefix = sb.toString();<a name="line.120"></a>
+<span class="sourceLineNo">121</span> doInit(conf);<a name="line.121"></a>
+<span class="sourceLineNo">122</span> }<a name="line.122"></a>
+<span class="sourceLineNo">123</span><a name="line.123"></a>
+<span class="sourceLineNo">124</span> @Override<a name="line.124"></a>
+<span class="sourceLineNo">125</span> public List<WAL> getWALs() {<a name="line.125"></a>
+<span class="sourceLineNo">126</span> if (wal != null) {<a name="line.126"></a>
+<span class="sourceLineNo">127</span> return Lists.newArrayList(wal);<a name="line.127"></a>
+<span class="sourceLineNo">128</span> }<a name="line.128"></a>
+<span class="sourceLineNo">129</span> walCreateLock.readLock().lock();<a name="line.129"></a>
+<span class="sourceLineNo">130</span> try {<a name="line.130"></a>
+<span class="sourceLineNo">131</span> if (wal == null) {<a name="line.131"></a>
+<span class="sourceLineNo">132</span> return Collections.emptyList();<a name="line.132"></a>
+<span class="sourceLineNo">133</span> } else {<a name="line.133"></a>
+<span class="sourceLineNo">134</span> return Lists.newArrayList(wal);<a name="line.134"></a>
+<span class="sourceLineNo">135</span> }<a name="line.135"></a>
+<span class="sourceLineNo">136</span> } finally {<a name="line.136"></a>
+<span class="sourceLineNo">137</span> walCreateLock.readLock().unlock();<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><a name="line.140"></a>
+<span class="sourceLineNo">141</span> @Override<a name="line.141"></a>
+<span class="sourceLineNo">142</span> public T getWAL(RegionInfo region) throws IOException {<a name="line.142"></a>
+<span class="sourceLineNo">143</span> T walCopy = wal;<a name="line.143"></a>
+<span class="sourceLineNo">144</span> if (walCopy != null) {<a name="line.144"></a>
+<span class="sourceLineNo">145</span> return walCopy;<a name="line.145"></a>
+<span class="sourceLineNo">146</span> }<a name="line.146"></a>
+<span class="sourceLineNo">147</span> walCreateLock.writeLock().lock();<a name="line.147"></a>
+<span class="sourceLineNo">148</span> try {<a name="line.148"></a>
+<span class="sourceLineNo">149</span> walCopy = wal;<a name="line.149"></a>
+<span class="sourceLineNo">150</span> if (walCopy != null) {<a name="line.150"></a>
+<span class="sourceLineNo">151</span> return walCopy;<a name="line.151"></a>
+<span class="sourceLineNo">152</span> }<a name="line.152"></a>
+<span class="sourceLineNo">153</span> walCopy = createWAL();<a name="line.153"></a>
+<span class="sourceLineNo">154</span> boolean succ = false;<a name="line.154"></a>
+<span class="sourceLineNo">155</span> try {<a name="line.155"></a>
+<span class="sourceLineNo">156</span> walCopy.init();<a name="line.156"></a>
+<span class="sourceLineNo">157</span> succ = true;<a name="line.157"></a>
+<span class="sourceLineNo">158</span> } finally {<a name="line.158"></a>
+<span class="sourceLineNo">159</span> if (!succ) {<a name="line.159"></a>
+<span class="sourceLineNo">160</span> walCopy.close();<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> wal = walCopy;<a name="line.163"></a>
+<span class="sourceLineNo">164</span> return walCopy;<a name="line.164"></a>
+<span class="sourceLineNo">165</span> } finally {<a name="line.165"></a>
+<span class="sourceLineNo">166</span> walCreateLock.writeLock().unlock();<a name="line.166"></a>
+<span class="sourceLineNo">167</span> }<a name="line.167"></a>
+<span class="sourceLineNo">168</span> }<a name="line.168"></a>
+<span class="sourceLineNo">169</span><a name="line.169"></a>
+<span class="sourceLineNo">170</span> protected abstract T createWAL() throws IOException;<a name="line.170"></a>
+<span class="sourceLineNo">171</span><a name="line.171"></a>
+<span class="sourceLineNo">172</span> protected abstract void doInit(Configuration conf) throws IOException;<a name="line.172"></a>
+<span class="sourceLineNo">173</span><a name="line.173"></a>
+<span class="sourceLineNo">174</span> @Override<a name="line.174"></a>
+<span class="sourceLineNo">175</span> public void shutdown() throws IOException {<a name="line.175"></a>
+<span class="sourceLineNo">176</span> T log = this.wal;<a name="line.176"></a>
+<span class="sourceLineNo">177</span> if (log != null) {<a name="line.177"></a>
+<span class="sourceLineNo">178</span> log.shutdown();<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><a name="line.181"></a>
+<span class="sourceLineNo">182</span> @Override<a name="line.182"></a>
+<span class="sourceLineNo">183</span> public void close() throws IOException {<a name="line.183"></a>
+<span class="sourceLineNo">184</span> T log = this.wal;<a name="line.184"></a>
+<span class="sourceLineNo">185</span> if (log != null) {<a name="line.185"></a>
+<span class="sourceLineNo">186</span> log.close();<a name="line.186"></a>
+<span class="sourceLineNo">187</span> }<a name="line.187"></a>
+<span class="sourceLineNo">188</span> }<a name="line.188"></a>
+<span class="sourceLineNo">189</span><a name="line.189"></a>
+<span class="sourceLineNo">190</span> /**<a name="line.190"></a>
+<span class="sourceLineNo">191</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.191"></a>
+<span class="sourceLineNo">192</span> * number of files (rolled and active). if either of them aren't, count 0 for that provider.<a name="line.192"></a>
+<span class="sourceLineNo">193</span> */<a name="line.193"></a>
+<span class="sourceLineNo">194</span> @Override<a name="line.194"></a>
+<span class="sourceLineNo">195</span> public long getNumLogFiles() {<a name="line.195"></a>
+<span class="sourceLineNo">196</span> T log = this.wal;<a name="line.196"></a>
+<span class="sourceLineNo">197</span> return log == null ? 0 : log.getNumLogFiles();<a name="line.197"></a>
+<span class="sourceLineNo">198</span> }<a name="line.198"></a>
+<span class="sourceLineNo">199</span><a name="line.199"></a>
+<span class="sourceLineNo">200</span> /**<a name="line.200"></a>
+<span class="sourceLineNo">201</span> * iff the given WALFactory is using the DefaultWALProvider for meta and/or non-meta, count the<a name="line.201"></a>
+<span class="sourceLineNo">202</span> * size of files (only rolled). if either of them aren't, count 0 for that provider.<a name="line.202"></a>
+<span class="sourceLineNo">203</span> */<a name="line.203"></a>
+<span class="sourceLineNo">204</span> @Override<a name="line.204"></a>
+<span class="sourceLineNo">205</span> public long getLogFileSize() {<a name="line.205"></a>
+<span class="sourceLineNo">206</span> T log = this.wal;<a name="line.206"></a>
+<span class="sourceLineNo">207</span> return log == null ? 0 : log.getLogFileSize();<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> /**<a name="line.210"></a>
+<span class="sourceLineNo">211</span> * returns the number of rolled WAL files.<a name="line.211"></a>
+<span class="sourceLineNo">212</span> */<a name="line.212"></a>
+<span class="sourceLineNo">213</span> @VisibleForTesting<a name="line.213"></a>
+<span class="sourceLineNo">214</span> public static int getNumRolledLogFiles(WAL wal) {<a name="line.214"></a>
+<span class="sourceLineNo">215</span> return ((AbstractFSWAL<?>) wal).getNumRolledLogFiles();<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> /**<a name="line.218"></a>
+<span class="sourceLineNo">219</span> * returns the size of rolled WAL files.<a name="line.219"></a>
+<span class="sourceLineNo">220</span> */<a name="line.220"></a>
+<span class="sourceLineNo">221</span> @VisibleForTesting<a name="line.221"></a>
+<span class="sourceLineNo">222</span> public static long getLogFileSize(WAL wal) {<a name="line.222"></a>
+<span class="sourceLineNo">223</span> return ((AbstractFSWAL<?>) wal).getLogFileSize();<a name="line.223"></a>
+<span class="sourceLineNo">224</span> }<a name="line.224"></a>
+<span class="sourceLineNo">225</span><a name="line.225"></a>
+<span class="sourceLineNo">226</span> /**<a name="line.226"></a>
+<span class="sourceLineNo">227</span> * return the current filename from the current wal.<a name="line.227"></a>
+<span class="sourceLineNo">228</span> */<a name="line.228"></a>
+<span class="sourceLineNo">229</span> @VisibleForTesting<a name="line.229"></a>
+<span class="sourceLineNo">230</span> public static Path getCurrentFileName(final WAL wal) {<a name="line.230"></a>
+<span class="sourceLineNo">231</span> return ((AbstractFSWAL<?>) wal).getCurrentFileName();<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> /**<a name="line.234"></a>
+<span class="sourceLineNo">235</span> * request a log roll, but don't actually do it.<a name="line.235"></a>
+<span class="sourceLineNo">236</span> */<a name="line.236"></a>
+<span class="sourceLineNo">237</span> @VisibleForTesting<a name="line.237"></a>
+<span class="sourceLineNo">238</span> static void requestLogRoll(final WAL wal) {<a name="line.238"></a>
+<span class="sourceLineNo">239</span> ((AbstractFSWAL<?>) wal).requestLogRoll();<a name="line.239"></a>
+<span class="sourceLineNo">240</span> }<a name="line.240"></a>
+<span class="sourceLineNo">241</span><a name="line.241"></a>
+<span class="sourceLineNo">242</span> // should be package private; more visible for use in AbstractFSWAL<a name="line.242"></a>
+<span class="sourceLineNo">243</span> public static final String WAL_FILE_NAME_DELIMITER = ".";<a name="line.243"></a>
+<span class="sourceLineNo">244</span> /** The hbase:meta region's WAL filename extension */<a name="line.244"></a>
<span class="sourceLineNo">245</span> @VisibleForTesting<a name="line.245"></a>
-<span class="sourceLineNo">246</span> public static long extractFileNumFromWAL(final WAL wal) {<a name="line.246"></a>
-<span class="sourceLineNo">247</span> final Path walName = ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.247"></a>
-<span class="sourceLineNo">248</span> if (walName == null) {<a name="line.248"></a>
-<span class="sourceLineNo">249</span> throw new IllegalArgumentException("The WAL path couldn't be null");<a name="line.249"></a>
-<span class="sourceLineNo">250</span> }<a name="line.250"></a>
-<span class="sourceLineNo">251</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(walName.getName());<a name="line.251"></a>
-<span class="sourceLineNo">252</span> if (matcher.matches()) {<a name="line.252"></a>
-<span class="sourceLineNo">253</span> return Long.parseLong(matcher.group(2));<a name="line.253"></a>
-<span class="sourceLineNo">254</span> } else {<a name="line.254"></a>
-<span class="sourceLineNo">255</span> throw new IllegalArgumentException(walName.getName() + " is not a valid wal file name");<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><a name="line.258"></a>
-<span class="sourceLineNo">259</span> /**<a name="line.259"></a>
-<span class="sourceLineNo">260</span> * Pattern used to validate a WAL file name see {@link #validateWALFilename(String)} for<a name="line.260"></a>
-<span class="sourceLineNo">261</span> * description.<a name="line.261"></a>
-<span class="sourceLineNo">262</span> */<a name="line.262"></a>
-<span class="sourceLineNo">263</span> private static final Pattern WAL_FILE_NAME_PATTERN =<a name="line.263"></a>
-<span class="sourceLineNo">264</span> Pattern.compile("(.+)\\.(\\d+)(\\.[0-9A-Za-z]+)?");<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> * A WAL file name is of the format: &lt;wal-name&gt;{@link #WAL_FILE_NAME_DELIMITER}<a name="line.267"></a>
-<span class="sourceLineNo">268</span> * &lt;file-creation-timestamp&gt;[.&lt;suffix&gt;]. provider-name is usually made up of a<a name="line.268"></a>
-<span class="sourceLineNo">269</span> * server-name and a provider-id<a name="line.269"></a>
-<span class="sourceLineNo">270</span> * @param filename name of the file to validate<a name="line.270"></a>
-<span class="sourceLineNo">271</span> * @return <tt>true</tt> if the filename matches an WAL, <tt>false</tt> otherwise<a name="line.271"></a>
-<span class="sourceLineNo">272</span> */<a name="line.272"></a>
-<span class="sourceLineNo">273</span> public static boolean validateWALFilename(String filename) {<a name="line.273"></a>
-<span class="sourceLineNo">274</span> return WAL_FILE_NAME_PATTERN.matcher(filename).matches();<a name="line.274"></a>
-<span class="sourceLineNo">275</span> }<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> * Construct the directory name for all WALs on a given server. Dir names currently look like this<a name="line.278"></a>
-<span class="sourceLineNo">279</span> * for WALs: <code>hbase//WALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.279"></a>
-<span class="sourceLineNo">280</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.280"></a>
-<span class="sourceLineNo">281</span> * @return the relative WAL directory name, e.g. <code>.logs/1.example.org,60030,12345</code> if<a name="line.281"></a>
-<span class="sourceLineNo">282</span> * <code>serverName</code> passed is <code>1.example.org,60030,12345</code><a name="line.282"></a>
-<span class="sourceLineNo">283</span> */<a name="line.283"></a>
-<span class="sourceLineNo">284</span> public static String getWALDirectoryName(final String serverName) {<a name="line.284"></a>
-<span class="sourceLineNo">285</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_LOGDIR_NAME);<a name="line.285"></a>
-<span class="sourceLineNo">286</span> dirName.append("/");<a name="line.286"></a>
-<span class="sourceLineNo">287</span> dirName.append(serverName);<a name="line.287"></a>
-<span class="sourceLineNo">288</span> return dirName.toString();<a name="line.288"></a>
+<span class="sourceLineNo">246</span> public static final String META_WAL_PROVIDER_ID = ".meta";<a name="line.246"></a>
+<span class="sourceLineNo">247</span> static final String DEFAULT_PROVIDER_ID = "default";<a name="line.247"></a>
+<span class="sourceLineNo">248</span><a name="line.248"></a>
+<span class="sourceLineNo">249</span> // Implementation details that currently leak in tests or elsewhere follow<a name="line.249"></a>
+<span class="sourceLineNo">250</span> /** File Extension used while splitting an WAL into regions (HBASE-2312) */<a name="line.250"></a>
+<span class="sourceLineNo">251</span> public static final String SPLITTING_EXT = "-splitting";<a name="line.251"></a>
+<span class="sourceLineNo">252</span><a name="line.252"></a>
+<span class="sourceLineNo">253</span> /**<a name="line.253"></a>
+<span class="sourceLineNo">254</span> * It returns the file create timestamp from the file name. For name format see<a name="line.254"></a>
+<span class="sourceLineNo">255</span> * {@link #validateWALFilename(String)} public until remaining tests move to o.a.h.h.wal<a name="line.255"></a>
+<span class="sourceLineNo">256</span> * @param wal must not be null<a name="line.256"></a>
+<span class="sourceLineNo">257</span> * @return the file number that is part of the WAL file name<a name="line.257"></a>
+<span class="sourceLineNo">258</span> */<a name="line.258"></a>
+<span class="sourceLineNo">259</span> @VisibleForTesting<a name="line.259"></a>
+<span class="sourceLineNo">260</span> public static long extractFileNumFromWAL(final WAL wal) {<a name="line.260"></a>
+<span class="sourceLineNo">261</span> final Path walName = ((AbstractFSWAL<?>) wal).getCurrentFileName();<a name="line.261"></a>
+<span class="sourceLineNo">262</span> if (walName == null) {<a name="line.262"></a>
+<span class="sourceLineNo">263</span> throw new IllegalArgumentException("The WAL path couldn't be null");<a name="line.263"></a>
+<span class="sourceLineNo">264</span> }<a name="line.264"></a>
+<span class="sourceLineNo">265</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(walName.getName());<a name="line.265"></a>
+<span class="sourceLineNo">266</span> if (matcher.matches()) {<a name="line.266"></a>
+<span class="sourceLineNo">267</span> return Long.parseLong(matcher.group(2));<a name="line.267"></a>
+<span class="sourceLineNo">268</span> } else {<a name="line.268"></a>
+<span class="sourceLineNo">269</span> throw new IllegalArgumentException(walName.getName() + " is not a valid wal file name");<a name="line.269"></a>
+<span class="sourceLineNo">270</span> }<a name="line.270"></a>
+<span class="sourceLineNo">271</span> }<a name="line.271"></a>
+<span class="sourceLineNo">272</span><a name="line.272"></a>
+<span class="sourceLineNo">273</span> /**<a name="line.273"></a>
+<span class="sourceLineNo">274</span> * Pattern used to validate a WAL file name see {@link #validateWALFilename(String)} for<a name="line.274"></a>
+<span class="sourceLineNo">275</span> * description.<a name="line.275"></a>
+<span class="sourceLineNo">276</span> */<a name="line.276"></a>
+<span class="sourceLineNo">277</span> private static final Pattern WAL_FILE_NAME_PATTERN =<a name="line.277"></a>
+<span class="sourceLineNo">278</span> Pattern.compile("(.+)\\.(\\d+)(\\.[0-9A-Za-z]+)?");<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> * A WAL file name is of the format: &lt;wal-name&gt;{@link #WAL_FILE_NAME_DELIMITER}<a name="line.281"></a>
+<span class="sourceLineNo">282</span> * &lt;file-creation-timestamp&gt;[.&lt;suffix&gt;]. provider-name is usually made up of a<a name="line.282"></a>
+<span class="sourceLineNo">283</span> * server-name and a provider-id<a name="line.283"></a>
+<span class="sourceLineNo">284</span> * @param filename name of the file to validate<a name="line.284"></a>
+<span class="sourceLineNo">285</span> * @return <tt>true</tt> if the filename matches an WAL, <tt>false</tt> otherwise<a name="line.285"></a>
+<span class="sourceLineNo">286</span> */<a name="line.286"></a>
+<span class="sourceLineNo">287</span> public static boolean validateWALFilename(String filename) {<a name="line.287"></a>
+<span class="sourceLineNo">288</span> return WAL_FILE_NAME_PATTERN.matcher(filename).matches();<a name="line.288"></a>
<span class="sourceLineNo">289</span> }<a name="line.289"></a>
<span class="sourceLineNo">290</span><a name="line.290"></a>
<span class="sourceLineNo">291</span> /**<a name="line.291"></a>
-<span class="sourceLineNo">292</span> * Construct the directory name for all old WALs on a given server. The default old WALs dir looks<a name="line.292"></a>
-<span class="sourceLineNo">293</span> * like: <code>hbase/oldWALs</code>. If you config hbase.separate.oldlogdir.by.regionserver to<a name="line.293"></a>
-<span class="sourceLineNo">294</span> * true, it looks like <code>hbase//oldWALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.294"></a>
-<span class="sourceLineNo">295</span> * @param conf<a name="line.295"></a>
-<span class="sourceLineNo">296</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.296"></a>
-<span class="sourceLineNo">297</span> * @return the relative WAL directory name<a name="line.297"></a>
-<span class="sourceLineNo">298</span> */<a name="line.298"></a>
-<span class="sourceLineNo">299</span> public static String getWALArchiveDirectoryName(Configuration conf, final String serverName) {<a name="line.299"></a>
-<span class="sourceLineNo">300</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.300"></a>
-<span class="sourceLineNo">301</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.301"></a>
-<span class="sourceLineNo">302</span> dirName.append(Path.SEPARATOR);<a name="line.302"></a>
-<span class="sourceLineNo">303</span> dirName.append(serverName);<a name="line.303"></a>
-<span class="sourceLineNo">304</span> }<a name="line.304"></a>
-<span class="sourceLineNo">305</span> return dirName.toString();<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> /**<a name="line.308"></a>
-<span class="sourceLineNo">309</span> * Pulls a ServerName out of a Path generated according to our layout rules. In the below layouts,<a name="line.309"></a>
-<span class="sourceLineNo">310</span> * this method ignores the format of the logfile component. Current format: [base directory for<a name="line.310"></a>
-<span class="sourceLineNo">311</span> * hbase]/hbase/.logs/ServerName/logfile or [base directory for<a name="line.311"></a>
-<span class="sourceLineNo">312</span> * hbase]/hbase/.logs/ServerName-splitting/logfile Expected to work for individual log files and<a name="line.312"></a>
-<span class="sourceLineNo">313</span> * server-specific directories.<a name="line.313"></a>
-<span class="sourceLineNo">314</span> * @return null if it's not a log file. Returns the ServerName of the region server that created<a name="line.314"></a>
-<span class="sourceLineNo">315</span> * this log file otherwise.<a name="line.315"></a>
-<span class="sourceLineNo">316</span> */<a name="line.316"></a>
-<span class="sourceLineNo">317</span> public static ServerName getServerNameFromWALDirectoryName(Configuration conf, String path)<a name="line.317"></a>
-<span class="sourceLineNo">318</span> throws IOException {<a name="line.318"></a>
-<span class="sourceLineNo">319</span> if (path == null || path.length() <= HConstants.HREGION_LOGDIR_NAME.length()) {<a name="line.319"></a>
-<span class="sourceLineNo">320</span> return null;<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> if (conf == null) {<a name="line.323"></a>
-<span class="sourceLineNo">324</span> throw new IllegalArgumentException("parameter conf must be set");<a name="line.324"></a>
-<span class="sourceLineNo">325</span> }<a name="line.325"></a>
-<span class="sourceLineNo">326</span><a name="line.326"></a>
-<span class="sourceLineNo">327</span> final String rootDir = conf.get(HConstants.HBASE_DIR);<a name="line.327"></a>
-<span class="sourceLineNo">328</span> if (rootDir == null || rootDir.isEmpty()) {<a name="line.328"></a>
-<span class="sourceLineNo">329</span> throw new IllegalArgumentException(HConstants.HBASE_DIR + " key not found in conf.");<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> final StringBuilder startPathSB = new StringBuilder(rootDir);<a name="line.332"></a>
-<span class="sourceLineNo">333</span> if (!rootDir.endsWith("/")) {<a name="line.333"></a>
-<span class="sourceLineNo">334</span> startPathSB.append('/');<a name="line.334"></a>
+<span class="sourceLineNo">292</span> * Construct the directory name for all WALs on a given server. Dir names currently look like this<a name="line.292"></a>
+<span class="sourceLineNo">293</span> * for WALs: <code>hbase//WALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.293"></a>
+<span class="sourceLineNo">294</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.294"></a>
+<span class="sourceLineNo">295</span> * @return the relative WAL directory name, e.g. <code>.logs/1.example.org,60030,12345</code> if<a name="line.295"></a>
+<span class="sourceLineNo">296</span> * <code>serverName</code> passed is <code>1.example.org,60030,12345</code><a name="line.296"></a>
+<span class="sourceLineNo">297</span> */<a name="line.297"></a>
+<span class="sourceLineNo">298</span> public static String getWALDirectoryName(final String serverName) {<a name="line.298"></a>
+<span class="sourceLineNo">299</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_LOGDIR_NAME);<a name="line.299"></a>
+<span class="sourceLineNo">300</span> dirName.append("/");<a name="line.300"></a>
+<span class="sourceLineNo">301</span> dirName.append(serverName);<a name="line.301"></a>
+<span class="sourceLineNo">302</span> return dirName.toString();<a name="line.302"></a>
+<span class="sourceLineNo">303</span> }<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> * Construct the directory name for all old WALs on a given server. The default old WALs dir looks<a name="line.306"></a>
+<span class="sourceLineNo">307</span> * like: <code>hbase/oldWALs</code>. If you config hbase.separate.oldlogdir.by.regionserver to<a name="line.307"></a>
+<span class="sourceLineNo">308</span> * true, it looks like <code>hbase//oldWALs/kalashnikov.att.net,61634,1486865297088</code>.<a name="line.308"></a>
+<span class="sourceLineNo">309</span> * @param conf<a name="line.309"></a>
+<span class="sourceLineNo">310</span> * @param serverName Server name formatted as described in {@link ServerName}<a name="line.310"></a>
+<span class="sourceLineNo">311</span> * @return the relative WAL directory name<a name="line.311"></a>
+<span class="sourceLineNo">312</span> */<a name="line.312"></a>
+<span class="sourceLineNo">313</span> public static String getWALArchiveDirectoryName(Configuration conf, final String serverName) {<a name="line.313"></a>
+<span class="sourceLineNo">314</span> StringBuilder dirName = new StringBuilder(HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.314"></a>
+<span class="sourceLineNo">315</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.315"></a>
+<span class="sourceLineNo">316</span> dirName.append(Path.SEPARATOR);<a name="line.316"></a>
+<span class="sourceLineNo">317</span> dirName.append(serverName);<a name="line.317"></a>
+<span class="sourceLineNo">318</span> }<a name="line.318"></a>
+<span class="sourceLineNo">319</span> return dirName.toString();<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> * Pulls a ServerName out of a Path generated according to our layout rules. In the below layouts,<a name="line.323"></a>
+<span class="sourceLineNo">324</span> * this method ignores the format of the logfile component. Current format: [base directory for<a name="line.324"></a>
+<span class="sourceLineNo">325</span> * hbase]/hbase/.logs/ServerName/logfile or [base directory for<a name="line.325"></a>
+<span class="sourceLineNo">326</span> * hbase]/hbase/.logs/ServerName-splitting/logfile Expected to work for individual log files and<a name="line.326"></a>
+<span class="sourceLineNo">327</span> * server-specific directories.<a name="line.327"></a>
+<span class="sourceLineNo">328</span> * @return null if it's not a log file. Returns the ServerName of the region server that created<a name="line.328"></a>
+<span class="sourceLineNo">329</span> * this log file otherwise.<a name="line.329"></a>
+<span class="sourceLineNo">330</span> */<a name="line.330"></a>
+<span class="sourceLineNo">331</span> public static ServerName getServerNameFromWALDirectoryName(Configuration conf, String path)<a name="line.331"></a>
+<span class="sourceLineNo">332</span> throws IOException {<a name="line.332"></a>
+<span class="sourceLineNo">333</span> if (path == null || path.length() <= HConstants.HREGION_LOGDIR_NAME.length()) {<a name="line.333"></a>
+<span class="sourceLineNo">334</span> return null;<a name="line.334"></a>
<span class="sourceLineNo">335</span> }<a name="line.335"></a>
-<span class="sourceLineNo">336</span> startPathSB.append(HConstants.HREGION_LOGDIR_NAME);<a name="line.336"></a>
-<span class="sourceLineNo">337</span> if (!HConstants.HREGION_LOGDIR_NAME.endsWith("/")) {<a name="line.337"></a>
-<span class="sourceLineNo">338</span> startPathSB.append('/');<a name="line.338"></a>
+<span class="sourceLineNo">336</span><a name="line.336"></a>
+<span class="sourceLineNo">337</span> if (conf == null) {<a name="line.337"></a>
+<span class="sourceLineNo">338</span> throw new IllegalArgumentException("parameter conf must be set");<a name="line.338"></a>
<span class="sourceLineNo">339</span> }<a name="line.339"></a>
-<span class="sourceLineNo">340</span> final String startPath = startPathSB.toString();<a name="line.340"></a>
-<span class="sourceLineNo">341</span><a name="line.341"></a>
-<span class="sourceLineNo">342</span> String fullPath;<a name="line.342"></a>
-<span class="sourceLineNo">343</span> try {<a name="line.343"></a>
-<span class="sourceLineNo">344</span> fullPath = FileSystem.get(conf).makeQualified(new Path(path)).toString();<a name="line.344"></a>
-<span class="sourceLineNo">345</span> } catch (IllegalArgumentException e) {<a name="line.345"></a>
-<span class="sourceLineNo">346</span> LOG.info("Call to makeQualified failed on " + path + " " + e.getMessage());<a name="line.346"></a>
-<span class="sourceLineNo">347</span> return null;<a name="line.347"></a>
-<span class="sourceLineNo">348</span> }<a name="line.348"></a>
-<span class="sourceLineNo">349</span><a name="line.349"></a>
-<span class="sourceLineNo">350</span> if (!fullPath.startsWith(startPath)) {<a name="line.350"></a>
-<span class="sourceLineNo">351</span> return null;<a name="line.351"></a>
-<span class="sourceLineNo">352</span> }<a name="line.352"></a>
-<span class="sourceLineNo">353</span><a name="line.353"></a>
-<span class="sourceLineNo">354</span> final String serverNameAndFile = fullPath.substring(startPath.length());<a name="line.354"></a>
+<span class="sourceLineNo">340</span><a name="line.340"></a>
+<span class="sourceLineNo">341</span> final String rootDir = conf.get(HConstants.HBASE_DIR);<a name="line.341"></a>
+<span class="sourceLineNo">342</span> if (rootDir == null || rootDir.isEmpty()) {<a name="line.342"></a>
+<span class="sourceLineNo">343</span> throw new IllegalArgumentException(HConstants.HBASE_DIR + " key not found in conf.");<a name="line.343"></a>
+<span class="sourceLineNo">344</span> }<a name="line.344"></a>
+<span class="sourceLineNo">345</span><a name="line.345"></a>
+<span class="sourceLineNo">346</span> final StringBuilder startPathSB = new StringBuilder(rootDir);<a name="line.346"></a>
+<span class="sourceLineNo">347</span> if (!rootDir.endsWith("/")) {<a name="line.347"></a>
+<span class="sourceLineNo">348</span> startPathSB.append('/');<a name="line.348"></a>
+<span class="sourceLineNo">349</span> }<a name="line.349"></a>
+<span class="sourceLineNo">350</span> startPathSB.append(HConstants.HREGION_LOGDIR_NAME);<a name="line.350"></a>
+<span class="sourceLineNo">351</span> if (!HConstants.HREGION_LOGDIR_NAME.endsWith("/")) {<a name="line.351"></a>
+<span class="sourceLineNo">352</span> startPathSB.append('/');<a name="line.352"></a>
+<span class="sourceLineNo">353</span> }<a name="line.353"></a>
+<span class="sourceLineNo">354</span> final String startPath = startPathSB.toString();<a name="line.354"></a>
<span class="sourceLineNo">355</span><a name="line.355"></a>
-<span class="sourceLineNo">356</span> if (serverNameAndFile.indexOf('/') < "a,0,0".length()) {<a name="line.356"></a>
-<span class="sourceLineNo">357</span> // Either it's a file (not a directory) or it's not a ServerName format<a name="line.357"></a>
-<span class="sourceLineNo">358</span> return null;<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> Path p = new Path(path);<a name="line.361"></a>
-<span class="sourceLineNo">362</span> return getServerNameFromWALDirectoryName(p);<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> /**<a name="line.365"></a>
-<span class="sourceLineNo">366</span> * This function returns region server name from a log file name which is in one of the following<a name="line.366"></a>
-<span class="sourceLineNo">367</span> * formats:<a name="line.367"></a>
-<span class="sourceLineNo">368</span> * <ul><a name="line.368"></a>
-<span class="sourceLineNo">369</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;-splitting/...</li><a name="line.369"></a>
-<span class="sourceLineNo">370</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;/...</li><a name="line.370"></a>
-<span class="sourceLineNo">371</span> * </ul><a name="line.371"></a>
-<span class="sourceLineNo">372</span> * @return null if the passed in logFile isn't a valid WAL file path<a name="line.372"></a>
-<span class="sourceLineNo">373</span> */<a name="line.373"></a>
-<span class="sourceLineNo">374</span> public static ServerName getServerNameFromWALDirectoryName(Path logFile) {<a name="line.374"></a>
-<span class="sourceLineNo">375</span> String logDirName = logFile.getParent().getName();<a name="line.375"></a>
-<span class="sourceLineNo">376</span> // We were passed the directory and not a file in it.<a name="line.376"></a>
-<span class="sourceLineNo">377</span> if (logDirName.equals(HConstants.HREGION_LOGDIR_NAME)) {<a name="line.377"></a>
-<span class="sourceLineNo">378</span> logDirName = logFile.getName();<a name="line.378"></a>
-<span class="sourceLineNo">379</span> }<a name="line.379"></a>
-<span class="sourceLineNo">380</span> ServerName serverName = null;<a name="line.380"></a>
-<span class="sourceLineNo">381</span> if (logDirName.endsWith(SPLITTING_EXT)) {<a name="line.381"></a>
-<span class="sourceLineNo">382</span> logDirName = logDirName.substring(0, logDirName.length() - SPLITTING_EXT.length());<a name="line.382"></a>
-<span class="sourceLineNo">383</span> }<a name="line.383"></a>
-<span class="sourceLineNo">384</span> try {<a name="line.384"></a>
-<span class="sourceLineNo">385</span> serverName = ServerName.parseServerName(logDirName);<a name="line.385"></a>
-<span class="sourceLineNo">386</span> } catch (IllegalArgumentException | IllegalStateException ex) {<a name="line.386"></a>
-<span class="sourceLineNo">387</span> serverName = null;<a name="line.387"></a>
-<span class="sourceLineNo">388</span> LOG.warn("Cannot parse a server name from path=" + logFile + "; " + ex.getMessage());<a name="line.388"></a>
-<span class="sourceLineNo">389</span> }<a name="line.389"></a>
-<span class="sourceLineNo">390</span> if (serverName != null && serverName.getStartcode() < 0) {<a name="line.390"></a>
-<span class="sourceLineNo">391</span> LOG.warn("Invalid log file path=" + logFile);<a name="line.391"></a>
-<span class="sourceLineNo">392</span> serverName = null;<a name="line.392"></a>
+<span class="sourceLineNo">356</span> String fullPath;<a name="line.356"></a>
+<span class="sourceLineNo">357</span> try {<a name="line.357"></a>
+<span class="sourceLineNo">358</span> fullPath = FileSystem.get(conf).makeQualified(new Path(path)).toString();<a name="line.358"></a>
+<span class="sourceLineNo">359</span> } catch (IllegalArgumentException e) {<a name="line.359"></a>
+<span class="sourceLineNo">360</span> LOG.info("Call to makeQualified failed on " + path + " " + e.getMessage());<a name="line.360"></a>
+<span class="sourceLineNo">361</span> return null;<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> if (!fullPath.startsWith(startPath)) {<a name="line.364"></a>
+<span class="sourceLineNo">365</span> return null;<a name="line.365"></a>
+<span class="sourceLineNo">366</span> }<a name="line.366"></a>
+<span class="sourceLineNo">367</span><a name="line.367"></a>
+<span class="sourceLineNo">368</span> final String serverNameAndFile = fullPath.substring(startPath.length());<a name="line.368"></a>
+<span class="sourceLineNo">369</span><a name="line.369"></a>
+<span class="sourceLineNo">370</span> if (serverNameAndFile.indexOf('/') < "a,0,0".length()) {<a name="line.370"></a>
+<span class="sourceLineNo">371</span> // Either it's a file (not a directory) or it's not a ServerName format<a name="line.371"></a>
+<span class="sourceLineNo">372</span> return null;<a name="line.372"></a>
+<span class="sourceLineNo">373</span> }<a name="line.373"></a>
+<span class="sourceLineNo">374</span><a name="line.374"></a>
+<span class="sourceLineNo">375</span> Path p = new Path(path);<a name="line.375"></a>
+<span class="sourceLineNo">376</span> return getServerNameFromWALDirectoryName(p);<a name="line.376"></a>
+<span class="sourceLineNo">377</span> }<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> * This function returns region server name from a log file name which is in one of the following<a name="line.380"></a>
+<span class="sourceLineNo">381</span> * formats:<a name="line.381"></a>
+<span class="sourceLineNo">382</span> * <ul><a name="line.382"></a>
+<span class="sourceLineNo">383</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;-splitting/...</li><a name="line.383"></a>
+<span class="sourceLineNo">384</span> * <li>hdfs://&lt;name node&gt;/hbase/.logs/&lt;server name&gt;/...</li><a name="line.384"></a>
+<span class="sourceLineNo">385</span> * </ul><a name="line.385"></a>
+<span class="sourceLineNo">386</span> * @return null if the passed in logFile isn't a valid WAL file path<a name="line.386"></a>
+<span class="sourceLineNo">387</span> */<a name="line.387"></a>
+<span class="sourceLineNo">388</span> public static ServerName getServerNameFromWALDirectoryName(Path logFile) {<a name="line.388"></a>
+<span class="sourceLineNo">389</span> String logDirName = logFile.getParent().getName();<a name="line.389"></a>
+<span class="sourceLineNo">390</span> // We were passed the directory and not a file in it.<a name="line.390"></a>
+<span class="sourceLineNo">391</span> if (logDirName.equals(HConstants.HREGION_LOGDIR_NAME)) {<a name="line.391"></a>
+<span class="sourceLineNo">392</span> logDirName = logFile.getName();<a name="line.392"></a>
<span class="sourceLineNo">393</span> }<a name="line.393"></a>
-<span class="sourceLineNo">394</span> return serverName;<a name="line.394"></a>
-<span class="sourceLineNo">395</span> }<a name="line.395"></a>
-<span class="sourceLineNo">396</span><a name="line.396"></a>
-<span class="sourceLineNo">397</span> public static boolean isMetaFile(Path p) {<a name="line.397"></a>
-<span class="sourceLineNo">398</span> return isMetaFile(p.getName());<a name="line.398"></a>
-<span class="sourceLineNo">399</span> }<a name="line.399"></a>
-<span class="sourceLineNo">400</span><a name="line.400"></a>
-<span class="sourceLineNo">401</span> public static boolean isMetaFile(String p) {<a name="line.401"></a>
-<span class="sourceLineNo">402</span> if (p != null && p.endsWith(META_WAL_PROVIDER_ID)) {<a name="line.402"></a>
-<span class="sourceLineNo">403</span> return true;<a name="line.403"></a>
-<span class="sourceLineNo">404</span> }<a name="line.404"></a>
-<span class="sourceLineNo">405</span> return false;<a name="line.405"></a>
-<span class="sourceLineNo">406</span> }<a name="line.406"></a>
-<span class="sourceLineNo">407</span><a name="line.407"></a>
-<span class="sourceLineNo">408</span> public static boolean isArchivedLogFile(Path p) {<a name="line.408"></a>
-<span class="sourceLineNo">409</span> String oldLog = Path.SEPARATOR + HConstants.HREGION_OLDLOGDIR_NAME + Path.SEPARATOR;<a name="line.409"></a>
-<span class="sourceLineNo">410</span> return p.toString().contains(oldLog);<a name="line.410"></a>
-<span class="sourceLineNo">411</span> }<a name="line.411"></a>
-<span class="sourceLineNo">412</span><a name="line.412"></a>
-<span class="sourceLineNo">413</span> /**<a name="line.413"></a>
-<span class="sourceLineNo">414</span> * Get the archived WAL file path<a name="line.414"></a>
-<span class="sourceLineNo">415</span> * @param path - active WAL file path<a name="line.415"></a>
-<span class="sourceLineNo">416</span> * @param conf - configuration<a name="line.416"></a>
-<span class="sourceLineNo">417</span> * @return archived path if exists, path - otherwise<a name="line.417"></a>
-<span class="sourceLineNo">418</span> * @throws IOException exception<a name="line.418"></a>
-<span class="sourceLineNo">419</span> */<a name="line.419"></a>
-<span class="sourceLineNo">420</span> public static Path getArchivedLogPath(Path path, Configuration conf) throws IOException {<a name="line.420"></a>
-<span class="sourceLineNo">421</span> Path rootDir = FSUtils.getRootDir(conf);<a name="line.421"></a>
-<span class="sourceLineNo">422</span> Path oldLogDir = new Path(rootDir, HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.422"></a>
-<span class="sourceLineNo">423</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.423"></a>
-<span class="sourceLineNo">424</span> ServerName serverName = getServerNameFromWALDirectoryName(path);<a name="line.424"></a>
-<span class="sourceLineNo">425</span> if (serverName == null) {<a name="line.425"></a>
-<span class="sourceLineNo">426</span> LOG.error("Couldn't locate log: " + path);<a name="line.426"></a>
-<span class="sourceLineNo">427</span> return path;<a name="line.427"></a>
-<span class="sourceLineNo">428</span> }<a name="line.428"></a>
-<span class="sourceLineNo">429</span> oldLogDir = new Path(oldLogDir, serverName.getServerName());<a name="line.429"></a>
-<span class="sourceLineNo">430</span> }<a name="line.430"></a>
-<span class="sourceLineNo">431</span> Path archivedLogLocation = new Path(oldLogDir, path.getName());<a name="line.431"></a>
-<span class="sourceLineNo">432</span> final FileSystem fs = FSUtils.getCurrentFileSystem(conf);<a name="line.432"></a>
-<span class="sourceLineNo">433</span><a name="line.433"></a>
-<span class="sourceLineNo">434</span> if (fs.exists(archivedLogLocation)) {<a name="line.434"></a>
-<span class="sourceLineNo">435</span> LOG.info("Log " + path + " was moved to " + archivedLogLocation);<a name="line.435"></a>
-<span class="sourceLineNo">436</span> return archivedLogLocation;<a name="line.436"></a>
-<span class="sourceLineNo">437</span> } else {<a name="line.437"></a>
-<span class="sourceLineNo">438</span> LOG.error("Couldn't locate log: " + path);<a name="line.438"></a>
-<span class="sourceLineNo">439</span> return path;<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> /**<a name="line.443"></a>
-<span class="sourceLineNo">444</span> * Opens WAL reader with retries and additional exception handling<a name="line.444"></a>
-<span class="sourceLineNo">445</span> * @param path path to WAL file<a name="line.445"></a>
-<span class="sourceLineNo">446</span> * @param conf configuration<a name="line.446"></a>
-<span class="sourceLineNo">447</span> * @return WAL Reader instance<a name="line.447"></a>
-<span class="sourceLineNo">448</span> * @throws IOException<a name="line.448"></a>
-<span class="sourceLineNo">449</span> */<a name="line.449"></a>
-<span class="sourceLineNo">450</span> public static org.apache.hadoop.hbase.wal.WAL.Reader openReader(Path path, Configuration conf)<a name="line.450"></a>
-<span class="sourceLineNo">451</span> throws IOException<a name="line.451"></a>
-<span class="sourceLineNo">452</span><a name="line.452"></a>
-<span class="sourceLineNo">453</span> {<a name="line.453"></a>
-<span class="sourceLineNo">454</span> long retryInterval = 2000; // 2 sec<a name="line.454"></a>
-<span class="sourceLineNo">455</span> int maxAttempts = 30;<a name="line.455"></a>
-<span class="sourceLineNo">456</span> int attempt = 0;<a name="line.456"></a>
-<span class="sourceLineNo">457</span> Exception ee = null;<a name="line.457"></a>
-<span class="sourceLineNo">458</span> org.apache.hadoop.hbase.wal.WAL.Reader reader = null;<a name="line.458"></a>
-<span class="sourceLineNo">459</span> while (reader == null && attempt++ < maxAttempts) {<a name="line.459"></a>
-<span class="sourceLineNo">460</span> try {<a name="line.460"></a>
-<span class="sourceLineNo">461</span> // Detect if this is a new file, if so get a new reader else<a name="line.461"></a>
-<span class="sourceLineNo">462</span> // reset the current reader so that we see the new data<a name="line.462"></a>
-<span class="sourceLineNo">463</span> reader = WALFactory.createReader(path.getFileSystem(conf), path, conf);<a name="line.463"></a>
-<span class="sourceLineNo">464</span> return reader;<a name="line.464"></a>
-<span class="sourceLineNo">465</span> } catch (FileNotFoundException fnfe) {<a name="line.465"></a>
-<span class="sourceLineNo">466</span> // If the log was archived, continue reading from there<a name="line.466"></a>
-<span class="sourceLineNo">467</span> Path archivedLog = AbstractFSWALProvider.getArchivedLogPath(path, conf);<a name="line.467"></a>
-<span class="sourceLineNo">468</span> if (!Objects.equals(path, archivedLog)) {<a name="line.468"></a>
-<span class="sourceLineNo">469</span> return openReader(archivedLog, conf);<a name="line.469"></a>
-<span class="sourceLineNo">470</span> } else {<a name="line.470"></a>
-<span class="sourceLineNo">471</span> throw fnfe;<a name="line.471"></a>
-<span class="sourceLineNo">472</span> }<a name="line.472"></a>
-<span class="sourceLineNo">473</span> } catch (LeaseNotRecoveredException lnre) {<a name="line.473"></a>
-<span class="sourceLineNo">474</span> // HBASE-15019 the WAL was not closed due to some hiccup.<a name="line.474"></a>
-<span class="sourceLineNo">475</span> LOG.warn("Try to recover the WAL lease " + path, lnre);<a name="line.475"></a>
-<span class="sourceLineNo">476</span> recoverLease(conf, path);<a name="line.476"></a>
-<span class="sourceLineNo">477</span> reader = null;<a name="line.477"></a>
-<span class="sourceLineNo">478</span> ee = lnre;<a name="line.478"></a>
-<span class="sourceLineNo">479</span> } catch (NullPointerException npe) {<a name="line.479"></a>
-<span class="sourceLineNo">480</span> // Workaround for race condition in HDFS-4380<a name="line.480"></a>
-<span class="sourceLineNo">481</span> // which throws a NPE if we open a file before any data node has the most recent block<a name="line.481"></a>
-<span class="sourceLineNo">482</span> // Just sleep and retry. Will require re-reading compressed WALs for compressionContext.<a name="line.482"></a>
-<span class="sourceLineNo">483</span> LOG.warn("Got NPE opening reader, will retry.");<a name="line.483"></a>
-<span class="sourceLineNo">484</span> reader = null;<a name="line.484"></a>
-<span class="sourceLineNo">485</span> ee = npe;<a name="line.485"></a>
-<span class="sourceLineNo">486</span> }<a name="line.486"></a>
-<span class="sourceLineNo">487</span> if (reader == null) {<a name="line.487"></a>
-<span class="sourceLineNo">488</span> // sleep before next attempt<a name="line.488"></a>
-<span class="sourceLineNo">489</span> try {<a name="line.489"></a>
-<span class="sourceLineNo">490</span> Thread.sleep(retryInterval);<a name="line.490"></a>
-<span class="sourceLineNo">491</span> } catch (InterruptedException e) {<a name="line.491"></a>
-<span class="sourceLineNo">492</span> }<a name="line.492"></a>
-<span class="sourceLineNo">493</span> }<a name="line.493"></a>
-<span class="sourceLineNo">494</span> }<a name="line.494"></a>
-<span class="sourceLineNo">495</span> throw new IOException("Could not open reader", ee);<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> // For HBASE-15019<a name="line.498"></a>
-<span class="sourceLineNo">499</span> private static void recoverLease(final Configuration conf, final Path path) {<a name="line.499"></a>
-<span class="sourceLineNo">500</span> try {<a name="line.500"></a>
-<span class="sourceLineNo">501</span> final FileSystem dfs = FSUtils.getCurrentFileSystem(conf);<a name="line.501"></a>
-<span class="sourceLineNo">502</span> FSUtils fsUtils = FSUtils.getInstance(dfs, conf);<a name="line.502"></a>
-<span class="sourceLineNo">503</span> fsUtils.recoverFileLease(dfs, path, conf, new CancelableProgressable() {<a name="line.503"></a>
-<span class="sourceLineNo">504</span> @Override<a name="line.504"></a>
-<span class="sourceLineNo">505</span> public boolean progress() {<a name="line.505"></a>
-<span class="sourceLineNo">506</span> LOG.debug("Still trying to recover WAL lease: " + path);<a name="line.506"></a>
-<span class="sourceLineNo">507</span> return true;<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> } catch (IOException e) {<a name="line.510"></a>
-<span class="sourceLineNo">511</span> LOG.warn("unable to recover lease for WAL: " + path, e);<a name="line.511"></a>
-<span class="sourceLineNo">512</span> }<a name="line.512"></a>
-<span class="sourceLineNo">513</span> }<a name="line.513"></a>
-<span class="sourceLineNo">514</span><a name="line.514"></a>
-<span class="sourceLineNo">515</span> @Override<a name="line.515"></a>
-<span class="sourceLineNo">516</span> public void addWALActionsListener(WALActionsListener listener) {<a name="line.516"></a>
-<span class="sourceLineNo">517</span> listeners.add(listener);<a name="line.517"></a>
-<span class="sourceLineNo">518</span> }<a name="line.518"></a>
-<span class="sourceLineNo">519</span><a name="line.519"></a>
-<span class="sourceLineNo">520</span> private static String getWALNameGroupFromWALName(String name, int group) {<a name="line.520"></a>
-<span class="sourceLineNo">521</span> Matcher matcher = WAL_FILE_NAME_PATTERN.matcher(name);<a name="line.521"></a>
-<span class="sourceLineNo">522</span> if (matcher.matches()) {<a name="line.522"></a>
-<span class="sourceLineNo">523</span> return matcher.group(group);<a name="line.523"></a>
-<span class="sourceLineNo">524</span> } else {<a name="line.524"></a>
-<span class="sourceLineNo">525</span> throw new IllegalArgumentException(name + " is not a valid wal file name");<a name="line.525"></a>
+<span class="sourceLineNo">394</span> ServerName serverName = null;<a name="line.394"></a>
+<span class="sourceLineNo">395</span> if (logDirName.endsWith(SPLITTING_EXT)) {<a name="line.395"></a>
+<span class="sourceLineNo">396</span> logDirName = logDirName.substring(0, logDirName.length() - SPLITTING_EXT.length());<a name="line.396"></a>
+<span class="sourceLineNo">397</span> }<a name="line.397"></a>
+<span class="sourceLineNo">398</span> try {<a name="line.398"></a>
+<span class="sourceLineNo">399</span> serverName = ServerName.parseServerName(logDirName);<a name="line.399"></a>
+<span class="sourceLineNo">400</span> } catch (IllegalArgumentException | IllegalStateException ex) {<a name="line.400"></a>
+<span class="sourceLineNo">401</span> serverName = null;<a name="line.401"></a>
+<span class="sourceLineNo">402</span> LOG.warn("Cannot parse a server name from path=" + logFile + "; " + ex.getMessage());<a name="line.402"></a>
+<span class="sourceLineNo">403</span> }<a name="line.403"></a>
+<span class="sourceLineNo">404</span> if (serverName != null && serverName.getStartcode() < 0) {<a name="line.404"></a>
+<span class="sourceLineNo">405</span> LOG.warn("Invalid log file path=" + logFile);<a name="line.405"></a>
+<span class="sourceLineNo">406</span> serverName = null;<a name="line.406"></a>
+<span class="sourceLineNo">407</span> }<a name="line.407"></a>
+<span class="sourceLineNo">408</span> return serverName;<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> public static boolean isMetaFile(Path p) {<a name="line.411"></a>
+<span class="sourceLineNo">412</span> return isMetaFile(p.getName());<a name="line.412"></a>
+<span class="sourceLineNo">413</span> }<a name="line.413"></a>
+<span class="sourceLineNo">414</span><a name="line.414"></a>
+<span class="sourceLineNo">415</span> public static boolean isMetaFile(String p) {<a name="line.415"></a>
+<span class="sourceLineNo">416</span> if (p != null && p.endsWith(META_WAL_PROVIDER_ID)) {<a name="line.416"></a>
+<span class="sourceLineNo">417</span> return true;<a name="line.417"></a>
+<span class="sourceLineNo">418</span> }<a name="line.418"></a>
+<span class="sourceLineNo">419</span> return false;<a name="line.419"></a>
+<span class="sourceLineNo">420</span> }<a name="line.420"></a>
+<span class="sourceLineNo">421</span><a name="line.421"></a>
+<span class="sourceLineNo">422</span> public static boolean isArchivedLogFile(Path p) {<a name="line.422"></a>
+<span class="sourceLineNo">423</span> String oldLog = Path.SEPARATOR + HConstants.HREGION_OLDLOGDIR_NAME + Path.SEPARATOR;<a name="line.423"></a>
+<span class="sourceLineNo">424</span> return p.toString().contains(oldLog);<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> * Get the archived WAL file path<a name="line.428"></a>
+<span class="sourceLineNo">429</span> * @param path - active WAL file path<a name="line.429"></a>
+<span class="sourceLineNo">430</span> * @param conf - configuration<a name="line.430"></a>
+<span class="sourceLineNo">431</span> * @return archived path if exists, path - otherwise<a name="line.431"></a>
+<span class="sourceLineNo">432</span> * @throws IOException exception<a name="line.432"></a>
+<span class="sourceLineNo">433</span> */<a name="line.433"></a>
+<span class="sourceLineNo">434</span> public static Path getArchivedLogPath(Path path, Configuration conf) throws IOException {<a name="line.434"></a>
+<span class="sourceLineNo">435</span> Path rootDir = FSUtils.getRootDir(conf);<a name="line.435"></a>
+<span class="sourceLineNo">436</span> Path oldLogDir = new Path(rootDir, HConstants.HREGION_OLDLOGDIR_NAME);<a name="line.436"></a>
+<span class="sourceLineNo">437</span> if (conf.getBoolean(SEPARATE_OLDLOGDIR, DEFAULT_SEPARATE_OLDLOGDIR)) {<a name="line.437"></a>
+<span class="sourceLineNo">438</span> ServerName serverName = getServerNameFromWALDirectoryName(path);<a name="line.438"></a>
+<span class="sourceLineNo">439</span> if (serverName == null) {<a name="line.439"></a>
+<span class="sourceLineNo">440</span> LOG.error("Couldn't locate log: " + path);<a name="line.440"></a>
+<span class="sourceLineNo">441</span> return path;<a name="line.441"></a>
+<span class="sourceLineNo">442</span> }<a name="line.442"></a>
+<span class="sourceLineNo">443</span> oldLogDir = new Path(oldLogDir, serverName.getServerName());<a name="line.443"></a>
+<span class="sourceLineNo">444</span> }<a name="line.444"></a>
+<span class="sourceLineNo">445</span> Path archivedLogLocation = n
<TRUNCATED>