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


Java StreamObserver.onError方法代碼示例

本文整理匯總了Java中io.grpc.stub.StreamObserver.onError方法的典型用法代碼示例。如果您正苦於以下問題:Java StreamObserver.onError方法的具體用法?Java StreamObserver.onError怎麽用?Java StreamObserver.onError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在io.grpc.stub.StreamObserver的用法示例。


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

示例1: downloadProductImage

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void downloadProductImage(DownloadProductImageRequest request, StreamObserver<DataChunk> responseObserver) {
  try {
    BufferedInputStream imageStream = new BufferedInputStream(
        productImageSeeker.seekProductImage(request.getProductId())
    );
    int bufferSize = 256 * 1024;// 256k
    byte[] buffer = new byte[bufferSize];
    int length;
    while ((length = imageStream.read(buffer, 0, bufferSize)) != -1) {
      responseObserver.onNext(
          DataChunk.newBuilder().setData(ByteString.copyFrom(buffer, 0, length)).build()
      );
    }
    responseObserver.onCompleted();
    imageStream.close();
    counter.labels("downloadProductImage", "success");
  } catch (Exception e) {
    counter.labels("downloadProductImage", "failed");
    log.error("error on read product image", e);
    responseObserver.onError(e);
  }

}
 
開發者ID:email2liyang,項目名稱:grpc-mate,代碼行數:25,代碼來源:ProductReadService.java

示例2: execute

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void execute(
    ExecuteRequest request, StreamObserver<Operation> responseObserver) {
  Instance instance;
  try {
    instance = instances.get(request.getInstanceName());
  } catch (InstanceNotFoundException ex) {
    responseObserver.onError(BuildFarmInstances.toStatusException(ex));
    return;
  }

  instance.execute(
      request.getAction(),
      request.getSkipCacheLookup(),
      request.getTotalInputFileCount(),
      request.getTotalInputFileBytes(),
      (operation) -> {
        responseObserver.onNext(operation);
        responseObserver.onCompleted();
      });
}
 
開發者ID:bazelbuild,項目名稱:bazel-buildfarm,代碼行數:22,代碼來源:ExecutionService.java

示例3: failPlease

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void failPlease(FailWithProbabilityOrSucceedEchoRequest request,
                       StreamObserver<EchoResponse> responseObserver) {
    EchoRequest echoRequest = request.getEchoRequest();
    int failProbability = request.getFailProbability();
    Preconditions.checkArgument(failProbability >= 0 && failProbability <= 100,
            "fail probability not [" + failProbability + "] not in range [0, 100] inclusive");
    logger.info("fail please - p(" + failProbability + " / 100)" + " echo: " + echoRequest.getEcho()
            + " with " + "repetitions: " + echoRequest.getRepeatEcho() + " received at "
            + DATE_FORMAT.format(new Date(System.currentTimeMillis())));

    int randomFail = RANDOM.nextInt(100);
    if (randomFail < failProbability) {
        Status status = Status.INTERNAL;
        status = status.withCause(new FailPleaseException("Looks like you hit jackpot - we failed!"));
        responseObserver.onError(status.asRuntimeException());
    } else {
        responseObserver.onNext(buildEchoResponseFromEchoRequest(echoRequest));
        responseObserver.onCompleted();
    }
}
 
開發者ID:mavrukin,項目名稱:grpc-base-gradle,代碼行數:22,代碼來源:SimpleServiceImpl.java

示例4: updateActionResult

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void updateActionResult(
    UpdateActionResultRequest request,
    StreamObserver<ActionResult> responseObserver) {
  Instance instance;
  try {
    instance = instances.get(request.getInstanceName());
  } catch (InstanceNotFoundException ex) {
    responseObserver.onError(BuildFarmInstances.toStatusException(ex));
    return;
  }

  ActionResult actionResult = request.getActionResult();
  instance.putActionResult(request.getActionDigest(), actionResult);

  responseObserver.onNext(actionResult);
  responseObserver.onCompleted();
}
 
開發者ID:bazelbuild,項目名稱:bazel-buildfarm,代碼行數:19,代碼來源:ActionCacheService.java

示例5: publish

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void publish(@NonNull MSG_Facts request,
        @NonNull StreamObserver<MSG_Empty> responseObserver) {
    List<Fact> facts = request.getFactList().stream().map(converter::fromProto).collect(
            Collectors.toList());
    final int size = facts.size();
    log.debug("publish {} fact{}", size, size > 1 ? "s" : "");
    log.trace("publish {}", facts);
    try {

        log.trace("store publish {}", facts);
        store.publish(facts);
        log.trace("store publish done");
        responseObserver.onNext(MSG_Empty.getDefaultInstance());
        responseObserver.onCompleted();
    } catch (Throwable e) {
        log.error("Problem while publishing: ", e);
        responseObserver.onError(new StatusRuntimeException(Status.INTERNAL.withDescription(e
                .getMessage())));
    }
}
 
開發者ID:uweschaefer,項目名稱:factcast,代碼行數:22,代碼來源:FactStoreGrpcService.java

示例6: invoke

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void invoke(byte[] msg, StreamObserver<byte[]> responseObserver) {
  final RequestBody reqBody = RequestBody.create(OCTET_STREAM, msg);
  final Request req = new Request.Builder().url(url).post(reqBody).build();
  try {
    try (Response resp = client.newCall(req).execute()) {
      final ResponseBody respBody = resp.body();
      if (respBody != null) {
        responseObserver.onNext(respBody.bytes());
      }
    }
    responseObserver.onCompleted();
  } catch (IOException e) {
    responseObserver.onError(e);
  }
}
 
開發者ID:codahale,項目名稱:grpc-proxy,代碼行數:17,代碼來源:ProxyHandlerRegistry.java

示例7: clientstream

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@RequestMapping("/clientstream")
public HelloReply clientstream(@RequestParam(value = "name", required = false) String name) {
  HelloRequest request = new HelloRequest();
  request.setName(name);
  RpcContext.getContext().set("123", "123");
  StreamObserver<com.quancheng.examples.model.hello.HelloRequest> requestObserver =
      helloService.sayHelloClientStream(responseObserver());
  try {
    for (int i = 0; i < 10; i++) {
      requestObserver.onNext(request);
    }
  } catch (Exception e) {
    requestObserver.onError(e);
  }
  requestObserver.onCompleted();
  return null;
}
 
開發者ID:venus-boot,項目名稱:saluki,代碼行數:18,代碼來源:ProxyServiceController.java

示例8: poll

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void poll(
    PollOperationRequest request,
    StreamObserver<com.google.rpc.Status> responseObserver) {
  Instance instance;
  try {
    instance = instances.getFromOperationName(
        request.getOperationName());
  } catch (InstanceNotFoundException ex) {
    responseObserver.onError(BuildFarmInstances.toStatusException(ex));
    return;
  }

  boolean ok = instance.pollOperation(
      request.getOperationName(),
      request.getStage());
  Code code = ok ? Code.OK : Code.UNAVAILABLE;
  responseObserver.onNext(com.google.rpc.Status.newBuilder()
      .setCode(code.getNumber())
      .build());
  responseObserver.onCompleted();
}
 
開發者ID:bazelbuild,項目名稱:bazel-buildfarm,代碼行數:23,代碼來源:OperationQueueService.java

示例9: oneToMany

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
/**
 * Implements a unary -> stream call as {@link Mono} -> {@link Flux}, where the server responds with a
 * stream of messages.
 */
public static <TRequest, TResponse> void oneToMany(
        TRequest request, StreamObserver<TResponse> responseObserver,
        Function<Mono<TRequest>, Flux<TResponse>> delegate) {
    try {
        Mono<TRequest> rxRequest = Mono.just(request);

        Flux<TResponse> rxResponse = Preconditions.checkNotNull(delegate.apply(rxRequest));
        rxResponse.subscribe(new ReactivePublisherBackpressureOnReadyHandler<>(
                (ServerCallStreamObserver<TResponse>) responseObserver));
    } catch (Throwable throwable) {
        responseObserver.onError(prepareError(throwable));
    }
}
 
開發者ID:salesforce,項目名稱:reactive-grpc,代碼行數:18,代碼來源:ServerCalls.java

示例10: searchProducts

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void searchProducts(SearchProductsRequest request, StreamObserver<SearchProductsResponse> responseObserver) {
  try {
    responseObserver.onNext(productDao.searchProducts(request));
    responseObserver.onCompleted();
    counter.labels("searchProducts", "success");
  } catch (Exception e) {
    log.error(" error on search product with request - {}", request, e);
    responseObserver.onError(e);
    counter.labels("searchProducts", "failed");
  }
}
 
開發者ID:email2liyang,項目名稱:grpc-mate,代碼行數:13,代碼來源:ProductReadService.java

示例11: getStore

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
public void getStore(GetStoreRequest request, StreamObserver<GetStoreResponse> resp) {
  try {
    resp.onNext(getStoreResp.removeFirst().get());
    resp.onCompleted();
  } catch (Exception e) {
    resp.onError(Status.INTERNAL.asRuntimeException());
  }
}
 
開發者ID:pingcap,項目名稱:tikv-client-lib-java,代碼行數:9,代碼來源:PDMockServer.java

示例12: onPlayerLogin

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void onPlayerLogin(PlayerLoginEvent event, StreamObserver<PlayerLoginEvent> observer) {
    try {
        getPluginManager().onPlayerLogin(event, observer);
    } catch (ServiceNotConnectedException ex) {
        log.error("Not connected:", ex);
        observer.onError(ex);
    }
}
 
開發者ID:JungleTree,項目名稱:JungleTree,代碼行數:10,代碼來源:JungleConnectorGrpcClient.java

示例13: onPlayerJoin

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void onPlayerJoin(PlayerJoinEvent event, StreamObserver<PlayerJoinEvent> observer) {
    try {
        getPluginManager().onPlayerJoin(event, observer);
    } catch (ServiceNotConnectedException ex) {
        log.error("Not connected:", ex);
        observer.onError(ex);
    }
}
 
開發者ID:JungleTree,項目名稱:JungleTree,代碼行數:10,代碼來源:JungleConnectorGrpcClient.java

示例14: getOperation

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void getOperation(
    GetOperationRequest request,
    StreamObserver<Operation> responseObserver) {
  Instance instance;
  try {
    instance = instances.getFromOperationName(request.getName());
  } catch (InstanceNotFoundException ex) {
    responseObserver.onError(BuildFarmInstances.toStatusException(ex));
    return;
  }

  responseObserver.onNext(instance.getOperation(request.getName()));
  responseObserver.onCompleted();
}
 
開發者ID:bazelbuild,項目名稱:bazel-buildfarm,代碼行數:16,代碼來源:OperationsService.java

示例15: listOperations

import io.grpc.stub.StreamObserver; //導入方法依賴的package包/類
@Override
public void listOperations(
    ListOperationsRequest request,
    StreamObserver<ListOperationsResponse> responseObserver) {
  Instance instance;
  try {
    instance = instances.getFromOperationsCollectionName(
        request.getName());
  } catch (InstanceNotFoundException ex) {
    responseObserver.onError(BuildFarmInstances.toStatusException(ex));
    return;
  }

  int pageSize = request.getPageSize();
  if (pageSize < 0) {
    responseObserver.onError(new StatusException(Status.OUT_OF_RANGE));
    return;
  }

  ImmutableList.Builder<Operation> operations =
      new ImmutableList.Builder<Operation>();

  String nextPageToken = instance.listOperations(
      pageSize,
      request.getPageToken(),
      request.getFilter(),
      operations);

  responseObserver.onNext(ListOperationsResponse.newBuilder()
      .addAllOperations(operations.build())
      .setNextPageToken(nextPageToken)
      .build());
  responseObserver.onCompleted();
}
 
開發者ID:bazelbuild,項目名稱:bazel-buildfarm,代碼行數:35,代碼來源:OperationsService.java


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