HBASE-17779 disable_table_replication returns misleading message and does not turn off replication (Janos Gub)
This commit is contained in:
parent
c97905a962
commit
318298047b
|
@ -647,15 +647,17 @@ public class ReplicationAdmin implements Closeable {
|
|||
/**
|
||||
* Set the table's replication switch if the table's replication switch is already not set.
|
||||
* @param tableName name of the table
|
||||
* @param isRepEnabled is replication switch enable or disable
|
||||
* @param enableRep is replication switch enable or disable
|
||||
* @throws IOException if a remote or network exception occurs
|
||||
*/
|
||||
private void setTableRep(final TableName tableName, boolean isRepEnabled) throws IOException {
|
||||
private void setTableRep(final TableName tableName, boolean enableRep) throws IOException {
|
||||
Admin admin = null;
|
||||
try {
|
||||
admin = this.connection.getAdmin();
|
||||
HTableDescriptor htd = admin.getTableDescriptor(tableName);
|
||||
if (isTableRepEnabled(htd) ^ isRepEnabled) {
|
||||
ReplicationState currentReplicationState = getTableReplicationState(htd);
|
||||
if (enableRep && currentReplicationState != ReplicationState.ENABLED
|
||||
|| !enableRep && currentReplicationState != ReplicationState.DISABLED) {
|
||||
boolean isOnlineSchemaUpdateEnabled =
|
||||
this.connection.getConfiguration()
|
||||
.getBoolean("hbase.online.schema.update.enable", true);
|
||||
|
@ -663,7 +665,7 @@ public class ReplicationAdmin implements Closeable {
|
|||
admin.disableTable(tableName);
|
||||
}
|
||||
for (HColumnDescriptor hcd : htd.getFamilies()) {
|
||||
hcd.setScope(isRepEnabled ? HConstants.REPLICATION_SCOPE_GLOBAL
|
||||
hcd.setScope(enableRep ? HConstants.REPLICATION_SCOPE_GLOBAL
|
||||
: HConstants.REPLICATION_SCOPE_LOCAL);
|
||||
}
|
||||
admin.modifyTable(tableName, htd);
|
||||
|
@ -684,17 +686,34 @@ public class ReplicationAdmin implements Closeable {
|
|||
}
|
||||
|
||||
/**
|
||||
* @param htd table descriptor details for the table to check
|
||||
* @return true if table's replication switch is enabled
|
||||
* This enum indicates the current state of the replication for a given table.
|
||||
*/
|
||||
private boolean isTableRepEnabled(HTableDescriptor htd) {
|
||||
private enum ReplicationState {
|
||||
ENABLED, // all column families enabled
|
||||
MIXED, // some column families enabled, some disabled
|
||||
DISABLED // all column families disabled
|
||||
}
|
||||
|
||||
/**
|
||||
* @param htd table descriptor details for the table to check
|
||||
* @return ReplicationState the current state of the table.
|
||||
*/
|
||||
private ReplicationState getTableReplicationState(HTableDescriptor htd) {
|
||||
boolean hasEnabled = false;
|
||||
boolean hasDisabled = false;
|
||||
|
||||
for (HColumnDescriptor hcd : htd.getFamilies()) {
|
||||
if (hcd.getScope() != HConstants.REPLICATION_SCOPE_GLOBAL
|
||||
&& hcd.getScope() != HConstants.REPLICATION_SCOPE_SERIAL) {
|
||||
return false;
|
||||
hasDisabled = true;
|
||||
} else {
|
||||
hasEnabled = true;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
|
||||
if (hasEnabled && hasDisabled) return ReplicationState.MIXED;
|
||||
if (hasEnabled) return ReplicationState.ENABLED;
|
||||
return ReplicationState.DISABLED;
|
||||
}
|
||||
|
||||
private void checkConfiguredWALEntryFilters(ReplicationPeerConfig peerConfig)
|
||||
|
|
|
@ -69,6 +69,23 @@ public class TestReplicationAdminWithClusters extends TestReplicationBase {
|
|||
TestReplicationBase.tearDownAfterClass();
|
||||
}
|
||||
|
||||
@Test(timeout = 300000)
|
||||
public void disableNotFullReplication() throws Exception {
|
||||
HTableDescriptor table = admin2.getTableDescriptor(tableName);
|
||||
HColumnDescriptor f = new HColumnDescriptor("notReplicatedFamily");
|
||||
table.addFamily(f);
|
||||
admin1.disableTable(tableName);
|
||||
admin1.modifyTable(tableName, table);
|
||||
admin1.enableTable(tableName);
|
||||
|
||||
|
||||
admin.disableTableRep(tableName);
|
||||
table = admin1.getTableDescriptor(tableName);
|
||||
for (HColumnDescriptor fam : table.getColumnFamilies()) {
|
||||
assertEquals(fam.getScope(), HConstants.REPLICATION_SCOPE_LOCAL);
|
||||
}
|
||||
}
|
||||
|
||||
@Test(timeout = 300000)
|
||||
public void testEnableReplicationWhenSlaveClusterDoesntHaveTable() throws Exception {
|
||||
admin.disableTableRep(tableName);
|
||||
|
|
Loading…
Reference in New Issue