YARN-4701. When task logs are not available, port 8041 is referenced instead of port 8042 (haibochen via rkanter)

This commit is contained in:
Robert Kanter 2016-02-25 12:48:02 -08:00
parent 8808779db3
commit c4d4df8de0
5 changed files with 56 additions and 9 deletions

View File

@ -68,8 +68,8 @@ public class AMAttemptInfo {
if (containerId != null) { if (containerId != null) {
this.containerId = containerId.toString(); this.containerId = containerId.toString();
this.logsLink = join(host, pathPrefix, this.logsLink = join(host, pathPrefix,
ujoin("logs", this.nodeId, this.containerId, jobId, user)); ujoin("logs", this.nodeHttpAddress, this.containerId, jobId, user));
this.shortLogsLink = ujoin("logs", this.nodeId, this.containerId, this.shortLogsLink = ujoin("logs", this.nodeHttpAddress, this.containerId,
jobId, user); jobId, user);
} }
} }

View File

@ -766,7 +766,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
for (int i = 0; i < attempts.length(); i++) { for (int i = 0; i < attempts.length(); i++) {
JSONObject attempt = attempts.getJSONObject(i); JSONObject attempt = attempts.getJSONObject(i);
verifyHsJobAttemptsGeneric(job, attempt.getString("nodeHttpAddress"), verifyHsJobAttemptsGeneric(job, attempt.getString("nodeHttpAddress"),
attempt.getString("nodeId"), attempt.getInt("id"), attempt.getInt("id"),
attempt.getLong("startTime"), attempt.getString("containerId"), attempt.getLong("startTime"), attempt.getString("containerId"),
attempt.getString("logsLink")); attempt.getString("logsLink"));
} }
@ -779,7 +779,6 @@ public class TestHsWebServicesJobs extends JerseyTest {
Element element = (Element) nodes.item(i); Element element = (Element) nodes.item(i);
verifyHsJobAttemptsGeneric(job, verifyHsJobAttemptsGeneric(job,
WebServicesTestUtils.getXmlString(element, "nodeHttpAddress"), WebServicesTestUtils.getXmlString(element, "nodeHttpAddress"),
WebServicesTestUtils.getXmlString(element, "nodeId"),
WebServicesTestUtils.getXmlInt(element, "id"), WebServicesTestUtils.getXmlInt(element, "id"),
WebServicesTestUtils.getXmlLong(element, "startTime"), WebServicesTestUtils.getXmlLong(element, "startTime"),
WebServicesTestUtils.getXmlString(element, "containerId"), WebServicesTestUtils.getXmlString(element, "containerId"),
@ -788,7 +787,7 @@ public class TestHsWebServicesJobs extends JerseyTest {
} }
public void verifyHsJobAttemptsGeneric(Job job, String nodeHttpAddress, public void verifyHsJobAttemptsGeneric(Job job, String nodeHttpAddress,
String nodeId, int id, long startTime, String containerId, String logsLink) { int id, long startTime, String containerId, String logsLink) {
boolean attemptFound = false; boolean attemptFound = false;
for (AMInfo amInfo : job.getAMInfos()) { for (AMInfo amInfo : job.getAMInfos()) {
if (amInfo.getAppAttemptId().getAttemptId() == id) { if (amInfo.getAppAttemptId().getAttemptId() == id) {
@ -798,16 +797,14 @@ public class TestHsWebServicesJobs extends JerseyTest {
int nmPort = amInfo.getNodeManagerPort(); int nmPort = amInfo.getNodeManagerPort();
WebServicesTestUtils.checkStringMatch("nodeHttpAddress", nmHost + ":" WebServicesTestUtils.checkStringMatch("nodeHttpAddress", nmHost + ":"
+ nmHttpPort, nodeHttpAddress); + nmHttpPort, nodeHttpAddress);
WebServicesTestUtils.checkStringMatch("nodeId",
NodeId.newInstance(nmHost, nmPort).toString(), nodeId);
assertTrue("startime not greater than 0", startTime > 0); assertTrue("startime not greater than 0", startTime > 0);
WebServicesTestUtils.checkStringMatch("containerId", amInfo WebServicesTestUtils.checkStringMatch("containerId", amInfo
.getContainerId().toString(), containerId); .getContainerId().toString(), containerId);
String localLogsLink = join( String localLogsLink = join(
"hsmockwebapp", "hsmockwebapp",
ujoin("logs", nodeId, containerId, MRApps.toString(job.getID()), ujoin("logs", nodeHttpAddress, containerId,
job.getUserName())); MRApps.toString(job.getID()), job.getUserName()));
assertTrue("logsLink", logsLink.contains(localLogsLink)); assertTrue("logsLink", logsLink.contains(localLogsLink));
} }

View File

@ -230,6 +230,9 @@ Release 2.9.0 - UNRELEASED
YARN-4729. SchedulerApplicationAttempt#getTotalRequiredResources can throw YARN-4729. SchedulerApplicationAttempt#getTotalRequiredResources can throw
an NPE. (kasha) an NPE. (kasha)
YARN-4701. When task logs are not available, port 8041 is referenced
instead of port 8042 (haibochen via rkanter)
Release 2.8.0 - UNRELEASED Release 2.8.0 - UNRELEASED
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -80,11 +80,17 @@ public class AggregatedLogsBlock extends HtmlBlock {
logEntity = containerId.toString(); logEntity = containerId.toString();
} }
String nmApplicationLogUrl = getApplicationLogURL(applicationId);
if (!conf.getBoolean(YarnConfiguration.LOG_AGGREGATION_ENABLED, if (!conf.getBoolean(YarnConfiguration.LOG_AGGREGATION_ENABLED,
YarnConfiguration.DEFAULT_LOG_AGGREGATION_ENABLED)) { YarnConfiguration.DEFAULT_LOG_AGGREGATION_ENABLED)) {
html.h1() html.h1()
._("Aggregation is not enabled. Try the nodemanager at " + nodeId) ._("Aggregation is not enabled. Try the nodemanager at " + nodeId)
._(); ._();
if(nmApplicationLogUrl != null) {
html.h1()
._("Or see application log at " + nmApplicationLogUrl)
._();
}
return; return;
} }
@ -107,6 +113,11 @@ public class AggregatedLogsBlock extends HtmlBlock {
._("Logs not available for " + logEntity ._("Logs not available for " + logEntity
+ ". Aggregation may not be complete, " + ". Aggregation may not be complete, "
+ "Check back later or try the nodemanager at " + nodeId)._(); + "Check back later or try the nodemanager at " + nodeId)._();
if(nmApplicationLogUrl != null) {
html.h1()
._("Or see application log at " + nmApplicationLogUrl)
._();
}
return; return;
} catch (Exception ex) { } catch (Exception ex) {
html.h1() html.h1()
@ -353,4 +364,20 @@ public class AggregatedLogsBlock extends HtmlBlock {
limits.end = end; limits.end = end;
return limits; return limits;
} }
private String getApplicationLogURL(ApplicationId applicationId) {
String appId = applicationId.toString();
if (appId == null || appId.isEmpty()) {
return null;
}
String nodeId = $(NM_NODENAME);
if(nodeId == null || nodeId.isEmpty()) {
return null;
}
StringBuilder sb = new StringBuilder();
String scheme = YarnConfiguration.useHttps(this.conf) ? "https://":
"http://";
sb.append(scheme).append(nodeId).append("/node/application/").append(appId);
return sb.toString();
}
} }

View File

@ -88,6 +88,26 @@ public class TestAggregatedLogsBlock {
} }
@Test
public void testBlockContainsPortNumForUnavailableAppLog() {
FileUtil.fullyDelete(new File("target/logs"));
Configuration configuration = getConfiguration();
String nodeName = configuration.get(YarnConfiguration.NM_WEBAPP_ADDRESS,
YarnConfiguration.DEFAULT_NM_WEBAPP_ADDRESS);
AggregatedLogsBlockForTest aggregatedBlock = getAggregatedLogsBlockForTest(
configuration, "admin", "container_0_0001_01_000001", nodeName);
ByteArrayOutputStream data = new ByteArrayOutputStream();
PrintWriter printWriter = new PrintWriter(data);
HtmlBlock html = new HtmlBlockForTest();
HtmlBlock.Block block = new BlockForTest(html, printWriter, 10, false);
aggregatedBlock.render(block);
block.getWriter().flush();
String out = data.toString();
assertTrue(out.contains(nodeName));
}
/** /**
* try to read bad logs * try to read bad logs
* *