mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Fix excessive memory consumption in the new sort pre-reading code.
LogicalTapeRewind() should not allocate large read buffer, if the tape is completely empty. The calling code relies on that, for its calculation of how much memory to allocate for the read buffers. That lead to massive overallocation of memory, if maxTapes was high, but only a few tapes were actually used. Reported by Tomas Vondra Discussion: <7303da46-daf7-9c68-3cc1-9f83235cf37e@2ndquadrant.com>
This commit is contained in:
@@ -778,11 +778,16 @@ LogicalTapeRewind(LogicalTapeSet *lts, int tapenum, bool forWrite)
|
|||||||
datablocknum = ltsRewindFrozenIndirectBlock(lts, lt->indirect);
|
datablocknum = ltsRewindFrozenIndirectBlock(lts, lt->indirect);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Allocate a read buffer */
|
/* Allocate a read buffer (unless the tape is empty) */
|
||||||
if (lt->buffer)
|
if (lt->buffer)
|
||||||
pfree(lt->buffer);
|
pfree(lt->buffer);
|
||||||
lt->buffer = palloc(lt->read_buffer_size);
|
lt->buffer = NULL;
|
||||||
lt->buffer_size = lt->read_buffer_size;
|
lt->buffer_size = 0;
|
||||||
|
if (datablocknum != -1L)
|
||||||
|
{
|
||||||
|
lt->buffer = palloc(lt->read_buffer_size);
|
||||||
|
lt->buffer_size = lt->read_buffer_size;
|
||||||
|
}
|
||||||
|
|
||||||
/* Read the first block, or reset if tape is empty */
|
/* Read the first block, or reset if tape is empty */
|
||||||
lt->curBlockNumber = 0L;
|
lt->curBlockNumber = 0L;
|
||||||
|
Reference in New Issue
Block a user