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


Java StreamObserver類代碼示例

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


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

示例1: downloadProducts

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Override
public void downloadProducts(DownloadProductsRequest request, StreamObserver<Product> responseObserver) {
  PublishSubject<Product> productPublishSubject = PublishSubject.create();
  productPublishSubject
      .doOnNext(product -> {
        responseObserver.onNext(product);
        counter.labels("downloadProducts", "success");
      })
      .doOnComplete(() -> responseObserver.onCompleted())
      .doOnError(t -> {
        responseObserver.onError(t);
        counter.labels("downloadProducts", "failed");
      })
      .subscribe();
  productDao.downloadProducts(request, productPublishSubject);
}
 
開發者ID:email2liyang,項目名稱:grpc-mate,代碼行數:17,代碼來源:ProductReadService.java

示例2: manyToOne

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Test
public void manyToOne() {
    AtomicBoolean called = new AtomicBoolean(false);
    GreeterGrpc.GreeterStub stub = GreeterGrpc.newStub(channel);

    StreamObserver<HelloRequest> requestStream = stub.sayHelloReqStream(new LambdaStreamObserver<>(
            response -> {
                assertThat(response.getMessage()).isEqualTo("Hello A and B and C");
                called.set(true);
            }
    ));

    requestStream.onNext(HelloRequest.newBuilder().setName("A").build());
    requestStream.onNext(HelloRequest.newBuilder().setName("B").build());
    requestStream.onNext(HelloRequest.newBuilder().setName("C").build());
    requestStream.onCompleted();

    await().atMost(1, TimeUnit.SECONDS).untilTrue(called);
}
 
開發者ID:salesforce,項目名稱:reactive-grpc,代碼行數:20,代碼來源:StandardClientReactiveServerInteropTest.java

示例3: manyToOne

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
/**
 * Implements a stream -> unary call as {@link Flux} -> {@link Mono}, where the client transits a stream of
 * messages.
 */
public static <TRequest, TResponse> Mono<TResponse> manyToOne(
        Flux<TRequest> rxRequest,
        Function<StreamObserver<TResponse>, StreamObserver<TRequest>> delegate) {
    try {
        return Mono
                .<TResponse>create(emitter -> {
                    ReactiveProducerStreamObserver<TRequest, TResponse> reactiveProducerStreamObserver = new ReactiveProducerStreamObserver<>(
                            rxRequest,
                            emitter::success,
                            emitter::error,
                            Runnables.doNothing());
                    delegate.apply(
                            new CancellableStreamObserver<>(reactiveProducerStreamObserver,
                            reactiveProducerStreamObserver::cancel));
                    reactiveProducerStreamObserver.rxSubscribe();
                })
                .transform(Operators.lift(new SubscribeOnlyOnceLifter<TResponse>()));
    } catch (Throwable throwable) {
        return Mono.error(throwable);
    }
}
 
開發者ID:salesforce,項目名稱:reactive-grpc,代碼行數:26,代碼來源:ClientCalls.java

示例4: 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

示例5: 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

示例6: testPublishSome

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Test
public void testPublishSome() throws Exception {

    doNothing().when(backend).publish(acFactList.capture());
    Builder b = MSG_Facts.newBuilder();

    Test0Fact f1 = new Test0Fact();
    Test0Fact f2 = new Test0Fact();
    MSG_Fact msg1 = protoConverter.toProto(f1);
    MSG_Fact msg2 = protoConverter.toProto(f2);

    b.addAllFact(Arrays.asList(msg1, msg2));
    MSG_Facts r = b.build();

    uut.publish(r, mock(StreamObserver.class));

    verify(backend).publish(anyList());

    List<Fact> facts = acFactList.getValue();
    assertFalse(facts.isEmpty());
    assertEquals(2, facts.size());
    assertEquals(f1.id(), facts.get(0).id());
    assertEquals(f2.id(), facts.get(1).id());

}
 
開發者ID:uweschaefer,項目名稱:factcast,代碼行數:26,代碼來源:FactStoreGrpcService0Test.java

示例7: sayHelloStreaming

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Override
public void sayHelloStreaming(HelloRequest req, StreamObserver<HelloReply> responseObserver) {
  try {
    logger.info("Saying hi");
    responseObserver.onNext(
        HelloReply.newBuilder().setMessage("Hello " + req.getName()).build());
    Thread.sleep(100);
    logger.info("Saying hi");
    responseObserver.onNext(
        HelloReply.newBuilder().setMessage("Hello " + req.getName() + "!").build());
    Thread.sleep(100);
    logger.info("Saying hi");
    responseObserver.onNext(
        HelloReply.newBuilder().setMessage("Hello " + req.getName() + "!!").build());
  } catch (InterruptedException e) {
    responseObserver.onError(e);
  } finally {
    responseObserver.onCompleted();
  }
}
 
開發者ID:google,項目名稱:rejoiner,代碼行數:21,代碼來源:HelloWorldServer.java

示例8: subscribe

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Override
public Subscription subscribe(@NonNull SubscriptionRequestTO req,
        @NonNull FactObserver observer) {
    SubscriptionImpl<Fact> subscription = SubscriptionImpl.on(observer);

    StreamObserver<FactStoreProto.MSG_Notification> responseObserver = new ClientStreamObserver(
            subscription);

    ClientCall<MSG_SubscriptionRequest, MSG_Notification> call = stub.getChannel().newCall(
            RemoteFactStoreGrpc.METHOD_SUBSCRIBE, stub.getCallOptions()
                    .withWaitForReady()
                    .withCompression("gzip"));

    asyncServerStreamingCall(call, converter.toProto(req), responseObserver);

    return subscription.onClose(() -> {
        cancel(call);
    });
}
 
開發者ID:uweschaefer,項目名稱:factcast,代碼行數:20,代碼來源:GrpcFactStore.java

示例9: 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

示例10: manyToMany

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
/**
 * Implements a bidirectional stream -> stream call as {@link Flowable} -> {@link Flowable}, where both the client
 * and the server independently stream to each other.
 */
public static <TRequest, TResponse> Flowable<TResponse> manyToMany(
        Flowable<TRequest> rxRequest,
        Function<StreamObserver<TResponse>, StreamObserver<TRequest>> delegate) {
    try {
        final RxProducerConsumerStreamObserver<TRequest, TResponse> consumerStreamObserver = new RxProducerConsumerStreamObserver<TRequest, TResponse>(rxRequest);
        delegate.apply(new CancellableStreamObserver<TRequest, TResponse>(consumerStreamObserver, new Runnable() {
            @Override
            public void run() {
                consumerStreamObserver.cancel();
            }
        }));
        consumerStreamObserver.rxSubscribe();
        return ((Flowable<TResponse>) consumerStreamObserver.getRxConsumer())
                .lift(new SubscribeOnlyOnceFlowableOperator<TResponse>());
    } catch (Throwable throwable) {
        return Flowable.error(throwable);
    }
}
 
開發者ID:salesforce,項目名稱:reactive-grpc,代碼行數:23,代碼來源:ClientCalls.java

示例11: put

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

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

示例12: onLinksVanished

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
private void onLinksVanished(LinkVanishedMsg request,
                             StreamObserver<Void> responseObserver) {
    String scheme = request.getProviderId();
    switch (request.getSubjectCase()) {
    case CONNECT_POINT:
        ConnectPoint cp = translate(request.getConnectPoint());
        getLinkProviderServiceFor(scheme).linksVanished(cp);
        break;
    case DEVICE_ID:
        DeviceId did = deviceId(request.getDeviceId());
        getLinkProviderServiceFor(scheme).linksVanished(did);
        break;
    case LINK_DESCRIPTION:
        LinkDescription desc = translate(request.getLinkDescription());
        getLinkProviderServiceFor(scheme).linkVanished(desc);
        break;
    case SUBJECT_NOT_SET:
    default:
        // do nothing
        break;
    }
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:23,代碼來源:LinkProviderServiceServerProxy.java

示例13: onTxEvent

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Override
public void onTxEvent(GrpcTxEvent message, StreamObserver<GrpcAck> responseObserver) {
  boolean ok = txConsistentService.handle(new TxEvent(
      message.getServiceName(),
      message.getInstanceId(),
      new Date(message.getTimestamp()),
      message.getGlobalTxId(),
      message.getLocalTxId(),
      message.getParentTxId().isEmpty() ? null : message.getParentTxId(),
      message.getType(),
      message.getCompensationMethod(),
      message.getPayloads().toByteArray()
  ));

  responseObserver.onNext(ok ? ALLOW : REJECT);
  responseObserver.onCompleted();
}
 
開發者ID:apache,項目名稱:incubator-servicecomb-saga,代碼行數:18,代碼來源:GrpcTxEventEndpointImpl.java

示例14: createUser

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Override
public void createUser(MetaProto.UserParam user,
                       StreamObserver<StatusProto.ResponseStatus> responseStreamObserver)
{
    TransactionController txController = null;
    try {
        txController = ConnectionPool.INSTANCE().getTxController();
        ActionResponse input = new ActionResponse();
        input.setParam(user);
        txController.setAutoCommit(false);
        txController.addAction(new CreateUserAction());
        txController.commit(input);
        responseStreamObserver.onNext(MetaConstants.OKStatus);
        responseStreamObserver.onCompleted();
    }
    catch (ParaFlowException e) {
        responseStreamObserver.onNext(e.getResponseStatus());
        responseStreamObserver.onCompleted();
        e.handle();
    }
    finally {
        if (txController != null) {
            txController.close();
        }
    }
}
 
開發者ID:dbiir,項目名稱:paraflow,代碼行數:27,代碼來源:MetaService.java

示例15: testNullsOnConstructor

import io.grpc.stub.StreamObserver; //導入依賴的package包/類
@Test
public void testNullsOnConstructor() throws Exception {

    String id = "id";
    StreamObserver so = mock(StreamObserver.class);
    Function p = mock(Function.class);

    expectNPE(() -> new GrpcObserverAdapter(null, so, p));
    expectNPE(() -> new GrpcObserverAdapter(null, null, p));
    expectNPE(() -> new GrpcObserverAdapter(null, null, null));

    expectNPE(() -> new GrpcObserverAdapter(id, so, null));
    expectNPE(() -> new GrpcObserverAdapter(id, null, p));
    expectNPE(() -> new GrpcObserverAdapter(id, null, null));

}
 
開發者ID:uweschaefer,項目名稱:factcast,代碼行數:17,代碼來源:GrpcObserverAdapter0Test.java


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