alluxio.master.block.BlockMasterClientServiceHandler Maven / Gradle / Ivy
/*
* 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.master.block;
import alluxio.RpcUtils;
import alluxio.client.block.options.GetWorkerReportOptions;
import alluxio.grpc.BlockMasterClientServiceGrpc;
import alluxio.grpc.BlockMasterInfo;
import alluxio.grpc.BlockMasterInfoField;
import alluxio.grpc.GetBlockInfoPOptions;
import alluxio.grpc.GetBlockInfoPRequest;
import alluxio.grpc.GetBlockInfoPResponse;
import alluxio.grpc.GetBlockMasterInfoPOptions;
import alluxio.grpc.GetBlockMasterInfoPResponse;
import alluxio.grpc.GetCapacityBytesPOptions;
import alluxio.grpc.GetCapacityBytesPResponse;
import alluxio.grpc.GetUsedBytesPOptions;
import alluxio.grpc.GetUsedBytesPResponse;
import alluxio.grpc.GetWorkerInfoListPOptions;
import alluxio.grpc.GetWorkerInfoListPResponse;
import alluxio.grpc.GetWorkerLostStoragePOptions;
import alluxio.grpc.GetWorkerLostStoragePResponse;
import alluxio.grpc.GetWorkerReportPOptions;
import alluxio.grpc.GrpcUtils;
import com.google.common.base.Preconditions;
import io.grpc.stub.StreamObserver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Arrays;
import java.util.stream.Collectors;
/**
* This class is a gRPC handler for block master RPCs invoked by an Alluxio client.
*/
public final class BlockMasterClientServiceHandler
extends BlockMasterClientServiceGrpc.BlockMasterClientServiceImplBase {
private static final Logger LOG = LoggerFactory.getLogger(BlockMasterClientServiceHandler.class);
private final BlockMaster mBlockMaster;
/**
* Creates a new instance of {@link BlockMasterClientServiceHandler}.
*
* @param blockMaster the {@link BlockMaster} the handler uses internally
*/
public BlockMasterClientServiceHandler(BlockMaster blockMaster) {
Preconditions.checkNotNull(blockMaster, "blockMaster");
mBlockMaster = blockMaster;
}
@Override
public void getBlockInfo(GetBlockInfoPRequest request,
StreamObserver responseObserver) {
long blockId = request.getBlockId();
GetBlockInfoPOptions options = request.getOptions();
RpcUtils.call(LOG, (RpcUtils.RpcCallableThrowsIOException) () -> {
return GetBlockInfoPResponse.newBuilder()
.setBlockInfo(GrpcUtils.toProto(mBlockMaster.getBlockInfo(blockId))).build();
}, "CreateFile", "blockId=%s, options=%s", responseObserver, blockId, options);
}
@Override
public void getBlockMasterInfo(GetBlockMasterInfoPOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG,
(RpcUtils.RpcCallableThrowsIOException) () -> {
BlockMasterInfo.Builder infoBuilder = BlockMasterInfo.newBuilder();
for (BlockMasterInfoField field : (options.getFiltersCount() != 0)
? options.getFiltersList()
: Arrays.asList(BlockMasterInfoField.values())) {
switch (field) {
case CAPACITY_BYTES:
infoBuilder.setCapacityBytes(mBlockMaster.getCapacityBytes());
break;
case CAPACITY_BYTES_ON_TIERS:
infoBuilder.putAllCapacityBytesOnTiers(mBlockMaster.getTotalBytesOnTiers());
break;
case FREE_BYTES:
infoBuilder
.setFreeBytes(mBlockMaster.getCapacityBytes() - mBlockMaster.getUsedBytes());
break;
case LIVE_WORKER_NUM:
infoBuilder.setLiveWorkerNum(mBlockMaster.getWorkerCount());
break;
case LOST_WORKER_NUM:
infoBuilder.setLostWorkerNum(mBlockMaster.getLostWorkerCount());
break;
case USED_BYTES:
infoBuilder.setUsedBytes(mBlockMaster.getUsedBytes());
break;
case USED_BYTES_ON_TIERS:
infoBuilder.putAllUsedBytesOnTiers(mBlockMaster.getUsedBytesOnTiers());
break;
default:
LOG.warn("Unrecognized block master info field: " + field);
}
}
return GetBlockMasterInfoPResponse.newBuilder().setBlockMasterInfo(infoBuilder).build();
}, "getBlockMasterInfo", "Options=%s", responseObserver, options);
}
@Override
public void getCapacityBytes(GetCapacityBytesPOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG,
(RpcUtils.RpcCallableThrowsIOException) () -> {
return GetCapacityBytesPResponse.newBuilder().setBytes(mBlockMaster.getCapacityBytes())
.build();
}, "getCapacityBytes", "options=%s", responseObserver, options);
}
@Override
public void getUsedBytes(GetUsedBytesPOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG, (RpcUtils.RpcCallableThrowsIOException) () -> {
return GetUsedBytesPResponse.newBuilder().setBytes(mBlockMaster.getUsedBytes()).build();
}, "getUsedBytes", "options=%s", responseObserver, options);
}
@Override
public void getWorkerInfoList(GetWorkerInfoListPOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG,
(RpcUtils.RpcCallableThrowsIOException) () -> {
return GetWorkerInfoListPResponse.newBuilder().addAllWorkerInfos(mBlockMaster
.getWorkerInfoList().stream().map(GrpcUtils::toProto).collect(Collectors.toList()))
.build();
}, "getWorkerInfoList", "options=%s", responseObserver, options);
}
@Override
public void getWorkerReport(GetWorkerReportPOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG,
(RpcUtils.RpcCallableThrowsIOException) () -> {
return GetWorkerInfoListPResponse.newBuilder()
.addAllWorkerInfos(
mBlockMaster.getWorkerReport(new GetWorkerReportOptions(options)).stream()
.map(GrpcUtils::toProto).collect(Collectors.toList()))
.build();
}, "getWorkerInfoList", "options=%s", responseObserver, options);
}
@Override
public void getWorkerLostStorage(GetWorkerLostStoragePOptions options,
StreamObserver responseObserver) {
RpcUtils.call(LOG,
(RpcUtils.RpcCallableThrowsIOException) () ->
GetWorkerLostStoragePResponse.newBuilder()
.addAllWorkerLostStorageInfo(mBlockMaster.getWorkerLostStorage()).build(),
"getWorkerLostStorage", "options=%s", responseObserver, options);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy