From 1ef48f1d4b81d25952f9babf93f63bdff52f9a51 Mon Sep 17 00:00:00 2001 From: Junping Du Date: Wed, 6 Sep 2017 14:53:31 -0700 Subject: [PATCH] YARN-7144. Log Aggregation controller should not swallow the exceptions when it calls closeWriter and closeReader. Contributed by Xuan Gong. (cherry picked from commit 22de9449f8aa72c5b0bb586b8253390773502189) --- .../logaggregation/AggregatedLogFormat.java | 27 +++++++++---------- .../LogAggregationFileController.java | 10 +++---- 2 files changed, 17 insertions(+), 20 deletions(-) diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/AggregatedLogFormat.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/AggregatedLogFormat.java index 73b83b88039..6766f8064bc 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/AggregatedLogFormat.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/AggregatedLogFormat.java @@ -44,11 +44,8 @@ import java.util.Map; import java.util.Map.Entry; import java.util.Set; import java.util.regex.Pattern; -import org.apache.commons.io.IOUtils; import org.apache.commons.io.input.BoundedInputStream; import org.apache.commons.io.output.WriterOutputStream; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; import org.apache.commons.math3.util.Pair; import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceAudience.Public; @@ -61,6 +58,7 @@ import org.apache.hadoop.fs.FileContext; import org.apache.hadoop.fs.Options; import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.permission.FsPermission; +import org.apache.hadoop.io.IOUtils; import org.apache.hadoop.io.SecureIOUtils; import org.apache.hadoop.io.Writable; import org.apache.hadoop.io.file.tfile.TFile; @@ -71,7 +69,8 @@ import org.apache.hadoop.yarn.api.records.LogAggregationContext; import org.apache.hadoop.yarn.conf.YarnConfiguration; import org.apache.hadoop.yarn.exceptions.YarnRuntimeException; import org.apache.hadoop.yarn.util.Times; - +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import com.google.common.annotations.VisibleForTesting; import com.google.common.base.Predicate; import com.google.common.collect.Iterables; @@ -81,7 +80,8 @@ import com.google.common.collect.Sets; @Evolving public class AggregatedLogFormat { - private static final Log LOG = LogFactory.getLog(AggregatedLogFormat.class); + private final static Logger LOG = LoggerFactory.getLogger( + AggregatedLogFormat.class); private static final LogKey APPLICATION_ACL_KEY = new LogKey("APPLICATION_ACL"); private static final LogKey APPLICATION_OWNER_KEY = new LogKey("APPLICATION_OWNER"); private static final LogKey VERSION_KEY = new LogKey("VERSION"); @@ -245,7 +245,7 @@ public class AggregatedLogFormat { in = secureOpenFile(logFile); } catch (IOException e) { logErrorMessage(logFile, e); - IOUtils.closeQuietly(in); + IOUtils.cleanupWithLogger(LOG, in); continue; } @@ -283,7 +283,7 @@ public class AggregatedLogFormat { String message = logErrorMessage(logFile, e); out.write(message.getBytes(Charset.forName("UTF-8"))); } finally { - IOUtils.closeQuietly(in); + IOUtils.cleanupWithLogger(LOG, in); } } } @@ -554,7 +554,7 @@ public class AggregatedLogFormat { } catch (Exception e) { LOG.warn("Exception closing writer", e); } finally { - IOUtils.closeQuietly(this.fsDataOStream); + IOUtils.cleanupWithLogger(LOG, this.fsDataOStream); } } } @@ -602,7 +602,7 @@ public class AggregatedLogFormat { } return null; } finally { - IOUtils.closeQuietly(ownerScanner); + IOUtils.cleanupWithLogger(LOG, ownerScanner); } } @@ -648,7 +648,7 @@ public class AggregatedLogFormat { } return acls; } finally { - IOUtils.closeQuietly(aclScanner); + IOUtils.cleanupWithLogger(LOG, aclScanner); } } @@ -773,8 +773,7 @@ public class AggregatedLogFormat { } } } finally { - IOUtils.closeQuietly(ps); - IOUtils.closeQuietly(os); + IOUtils.cleanupWithLogger(LOG, ps, os); } } @@ -1000,9 +999,7 @@ public class AggregatedLogFormat { } public void close() { - IOUtils.closeQuietly(scanner); - IOUtils.closeQuietly(reader); - IOUtils.closeQuietly(fsDataIStream); + IOUtils.cleanupWithLogger(LOG, scanner, reader, fsDataIStream); } } diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/filecontroller/LogAggregationFileController.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/filecontroller/LogAggregationFileController.java index aafdb664b39..39f3dc339f5 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/filecontroller/LogAggregationFileController.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-common/src/main/java/org/apache/hadoop/yarn/logaggregation/filecontroller/LogAggregationFileController.java @@ -37,9 +37,6 @@ import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; -import org.apache.commons.io.IOUtils; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceStability.Unstable; import org.apache.hadoop.conf.Configuration; @@ -47,6 +44,7 @@ import org.apache.hadoop.fs.FileStatus; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; import org.apache.hadoop.fs.permission.FsPermission; +import org.apache.hadoop.io.IOUtils; import org.apache.hadoop.security.UserGroupInformation; import org.apache.hadoop.yarn.api.records.ApplicationAccessType; import org.apache.hadoop.yarn.api.records.ApplicationId; @@ -56,6 +54,8 @@ import org.apache.hadoop.yarn.exceptions.YarnRuntimeException; import org.apache.hadoop.yarn.logaggregation.LogAggregationUtils; import org.apache.hadoop.yarn.webapp.View.ViewContext; import org.apache.hadoop.yarn.webapp.view.HtmlBlock.Block; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.apache.hadoop.yarn.logaggregation.AggregatedLogFormat.LogKey; import org.apache.hadoop.yarn.logaggregation.AggregatedLogFormat.LogValue; import org.apache.hadoop.yarn.logaggregation.ContainerLogMeta; @@ -68,7 +68,7 @@ import org.apache.hadoop.yarn.logaggregation.ContainerLogsRequest; @Unstable public abstract class LogAggregationFileController { - private static final Log LOG = LogFactory.getLog( + private static final Logger LOG = LoggerFactory.getLogger( LogAggregationFileController.class); /* @@ -193,7 +193,7 @@ public abstract class LogAggregationFileController { protected void closePrintStream(OutputStream out) { if (out != System.out) { - IOUtils.closeQuietly(out); + IOUtils.cleanupWithLogger(LOG, out); } }