YARN-5339. Passing file to -out for YARN log CLI doesnt give warning or error code. Contributed by Xuan Gong.
(cherry picked from commit 7e5355c14e
)
This commit is contained in:
parent
2231ef22f5
commit
e3bc4faa96
|
@ -26,7 +26,9 @@ import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.TreeMap;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import javax.ws.rs.core.MediaType;
|
import javax.ws.rs.core.MediaType;
|
||||||
|
@ -51,6 +53,7 @@ import org.apache.hadoop.yarn.api.records.ApplicationId;
|
||||||
import org.apache.hadoop.yarn.api.records.ApplicationReport;
|
import org.apache.hadoop.yarn.api.records.ApplicationReport;
|
||||||
import org.apache.hadoop.yarn.api.records.ContainerId;
|
import org.apache.hadoop.yarn.api.records.ContainerId;
|
||||||
import org.apache.hadoop.yarn.api.records.ContainerReport;
|
import org.apache.hadoop.yarn.api.records.ContainerReport;
|
||||||
|
import org.apache.hadoop.yarn.api.records.ContainerState;
|
||||||
import org.apache.hadoop.yarn.api.records.YarnApplicationState;
|
import org.apache.hadoop.yarn.api.records.YarnApplicationState;
|
||||||
import org.apache.hadoop.yarn.client.api.YarnClient;
|
import org.apache.hadoop.yarn.client.api.YarnClient;
|
||||||
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
|
@ -249,7 +252,7 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
|
|
||||||
ContainerLogsRequest request = new ContainerLogsRequest(appId,
|
ContainerLogsRequest request = new ContainerLogsRequest(appId,
|
||||||
isApplicationFinished(appState), appOwner, nodeAddress, null,
|
isApplicationFinished(appState), appOwner, nodeAddress, null,
|
||||||
containerIdStr, localDir, logs, bytes);
|
containerIdStr, localDir, logs, bytes, null);
|
||||||
|
|
||||||
if (showContainerLogInfo) {
|
if (showContainerLogInfo) {
|
||||||
return showContainerLogInfo(request, logCliHelper);
|
return showContainerLogInfo(request, logCliHelper);
|
||||||
|
@ -471,9 +474,14 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
.queryParam("size", Long.toString(request.getBytes()))
|
.queryParam("size", Long.toString(request.getBytes()))
|
||||||
.accept(MediaType.TEXT_PLAIN).get(ClientResponse.class);
|
.accept(MediaType.TEXT_PLAIN).get(ClientResponse.class);
|
||||||
out.println(response.getEntity(String.class));
|
out.println(response.getEntity(String.class));
|
||||||
out.println("End of LogType:" + logFile + ". This log file belongs"
|
StringBuilder sb = new StringBuilder();
|
||||||
+ " to a running container (" + containerIdStr + ") and so may"
|
sb.append("End of LogType:" + logFile + ".");
|
||||||
+ " not be complete.");
|
if (request.getContainerState() == ContainerState.RUNNING) {
|
||||||
|
sb.append(" This log file belongs"
|
||||||
|
+ " to a running container (" + containerIdStr + ") and so may"
|
||||||
|
+ " not be complete.");
|
||||||
|
}
|
||||||
|
out.println(sb.toString());
|
||||||
out.flush();
|
out.flush();
|
||||||
foundAnyLogs = true;
|
foundAnyLogs = true;
|
||||||
} catch (ClientHandlerException | UniformInterfaceException ex) {
|
} catch (ClientHandlerException | UniformInterfaceException ex) {
|
||||||
|
@ -646,6 +654,9 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
} else {
|
} else {
|
||||||
if (nodeHttpAddress != null && containerId != null
|
if (nodeHttpAddress != null && containerId != null
|
||||||
&& !nodeHttpAddress.isEmpty() && !containerId.isEmpty()) {
|
&& !nodeHttpAddress.isEmpty() && !containerId.isEmpty()) {
|
||||||
|
ContainerState containerState = getContainerReport(containerId)
|
||||||
|
.getContainerState();
|
||||||
|
request.setContainerState(containerState);
|
||||||
printContainerLogsFromRunningApplication(conf,
|
printContainerLogsFromRunningApplication(conf,
|
||||||
request, logCliHelper);
|
request, logCliHelper);
|
||||||
}
|
}
|
||||||
|
@ -881,6 +892,7 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
}
|
}
|
||||||
nodeId = report.getAssignedNode().toString();
|
nodeId = report.getAssignedNode().toString();
|
||||||
request.setNodeId(nodeId);
|
request.setNodeId(nodeId);
|
||||||
|
request.setContainerState(report.getContainerState());
|
||||||
} catch (IOException | YarnException ex) {
|
} catch (IOException | YarnException ex) {
|
||||||
if (isAppFinished) {
|
if (isAppFinished) {
|
||||||
return printContainerLogsForFinishedApplicationWithoutNodeId(
|
return printContainerLogsForFinishedApplicationWithoutNodeId(
|
||||||
|
@ -1021,6 +1033,7 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
newOptions.setNodeHttpAddress(httpAddress
|
newOptions.setNodeHttpAddress(httpAddress
|
||||||
.replaceFirst(WebAppUtils.getHttpSchemePrefix(getConf()), ""));
|
.replaceFirst(WebAppUtils.getHttpSchemePrefix(getConf()), ""));
|
||||||
}
|
}
|
||||||
|
newOptions.setContainerState(container.getContainerState());
|
||||||
newOptionsList.add(newOptions);
|
newOptionsList.add(newOptions);
|
||||||
}
|
}
|
||||||
return newOptionsList;
|
return newOptionsList;
|
||||||
|
@ -1031,11 +1044,18 @@ public class LogsCLI extends Configured implements Tool {
|
||||||
List<ContainerReport> reports = new ArrayList<ContainerReport>();
|
List<ContainerReport> reports = new ArrayList<ContainerReport>();
|
||||||
List<ApplicationAttemptReport> attempts =
|
List<ApplicationAttemptReport> attempts =
|
||||||
yarnClient.getApplicationAttempts(options.getAppId());
|
yarnClient.getApplicationAttempts(options.getAppId());
|
||||||
|
Map<ContainerId, ContainerReport> containerMap = new TreeMap<
|
||||||
|
ContainerId, ContainerReport>();
|
||||||
for (ApplicationAttemptReport attempt : attempts) {
|
for (ApplicationAttemptReport attempt : attempts) {
|
||||||
List<ContainerReport> containers = yarnClient.getContainers(
|
List<ContainerReport> containers = yarnClient.getContainers(
|
||||||
attempt.getApplicationAttemptId());
|
attempt.getApplicationAttemptId());
|
||||||
reports.addAll(containers);
|
for (ContainerReport container : containers) {
|
||||||
|
if (!containerMap.containsKey(container.getContainerId())) {
|
||||||
|
containerMap.put(container.getContainerId(), container);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
reports.addAll(containerMap.values());
|
||||||
return reports;
|
return reports;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.hadoop.yarn.logaggregation;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
import org.apache.hadoop.yarn.api.records.ApplicationId;
|
||||||
|
import org.apache.hadoop.yarn.api.records.ContainerState;
|
||||||
|
|
||||||
public class ContainerLogsRequest {
|
public class ContainerLogsRequest {
|
||||||
private ApplicationId appId;
|
private ApplicationId appId;
|
||||||
|
@ -31,6 +32,7 @@ public class ContainerLogsRequest {
|
||||||
private String outputLocalDir;
|
private String outputLocalDir;
|
||||||
private List<String> logTypes;
|
private List<String> logTypes;
|
||||||
private long bytes;
|
private long bytes;
|
||||||
|
private ContainerState containerState;
|
||||||
|
|
||||||
public ContainerLogsRequest() {}
|
public ContainerLogsRequest() {}
|
||||||
|
|
||||||
|
@ -44,12 +46,13 @@ public class ContainerLogsRequest {
|
||||||
this.setOutputLocalDir(request.getOutputLocalDir());
|
this.setOutputLocalDir(request.getOutputLocalDir());
|
||||||
this.setLogTypes(request.getLogTypes());
|
this.setLogTypes(request.getLogTypes());
|
||||||
this.setBytes(request.getBytes());
|
this.setBytes(request.getBytes());
|
||||||
|
this.setContainerState(request.getContainerState());
|
||||||
}
|
}
|
||||||
|
|
||||||
public ContainerLogsRequest(ApplicationId applicationId,
|
public ContainerLogsRequest(ApplicationId applicationId,
|
||||||
boolean isAppFinished, String owner,
|
boolean isAppFinished, String owner,
|
||||||
String address, String httpAddress, String container, String localDir,
|
String address, String httpAddress, String container, String localDir,
|
||||||
List<String> logs, long bytes) {
|
List<String> logs, long bytes, ContainerState containerState) {
|
||||||
this.setAppId(applicationId);
|
this.setAppId(applicationId);
|
||||||
this.setAppFinished(isAppFinished);
|
this.setAppFinished(isAppFinished);
|
||||||
this.setAppOwner(owner);
|
this.setAppOwner(owner);
|
||||||
|
@ -59,6 +62,7 @@ public class ContainerLogsRequest {
|
||||||
this.setOutputLocalDir(localDir);
|
this.setOutputLocalDir(localDir);
|
||||||
this.setLogTypes(logs);
|
this.setLogTypes(logs);
|
||||||
this.setBytes(bytes);
|
this.setBytes(bytes);
|
||||||
|
this.setContainerState(containerState);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApplicationId getAppId() {
|
public ApplicationId getAppId() {
|
||||||
|
@ -132,4 +136,12 @@ public class ContainerLogsRequest {
|
||||||
public void setBytes(long bytes) {
|
public void setBytes(long bytes) {
|
||||||
this.bytes = bytes;
|
this.bytes = bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ContainerState getContainerState() {
|
||||||
|
return containerState;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setContainerState(ContainerState containerState) {
|
||||||
|
this.containerState = containerState;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue