HDFS-15779. EC: fix NPE caused by StripedWriter.clearBuffers during reconstruct block. Contributed by Hongbing Wang
(cherry picked from commit 15a1f7adfc
)
This commit is contained in:
parent
96773ec81b
commit
164a4e63e0
|
@ -296,7 +296,8 @@ class StripedWriter {
|
||||||
*/
|
*/
|
||||||
void clearBuffers() {
|
void clearBuffers() {
|
||||||
for (StripedBlockWriter writer : writers) {
|
for (StripedBlockWriter writer : writers) {
|
||||||
ByteBuffer targetBuffer = writer.getTargetBuffer();
|
ByteBuffer targetBuffer =
|
||||||
|
writer != null ? writer.getTargetBuffer() : null;
|
||||||
if (targetBuffer != null) {
|
if (targetBuffer != null) {
|
||||||
targetBuffer.clear();
|
targetBuffer.clear();
|
||||||
}
|
}
|
||||||
|
@ -305,7 +306,8 @@ class StripedWriter {
|
||||||
|
|
||||||
void close() {
|
void close() {
|
||||||
for (StripedBlockWriter writer : writers) {
|
for (StripedBlockWriter writer : writers) {
|
||||||
ByteBuffer targetBuffer = writer.getTargetBuffer();
|
ByteBuffer targetBuffer =
|
||||||
|
writer != null ? writer.getTargetBuffer() : null;
|
||||||
if (targetBuffer != null) {
|
if (targetBuffer != null) {
|
||||||
reconstructor.freeBuffer(targetBuffer);
|
reconstructor.freeBuffer(targetBuffer);
|
||||||
writer.freeTargetBuffer();
|
writer.freeTargetBuffer();
|
||||||
|
@ -313,7 +315,9 @@ class StripedWriter {
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < targets.length; i++) {
|
for (int i = 0; i < targets.length; i++) {
|
||||||
writers[i].close();
|
if (writers[i] != null) {
|
||||||
|
writers[i].close();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue