HBASE-5206 revert because of test failues in trunk build.

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1300725 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Zhihong Yu 2012-03-14 21:25:51 +00:00
parent 2ec60a022e
commit d73aee4f66
10 changed files with 19 additions and 149 deletions

View File

@ -1586,7 +1586,7 @@ public class AssignmentManager extends ZooKeeperListener {
if(versionOfOfflineNode != -1){ if(versionOfOfflineNode != -1){
if (isDisabledorDisablingRegionInRIT(region)) { if (isDisabledorDisablingRegionInRIT(region)) {
return; return;
} else setEnabledTable(region); }
} }
} }
@ -2201,14 +2201,6 @@ public class AssignmentManager extends ZooKeeperListener {
LOG.info("Bulk assigning done"); LOG.info("Bulk assigning done");
} }
private void setEnabledTable(HRegionInfo hri) {
String tableName = hri.getTableNameAsString();
boolean isTableEnabled = this.zkTable.isEnabledTable(tableName);
if (!isTableEnabled) {
setEnabledTable(tableName);
}
}
/** /**
* Assigns all user regions, if any exist. Used during cluster startup. * Assigns all user regions, if any exist. Used during cluster startup.
* <p> * <p>
@ -2244,9 +2236,6 @@ public class AssignmentManager extends ZooKeeperListener {
} else { } else {
// assign regions in round-robin fashion // assign regions in round-robin fashion
assignUserRegions(new ArrayList<HRegionInfo>(allRegions.keySet()), servers); assignUserRegions(new ArrayList<HRegionInfo>(allRegions.keySet()), servers);
for (HRegionInfo hri : allRegions.keySet()) {
setEnabledTable(hri);
}
return; return;
} }
LOG.info("Bulk assigning " + allRegions.size() + " region(s) across " + LOG.info("Bulk assigning " + allRegions.size() + " region(s) across " +
@ -2255,9 +2244,6 @@ public class AssignmentManager extends ZooKeeperListener {
// Use fixed count thread pool assigning. // Use fixed count thread pool assigning.
BulkAssigner ba = new StartupBulkAssigner(this.master, bulkPlan, this); BulkAssigner ba = new StartupBulkAssigner(this.master, bulkPlan, this);
ba.bulkAssign(); ba.bulkAssign();
for (HRegionInfo hri : allRegions.keySet()) {
setEnabledTable(hri);
}
LOG.info("Bulk assigning done"); LOG.info("Bulk assigning done");
} }
@ -2451,8 +2437,6 @@ public class AssignmentManager extends ZooKeeperListener {
new TreeMap<ServerName, List<Pair<HRegionInfo, Result>>>(); new TreeMap<ServerName, List<Pair<HRegionInfo, Result>>>();
// Iterate regions in META // Iterate regions in META
for (Result result : results) { for (Result result : results) {
boolean disabled = false;
boolean disablingOrEnabling = false;
Pair<HRegionInfo, ServerName> region = MetaReader.parseCatalogResult(result); Pair<HRegionInfo, ServerName> region = MetaReader.parseCatalogResult(result);
if (region == null) continue; if (region == null) continue;
HRegionInfo regionInfo = region.getFirst(); HRegionInfo regionInfo = region.getFirst();
@ -2486,13 +2470,6 @@ public class AssignmentManager extends ZooKeeperListener {
offlineServers.put(regionLocation, offlineRegions); offlineServers.put(regionLocation, offlineRegions);
} }
offlineRegions.add(new Pair<HRegionInfo,Result>(regionInfo, result)); offlineRegions.add(new Pair<HRegionInfo,Result>(regionInfo, result));
disabled = checkIfRegionBelongsToDisabled(regionInfo);
disablingOrEnabling = addTheTablesInPartialState(this.disablingTables,
this.enablingTables, regionInfo, tableName);
// need to enable the table if not disabled or disabling or enabling
// this will be used in rolling restarts
enableTableIfNotDisabledOrDisablingOrEnabling(disabled,
disablingOrEnabling, tableName);
} else { } else {
// Region is being served and on an active server // Region is being served and on an active server
// add only if region not in disabled and enabling table // add only if region not in disabled and enabling table
@ -2501,37 +2478,21 @@ public class AssignmentManager extends ZooKeeperListener {
regions.put(regionInfo, regionLocation); regions.put(regionInfo, regionLocation);
addToServers(regionLocation, regionInfo); addToServers(regionLocation, regionInfo);
} }
disablingOrEnabling = addTheTablesInPartialState(this.disablingTables, addTheTablesInPartialState(this.disablingTables, this.enablingTables, regionInfo,
this.enablingTables, regionInfo, tableName); tableName);
disabled = checkIfRegionBelongsToDisabled(regionInfo);
// need to enable the table if not disabled or disabling or enabling
// this will be used in rolling restarts
enableTableIfNotDisabledOrDisablingOrEnabling(disabled,
disablingOrEnabling, tableName);
} }
} }
return offlineServers; return offlineServers;
} }
private void enableTableIfNotDisabledOrDisablingOrEnabling(boolean disabled, private void addTheTablesInPartialState(Set<String> disablingTables,
boolean disablingOrEnabling, String tableName) {
if (!disabled && !disablingOrEnabling
&& !getZKTable().isEnabledTable(tableName)) {
setEnabledTable(tableName);
}
}
private Boolean addTheTablesInPartialState(Set<String> disablingTables,
Set<String> enablingTables, HRegionInfo regionInfo, Set<String> enablingTables, HRegionInfo regionInfo,
String disablingTableName) { String disablingTableName) {
if (checkIfRegionBelongsToDisabling(regionInfo)) { if (checkIfRegionBelongsToDisabling(regionInfo)) {
disablingTables.add(disablingTableName); disablingTables.add(disablingTableName);
return true;
} else if (checkIfRegionsBelongsToEnabling(regionInfo)) { } else if (checkIfRegionsBelongsToEnabling(regionInfo)) {
enablingTables.add(disablingTableName); enablingTables.add(disablingTableName);
return true;
} }
return false;
} }
/** /**
@ -3348,16 +3309,4 @@ public class AssignmentManager extends ZooKeeperListener {
this.threadPoolExecutorService.shutdown(); this.threadPoolExecutorService.shutdown();
} }
} }
protected void setEnabledTable(String tableName) {
try {
this.zkTable.setEnabledTable(tableName);
} catch (KeeperException e) {
// here we can abort as it is the start up flow
String errorMsg = "Unable to ensure that the table " + tableName
+ " is enabled because of a ZooKeeper issue:" + e;
LOG.error(errorMsg);
this.master.abort(errorMsg, e);
}
}
} }

View File

@ -626,9 +626,6 @@ Server {
this.assignmentManager.regionOnline(HRegionInfo.ROOT_REGIONINFO, this.assignmentManager.regionOnline(HRegionInfo.ROOT_REGIONINFO,
this.catalogTracker.getRootLocation()); this.catalogTracker.getRootLocation());
} }
// Enable the ROOT table if on process fail over the RS containing ROOT
// was active.
enableCatalogTables(Bytes.toString(HConstants.ROOT_TABLE_NAME));
LOG.info("-ROOT- assigned=" + assigned + ", rit=" + rit + LOG.info("-ROOT- assigned=" + assigned + ", rit=" + rit +
", location=" + catalogTracker.getRootLocation()); ", location=" + catalogTracker.getRootLocation());
@ -654,19 +651,12 @@ Server {
this.assignmentManager.regionOnline(HRegionInfo.FIRST_META_REGIONINFO, this.assignmentManager.regionOnline(HRegionInfo.FIRST_META_REGIONINFO,
this.catalogTracker.getMetaLocation()); this.catalogTracker.getMetaLocation());
} }
enableCatalogTables(Bytes.toString(HConstants.META_TABLE_NAME));
LOG.info(".META. assigned=" + assigned + ", rit=" + rit + LOG.info(".META. assigned=" + assigned + ", rit=" + rit +
", location=" + catalogTracker.getMetaLocation()); ", location=" + catalogTracker.getMetaLocation());
status.setStatus("META and ROOT assigned."); status.setStatus("META and ROOT assigned.");
return assigned; return assigned;
} }
private void enableCatalogTables(String catalogTableName) {
if (!this.assignmentManager.getZKTable().isEnabledTable(catalogTableName)) {
this.assignmentManager.setEnabledTable(catalogTableName);
}
}
void fixupDaughters(final MonitoredTask status) throws IOException { void fixupDaughters(final MonitoredTask status) throws IOException {
final Map<HRegionInfo, Result> offlineSplitParents = final Map<HRegionInfo, Result> offlineSplitParents =
new HashMap<HRegionInfo, Result>(); new HashMap<HRegionInfo, Result>();

View File

@ -81,7 +81,8 @@ public class DeleteTableHandler extends TableEventHandler {
this.masterServices.getTableDescriptors().remove(Bytes.toString(tableName)); this.masterServices.getTableDescriptors().remove(Bytes.toString(tableName));
// If entry for this table in zk, and up in AssignmentManager, remove it. // If entry for this table in zk, and up in AssignmentManager, remove it.
am.getZKTable().setDeletedTable(Bytes.toString(tableName)); // Call to undisableTable does this. TODO: Make a more formal purge table.
am.getZKTable().setEnabledTable(Bytes.toString(tableName));
} }
@Override @Override

View File

@ -327,27 +327,13 @@ public class ServerShutdownHandler extends EventHandler {
public static boolean processDeadRegion(HRegionInfo hri, Result result, public static boolean processDeadRegion(HRegionInfo hri, Result result,
AssignmentManager assignmentManager, CatalogTracker catalogTracker) AssignmentManager assignmentManager, CatalogTracker catalogTracker)
throws IOException { throws IOException {
boolean tablePresent = assignmentManager.getZKTable().isTablePresent(
hri.getTableNameAsString());
if (!tablePresent) {
LOG.info("The table " + hri.getTableNameAsString()
+ " was deleted. Hence not proceeding.");
return false;
}
// If table is not disabled but the region is offlined, // If table is not disabled but the region is offlined,
boolean disabled = assignmentManager.getZKTable().isDisabledTable( boolean disabled = assignmentManager.getZKTable().isDisabledTable(
hri.getTableNameAsString()); hri.getTableNameAsString());
if (disabled){ if (disabled) return false;
LOG.info("The table " + hri.getTableNameAsString()
+ " was disabled. Hence not proceeding.");
return false;
}
if (hri.isOffline() && hri.isSplit()) { if (hri.isOffline() && hri.isSplit()) {
LOG.debug("Offlined and split region " + hri.getRegionNameAsString() + LOG.debug("Offlined and split region " + hri.getRegionNameAsString() +
"; checking daughter presence"); "; checking daughter presence");
if (MetaReader.getRegion(catalogTracker, hri.getRegionName()) == null) {
return false;
}
fixupDaughters(result, assignmentManager, catalogTracker); fixupDaughters(result, assignmentManager, catalogTracker);
return false; return false;
} }

View File

@ -218,7 +218,7 @@ public class ZKTable {
public boolean checkEnabledAndSetDisablingTable(final String tableName) public boolean checkEnabledAndSetDisablingTable(final String tableName)
throws KeeperException { throws KeeperException {
synchronized (this.cache) { synchronized (this.cache) {
if (this.cache.get(tableName) != null && !isEnabledTable(tableName)) { if (!isEnabledTable(tableName)) {
return false; return false;
} }
setTableState(tableName, TableState.DISABLING); setTableState(tableName, TableState.DISABLING);
@ -267,7 +267,10 @@ public class ZKTable {
} }
public boolean isEnabledTable(String tableName) { public boolean isEnabledTable(String tableName) {
return isTableState(tableName, TableState.ENABLED); synchronized (this.cache) {
// No entry in cache means enabled table.
return !this.cache.containsKey(tableName);
}
} }
/** /**
@ -282,7 +285,7 @@ public class ZKTable {
public static boolean isEnabledTable(final ZooKeeperWatcher zkw, public static boolean isEnabledTable(final ZooKeeperWatcher zkw,
final String tableName) final String tableName)
throws KeeperException { throws KeeperException {
return getTableState(zkw, tableName) == TableState.ENABLED; return getTableState(zkw, tableName) == null;
} }
public boolean isDisablingOrDisabledTable(final String tableName) { public boolean isDisablingOrDisabledTable(final String tableName) {
@ -334,47 +337,23 @@ public class ZKTable {
} }
/** /**
* Deletes the table in zookeeper. Fails silently if the * Enables the table in zookeeper. Fails silently if the
* table is not currently disabled in zookeeper. Sets no watches. * table is not currently disabled in zookeeper. Sets no watches.
* @param tableName * @param tableName
* @throws KeeperException unexpected zookeeper exception * @throws KeeperException unexpected zookeeper exception
*/ */
public void setDeletedTable(final String tableName) public void setEnabledTable(final String tableName)
throws KeeperException { throws KeeperException {
synchronized (this.cache) { synchronized (this.cache) {
if (this.cache.remove(tableName) == null) { if (this.cache.remove(tableName) == null) {
LOG.warn("Moving table " + tableName + " state to deleted but was " + LOG.warn("Moving table " + tableName + " state to enabled but was " +
"already deleted"); "already enabled");
} }
ZKUtil.deleteNodeFailSilent(this.watcher, ZKUtil.deleteNodeFailSilent(this.watcher,
ZKUtil.joinZNode(this.watcher.tableZNode, tableName)); ZKUtil.joinZNode(this.watcher.tableZNode, tableName));
} }
} }
/**
* Sets the ENABLED state in the cache and deletes the zookeeper node. Fails
* silently if the node is not in enabled in zookeeper
*
* @param tableName
* @throws KeeperException
*/
public void setEnabledTable(final String tableName) throws KeeperException {
setTableState(tableName, TableState.ENABLED);
}
/**
* check if table is present .
*
* @param tableName
* @return True if the table is present
*/
public boolean isTablePresent(final String tableName) {
synchronized (this.cache) {
TableState state = this.cache.get(tableName);
return !(state == null);
}
}
/** /**
* Gets a list of all the tables set as disabled in zookeeper. * Gets a list of all the tables set as disabled in zookeeper.
* @return Set of disabled tables, empty Set if none * @return Set of disabled tables, empty Set if none

View File

@ -222,9 +222,6 @@ public class TestAdmin {
ht.get(get); ht.get(get);
this.admin.disableTable(table); this.admin.disableTable(table);
assertTrue("Table must be disabled.", TEST_UTIL.getHBaseCluster()
.getMaster().getAssignmentManager().getZKTable().isDisabledTable(
Bytes.toString(table)));
// Test that table is disabled // Test that table is disabled
get = new Get(row); get = new Get(row);
@ -239,9 +236,6 @@ public class TestAdmin {
} }
assertTrue(ok); assertTrue(ok);
this.admin.enableTable(table); this.admin.enableTable(table);
assertTrue("Table must be enabled.", TEST_UTIL.getHBaseCluster()
.getMaster().getAssignmentManager().getZKTable().isEnabledTable(
Bytes.toString(table)));
// Test that table is enabled // Test that table is enabled
try { try {
@ -313,9 +307,6 @@ public class TestAdmin {
HConstants.CATALOG_FAMILY).close(); HConstants.CATALOG_FAMILY).close();
tables = this.admin.listTables(); tables = this.admin.listTables();
assertEquals(numTables + 1, tables.length); assertEquals(numTables + 1, tables.length);
assertTrue("Table must be enabled.", TEST_UTIL.getHBaseCluster()
.getMaster().getAssignmentManager().getZKTable().isEnabledTable(
"testCreateTable"));
} }
@Test @Test

View File

@ -69,8 +69,6 @@ public class TestMaster {
HMaster m = cluster.getMaster(); HMaster m = cluster.getMaster();
HTable ht = TEST_UTIL.createTable(TABLENAME, FAMILYNAME); HTable ht = TEST_UTIL.createTable(TABLENAME, FAMILYNAME);
assertTrue(m.assignmentManager.getZKTable().isEnabledTable
(Bytes.toString(TABLENAME)));
TEST_UTIL.loadTable(ht, FAMILYNAME); TEST_UTIL.loadTable(ht, FAMILYNAME);
ht.close(); ht.close();

View File

@ -743,8 +743,6 @@ public class TestMasterFailover {
master.assignRegion(hri); master.assignRegion(hri);
} }
assertTrue(" Table must be enabled.", master.getAssignmentManager()
.getZKTable().isEnabledTable("enabledTable"));
// we also need regions assigned out on the dead server // we also need regions assigned out on the dead server
List<HRegionInfo> enabledAndOnDeadRegions = new ArrayList<HRegionInfo>(); List<HRegionInfo> enabledAndOnDeadRegions = new ArrayList<HRegionInfo>();
enabledAndOnDeadRegions.add(enabledRegions.remove(0)); enabledAndOnDeadRegions.add(enabledRegions.remove(0));
@ -790,9 +788,6 @@ public class TestMasterFailover {
ZKTable zktable = new ZKTable(zkw); ZKTable zktable = new ZKTable(zkw);
zktable.setDisabledTable(Bytes.toString(disabledTable)); zktable.setDisabledTable(Bytes.toString(disabledTable));
assertTrue(" The enabled table should be identified on master fail over.",
zktable.isEnabledTable("enabledTable"));
/* /*
* ZK = CLOSING * ZK = CLOSING
*/ */

View File

@ -20,7 +20,6 @@
package org.apache.hadoop.hbase.master; package org.apache.hadoop.hbase.master;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.io.IOException; import java.io.IOException;
import java.util.List; import java.util.List;
@ -97,9 +96,6 @@ public class TestMasterRestartAfterDisablingTable {
cluster.hbaseCluster.waitOnMaster(activeMaster); cluster.hbaseCluster.waitOnMaster(activeMaster);
cluster.waitForActiveAndReadyMaster(); cluster.waitForActiveAndReadyMaster();
assertTrue("The table should not be in enabled state", cluster.getMaster()
.getAssignmentManager().getZKTable().isDisablingOrDisabledTable(
"tableRestart"));
log("Enabling table\n"); log("Enabling table\n");
// Need a new Admin, the previous one is on the old master // Need a new Admin, the previous one is on the old master
HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration()); HBaseAdmin admin = new HBaseAdmin(TEST_UTIL.getConfiguration());
@ -112,8 +108,6 @@ public class TestMasterRestartAfterDisablingTable {
assertEquals( assertEquals(
"The assigned regions were not onlined after master switch except for the catalog tables.", "The assigned regions were not onlined after master switch except for the catalog tables.",
6, regions.size()); 6, regions.size());
assertTrue("The table should be in enabled state", cluster.getMaster()
.getAssignmentManager().getZKTable().isEnabledTable("tableRestart"));
ht.close(); ht.close();
TEST_UTIL.shutdownMiniCluster(); TEST_UTIL.shutdownMiniCluster();
} }

View File

@ -68,42 +68,29 @@ public class TestZKTable {
ZooKeeperWatcher zkw = new ZooKeeperWatcher(TEST_UTIL.getConfiguration(), ZooKeeperWatcher zkw = new ZooKeeperWatcher(TEST_UTIL.getConfiguration(),
name, abortable, true); name, abortable, true);
ZKTable zkt = new ZKTable(zkw); ZKTable zkt = new ZKTable(zkw);
assertFalse(zkt.isEnabledTable(name)); assertTrue(zkt.isEnabledTable(name));
assertFalse(zkt.isDisablingTable(name)); assertFalse(zkt.isDisablingTable(name));
assertFalse(zkt.isDisabledTable(name)); assertFalse(zkt.isDisabledTable(name));
assertFalse(zkt.isEnablingTable(name)); assertFalse(zkt.isEnablingTable(name));
assertFalse(zkt.isDisablingOrDisabledTable(name)); assertFalse(zkt.isDisablingOrDisabledTable(name));
assertFalse(zkt.isDisabledOrEnablingTable(name)); assertFalse(zkt.isDisabledOrEnablingTable(name));
assertFalse(zkt.isTablePresent(name));
zkt.setDisablingTable(name); zkt.setDisablingTable(name);
assertTrue(zkt.isDisablingTable(name)); assertTrue(zkt.isDisablingTable(name));
assertTrue(zkt.isDisablingOrDisabledTable(name)); assertTrue(zkt.isDisablingOrDisabledTable(name));
assertFalse(zkt.getDisabledTables().contains(name)); assertFalse(zkt.getDisabledTables().contains(name));
assertTrue(zkt.isTablePresent(name));
zkt.setDisabledTable(name); zkt.setDisabledTable(name);
assertTrue(zkt.isDisabledTable(name)); assertTrue(zkt.isDisabledTable(name));
assertTrue(zkt.isDisablingOrDisabledTable(name)); assertTrue(zkt.isDisablingOrDisabledTable(name));
assertFalse(zkt.isDisablingTable(name)); assertFalse(zkt.isDisablingTable(name));
assertTrue(zkt.getDisabledTables().contains(name)); assertTrue(zkt.getDisabledTables().contains(name));
assertTrue(zkt.isTablePresent(name));
zkt.setEnablingTable(name); zkt.setEnablingTable(name);
assertTrue(zkt.isEnablingTable(name)); assertTrue(zkt.isEnablingTable(name));
assertTrue(zkt.isDisabledOrEnablingTable(name)); assertTrue(zkt.isDisabledOrEnablingTable(name));
assertFalse(zkt.isDisabledTable(name)); assertFalse(zkt.isDisabledTable(name));
assertFalse(zkt.getDisabledTables().contains(name)); assertFalse(zkt.getDisabledTables().contains(name));
assertTrue(zkt.isTablePresent(name));
zkt.setEnabledTable(name); zkt.setEnabledTable(name);
assertTrue(zkt.isEnabledTable(name)); assertTrue(zkt.isEnabledTable(name));
assertFalse(zkt.isEnablingTable(name)); assertFalse(zkt.isEnablingTable(name));
assertTrue(zkt.isTablePresent(name));
zkt.setDeletedTable(name);
assertFalse(zkt.isEnabledTable(name));
assertFalse(zkt.isDisablingTable(name));
assertFalse(zkt.isDisabledTable(name));
assertFalse(zkt.isEnablingTable(name));
assertFalse(zkt.isDisablingOrDisabledTable(name));
assertFalse(zkt.isDisabledOrEnablingTable(name));
assertFalse(zkt.isTablePresent(name));
} }
@org.junit.Rule @org.junit.Rule