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


Java QueryInProgress類代碼示例

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


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

示例1: stopQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public void stopQueryMaster(QueryId queryId) {
  try {
    FinalApplicationStatus appStatus = FinalApplicationStatus.UNDEFINED;
    QueryInProgress queryInProgress = masterContext.getQueryJobManager().getQueryInProgress(queryId);
    if(queryInProgress == null) {
      return;
    }
    TajoProtos.QueryState state = queryInProgress.getQueryInfo().getQueryState();
    if (state == TajoProtos.QueryState.QUERY_SUCCEEDED) {
      appStatus = FinalApplicationStatus.SUCCEEDED;
    } else if (state == TajoProtos.QueryState.QUERY_FAILED || state == TajoProtos.QueryState.QUERY_ERROR) {
      appStatus = FinalApplicationStatus.FAILED;
    } else if (state == TajoProtos.QueryState.QUERY_ERROR) {
      appStatus = FinalApplicationStatus.FAILED;
    }
    FinishApplicationMasterRequest request = recordFactory
        .newRecordInstance(FinishApplicationMasterRequest.class);
    request.setAppAttemptId(ApplicationIdUtils.createApplicationAttemptId(queryId));
    request.setFinishApplicationStatus(appStatus);
    request.setDiagnostics("QueryMaster shutdown by TajoMaster.");
    rmClient.finishApplicationMaster(request);
  } catch (Exception e) {
    LOG.error(e.getMessage(), e);
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:27,代碼來源:YarnTajoResourceManager.java

示例2: stopQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public void stopQueryMaster(QueryId queryId) {
  try {
    FinalApplicationStatus appStatus = FinalApplicationStatus.UNDEFINED;
    QueryInProgress queryInProgress = masterContext.getQueryJobManager().getQueryInProgress(queryId);
    if(queryInProgress == null) {
      return;
    }
    TajoProtos.QueryState state = queryInProgress.getQueryInfo().getQueryState();
    if (state == TajoProtos.QueryState.QUERY_SUCCEEDED) {
      appStatus = FinalApplicationStatus.SUCCEEDED;
    } else if (state == TajoProtos.QueryState.QUERY_FAILED || state == TajoProtos.QueryState.QUERY_ERROR) {
      appStatus = FinalApplicationStatus.FAILED;
    } else if (state == TajoProtos.QueryState.QUERY_ERROR) {
      appStatus = FinalApplicationStatus.FAILED;
    }
    FinishApplicationMasterRequest request = recordFactory
        .newRecordInstance(FinishApplicationMasterRequest.class);
    request.setFinalApplicationStatus(appStatus);
    request.setDiagnostics("QueryMaster shutdown by TajoMaster.");
    rmClient.finishApplicationMaster(request);
  } catch (Exception e) {
    LOG.error(e.getMessage(), e);
  }
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:26,代碼來源:YarnTajoResourceManager.java

示例3: allocateQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public WorkerAllocatedResource allocateQueryMaster(QueryInProgress queryInProgress) {
  // Create a resource request for a query master
  WorkerResourceAllocationRequest qmResourceRequest = createQMResourceRequest(queryInProgress.getQueryId());

  // call future for async call
  CallFuture<WorkerResourceAllocationResponse> callFuture = new CallFuture<WorkerResourceAllocationResponse>();
  allocateWorkerResources(qmResourceRequest, callFuture);

  // Wait for 3 seconds
  WorkerResourceAllocationResponse response = null;
  try {
    response = callFuture.get(3, TimeUnit.SECONDS);
  } catch (Throwable t) {
    LOG.error(t);
    return null;
  }

  if (response.getWorkerAllocatedResourceList().size() == 0) {
    return null;
  }

  WorkerAllocatedResource resource = response.getWorkerAllocatedResource(0);
  registerQueryMaster(queryInProgress.getQueryId(), resource.getContainerId());
  return resource;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:27,代碼來源:TajoWorkerResourceManager.java

示例4: sortQueryInProgress

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
public static List<QueryInProgress> sortQueryInProgress(Collection<QueryInProgress> queryInProgresses,
                                                        final boolean desc) {
  List<QueryInProgress> queryProgressList = new ArrayList<QueryInProgress>(queryInProgresses);

  Collections.sort(queryProgressList, new Comparator<QueryInProgress>() {
    @Override
    public int compare(QueryInProgress query1, QueryInProgress query2) {
      if(desc) {
        return query2.getQueryId().toString().compareTo(query1.getQueryId().toString());
      } else {
        return query1.getQueryId().toString().compareTo(query2.getQueryId().toString());
      }
    }
  });

  return queryProgressList;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:18,代碼來源:JSPUtil.java

示例5: getRunningQueryList

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryListResponse getRunningQueryList(RpcController controller, GetQueryListRequest request)

    throws ServiceException {

  try {
    context.getSessionManager().touch(request.getSessionId().getId());
    GetQueryListResponse.Builder builder= GetQueryListResponse.newBuilder();

    Collection<QueryInProgress> queries
      = context.getQueryJobManager().getRunningQueries();

    BriefQueryInfo.Builder infoBuilder = BriefQueryInfo.newBuilder();

    for (QueryInProgress queryInProgress : queries) {
      QueryInfo queryInfo = queryInProgress.getQueryInfo();

      infoBuilder.setQueryId(queryInfo.getQueryId().getProto());
      infoBuilder.setState(queryInfo.getQueryState());
      infoBuilder.setQuery(queryInfo.getSql());
      infoBuilder.setStartTime(queryInfo.getStartTime());
      long endTime = (queryInfo.getFinishTime() == 0) ?
                     System.currentTimeMillis() : queryInfo.getFinishTime();
      infoBuilder.setFinishTime(endTime);
      infoBuilder.setProgress(queryInfo.getProgress());
      infoBuilder.setQueryMasterPort(queryInfo.getQueryMasterPort());
      infoBuilder.setQueryMasterHost(queryInfo.getQueryMasterHost());

      builder.addQueryList(infoBuilder.build());
    }

    GetQueryListResponse result = builder.build();
    return result;
  } catch (Throwable t) {
    throw new ServiceException(t);
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:38,代碼來源:TajoMasterClientService.java

示例6: startQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public void startQueryMaster(QueryInProgress queryInProgress) {
  WorkerResource queryMasterWorkerResource = null;
  synchronized(workerResourceLock) {
    queryMasterWorkerResource = queryMasterMap.get(queryInProgress.getQueryId());
  }

  if(queryMasterWorkerResource != null) {
    AllocatedWorkerResource allocatedWorkerResource = new AllocatedWorkerResource();
    allocatedWorkerResource.workerResource = queryMasterWorkerResource;
    allocatedWorkerResource.allocatedMemoryMB = queryMasterDefaultMemoryMB;
    allocatedWorkerResource.allocatedDiskSlots = queryMasterDefaultDiskSlot;

    startQueryMaster(queryInProgress.getQueryId(), allocatedWorkerResource);
  } else {
    //add queue
    TajoMasterProtocol.WorkerResourceAllocationRequest request =
        TajoMasterProtocol.WorkerResourceAllocationRequest.newBuilder()
          .setExecutionBlockId(QueryIdFactory.newExecutionBlockId(QueryIdFactory.NULL_QUERY_ID, 0).getProto())
          .setNumContainers(1)
          .setMinMemoryMBPerContainer(queryMasterDefaultMemoryMB)
          .setMaxMemoryMBPerContainer(queryMasterDefaultMemoryMB)
          .setMinDiskSlotPerContainer(queryMasterDefaultDiskSlot)
          .setMaxDiskSlotPerContainer(queryMasterDefaultDiskSlot)
          .setResourceRequestPriority(TajoMasterProtocol.ResourceRequestPriority.MEMORY)
          .build();
    try {
      requestQueue.put(new WorkerResourceRequest(queryInProgress.getQueryId(), true, request, null));
    } catch (InterruptedException e) {
    }
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:33,代碼來源:TajoWorkerResourceManager.java

示例7: getQueryResult

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryResultResponse getQueryResult(RpcController controller,
                                             GetQueryResultRequest request)
    throws ServiceException {
  QueryId queryId = new QueryId(request.getQueryId());
  QueryInProgress queryInProgress = context.getQueryJobManager().getQueryInProgress(queryId);
  QueryInfo queryInfo = queryInProgress.getQueryInfo();
  GetQueryResultResponse.Builder builder
      = GetQueryResultResponse.newBuilder();

  try {
    //TODO After implementation Tajo's user security feature, Should be modified.
    builder.setTajoUserName(UserGroupInformation.getCurrentUser().getUserName());
  } catch (IOException e) {
    LOG.warn("Can't get current user name");
  }
  switch (queryInfo.getQueryState()) {
    case QUERY_SUCCEEDED:
      // TODO check this logic needed
      //builder.setTableDesc((TableDescProto) queryJobManager.getResultDesc().getProto());
      break;
    case QUERY_FAILED:
    case QUERY_ERROR:
      builder.setErrorMessage("Query " + queryId + " is failed");
    default:
      builder.setErrorMessage("Query " + queryId + " is still running");
  }

  return builder.build();
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:31,代碼來源:TajoMasterClientService.java

示例8: getRunningQueryList

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryListResponse getRunningQueryList(RpcController controller,
                                         GetQueryListRequest request)
    throws ServiceException {
  GetQueryListResponse.Builder builder
    = GetQueryListResponse.newBuilder(); 
   
  Collection<QueryInProgress> queries 
    = context.getQueryJobManager().getRunningQueries();

  BriefQueryInfo.Builder infoBuilder = BriefQueryInfo.newBuilder();
 
  for (QueryInProgress queryInProgress : queries) {
    QueryInfo queryInfo = queryInProgress.getQueryInfo();

    infoBuilder.setQueryId(queryInfo.getQueryId().getProto());
    infoBuilder.setState(queryInfo.getQueryState());
    infoBuilder.setQuery(queryInfo.getSql());
    infoBuilder.setStartTime(queryInfo.getStartTime());
    long endTime = (queryInfo.getFinishTime() == 0) ? 
                   System.currentTimeMillis() : queryInfo.getFinishTime();
    infoBuilder.setFinishTime(endTime);
    infoBuilder.setProgress(queryInfo.getProgress());
    infoBuilder.setQueryMasterPort(queryInfo.getQueryMasterPort());
    infoBuilder.setQueryMasterHost(queryInfo.getQueryMasterHost());

    builder.addQueryList(infoBuilder.build());
  }

  GetQueryListResponse result = builder.build();
  return result;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:33,代碼來源:TajoMasterClientService.java

示例9: getFinishedQueryList

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryListResponse getFinishedQueryList(RpcController controller,
                                         GetQueryListRequest request)
    throws ServiceException {
  GetQueryListResponse.Builder builder
      = GetQueryListResponse.newBuilder();

  Collection<QueryInProgress> queries
      = context.getQueryJobManager().getFinishedQueries();

  BriefQueryInfo.Builder infoBuilder = BriefQueryInfo.newBuilder();

  for (QueryInProgress queryInProgress : queries) {
    QueryInfo queryInfo = queryInProgress.getQueryInfo();

    infoBuilder.setQueryId(queryInfo.getQueryId().getProto());
    infoBuilder.setState(queryInfo.getQueryState());
    infoBuilder.setQuery(queryInfo.getSql());
    infoBuilder.setStartTime(queryInfo.getStartTime());
    long endTime = (queryInfo.getFinishTime() == 0) ?
        System.currentTimeMillis() : queryInfo.getFinishTime();
    infoBuilder.setFinishTime(endTime);
    infoBuilder.setProgress(queryInfo.getProgress());
    infoBuilder.setQueryMasterPort(queryInfo.getQueryMasterPort());
    infoBuilder.setQueryMasterHost(queryInfo.getQueryMasterHost());

    builder.addQueryList(infoBuilder.build());
  }

  GetQueryListResponse result = builder.build();
  return result;
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:33,代碼來源:TajoMasterClientService.java

示例10: getQueryStatus

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryStatusResponse getQueryStatus(RpcController controller,
                                             GetQueryStatusRequest request)
    throws ServiceException {

  GetQueryStatusResponse.Builder builder
      = GetQueryStatusResponse.newBuilder();
  QueryId queryId = new QueryId(request.getQueryId());
  builder.setQueryId(request.getQueryId());

  if (queryId.equals(QueryIdFactory.NULL_QUERY_ID)) {
    builder.setResultCode(ResultCode.OK);
    builder.setState(TajoProtos.QueryState.QUERY_SUCCEEDED);
  } else {
    QueryInProgress queryInProgress = context.getQueryJobManager().getQueryInProgress(queryId);
    if (queryInProgress != null) {
      QueryInfo queryInfo = queryInProgress.getQueryInfo();
      builder.setResultCode(ResultCode.OK);
      builder.setState(queryInfo.getQueryState());
      builder.setProgress(queryInfo.getProgress());
      builder.setSubmitTime(queryInfo.getStartTime());
      if(queryInfo.getQueryMasterHost() != null) {
        builder.setQueryMasterHost(queryInfo.getQueryMasterHost());
        builder.setQueryMasterPort(queryInfo.getQueryMasterClientPort());
      }
      //builder.setInitTime(queryJobManager.getInitializationTime());
      //builder.setHasResult(!queryJobManager.isCreateTableStmt());
      if (queryInfo.getQueryState() == TajoProtos.QueryState.QUERY_SUCCEEDED) {
        builder.setFinishTime(queryInfo.getFinishTime());
      } else {
        builder.setFinishTime(System.currentTimeMillis());
      }
    } else {
      builder.setResultCode(ResultCode.ERROR);
      builder.setErrorMessage("No such query: " + queryId.toString());
    }
  }

  return builder.build();
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:41,代碼來源:TajoMasterClientService.java

示例11: getFinishedQueryList

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryListResponse getFinishedQueryList(RpcController controller, GetQueryListRequest request)
    throws ServiceException {

  try {
    context.getSessionManager().touch(request.getSessionId().getId());
    GetQueryListResponse.Builder builder = GetQueryListResponse.newBuilder();

    Collection<QueryInProgress> queries
        = context.getQueryJobManager().getFinishedQueries();

    BriefQueryInfo.Builder infoBuilder = BriefQueryInfo.newBuilder();

    for (QueryInProgress queryInProgress : queries) {
      QueryInfo queryInfo = queryInProgress.getQueryInfo();

      infoBuilder.setQueryId(queryInfo.getQueryId().getProto());
      infoBuilder.setState(queryInfo.getQueryState());
      infoBuilder.setQuery(queryInfo.getSql());
      infoBuilder.setStartTime(queryInfo.getStartTime());
      long endTime = (queryInfo.getFinishTime() == 0) ?
          System.currentTimeMillis() : queryInfo.getFinishTime();
      infoBuilder.setFinishTime(endTime);
      infoBuilder.setProgress(queryInfo.getProgress());
      infoBuilder.setQueryMasterPort(queryInfo.getQueryMasterPort());
      infoBuilder.setQueryMasterHost(queryInfo.getQueryMasterHost());

      builder.addQueryList(infoBuilder.build());
    }

    GetQueryListResponse result = builder.build();
    return result;
  } catch (Throwable t) {
    throw new ServiceException(t);
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:37,代碼來源:TajoMasterClientService.java

示例12: startQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public void startQueryMaster(QueryInProgress queryInProgress) {
  try {
    allocateAndLaunchQueryMaster(queryInProgress);

    queryInProgress.getEventHandler().handle(
        new QueryJobEvent(QueryJobEvent.Type.QUERY_JOB_START, queryInProgress.getQueryInfo()));

  } catch (YarnRemoteException e) {
    LOG.error(e.getMessage(), e);
    //TODO set QueryState(fail)
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:14,代碼來源:YarnTajoResourceManager.java

示例13: allocateQueryMaster

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public WorkerAllocatedResource allocateQueryMaster(QueryInProgress queryInProgress) {
  throw new UnimplementedException("allocateQueryMaster");
}
 
開發者ID:apache,項目名稱:incubator-tajo,代碼行數:5,代碼來源:YarnTajoResourceManager.java

示例14: getQueryResult

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryResultResponse getQueryResult(RpcController controller,
                                             GetQueryResultRequest request) throws ServiceException {
  try {
    context.getSessionManager().touch(request.getSessionId().getId());
    QueryId queryId = new QueryId(request.getQueryId());
    QueryInProgress queryInProgress = context.getQueryJobManager().getQueryInProgress(queryId);

    // if we cannot get a QueryInProgress instance from QueryJobManager,
    // the instance can be in the finished query list.
    if (queryInProgress == null) {
      queryInProgress = context.getQueryJobManager().getFinishedQuery(queryId);
    }

    GetQueryResultResponse.Builder builder = GetQueryResultResponse.newBuilder();

    // If we cannot the QueryInProgress instance from the finished list,
    // the query result was expired due to timeout.
    // In this case, we will result in error.
    if (queryInProgress == null) {
      builder.setErrorMessage("No such query: " + queryId.toString());
      return builder.build();
    }

    QueryInfo queryInfo = queryInProgress.getQueryInfo();

    try {
      //TODO After implementation Tajo's user security feature, Should be modified.
      builder.setTajoUserName(UserGroupInformation.getCurrentUser().getUserName());
    } catch (IOException e) {
      LOG.warn("Can't get current user name");
    }
    switch (queryInfo.getQueryState()) {
      case QUERY_SUCCEEDED:
        // TODO check this logic needed
        //builder.setTableDesc((TableDescProto) queryJobManager.getResultDesc().getProto());
        break;
      case QUERY_FAILED:
      case QUERY_ERROR:
        builder.setErrorMessage("Query " + queryId + " is failed");
      default:
        builder.setErrorMessage("Query " + queryId + " is still running");
    }

    return builder.build();
  } catch (Throwable t) {
    throw new ServiceException(t);
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:50,代碼來源:TajoMasterClientService.java

示例15: getQueryStatus

import org.apache.tajo.master.querymaster.QueryInProgress; //導入依賴的package包/類
@Override
public GetQueryStatusResponse getQueryStatus(RpcController controller,
                                             GetQueryStatusRequest request)
    throws ServiceException {

  try {
    context.getSessionManager().touch(request.getSessionId().getId());

    GetQueryStatusResponse.Builder builder = GetQueryStatusResponse.newBuilder();
    QueryId queryId = new QueryId(request.getQueryId());
    builder.setQueryId(request.getQueryId());

    if (queryId.equals(QueryIdFactory.NULL_QUERY_ID)) {
      builder.setResultCode(ResultCode.OK);
      builder.setState(TajoProtos.QueryState.QUERY_SUCCEEDED);
    } else {
      QueryInProgress queryInProgress = context.getQueryJobManager().getQueryInProgress(queryId);

      // It will try to find a query status from a finished query list.
      if (queryInProgress == null) {
        queryInProgress = context.getQueryJobManager().getFinishedQuery(queryId);
      }
      if (queryInProgress != null) {
        QueryInfo queryInfo = queryInProgress.getQueryInfo();
        builder.setResultCode(ResultCode.OK);
        builder.setState(queryInfo.getQueryState());
        builder.setProgress(queryInfo.getProgress());
        builder.setSubmitTime(queryInfo.getStartTime());
        if(queryInfo.getQueryMasterHost() != null) {
          builder.setQueryMasterHost(queryInfo.getQueryMasterHost());
          builder.setQueryMasterPort(queryInfo.getQueryMasterClientPort());
        }
        if (queryInfo.getQueryState() == TajoProtos.QueryState.QUERY_SUCCEEDED) {
          builder.setFinishTime(queryInfo.getFinishTime());
        } else {
          builder.setFinishTime(System.currentTimeMillis());
        }
      } else {
        builder.setResultCode(ResultCode.ERROR);
        builder.setErrorMessage("No such query: " + queryId.toString());
      }
    }
    return builder.build();

  } catch (Throwable t) {
    throw new  ServiceException(t);
  }
}
 
開發者ID:gruter,項目名稱:tajo-cdh,代碼行數:49,代碼來源:TajoMasterClientService.java


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