YARN-6310. OutputStreams in AggregatedLogFormat.LogWriter can be left open upon exceptions. Contributed by Haibo Chen

(cherry picked from commit deb9f56946)
This commit is contained in:
Jason Lowe 2017-03-10 11:11:25 -06:00
parent a47d8283b1
commit ef99e5ed89
2 changed files with 29 additions and 26 deletions

View File

@ -70,6 +70,9 @@ Release 2.7.4 - UNRELEASED
YARN-3269. Yarn.nodemanager.remote-app-log-dir could not be configured to YARN-3269. Yarn.nodemanager.remote-app-log-dir could not be configured to
fully qualified path. (Xuan Gong via junping_du) fully qualified path. (Xuan Gong via junping_du)
YARN-6310. OutputStreams in AggregatedLogFormat.LogWriter can be left
open upon exceptions (Haibo Chen via jlowe)
Release 2.7.3 - 2016-08-25 Release 2.7.3 - 2016-08-25
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -407,34 +407,34 @@ public class AggregatedLogFormat {
} }
private void writeVersion() throws IOException { private void writeVersion() throws IOException {
DataOutputStream out = this.writer.prepareAppendKey(-1); try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
VERSION_KEY.write(out); VERSION_KEY.write(out);
out.close(); }
out = this.writer.prepareAppendValue(-1); try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
out.writeInt(VERSION); out.writeInt(VERSION);
out.close(); }
} }
public void writeApplicationOwner(String user) throws IOException { public void writeApplicationOwner(String user) throws IOException {
DataOutputStream out = this.writer.prepareAppendKey(-1); try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
APPLICATION_OWNER_KEY.write(out); APPLICATION_OWNER_KEY.write(out);
out.close(); }
out = this.writer.prepareAppendValue(-1); try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
out.writeUTF(user); out.writeUTF(user);
out.close(); }
} }
public void writeApplicationACLs(Map<ApplicationAccessType, String> appAcls) public void writeApplicationACLs(Map<ApplicationAccessType, String> appAcls)
throws IOException { throws IOException {
DataOutputStream out = this.writer.prepareAppendKey(-1); try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
APPLICATION_ACL_KEY.write(out); APPLICATION_ACL_KEY.write(out);
out.close(); }
out = this.writer.prepareAppendValue(-1); try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
for (Entry<ApplicationAccessType, String> entry : appAcls.entrySet()) { for (Entry<ApplicationAccessType, String> entry : appAcls.entrySet()) {
out.writeUTF(entry.getKey().toString()); out.writeUTF(entry.getKey().toString());
out.writeUTF(entry.getValue()); out.writeUTF(entry.getValue());
}
} }
out.close();
} }
public void append(LogKey logKey, LogValue logValue) throws IOException { public void append(LogKey logKey, LogValue logValue) throws IOException {
@ -443,12 +443,12 @@ public class AggregatedLogFormat {
if (pendingUploadFiles.size() == 0) { if (pendingUploadFiles.size() == 0) {
return; return;
} }
DataOutputStream out = this.writer.prepareAppendKey(-1); try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
logKey.write(out); logKey.write(out);
out.close(); }
out = this.writer.prepareAppendValue(-1); try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
logValue.write(out, pendingUploadFiles); logValue.write(out, pendingUploadFiles);
out.close(); }
} }
public void close() { public void close() {