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:
parent
a47d8283b1
commit
ef99e5ed89
|
@ -70,6 +70,9 @@ Release 2.7.4 - UNRELEASED
|
|||
YARN-3269. Yarn.nodemanager.remote-app-log-dir could not be configured to
|
||||
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
|
||||
|
||||
INCOMPATIBLE CHANGES
|
||||
|
|
|
@ -407,34 +407,34 @@ public class AggregatedLogFormat {
|
|||
}
|
||||
|
||||
private void writeVersion() throws IOException {
|
||||
DataOutputStream out = this.writer.prepareAppendKey(-1);
|
||||
VERSION_KEY.write(out);
|
||||
out.close();
|
||||
out = this.writer.prepareAppendValue(-1);
|
||||
out.writeInt(VERSION);
|
||||
out.close();
|
||||
try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
|
||||
VERSION_KEY.write(out);
|
||||
}
|
||||
try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
|
||||
out.writeInt(VERSION);
|
||||
}
|
||||
}
|
||||
|
||||
public void writeApplicationOwner(String user) throws IOException {
|
||||
DataOutputStream out = this.writer.prepareAppendKey(-1);
|
||||
APPLICATION_OWNER_KEY.write(out);
|
||||
out.close();
|
||||
out = this.writer.prepareAppendValue(-1);
|
||||
out.writeUTF(user);
|
||||
out.close();
|
||||
try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
|
||||
APPLICATION_OWNER_KEY.write(out);
|
||||
}
|
||||
try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
|
||||
out.writeUTF(user);
|
||||
}
|
||||
}
|
||||
|
||||
public void writeApplicationACLs(Map<ApplicationAccessType, String> appAcls)
|
||||
throws IOException {
|
||||
DataOutputStream out = this.writer.prepareAppendKey(-1);
|
||||
APPLICATION_ACL_KEY.write(out);
|
||||
out.close();
|
||||
out = this.writer.prepareAppendValue(-1);
|
||||
for (Entry<ApplicationAccessType, String> entry : appAcls.entrySet()) {
|
||||
out.writeUTF(entry.getKey().toString());
|
||||
out.writeUTF(entry.getValue());
|
||||
try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
|
||||
APPLICATION_ACL_KEY.write(out);
|
||||
}
|
||||
try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
|
||||
for (Entry<ApplicationAccessType, String> entry : appAcls.entrySet()) {
|
||||
out.writeUTF(entry.getKey().toString());
|
||||
out.writeUTF(entry.getValue());
|
||||
}
|
||||
}
|
||||
out.close();
|
||||
}
|
||||
|
||||
public void append(LogKey logKey, LogValue logValue) throws IOException {
|
||||
|
@ -443,12 +443,12 @@ public class AggregatedLogFormat {
|
|||
if (pendingUploadFiles.size() == 0) {
|
||||
return;
|
||||
}
|
||||
DataOutputStream out = this.writer.prepareAppendKey(-1);
|
||||
logKey.write(out);
|
||||
out.close();
|
||||
out = this.writer.prepareAppendValue(-1);
|
||||
logValue.write(out, pendingUploadFiles);
|
||||
out.close();
|
||||
try (DataOutputStream out = this.writer.prepareAppendKey(-1)) {
|
||||
logKey.write(out);
|
||||
}
|
||||
try (DataOutputStream out = this.writer.prepareAppendValue(-1)) {
|
||||
logValue.write(out, pendingUploadFiles);
|
||||
}
|
||||
}
|
||||
|
||||
public void close() {
|
||||
|
|
Loading…
Reference in New Issue