From f4f2793f3b62d4d5519775e8d1031524027d1f71 Mon Sep 17 00:00:00 2001 From: Ankit Saurabh Date: Wed, 15 Feb 2023 18:28:42 +0000 Subject: [PATCH] HADOOP-18351. Reduce excess logging of errors during S3A prefetching reads (#5274) Contributed by Ankit Saurabh --- .../fs/impl/prefetch/CachingBlockManager.java | 20 +++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/impl/prefetch/CachingBlockManager.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/impl/prefetch/CachingBlockManager.java index 31084c7bf2..a0db4b308b 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/impl/prefetch/CachingBlockManager.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/impl/prefetch/CachingBlockManager.java @@ -302,7 +302,12 @@ public void cancelPrefetches() { private void read(BufferData data) throws IOException { synchronized (data) { - readBlock(data, false, BufferData.State.BLANK); + try { + readBlock(data, false, BufferData.State.BLANK); + } catch (IOException e) { + LOG.error("error reading block {}", data.getBlockNumber(), e); + throw e; + } } } @@ -362,9 +367,6 @@ private void readBlock(BufferData data, boolean isPrefetch, BufferData.State... buffer.flip(); data.setReady(expectedState); } catch (Exception e) { - String message = String.format("error during readBlock(%s)", data.getBlockNumber()); - LOG.error(message, e); - if (isPrefetch && tracker != null) { tracker.failed(); } @@ -406,7 +408,8 @@ public Void get() { try { blockManager.prefetch(data, taskQueuedStartTime); } catch (Exception e) { - LOG.error("error during prefetch", e); + LOG.info("error prefetching block {}. {}", data.getBlockNumber(), e.getMessage()); + LOG.debug("error prefetching block {}", data.getBlockNumber(), e); } return null; } @@ -493,7 +496,8 @@ private void addToCacheAndRelease(BufferData data, Future blockFuture, return; } } catch (Exception e) { - LOG.error("error waiting on blockFuture: {}", data, e); + LOG.info("error waiting on blockFuture: {}. {}", data, e.getMessage()); + LOG.debug("error waiting on blockFuture: {}", data, e); data.setDone(); return; } @@ -523,8 +527,8 @@ private void addToCacheAndRelease(BufferData data, Future blockFuture, data.setDone(); } catch (Exception e) { numCachingErrors.incrementAndGet(); - String message = String.format("error adding block to cache after wait: %s", data); - LOG.error(message, e); + LOG.info("error adding block to cache after wait: {}. {}", data, e.getMessage()); + LOG.debug("error adding block to cache after wait: {}", data, e); data.setDone(); }