YARN-4701. When task logs are not available, port 8041 is referenced instead of port 8042 (haibochen via rkanter)
(cherry picked from commit c4d4df8de0
)
This commit is contained in:
parent
6a75c5af09
commit
ec48848711
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
|
@ -169,6 +169,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
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -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
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue