From 3c70be7329fca2fe6760d45ae29a2a4afa30c262 Mon Sep 17 00:00:00 2001 From: Yang Yu Date: Wed, 8 May 2024 15:40:31 +0800 Subject: [PATCH] fix: Fix retry strategy for read IOException. Signed-off-by: Yang Yu --- .../org/apache/hadoop/fs/CosNFileReadTask.java | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/src/main/java/org/apache/hadoop/fs/CosNFileReadTask.java b/src/main/java/org/apache/hadoop/fs/CosNFileReadTask.java index 3dd5fbd..0d4462d 100644 --- a/src/main/java/org/apache/hadoop/fs/CosNFileReadTask.java +++ b/src/main/java/org/apache/hadoop/fs/CosNFileReadTask.java @@ -7,6 +7,7 @@ import java.io.IOException; import java.io.InputStream; +import java.net.SocketException; import java.util.concurrent.ThreadLocalRandom; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicBoolean; @@ -76,14 +77,14 @@ public void run() { try { this.retrieveBlock(); needRetry = false; - } catch (IOException ioException) { + } catch (SocketException socketException) { // if we get stream success, but exceptions occurs when read cos input stream String errMsg = String.format("retrieve block sdk socket failed, " + "retryIndex: [%d / %d], key: %s, range: [%d , %d], exception: %s", retryIndex, this.socketErrMaxRetryTimes, this.key, - this.readBuffer.getStart(), this.readBuffer.getEnd(), ioException.toString()); + this.readBuffer.getStart(), this.readBuffer.getEnd(), socketException.toString()); if (retryIndex <= this.socketErrMaxRetryTimes) { - LOG.info(errMsg, ioException); + LOG.info(errMsg, socketException); long sleepLeast = retryIndex * 300L; long sleepBound = retryIndex * 500L; try { @@ -96,11 +97,19 @@ public void run() { break; } } else { - this.setFailResult(errMsg, ioException); + this.setFailResult(errMsg, socketException); break; } + } catch (IOException ioException) { + String errMsg = String.format("retrieve block failed, " + + "retryIndex: [%d / %d], key: %s, range: [%d , %d], io exception: %s", + retryIndex, this.socketErrMaxRetryTimes, this.key, + this.readBuffer.getStart(), this.readBuffer.getEnd(), ioException); + this.setFailResult(errMsg, ioException); + break; } catch (Throwable throwable) { this.setFailResult("retrieve block failed", new IOException(throwable)); + break; } if (!needRetry) {