mirror of
https://github.com/postgres/postgres.git
synced 2025-07-05 07:21:24 +03:00
Fix a gradual memory leak in ExecReScanAgg(). Because the aggregation
hash table is allocated in a child context of the agg node's memory context, MemoryContextReset() will reset but *not* delete the child context. Since ExecReScanAgg() proceeds to build a new hash table from scratch (in a new sub-context), this results in leaking the header for the previous memory context. Therefore, use MemoryContextResetAndDeleteChildren() instead. Credit: My colleague Sailesh Krishnamurthy at Truviso for isolating the cause of the leak.
This commit is contained in:
@ -61,7 +61,7 @@
|
|||||||
* Portions Copyright (c) 1994, Regents of the University of California
|
* Portions Copyright (c) 1994, Regents of the University of California
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/backend/executor/nodeAgg.c,v 1.146.2.1 2007/02/02 00:07:28 tgl Exp $
|
* $PostgreSQL: pgsql/src/backend/executor/nodeAgg.c,v 1.146.2.2 2007/08/08 18:07:03 neilc Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1641,8 +1641,14 @@ ExecReScanAgg(AggState *node, ExprContext *exprCtxt)
|
|||||||
MemSet(econtext->ecxt_aggvalues, 0, sizeof(Datum) * node->numaggs);
|
MemSet(econtext->ecxt_aggvalues, 0, sizeof(Datum) * node->numaggs);
|
||||||
MemSet(econtext->ecxt_aggnulls, 0, sizeof(bool) * node->numaggs);
|
MemSet(econtext->ecxt_aggnulls, 0, sizeof(bool) * node->numaggs);
|
||||||
|
|
||||||
/* Release all temp storage */
|
/*
|
||||||
MemoryContextReset(node->aggcontext);
|
* Release all temp storage. Note that with AGG_HASHED, the hash table
|
||||||
|
* is allocated in a sub-context of the aggcontext. We're going to
|
||||||
|
* rebuild the hash table from scratch, so we need to use
|
||||||
|
* MemoryContextResetAndDeleteChildren() to avoid leaking the old hash
|
||||||
|
* table's memory context header.
|
||||||
|
*/
|
||||||
|
MemoryContextResetAndDeleteChildren(node->aggcontext);
|
||||||
|
|
||||||
if (((Agg *) node->ss.ps.plan)->aggstrategy == AGG_HASHED)
|
if (((Agg *) node->ss.ps.plan)->aggstrategy == AGG_HASHED)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user