HADOOP-11722. Some Instances of Services using ZKDelegationTokenSecretManager go down when old token cannot be deleted. Contributed by Arun Suresh.
This commit is contained in:
parent
968425e9f7
commit
fc90bf7b27
|
@ -1111,6 +1111,10 @@ Release 2.7.0 - UNRELEASED
|
||||||
HADOOP-11720. [JDK8] Fix javadoc errors caused by incorrect or illegal
|
HADOOP-11720. [JDK8] Fix javadoc errors caused by incorrect or illegal
|
||||||
tags in hadoop-tools. (Akira AJISAKA via ozawa)
|
tags in hadoop-tools. (Akira AJISAKA via ozawa)
|
||||||
|
|
||||||
|
HADOOP-11722. Some Instances of Services using
|
||||||
|
ZKDelegationTokenSecretManager go down when old token cannot be deleted.
|
||||||
|
(Arun Suresh via atm)
|
||||||
|
|
||||||
Release 2.6.1 - UNRELEASED
|
Release 2.6.1 - UNRELEASED
|
||||||
|
|
||||||
INCOMPATIBLE CHANGES
|
INCOMPATIBLE CHANGES
|
||||||
|
|
|
@ -55,6 +55,7 @@ import org.apache.hadoop.security.token.Token;
|
||||||
import org.apache.hadoop.security.token.delegation.web.DelegationTokenManager;
|
import org.apache.hadoop.security.token.delegation.web.DelegationTokenManager;
|
||||||
import org.apache.zookeeper.CreateMode;
|
import org.apache.zookeeper.CreateMode;
|
||||||
import org.apache.zookeeper.KeeperException;
|
import org.apache.zookeeper.KeeperException;
|
||||||
|
import org.apache.zookeeper.KeeperException.NoNodeException;
|
||||||
import org.apache.zookeeper.ZooDefs.Perms;
|
import org.apache.zookeeper.ZooDefs.Perms;
|
||||||
import org.apache.zookeeper.client.ZooKeeperSaslClient;
|
import org.apache.zookeeper.client.ZooKeeperSaslClient;
|
||||||
import org.apache.zookeeper.data.ACL;
|
import org.apache.zookeeper.data.ACL;
|
||||||
|
@ -709,7 +710,15 @@ public abstract class ZKDelegationTokenSecretManager<TokenIdent extends Abstract
|
||||||
try {
|
try {
|
||||||
if (zkClient.checkExists().forPath(nodeRemovePath) != null) {
|
if (zkClient.checkExists().forPath(nodeRemovePath) != null) {
|
||||||
while(zkClient.checkExists().forPath(nodeRemovePath) != null){
|
while(zkClient.checkExists().forPath(nodeRemovePath) != null){
|
||||||
|
try {
|
||||||
zkClient.delete().guaranteed().forPath(nodeRemovePath);
|
zkClient.delete().guaranteed().forPath(nodeRemovePath);
|
||||||
|
} catch (NoNodeException nne) {
|
||||||
|
// It is possible that the node might be deleted between the
|
||||||
|
// check and the actual delete.. which might lead to an
|
||||||
|
// exception that can bring down the daemon running this
|
||||||
|
// SecretManager
|
||||||
|
LOG.debug("Node already deleted by peer " + nodeRemovePath);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LOG.debug("Attempted to delete a non-existing znode " + nodeRemovePath);
|
LOG.debug("Attempted to delete a non-existing znode " + nodeRemovePath);
|
||||||
|
@ -761,7 +770,15 @@ public abstract class ZKDelegationTokenSecretManager<TokenIdent extends Abstract
|
||||||
try {
|
try {
|
||||||
if (zkClient.checkExists().forPath(nodeRemovePath) != null) {
|
if (zkClient.checkExists().forPath(nodeRemovePath) != null) {
|
||||||
while(zkClient.checkExists().forPath(nodeRemovePath) != null){
|
while(zkClient.checkExists().forPath(nodeRemovePath) != null){
|
||||||
|
try {
|
||||||
zkClient.delete().guaranteed().forPath(nodeRemovePath);
|
zkClient.delete().guaranteed().forPath(nodeRemovePath);
|
||||||
|
} catch (NoNodeException nne) {
|
||||||
|
// It is possible that the node might be deleted between the
|
||||||
|
// check and the actual delete.. which might lead to an
|
||||||
|
// exception that can bring down the daemon running this
|
||||||
|
// SecretManager
|
||||||
|
LOG.debug("Node already deleted by peer " + nodeRemovePath);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LOG.debug("Attempted to remove a non-existing znode " + nodeRemovePath);
|
LOG.debug("Attempted to remove a non-existing znode " + nodeRemovePath);
|
||||||
|
|
Loading…
Reference in New Issue