From 0ab3bc1b9a8dc23a11530119be87565b3ccd82bb Mon Sep 17 00:00:00 2001 From: Hongbing Wang <284734261@qq.com> Date: Thu, 1 Feb 2024 15:34:47 +0800 Subject: [PATCH] CDPD-66048. HDDS-10246. Remove KeyValueHandler.checkContainerIsHealthy to improve read performance (#6127) (cherry picked from commit 528fc9220bec909a1d0867039f3e6382020bf0b0) Change-Id: Ie4438d8e95a1148e7050f16201b4c890ddbee400 --- .../container/keyvalue/KeyValueHandler.java | 24 ------------------- 1 file changed, 24 deletions(-) diff --git a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/keyvalue/KeyValueHandler.java b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/keyvalue/KeyValueHandler.java index c4f7247238a..a585e903213 100644 --- a/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/keyvalue/KeyValueHandler.java +++ b/hadoop-hdds/container-service/src/main/java/org/apache/hadoop/ozone/container/keyvalue/KeyValueHandler.java @@ -583,7 +583,6 @@ ContainerCommandResponseProto handleGetBlock( try { BlockID blockID = BlockID.getFromProtobuf( request.getGetBlock().getBlockID()); - checkContainerIsHealthy(kvContainer, blockID, Type.GetBlock); responseData = blockManager.getBlock(kvContainer, blockID) .getProtoBufMessage(); final long numBytes = responseData.getSerializedSize(); @@ -618,8 +617,6 @@ ContainerCommandResponseProto handleGetCommittedBlockLength( try { BlockID blockID = BlockID .getFromProtobuf(request.getGetCommittedBlockLength().getBlockID()); - checkContainerIsHealthy(kvContainer, blockID, - Type.GetCommittedBlockLength); BlockUtils.verifyBCSId(kvContainer, blockID); blockLength = blockManager.getCommittedBlockLength(kvContainer, blockID); } catch (StorageContainerException ex) { @@ -706,7 +703,6 @@ ContainerCommandResponseProto handleReadChunk( .getChunkData()); Preconditions.checkNotNull(chunkInfo); - checkContainerIsHealthy(kvContainer, blockID, Type.ReadChunk); BlockUtils.verifyBCSId(kvContainer, blockID); if (dispatcherContext == null) { dispatcherContext = DispatcherContext.getHandleReadChunk(); @@ -744,25 +740,6 @@ ContainerCommandResponseProto handleReadChunk( return getReadChunkResponse(request, data, byteBufferToByteString); } - /** - * Throw an exception if the container is unhealthy. - * - * @throws StorageContainerException if the container is unhealthy. - */ - @VisibleForTesting - void checkContainerIsHealthy(KeyValueContainer kvContainer, BlockID blockID, - Type cmd) { - kvContainer.readLock(); - try { - if (kvContainer.getContainerData().getState() == State.UNHEALTHY) { - LOG.warn("{} request {} for UNHEALTHY container {} replica", cmd, - blockID, kvContainer.getContainerData().getContainerID()); - } - } finally { - kvContainer.readUnlock(); - } - } - /** * Handle Delete Chunk operation. Calls ChunkManager to process the request. */ @@ -927,7 +904,6 @@ ContainerCommandResponseProto handleGetSmallFile( try { BlockID blockID = BlockID.getFromProtobuf(getSmallFileReq.getBlock() .getBlockID()); - checkContainerIsHealthy(kvContainer, blockID, Type.GetSmallFile); BlockData responseData = blockManager.getBlock(kvContainer, blockID); ContainerProtos.ChunkInfo chunkInfoProto = null;