當前位置: 首頁>>代碼示例>>Java>>正文


Java ContainerStatus類代碼示例

本文整理匯總了Java中org.apache.hadoop.yarn.api.records.ContainerStatus的典型用法代碼示例。如果您正苦於以下問題:Java ContainerStatus類的具體用法?Java ContainerStatus怎麽用?Java ContainerStatus使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ContainerStatus類屬於org.apache.hadoop.yarn.api.records包,在下文中一共展示了ContainerStatus類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testAMRMClientAsyncShutDown

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Test (timeout = 10000)
public void testAMRMClientAsyncShutDown() throws Exception {
  Configuration conf = new Configuration();
  TestCallbackHandler callbackHandler = new TestCallbackHandler();
  @SuppressWarnings("unchecked")
  AMRMClient<ContainerRequest> client = mock(AMRMClientImpl.class);

  createAllocateResponse(new ArrayList<ContainerStatus>(),
    new ArrayList<Container>(), null);
  when(client.allocate(anyFloat())).thenThrow(
    new ApplicationAttemptNotFoundException("app not found, shut down"));

  AMRMClientAsync<ContainerRequest> asyncClient =
      AMRMClientAsync.createAMRMClientAsync(client, 10, callbackHandler);
  asyncClient.init(conf);
  asyncClient.start();

  asyncClient.registerApplicationMaster("localhost", 1234, null);

  Thread.sleep(50);

  verify(client, times(1)).allocate(anyFloat());
  asyncClient.stop();
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:25,代碼來源:TestAMRMClientAsync.java

示例2: publishContainerEndEvent

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
private static void publishContainerEndEvent(
    final TimelineClient timelineClient, ContainerStatus container,
    String domainId, UserGroupInformation ugi) {
  final TimelineEntity entity = new TimelineEntity();
  entity.setEntityId(container.getContainerId().toString());
  entity.setEntityType(DSEntity.DS_CONTAINER.toString());
  entity.setDomainId(domainId);
  entity.addPrimaryFilter("user", ugi.getShortUserName());
  TimelineEvent event = new TimelineEvent();
  event.setTimestamp(System.currentTimeMillis());
  event.setEventType(DSEvent.DS_CONTAINER_END.toString());
  event.addEventInfo("State", container.getState().name());
  event.addEventInfo("Exit Status", container.getExitStatus());
  entity.addEvent(event);
  try {
    timelineClient.putEntities(entity);
  } catch (YarnException | IOException e) {
    LOG.error("Container end event could not be published for "
        + container.getContainerId().toString(), e);
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:22,代碼來源:ApplicationMaster.java

示例3: testAMCrashAtAllocated

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Test
public void testAMCrashAtAllocated() {
  Container amContainer = allocateApplicationAttempt();
  String containerDiagMsg = "some error";
  int exitCode = 123;
  ContainerStatus cs =
      BuilderUtils.newContainerStatus(amContainer.getId(),
        ContainerState.COMPLETE, containerDiagMsg, exitCode);
  NodeId anyNodeId = NodeId.newInstance("host", 1234);
  applicationAttempt.handle(new RMAppAttemptContainerFinishedEvent(
    applicationAttempt.getAppAttemptId(), cs, anyNodeId));
  assertEquals(YarnApplicationAttemptState.ALLOCATED,
      applicationAttempt.createApplicationAttemptState());
  sendAttemptUpdateSavedEvent(applicationAttempt);
  assertEquals(RMAppAttemptState.FAILED,
    applicationAttempt.getAppAttemptState());
  verifyTokenCount(applicationAttempt.getAppAttemptId(), 1);
  verifyApplicationAttemptFinished(RMAppAttemptState.FAILED);
  boolean shouldCheckURL = (applicationAttempt.getTrackingUrl() != null);
  verifyAMCrashAtAllocatedDiagnosticInfo(applicationAttempt.getDiagnostics(),
    exitCode, shouldCheckURL);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:23,代碼來源:TestRMAppAttemptTransitions.java

示例4: onContainerStatusReceived

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@SuppressWarnings("deprecation")
@Override
public void onContainerStatusReceived(ContainerId containerId,
    ContainerStatus containerStatus) {
  if (containerId.getId() >= expectedSuccess) {
    errorMsgs.add("Container " + containerId +
        " should throw the exception onContainerStatusReceived");
    return;
  }
  actualQuerySuccess.addAndGet(1);
  actualQuerySuccessArray.set(containerId.getId(), 1);
  // move on to the following success tests
  asyncClient.stopContainerAsync(containerId, nodeId);

  // Shouldn't crash the test thread
  throw new RuntimeException("Ignorable Exception");
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:18,代碼來源:TestNMClientAsync.java

示例5: newAllocateResponse

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
public static AllocateResponse newAllocateResponse(int responseId,
    List<ContainerStatus> completedContainers,
    List<Container> allocatedContainers, List<NodeReport> updatedNodes,
    Resource availResources, AMCommand command, int numClusterNodes,
    PreemptionMessage preempt) {
  AllocateResponse response = recordFactory
      .newRecordInstance(AllocateResponse.class);
  response.setNumClusterNodes(numClusterNodes);
  response.setResponseId(responseId);
  response.setCompletedContainersStatuses(completedContainers);
  response.setAllocatedContainers(allocatedContainers);
  response.setUpdatedNodes(updatedNodes);
  response.setAvailableResources(availResources);
  response.setAMCommand(command);
  response.setPreemptionMessage(preempt);

  return response;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:19,代碼來源:BuilderUtils.java

示例6: getNodeStatus

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
private NodeStatus getNodeStatus() {
  NodeStatus status = recordFactory.newRecordInstance(NodeStatus.class);
  status.setContainersStatuses(new ArrayList<ContainerStatus>());
  status.setKeepAliveApplications(new ArrayList<ApplicationId>());

  status.setNodeHealthStatus(getNodeHealthStatus());
  status.setNodeId(getNodeId());
  status.setResponseId(1);
  return status;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:11,代碼來源:TestYarnServerApiClasses.java

示例7: getContainerStatuses

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
/**
 * Get a list of container statuses running on this NodeManager
 */
@Override
public GetContainerStatusesResponse getContainerStatuses(
    GetContainerStatusesRequest request) throws YarnException, IOException {

  List<ContainerStatus> succeededRequests = new ArrayList<ContainerStatus>();
  Map<ContainerId, SerializedException> failedRequests =
      new HashMap<ContainerId, SerializedException>();
  UserGroupInformation remoteUgi = getRemoteUgi();
  NMTokenIdentifier identifier = selectNMTokenIdentifier(remoteUgi);
  for (ContainerId id : request.getContainerIds()) {
    try {
      ContainerStatus status = getContainerStatusInternal(id, identifier);
      succeededRequests.add(status);
    } catch (YarnException e) {
      failedRequests.put(id, SerializedException.newInstance(e));
    }
  }
  return GetContainerStatusesResponse.newInstance(succeededRequests,
    failedRequests);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:24,代碼來源:ContainerManagerImpl.java

示例8: testGetContainerStatus

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
private void testGetContainerStatus(Container container, int index,
    ContainerState state, String diagnostics, List<Integer> exitStatuses)
        throws YarnException, IOException {
  while (true) {
    try {
      ContainerStatus status = nmClient.getContainerStatus(
          container.getId(), container.getNodeId());
      // NodeManager may still need some time to get the stable
      // container status
      if (status.getState() == state) {
        assertEquals(container.getId(), status.getContainerId());
        assertTrue("" + index + ": " + status.getDiagnostics(),
            status.getDiagnostics().contains(diagnostics));
        
        assertTrue("Exit Statuses are supposed to be in: " + exitStatuses +
            ", but the actual exit status code is: " + status.getExitStatus(),
            exitStatuses.contains(status.getExitStatus()));
        break;
      }
      Thread.sleep(100);
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:26,代碼來源:TestNMClient.java

示例9: getContainerStatuses

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Override
synchronized public GetContainerStatusesResponse getContainerStatuses(
    GetContainerStatusesRequest request) throws YarnException {
  List<ContainerStatus> statuses = new ArrayList<ContainerStatus>();
  for (ContainerId containerId : request.getContainerIds()) {
    List<Container> appContainers =
        containers.get(containerId.getApplicationAttemptId()
          .getApplicationId());
    Container container = null;
    for (Container c : appContainers) {
      if (c.getId().equals(containerId)) {
        container = c;
      }
    }
    if (container != null
        && containerStatusMap.get(container).getState() != null) {
      statuses.add(containerStatusMap.get(container));
    }
  }
  return GetContainerStatusesResponse.newInstance(statuses, null);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:22,代碼來源:NodeManager.java

示例10: waitForContainerState

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
public static void waitForContainerState(ContainerManagementProtocol containerManager,
      ContainerId containerID, ContainerState finalState, int timeOutMax)
      throws InterruptedException, YarnException, IOException {
List<ContainerId> list = new ArrayList<ContainerId>();
list.add(containerID);
GetContainerStatusesRequest request =
    GetContainerStatusesRequest.newInstance(list);
ContainerStatus containerStatus =
    containerManager.getContainerStatuses(request).getContainerStatuses()
      .get(0);
int timeoutSecs = 0;
  while (!containerStatus.getState().equals(finalState)
      && timeoutSecs++ < timeOutMax) {
      Thread.sleep(1000);
      LOG.info("Waiting for container to get into state " + finalState
          + ". Current state is " + containerStatus.getState());
      containerStatus = containerManager.getContainerStatuses(request).getContainerStatuses().get(0);
    }
    LOG.info("Container state is " + containerStatus.getState());
    Assert.assertEquals("ContainerState is not correct (timedout)",
        finalState, containerStatus.getState());
  }
 
開發者ID:naver,項目名稱:hadoop,代碼行數:23,代碼來源:BaseContainerManagerTest.java

示例11: getAppToContainerStatusMap

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
private Map<ApplicationId, List<ContainerStatus>> getAppToContainerStatusMap(
    List<ContainerStatus> containers) {
  Map<ApplicationId, List<ContainerStatus>> map =
      new HashMap<ApplicationId, List<ContainerStatus>>();
  for (ContainerStatus cs : containers) {
    ApplicationId applicationId =
        cs.getContainerId().getApplicationAttemptId().getApplicationId();
    List<ContainerStatus> appContainers = map.get(applicationId);
    if (appContainers == null) {
      appContainers = new ArrayList<ContainerStatus>();
      map.put(applicationId, appContainers);
    }
    appContainers.add(cs);
  }
  return map;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:17,代碼來源:TestNodeStatusUpdater.java

示例12: getContainers

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Override
public ConcurrentMap<ContainerId, Container> getContainers() {
  if (heartBeatID == 0) {
    return containers;
  } else if (heartBeatID == 1) {
    ContainerStatus containerStatus2 =
        createContainerStatus(2, ContainerState.RUNNING);
    putMockContainer(containerStatus2);

    ContainerStatus containerStatus3 =
        createContainerStatus(3, ContainerState.COMPLETE);
    putMockContainer(containerStatus3);
    return containers;
  } else if (heartBeatID == 2) {
    ContainerStatus containerStatus4 =
        createContainerStatus(4, ContainerState.RUNNING);
    putMockContainer(containerStatus4);

    ContainerStatus containerStatus5 =
        createContainerStatus(5, ContainerState.COMPLETE);
    putMockContainer(containerStatus5);
    return containers;
  } else if (heartBeatID == 3 || heartBeatID == 4) {
    return containers;
  } else {
    containers.clear();
    return containers;
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:30,代碼來源:TestNodeStatusUpdater.java

示例13: newInstance

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Private
@Unstable
public static AllocateResponse newInstance(int responseId,
    List<ContainerStatus> completedContainers,
    List<Container> allocatedContainers, List<NodeReport> updatedNodes,
    Resource availResources, AMCommand command, int numClusterNodes,
    PreemptionMessage preempt, List<NMToken> nmTokens, Token amRMToken,
    List<ContainerResourceIncrease> increasedContainers,
    List<ContainerResourceDecrease> decreasedContainers) {
  AllocateResponse response =
      newInstance(responseId, completedContainers, allocatedContainers,
        updatedNodes, availResources, command, numClusterNodes, preempt,
        nmTokens, increasedContainers, decreasedContainers);
  response.setAMRMToken(amRMToken);
  return response;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:17,代碼來源:AllocateResponse.java

示例14: getAMContainerCrashedDiagnostics

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
private String getAMContainerCrashedDiagnostics(
    RMAppAttemptContainerFinishedEvent finishEvent) {
  ContainerStatus status = finishEvent.getContainerStatus();
  StringBuilder diagnosticsBuilder = new StringBuilder();
  diagnosticsBuilder.append("AM Container for ").append(
    finishEvent.getApplicationAttemptId()).append(
    " exited with ").append(" exitCode: ").append(status.getExitStatus()).
    append("\n");
  if (this.getTrackingUrl() != null) {
    diagnosticsBuilder.append("For more detailed output,").append(
      " check application tracking page:").append(
      this.getTrackingUrl()).append(
      "Then, click on links to logs of each attempt.\n");
  }
  diagnosticsBuilder.append("Diagnostics: ").append(status.getDiagnostics())
      .append("Failing this attempt");
  return diagnosticsBuilder.toString();
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:19,代碼來源:RMAppAttemptImpl.java

示例15: transition

import org.apache.hadoop.yarn.api.records.ContainerStatus; //導入依賴的package包/類
@Override
public RMAppAttemptState transition(RMAppAttemptImpl appAttempt,
    RMAppAttemptEvent event) {

  RMAppAttemptContainerFinishedEvent containerFinishedEvent =
      (RMAppAttemptContainerFinishedEvent) event;
  ContainerStatus containerStatus =
      containerFinishedEvent.getContainerStatus();

  // Is this container the AmContainer? If the finished container is same as
  // the AMContainer, AppAttempt fails
  if (appAttempt.masterContainer != null
      && appAttempt.masterContainer.getId().equals(
          containerStatus.getContainerId())) {
    appAttempt.sendAMContainerToNM(appAttempt, containerFinishedEvent);

    // Remember the follow up transition and save the final attempt state.
    appAttempt.rememberTargetTransitionsAndStoreState(event,
        transitionToDo, RMAppAttemptState.FAILED, RMAppAttemptState.FAILED);
    return RMAppAttemptState.FINAL_SAVING;
  }

  // Add all finished containers so that they can be acked to NM
  addJustFinishedContainer(appAttempt, containerFinishedEvent);
  return this.currentState;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:27,代碼來源:RMAppAttemptImpl.java


注:本文中的org.apache.hadoop.yarn.api.records.ContainerStatus類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。