diff --git a/hadoop-mapreduce-project/CHANGES.txt b/hadoop-mapreduce-project/CHANGES.txt index 8f577b0562..0d6e075548 100644 --- a/hadoop-mapreduce-project/CHANGES.txt +++ b/hadoop-mapreduce-project/CHANGES.txt @@ -29,6 +29,8 @@ Trunk (unreleased changes) uri with no authority. (John George via jitendra) BUG FIXES + MAPREDUCE-3346. [Rumen] LoggedTaskAttempt#getHostName() returns null. + (amarrk) MAPREDUCE-2950. [Gridmix] TestUserResolve fails in trunk. (Ravi Gummadi via amarrk) diff --git a/hadoop-mapreduce-project/src/tools/org/apache/hadoop/tools/rumen/LoggedTaskAttempt.java b/hadoop-mapreduce-project/src/tools/org/apache/hadoop/tools/rumen/LoggedTaskAttempt.java index fde7d0545e..5437a15003 100644 --- a/hadoop-mapreduce-project/src/tools/org/apache/hadoop/tools/rumen/LoggedTaskAttempt.java +++ b/hadoop-mapreduce-project/src/tools/org/apache/hadoop/tools/rumen/LoggedTaskAttempt.java @@ -328,11 +328,27 @@ public class LoggedTaskAttempt implements DeepCompare { return hostName; } - + void setHostName(String hostName) { + this.hostName = hostName; + } + // hostName is saved in the format rackName/NodeName void setHostName(String hostName, String rackName) { - this.hostName = hostName == null || rackName == null ? null - : rackName.intern() + "/" + hostName.intern(); + if (hostName == null || hostName.length() == 0) { + throw new RuntimeException("Invalid entry! Missing hostname"); + } else if (rackName == null || rackName.length() == 0) { + setHostName(hostName); + } else { + // make sure that the rackname is prefixed with a '/' + if (!rackName.startsWith("/")) { + rackName = "/" + rackName; + } + // make sure that the hostname is prefixed with a '/' + if (!hostName.startsWith("/")) { + hostName = "/" + hostName; + } + setHostName(rackName.intern() + hostName.intern()); + } } public long getHdfsBytesRead() {