From bee448cacd142a4125e60c840022b65cc5fe9efa Mon Sep 17 00:00:00 2001 From: Arpit Agarwal Date: Fri, 2 May 2014 18:38:30 +0000 Subject: [PATCH] HADOOP-10562. Namenode exits on exception without printing stack trace in AbstractDelegationTokenSecretManager. (Contributed by Suresh Srinivas) git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1592002 13f79535-47bb-0310-9956-ffa450edef68 --- .../hadoop-common/CHANGES.txt | 3 ++ .../AbstractDelegationTokenSecretManager.java | 38 ++++++++----------- 2 files changed, 18 insertions(+), 23 deletions(-) diff --git a/hadoop-common-project/hadoop-common/CHANGES.txt b/hadoop-common-project/hadoop-common/CHANGES.txt index 736d8504adb..b31c4984c04 100644 --- a/hadoop-common-project/hadoop-common/CHANGES.txt +++ b/hadoop-common-project/hadoop-common/CHANGES.txt @@ -431,6 +431,9 @@ Release 2.5.0 - UNRELEASED HADOOP-10543. RemoteException's unwrapRemoteException method failed for PathIOException. (Yongjun Zhang via atm) + HADOOP-10562. Namenode exits on exception without printing stack trace + in AbstractDelegationTokenSecretManager. (Arpit Agarwal) + Release 2.4.1 - UNRELEASED INCOMPATIBLE CHANGES diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java index d892c5d7f36..b9e26b545c3 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java @@ -209,8 +209,7 @@ extends AbstractDelegationTokenIdentifier> currentTokens.put(identifier, new DelegationTokenInformation(renewDate, password, getTrackingIdIfEnabled(identifier))); } else { - throw new IOException( - "Same delegation token being added twice."); + throw new IOException("Same delegation token being added twice."); } } @@ -355,27 +354,24 @@ extends AbstractDelegationTokenIdentifier> */ public synchronized long renewToken(Token token, String renewer) throws InvalidToken, IOException { - long now = Time.now(); ByteArrayInputStream buf = new ByteArrayInputStream(token.getIdentifier()); DataInputStream in = new DataInputStream(buf); TokenIdent id = createIdentifier(); id.readFields(in); - LOG.info("Token renewal requested for identifier: "+id); - + LOG.info("Token renewal for identifier: " + id + "; total currentTokens " + + currentTokens.size()); + + long now = Time.now(); if (id.getMaxDate() < now) { - throw new InvalidToken("User " + renewer + - " tried to renew an expired token"); + throw new InvalidToken(renewer + " tried to renew an expired token"); } if ((id.getRenewer() == null) || (id.getRenewer().toString().isEmpty())) { - throw new AccessControlException("User " + renewer + - " tried to renew a token without " + - "a renewer"); + throw new AccessControlException(renewer + + " tried to renew a token without a renewer"); } if (!id.getRenewer().toString().equals(renewer)) { - throw new AccessControlException("Client " + renewer + - " tries to renew a token with " + - "renewer specified as " + - id.getRenewer()); + throw new AccessControlException(renewer + + " tries to renew a token with renewer " + id.getRenewer()); } DelegationKey key = allKeys.get(id.getMasterKeyId()); if (key == null) { @@ -386,8 +382,8 @@ extends AbstractDelegationTokenIdentifier> } byte[] password = createPassword(token.getIdentifier(), key.getKey()); if (!Arrays.equals(password, token.getPassword())) { - throw new AccessControlException("Client " + renewer - + " is trying to renew a token with " + "wrong password"); + throw new AccessControlException(renewer + + " is trying to renew a token with wrong password"); } long renewTime = Math.min(id.getMaxDate(), now + tokenRenewInterval); String trackingId = getTrackingIdIfEnabled(id); @@ -429,8 +425,7 @@ extends AbstractDelegationTokenIdentifier> throw new AccessControlException(canceller + " is not authorized to cancel the token"); } - DelegationTokenInformation info = null; - info = currentTokens.remove(id); + DelegationTokenInformation info = currentTokens.remove(id); if (info == null) { throw new InvalidToken("Token not found"); } @@ -554,14 +549,11 @@ extends AbstractDelegationTokenIdentifier> try { Thread.sleep(Math.min(5000, keyUpdateInterval)); // 5 seconds } catch (InterruptedException ie) { - LOG - .error("InterruptedExcpetion recieved for ExpiredTokenRemover thread " - + ie); + LOG.error("ExpiredTokenRemover received " + ie); } } } catch (Throwable t) { - LOG.error("ExpiredTokenRemover thread received unexpected exception. " - + t); + LOG.error("ExpiredTokenRemover thread received unexpected exception", t); Runtime.getRuntime().exit(-1); } }