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:
parent
237bc82af2
commit
cf3284dfb9
|
@ -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
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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");
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in New Issue