Skip to content

Commit

Permalink
DRILL-8485: HashJoinPOP memory leak is caused by an oom exception whe…
Browse files Browse the repository at this point in the history
…n read data from InputStream
  • Loading branch information
shfshihuafeng committed Mar 24, 2024
1 parent 26f4d30 commit b504a63
Showing 1 changed file with 15 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,10 @@
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Arrays;
import java.util.List;

import org.apache.drill.common.exceptions.UserException;
import org.apache.drill.exec.expr.TypeHelper;
import org.apache.drill.exec.memory.BufferAllocator;
import org.apache.drill.exec.metrics.DrillMetrics;
Expand Down Expand Up @@ -124,11 +126,19 @@ private void readVectors(InputStream input, RecordBatchDef batchDef) throws IOEx
for (SerializedField metaData : fieldList) {
final int dataLength = metaData.getBufferLength();
final MaterializedField field = MaterializedField.create(metaData);
final DrillBuf buf = allocator.read(dataLength, input);
final ValueVector vector = TypeHelper.getNewVector(field, allocator);
vector.load(metaData, buf);
buf.release(); // Vector now owns the buffer
vectorList.add(vector);
DrillBuf buf = null;
try {
buf = allocator.read(dataLength, input);
final ValueVector vector = TypeHelper.getNewVector(field, allocator);
vector.load(metaData, buf);
buf.release(); // Vector now owns the buffer
vectorList.add(vector);
} catch (OutOfMemoryError oom) {
for (ValueVector valueVector : vectorList) {
valueVector.clear();
}
throw UserException.memoryError(oom).message("Allocator memory failed").build(logger);
}
}
container.addCollection(vectorList);
container.buildSchema(svMode);
Expand Down

0 comments on commit b504a63

Please sign in to comment.