HBASE-22944 Check for hbase:quota table existence in SpaceQuotaRefresherChore

During startup, it's possible that quotas are enabled but the Master has
not yet created the hbase:quotas table.

Closes #559

Signed-off-by: stack <stack@apache.org>
Signed-off-by: Josh Elser <elserj@apache.org>
This commit is contained in:
shardul-cr7 2019-08-29 11:41:04 +05:30 committed by Josh Elser
parent e890776fe0
commit 2b3c9b18dd
2 changed files with 20 additions and 0 deletions

View File

@ -23,6 +23,7 @@ import java.util.Map.Entry;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.MetaTableAccessor;
import org.apache.hadoop.hbase.ScheduledChore; import org.apache.hadoop.hbase.ScheduledChore;
import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.TableName;
import org.apache.yetus.audience.InterfaceAudience; import org.apache.yetus.audience.InterfaceAudience;
@ -60,6 +61,7 @@ public class SpaceQuotaRefresherChore extends ScheduledChore {
private final RegionServerSpaceQuotaManager manager; private final RegionServerSpaceQuotaManager manager;
private final Connection conn; private final Connection conn;
private boolean quotaTablePresent = false;
public SpaceQuotaRefresherChore(RegionServerSpaceQuotaManager manager, Connection conn) { public SpaceQuotaRefresherChore(RegionServerSpaceQuotaManager manager, Connection conn) {
super(SpaceQuotaRefresherChore.class.getSimpleName(), super(SpaceQuotaRefresherChore.class.getSimpleName(),
@ -74,6 +76,13 @@ public class SpaceQuotaRefresherChore extends ScheduledChore {
@Override @Override
protected void chore() { protected void chore() {
try { try {
// check whether quotaTable is present or not.
if (!quotaTablePresent && !checkQuotaTableExists()) {
LOG.info("Quota table not found, skipping quota manager cache refresh.");
return;
}
// since quotaTable is present so setting the flag as true.
quotaTablePresent = true;
if (LOG.isTraceEnabled()) { if (LOG.isTraceEnabled()) {
LOG.trace("Reading current quota snapshots from hbase:quota."); LOG.trace("Reading current quota snapshots from hbase:quota.");
} }
@ -144,6 +153,16 @@ public class SpaceQuotaRefresherChore extends ScheduledChore {
} }
} }
/**
* Checks if hbase:quota exists in hbase:meta
*
* @return true if hbase:quota table is in meta, else returns false.
* @throws IOException throws IOException
*/
boolean checkQuotaTableExists() throws IOException {
return MetaTableAccessor.tableExists(getConnection(), QuotaUtil.QUOTA_TABLE_NAME);
}
/** /**
* Checks if the given <code>snapshot</code> is in violation, allowing the snapshot to be null. * Checks if the given <code>snapshot</code> is in violation, allowing the snapshot to be null.
* If the snapshot is null, this is interpreted as no snapshot which implies not in violation. * If the snapshot is null, this is interpreted as no snapshot which implies not in violation.

View File

@ -82,6 +82,7 @@ public class TestSpaceQuotaViolationPolicyRefresherChore {
chore = mock(SpaceQuotaRefresherChore.class); chore = mock(SpaceQuotaRefresherChore.class);
when(chore.getConnection()).thenReturn(conn); when(chore.getConnection()).thenReturn(conn);
when(chore.getManager()).thenReturn(manager); when(chore.getManager()).thenReturn(manager);
when(chore.checkQuotaTableExists()).thenReturn(true);
doCallRealMethod().when(chore).chore(); doCallRealMethod().when(chore).chore();
when(chore.isInViolation(any())).thenCallRealMethod(); when(chore.isInViolation(any())).thenCallRealMethod();
doCallRealMethod().when(chore).extractQuotaSnapshot(any(), any()); doCallRealMethod().when(chore).extractQuotaSnapshot(any(), any());