Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Prevent long-term memory leakage in autovacuum launcher.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 31 Aug 2022 20:23:20 +0000 (16:23 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 31 Aug 2022 20:23:20 +0000 (16:23 -0400)
get_database_list() failed to restore the caller's memory context,
instead leaving current context set to TopMemoryContext which is
how CommitTransactionCommand() leaves it.  The callers both think
they are using short-lived contexts, for the express purpose of
not having to worry about cleaning up individual allocations.
The net effect therefore is that supposedly short-lived allocations
could accumulate indefinitely in the launcher's TopMemoryContext.

Although this has been broken for a long time, it seems we didn't
have any obvious memory leak here until v15's rearrangement of the
stats logic.  I (tgl) am not entirely convinced that there's no
other leak at all, though, and we're surely at risk of adding one
in future back-patched fixes.  So back-patch to all supported
branches, even though this may be only a latent bug in pre-v15.

Reid Thompson

Discussion: https://postgr.es/m/972a4e12b68b0f96db514777a150ceef7dcd2e0f.camel@crunchydata.com

src/backend/postmaster/autovacuum.c

index ac0242c9d37c8ef9a90be85382896c1f02938f7c..cef8e230a9ad0566df484ad751608201132839a6 100644 (file)
@@ -1933,6 +1933,9 @@ get_database_list(void)
 
    CommitTransactionCommand();
 
+   /* Be sure to restore caller's memory context */
+   MemoryContextSwitchTo(resultcxt);
+
    return dblist;
 }