HBASE-3627 NPE in EventHandler when region already reassigned

git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1085075 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Stack 2011-03-24 19:01:50 +00:00
parent 237bc82af2
commit cf3284dfb9
7 changed files with 29 additions and 17 deletions

View File

@ -168,6 +168,7 @@ Release 0.90.2 - Unreleased
HBASE-3617 NoRouteToHostException during balancing will cause Master abort HBASE-3617 NoRouteToHostException during balancing will cause Master abort
(Ted Yu via Stack) (Ted Yu via Stack)
HBASE-3668 CatalogTracker.waitForMeta can wait forever and totally stall a RS HBASE-3668 CatalogTracker.waitForMeta can wait forever and totally stall a RS
HBASE-3627 NPE in EventHandler when region already reassigned
IMPROVEMENTS IMPROVEMENTS
HBASE-3542 MultiGet methods in Thrift HBASE-3542 MultiGet methods in Thrift

View File

@ -23,6 +23,7 @@ import java.io.EOFException;
import java.io.IOException; import java.io.IOException;
import java.net.ConnectException; import java.net.ConnectException;
import java.net.SocketTimeoutException; import java.net.SocketTimeoutException;
import java.net.SocketException;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
@ -390,8 +391,11 @@ public class CatalogTracker {
throw e; throw e;
} }
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
// We were passed the wrong address. Return 'protocol' == null. // Return 'protocol' == null.
LOG.debug("Timed out connecting to " + address); LOG.debug("Timed out connecting to " + address);
} catch (SocketException e) {
// Return 'protocol' == null.
LOG.debug("Exception connecting to " + address);
} catch (IOException ioe) { } catch (IOException ioe) {
Throwable cause = ioe.getCause(); Throwable cause = ioe.getCause();
if (cause != null && cause instanceof EOFException) { if (cause != null && cause instanceof EOFException) {

View File

@ -308,14 +308,9 @@ public class MetaReader {
} catch (java.net.SocketTimeoutException e) { } catch (java.net.SocketTimeoutException e) {
// Treat this exception + message as unavailable catalog table. Catch it // Treat this exception + message as unavailable catalog table. Catch it
// and fall through to return a null // and fall through to return a null
} catch (java.net.ConnectException e) { } catch (java.net.SocketException e) {
if (e.getMessage() != null &&
e.getMessage().contains("Connection refused")) {
// Treat this exception + message as unavailable catalog table. Catch it // Treat this exception + message as unavailable catalog table. Catch it
// and fall through to return a null // and fall through to return a null
} else {
throw e;
}
} catch (RemoteException re) { } catch (RemoteException re) {
IOException ioe = re.unwrapRemoteException(); IOException ioe = re.unwrapRemoteException();
if (ioe instanceof NotServingRegionException) { if (ioe instanceof NotServingRegionException) {

View File

@ -1770,6 +1770,10 @@ public class AssignmentManager extends ZooKeeperListener {
Stat stat = new Stat(); Stat stat = new Stat();
RegionTransitionData data = ZKAssign.getDataNoWatch(watcher, RegionTransitionData data = ZKAssign.getDataNoWatch(watcher,
node, stat); node, stat);
if (data == null) {
LOG.warn("Data is null, node " + node + " no longer exists");
break;
}
if (data.getEventType() == EventType.RS_ZK_REGION_OPENED) { if (data.getEventType() == EventType.RS_ZK_REGION_OPENED) {
LOG.debug("Region has transitioned to OPENED, allowing " + LOG.debug("Region has transitioned to OPENED, allowing " +
"watched event handlers to process"); "watched event handlers to process");

View File

@ -87,7 +87,11 @@ public class OpenRegionHandler extends EventHandler {
// If fails, just return. Someone stole the region from under us. // If fails, just return. Someone stole the region from under us.
// Calling transitionZookeeperOfflineToOpening initalizes this.version. // Calling transitionZookeeperOfflineToOpening initalizes this.version.
if (!transitionZookeeperOfflineToOpening(encodedName)) return; if (!transitionZookeeperOfflineToOpening(encodedName)) {
LOG.warn("Region was hijacked? It no longer exists, encodedName=" +
encodedName);
return;
}
// Open region. After a successful open, failures in subsequent processing // Open region. After a successful open, failures in subsequent processing
// needs to do a close as part of cleanup. // needs to do a close as part of cleanup.
@ -254,7 +258,7 @@ public class OpenRegionHandler extends EventHandler {
/** /**
* @return Instance of HRegion if successful open else null. * @return Instance of HRegion if successful open else null.
*/ */
private HRegion openRegion() { HRegion openRegion() {
HRegion region = null; HRegion region = null;
try { try {
// Instantiate the region. This also periodically tickles our zk OPENING // Instantiate the region. This also periodically tickles our zk OPENING

View File

@ -396,7 +396,8 @@ public class ZKAssign {
zkw.sync(node); zkw.sync(node);
Stat stat = new Stat(); Stat stat = new Stat();
byte [] bytes = ZKUtil.getDataNoWatch(zkw, node, stat); byte [] bytes = ZKUtil.getDataNoWatch(zkw, node, stat);
if(bytes == null) { if (bytes == null) {
// If it came back null, node does not exist.
throw KeeperException.create(Code.NONODE); throw KeeperException.create(Code.NONODE);
} }
RegionTransitionData data = RegionTransitionData.fromBytes(bytes); RegionTransitionData data = RegionTransitionData.fromBytes(bytes);
@ -674,8 +675,11 @@ public class ZKAssign {
// Read existing data of the node // Read existing data of the node
Stat stat = new Stat(); Stat stat = new Stat();
byte [] existingBytes = byte [] existingBytes = ZKUtil.getDataNoWatch(zkw, node, stat);
ZKUtil.getDataNoWatch(zkw, node, stat); if (existingBytes == null) {
// Node no longer exists. Return -1. It means unsuccessful transition.
return -1;
}
RegionTransitionData existingData = RegionTransitionData existingData =
RegionTransitionData.fromBytes(existingBytes); RegionTransitionData.fromBytes(existingBytes);
@ -762,7 +766,7 @@ public class ZKAssign {
* @param zkw zk reference * @param zkw zk reference
* @param pathOrRegionName fully-specified path or region name * @param pathOrRegionName fully-specified path or region name
* @param stat object to store node info into on getData call * @param stat object to store node info into on getData call
* @return data for the unassigned node * @return data for the unassigned node or null if node does not exist
* @throws KeeperException if unexpected zookeeper exception * @throws KeeperException if unexpected zookeeper exception
*/ */
public static RegionTransitionData getDataNoWatch(ZooKeeperWatcher zkw, public static RegionTransitionData getDataNoWatch(ZooKeeperWatcher zkw,
@ -771,7 +775,7 @@ public class ZKAssign {
String node = pathOrRegionName.startsWith("/") ? String node = pathOrRegionName.startsWith("/") ?
pathOrRegionName : getNodeName(zkw, pathOrRegionName); pathOrRegionName : getNodeName(zkw, pathOrRegionName);
byte [] data = ZKUtil.getDataNoWatch(zkw, node, stat); byte [] data = ZKUtil.getDataNoWatch(zkw, node, stat);
if(data == null) { if (data == null) {
return null; return null;
} }
return RegionTransitionData.fromBytes(data); return RegionTransitionData.fromBytes(data);

View File

@ -576,7 +576,7 @@ public class ZKUtil {
* @param zkw zk reference * @param zkw zk reference
* @param znode path of node * @param znode path of node
* @param stat node status to set if node exists * @param stat node status to set if node exists
* @return data of the specified znode, or null if does not exist * @return data of the specified znode, or null if node does not exist
* @throws KeeperException if unexpected zookeeper exception * @throws KeeperException if unexpected zookeeper exception
*/ */
public static byte [] getDataNoWatch(ZooKeeperWatcher zkw, String znode, public static byte [] getDataNoWatch(ZooKeeperWatcher zkw, String znode,