HDFS-9634. webhdfs client side exceptions don't provide enough details. Contributed by Eric Payne.

(cherry picked from commit 7b70500484574a565dd8cd5c7d8b5bc7c6d91154)
This commit is contained in:
Kihwal Lee 2016-01-20 13:19:44 -06:00
parent a02fab85ee
commit 67ba20e364
3 changed files with 26 additions and 8 deletions

View File

@ -24,6 +24,7 @@ import java.io.EOFException;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.lang.reflect.InvocationTargetException;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.InetSocketAddress; import java.net.InetSocketAddress;
import java.net.MalformedURLException; import java.net.MalformedURLException;
@ -511,6 +512,7 @@ public class WebHdfsFileSystem extends FileSystem
new ExcludeDatanodesParam(""); new ExcludeDatanodesParam("");
private boolean checkRetry; private boolean checkRetry;
private String redirectHost;
protected AbstractRunner(final HttpOpParam.Op op, boolean redirected) { protected AbstractRunner(final HttpOpParam.Op op, boolean redirected) {
this.op = op; this.op = op;
@ -562,7 +564,7 @@ public class WebHdfsFileSystem extends FileSystem
*/ */
protected HttpURLConnection connect(URL url) throws IOException { protected HttpURLConnection connect(URL url) throws IOException {
//redirect hostname and port //redirect hostname and port
String redirectHost = null; redirectHost = null;
// resolve redirects for a DN operation unless already resolved // resolve redirects for a DN operation unless already resolved
@ -667,6 +669,19 @@ public class WebHdfsFileSystem extends FileSystem
throw it; throw it;
} }
} catch (IOException ioe) { } catch (IOException ioe) {
// Attempt to include the redirected node in the exception. If the
// attempt to recreate the exception fails, just use the original.
String node = redirectHost;
if (node == null) {
node = url.getAuthority();
}
try {
ioe = ioe.getClass().getConstructor(String.class)
.newInstance(node + ": " + ioe.getMessage());
} catch (NoSuchMethodException | SecurityException
| InstantiationException | IllegalAccessException
| IllegalArgumentException | InvocationTargetException e) {
}
shouldRetry(ioe, retry); shouldRetry(ioe, retry);
} }
} }

View File

@ -1685,6 +1685,9 @@ Release 2.7.3 - UNRELEASED
HDFS-9569. Log the name of the fsimage being loaded for better HDFS-9569. Log the name of the fsimage being loaded for better
supportability. (Yongjun Zhang) supportability. (Yongjun Zhang)
HDFS-9634. webhdfs client side exceptions don't provide enough details
(Eric Payne via kihwal)
OPTIMIZATIONS OPTIMIZATIONS
BUG FIXES BUG FIXES

View File

@ -115,7 +115,7 @@ public class TestWebHdfsTimeouts {
fs.listFiles(new Path("/"), false); fs.listFiles(new Path("/"), false);
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("connect timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": connect timed out", e.getMessage());
} }
} }
@ -128,7 +128,7 @@ public class TestWebHdfsTimeouts {
fs.listFiles(new Path("/"), false); fs.listFiles(new Path("/"), false);
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("Read timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": Read timed out", e.getMessage());
} }
} }
@ -143,7 +143,7 @@ public class TestWebHdfsTimeouts {
fs.getDelegationToken("renewer"); fs.getDelegationToken("renewer");
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("connect timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": connect timed out", e.getMessage());
} }
} }
@ -157,7 +157,7 @@ public class TestWebHdfsTimeouts {
fs.getDelegationToken("renewer"); fs.getDelegationToken("renewer");
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("Read timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": Read timed out", e.getMessage());
} }
} }
@ -172,7 +172,7 @@ public class TestWebHdfsTimeouts {
fs.getFileChecksum(new Path("/file")); fs.getFileChecksum(new Path("/file"));
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("connect timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": connect timed out", e.getMessage());
} }
} }
@ -187,7 +187,7 @@ public class TestWebHdfsTimeouts {
fs.getFileChecksum(new Path("/file")); fs.getFileChecksum(new Path("/file"));
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("Read timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": Read timed out", e.getMessage());
} }
} }
@ -203,7 +203,7 @@ public class TestWebHdfsTimeouts {
os = fs.create(new Path("/file")); os = fs.create(new Path("/file"));
fail("expected timeout"); fail("expected timeout");
} catch (SocketTimeoutException e) { } catch (SocketTimeoutException e) {
assertEquals("connect timed out", e.getMessage()); assertEquals(fs.getUri().getAuthority() + ": connect timed out", e.getMessage());
} finally { } finally {
IOUtils.cleanup(LOG, os); IOUtils.cleanup(LOG, os);
} }