HADOOP-18592. Sasl connection failure should log remote address. (#5294)

Contributed by Viraj Jasani <vjasani@apache.org>

Signed-off-by: Chris Nauroth <cnauroth@apache.org>
Signed-off-by: Steve Loughran <stevel@apache.org>
Signed-off-by: Mingliang Liu <liuml07@apache.org>
This commit is contained in:
Viraj Jasani 2023-02-01 10:15:20 -08:00 committed by Mingliang Liu
parent 4836f1ec37
commit f3fa4af5dc
No known key found for this signature in database
GPG Key ID: A30C7AA33ABDB258

View File

@ -687,7 +687,7 @@ public class Client implements AutoCloseable {
* handle that, a relogin is attempted. * handle that, a relogin is attempted.
*/ */
private synchronized void handleSaslConnectionFailure( private synchronized void handleSaslConnectionFailure(
final int currRetries, final int maxRetries, final Exception ex, final int currRetries, final int maxRetries, final IOException ex,
final Random rand, final UserGroupInformation ugi) throws IOException, final Random rand, final UserGroupInformation ugi) throws IOException,
InterruptedException { InterruptedException {
ugi.doAs(new PrivilegedExceptionAction<Object>() { ugi.doAs(new PrivilegedExceptionAction<Object>() {
@ -698,10 +698,7 @@ public class Client implements AutoCloseable {
disposeSasl(); disposeSasl();
if (shouldAuthenticateOverKrb()) { if (shouldAuthenticateOverKrb()) {
if (currRetries < maxRetries) { if (currRetries < maxRetries) {
if(LOG.isDebugEnabled()) { LOG.debug("Exception encountered while connecting to the server {}", remoteId, ex);
LOG.debug("Exception encountered while connecting to "
+ "the server : " + ex);
}
// try re-login // try re-login
if (UserGroupInformation.isLoginKeytabBased()) { if (UserGroupInformation.isLoginKeytabBased()) {
UserGroupInformation.getLoginUser().reloginFromKeytab(); UserGroupInformation.getLoginUser().reloginFromKeytab();
@ -719,7 +716,11 @@ public class Client implements AutoCloseable {
+ UserGroupInformation.getLoginUser().getUserName() + " to " + UserGroupInformation.getLoginUser().getUserName() + " to "
+ remoteId; + remoteId;
LOG.warn(msg, ex); LOG.warn(msg, ex);
throw (IOException) new IOException(msg).initCause(ex); throw NetUtils.wrapException(remoteId.getAddress().getHostName(),
remoteId.getAddress().getPort(),
NetUtils.getHostname(),
0,
ex);
} }
} else { } else {
// With RequestHedgingProxyProvider, one rpc call will send multiple // With RequestHedgingProxyProvider, one rpc call will send multiple
@ -727,11 +728,9 @@ public class Client implements AutoCloseable {
// all other requests will be interrupted. It's not a big problem, // all other requests will be interrupted. It's not a big problem,
// and should not print a warning log. // and should not print a warning log.
if (ex instanceof InterruptedIOException) { if (ex instanceof InterruptedIOException) {
LOG.debug("Exception encountered while connecting to the server", LOG.debug("Exception encountered while connecting to the server {}", remoteId, ex);
ex);
} else { } else {
LOG.warn("Exception encountered while connecting to the server ", LOG.warn("Exception encountered while connecting to the server {}", remoteId, ex);
ex);
} }
} }
if (ex instanceof RemoteException) if (ex instanceof RemoteException)