All Downloads are FREE. Search and download functionalities are using the official Maven repository.

alluxio.client.block.stream.GrpcDataMessageBlockingStream Maven / Gradle / Ivy

There is a newer version: 313
Show newest version
/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in compliance with the License, which is
 * available at www.apache.org/licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied, as more fully set forth in the License.
 *
 * See the NOTICE file distributed with this work for information regarding copyright ownership.
 */

package alluxio.client.block.stream;

import alluxio.exception.status.DeadlineExceededException;
import alluxio.grpc.DataMessage;
import alluxio.grpc.DataMessageMarshaller;
import alluxio.network.protocol.databuffer.DataBuffer;

import com.google.common.base.Preconditions;
import io.grpc.stub.StreamObserver;

import java.io.IOException;
import java.util.function.Function;

import javax.annotation.concurrent.NotThreadSafe;

/**
 * A helper class for accessing gRPC bi-directional stream synchronously.
 *
 * @param  type of the request
 * @param  type of the response
 */
@NotThreadSafe
public class GrpcDataMessageBlockingStream extends GrpcBlockingStream {
  private final DataMessageMarshaller mRequestMarshaller;
  private final DataMessageMarshaller mResponseMarshaller;

  /**
   * @param rpcFunc the gRPC bi-directional stream stub function
   * @param bufferSize maximum number of incoming messages the buffer can hold
   * @param description description of this stream
   * @param requestMarshaller the marshaller for the request
   * @param responseMarshaller the marshaller for the response
   */
  public GrpcDataMessageBlockingStream(Function, StreamObserver> rpcFunc,
      int bufferSize, String description, DataMessageMarshaller requestMarshaller,
      DataMessageMarshaller responseMarshaller) {
    super((resObserver) -> {
      DataMessageClientResponseObserver newObserver =
          new DataMessageClientResponseObserver<>(resObserver, requestMarshaller,
              responseMarshaller);
      StreamObserver requestObserver = rpcFunc.apply(newObserver);
      return requestObserver;
    }, bufferSize, description);
    mRequestMarshaller = requestMarshaller;
    mResponseMarshaller = responseMarshaller;
  }

  @Override
  public ResT receive(long timeoutMs) throws IOException {
    if (mResponseMarshaller == null) {
      return super.receive(timeoutMs);
    }
    DataMessage message = receiveDataMessage(timeoutMs);
    if (message == null) {
      return null;
    }
    return mResponseMarshaller.combineData(message);
  }

  /**
   * Receives a response with data buffer from the server. Will wait until a response is received,
   * or throw an exception if times out. Caller of this method must release the buffer after reading
   * the data.
   *
   * @param timeoutMs maximum time to wait before giving up and throwing
   *                  a {@link DeadlineExceededException}
   * @return the response message with data buffer, or null if the inbound stream is completed
   * @throws IOException if any error occurs
   */
  public DataMessage receiveDataMessage(long timeoutMs) throws IOException {
    Preconditions.checkNotNull(mResponseMarshaller,
        "Cannot retrieve data message without a response marshaller.");
    ResT response = super.receive(timeoutMs);
    if (response == null) {
      return null;
    }
    DataBuffer buffer = mResponseMarshaller.pollBuffer(response);
    return new DataMessage<>(response, buffer);
  }

  /**
   * Sends a request. Will wait until the stream is ready before sending or timeout if the
   * given timeout is reached.
   *
   * @param message the request message with {@link DataBuffer attached}
   * @param timeoutMs maximum wait time before throwing a {@link DeadlineExceededException}
   * @throws IOException if any error occurs
   */
  public void sendDataMessage(DataMessage message, long timeoutMs)
      throws IOException {
    if (mRequestMarshaller != null) {
      mRequestMarshaller.offerBuffer(message.getBuffer(), message.getMessage());
    }
    super.send(message.getMessage(), timeoutMs);
  }

  @Override
  public void waitForComplete(long timeoutMs) throws IOException {
    if (mResponseMarshaller == null) {
      super.waitForComplete(timeoutMs);
      return;
    }
    DataMessage message;
    while (!isCanceled() && (message = receiveDataMessage(timeoutMs)) != null) {
      if (message.getBuffer() != null) {
        message.getBuffer().release();
      }
    }
    super.waitForComplete(timeoutMs);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy