HBASE-4308 Race between RegionOpenedHandler and AssignmentManager(Ram)

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1205513 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
ramkrishna 2011-11-23 18:03:10 +00:00
parent 10407c9a16
commit 42104d08f2
3 changed files with 35 additions and 17 deletions

View File

@ -441,6 +441,7 @@ Release 0.92.0 - Unreleased
HBASE-4623 Remove @deprecated Scan methods in 0.90 from TRUNK and 0.92 HBASE-4623 Remove @deprecated Scan methods in 0.90 from TRUNK and 0.92
HBASE-4842 [hbck] Fix intermittent failures on TestHBaseFsck.testHBaseFsck HBASE-4842 [hbck] Fix intermittent failures on TestHBaseFsck.testHBaseFsck
(Jon Hsieh) (Jon Hsieh)
HBASE-4308 Race between RegionOpenedHandler and AssignmentManager (Ram)
TESTS TESTS
HBASE-4450 test for number of blocks read: to serve as baseline for expected HBASE-4450 test for number of blocks read: to serve as baseline for expected

View File

@ -966,16 +966,36 @@ public class AssignmentManager extends ZooKeeperListener {
ZKAssign.getRegionName(this.master.getZooKeeper(), path); ZKAssign.getRegionName(this.master.getZooKeeper(), path);
RegionState rs = this.regionsInTransition.get(regionName); RegionState rs = this.regionsInTransition.get(regionName);
if (rs != null) { if (rs != null) {
HRegionInfo regionInfo = rs.getRegion();
if (rs.isSplitting() || rs.isSplit()) { if (rs.isSplitting() || rs.isSplit()) {
LOG.debug("Ephemeral node deleted, regionserver crashed?, " + LOG.debug("Ephemeral node deleted, regionserver crashed?, " +
"clearing from RIT; rs=" + rs); "clearing from RIT; rs=" + rs);
clearRegionFromTransition(rs.getRegion()); clearRegionFromTransition(rs.getRegion());
} else { } else {
LOG.warn("Node deleted but still in RIT: " + rs); LOG.debug("The znode of region " + regionInfo.getRegionNameAsString()
+ " has been deleted.");
if (rs.isOpened()) {
makeRegionOnline(rs, regionInfo);
} }
} }
} }
} }
}
private void makeRegionOnline(RegionState rs, HRegionInfo regionInfo) {
regionOnline(regionInfo, rs.serverName);
LOG.info("The master has opened the region "
+ regionInfo.getRegionNameAsString() + " that was online on "
+ rs.serverName);
if (this.getZKTable().isDisablingOrDisabledTable(
regionInfo.getTableNameAsString())) {
debugLog(regionInfo, "Opened region "
+ regionInfo.getRegionNameAsString() + " but "
+ "this table is disabled, triggering close of region");
unassign(regionInfo);
}
}
/** /**
* New unassigned node has been created. * New unassigned node has been created.

View File

@ -26,7 +26,6 @@ import org.apache.hadoop.hbase.HRegionInfo;
import org.apache.hadoop.hbase.Server; import org.apache.hadoop.hbase.Server;
import org.apache.hadoop.hbase.ServerName; import org.apache.hadoop.hbase.ServerName;
import org.apache.hadoop.hbase.executor.EventHandler; import org.apache.hadoop.hbase.executor.EventHandler;
import org.apache.hadoop.hbase.executor.EventHandler.EventType;
import org.apache.hadoop.hbase.master.AssignmentManager; import org.apache.hadoop.hbase.master.AssignmentManager;
import org.apache.hadoop.hbase.master.AssignmentManager.RegionState; import org.apache.hadoop.hbase.master.AssignmentManager.RegionState;
import org.apache.hadoop.hbase.zookeeper.ZKAssign; import org.apache.hadoop.hbase.zookeeper.ZKAssign;
@ -98,30 +97,28 @@ public class OpenedRegionHandler extends EventHandler implements TotesHRegionInf
// Code to defend against case where we get SPLIT before region open // Code to defend against case where we get SPLIT before region open
// processing completes; temporary till we make SPLITs go via zk -- 0.92. // processing completes; temporary till we make SPLITs go via zk -- 0.92.
RegionState regionState = this.assignmentManager.isRegionInTransition(regionInfo); RegionState regionState = this.assignmentManager.isRegionInTransition(regionInfo);
boolean openedNodeDeleted = false;
if (regionState != null if (regionState != null
&& regionState.getState().equals(RegionState.State.OPEN)) { && regionState.getState().equals(RegionState.State.OPEN)) {
if (deleteOpenedNode(expectedVersion)) { openedNodeDeleted = deleteOpenedNode(expectedVersion);
// Remove region from in-memory transition and unassigned node from ZK if (!openedNodeDeleted) {
this.assignmentManager.regionOnline(regionInfo, this.sn); LOG.error("The znode of region " + regionInfo.getRegionNameAsString()
debugLog(regionInfo, "The master has opened the region " + + " could not be deleted.");
regionInfo.getRegionNameAsString() + " that was online on " +
this.sn.toString());
} else {
LOG.error("The znode of region " + regionInfo.getRegionNameAsString() +
" could not be deleted.");
} }
} else { } else {
LOG.warn("Skipping the onlining of " + regionInfo.getRegionNameAsString() + LOG.warn("Skipping the onlining of " + regionInfo.getRegionNameAsString() +
" because regions is NOT in RIT -- presuming this is because it SPLIT"); " because regions is NOT in RIT -- presuming this is because it SPLIT");
} }
if (!openedNodeDeleted) {
if (this.assignmentManager.getZKTable().isDisablingOrDisabledTable( if (this.assignmentManager.getZKTable().isDisablingOrDisabledTable(
regionInfo.getTableNameAsString())) { regionInfo.getTableNameAsString())) {
debugLog(regionInfo, debugLog(regionInfo, "Opened region "
"Opened region " + regionInfo.getRegionNameAsString() + " but " + regionInfo.getRegionNameAsString() + " but "
+ "this table is disabled, triggering close of region"); + "this table is disabled, triggering close of region");
assignmentManager.unassign(regionInfo); assignmentManager.unassign(regionInfo);
} }
} }
}
private boolean deleteOpenedNode(int expectedVersion) { private boolean deleteOpenedNode(int expectedVersion) {
debugLog(regionInfo, "Handling OPENED event for " + debugLog(regionInfo, "Handling OPENED event for " +