Xact end leaves CurrentMemoryContext = TopMemoryContext

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Xact end leaves CurrentMemoryContext = TopMemoryContext
Дата
Msg-id 3478884.1718656625@sss.pgh.pa.us
обсуждение исходный текст
Ответы Re: Xact end leaves CurrentMemoryContext = TopMemoryContext
Re: Xact end leaves CurrentMemoryContext = TopMemoryContext
Список pgsql-hackers
AtCommit_Memory and friends have done $SUBJECT for at least a couple
of decades, but in the wake of analyzing bug #18512 [1], I'm feeling
like that's a really bad idea.  There is too much code running
around the system that assumes that it's fine to leak stuff in
CurrentMemoryContext.  If we execute any such thing between
AtCommit_Memory and the next AtStart_Memory, presto: we have a
session-lifespan memory leak.  I'm almost feeling that we should
have a policy that CurrentMemoryContext should never point at
TopMemoryContext.

As to what to do about it: I'm imagining that instead of resetting
CurrentMemoryContext to TopMemoryContext, we set it to some special
context that we expect we can reset every so often, like at the start
of the next transaction.  The existing TransactionAbortContext is
a very similar thing, and maybe could be repurposed/shared with this
usage.

Thoughts?

            regards, tom lane

[1] https://www.postgresql.org/message-id/18512-6e89f654d7da884d%40postgresql.org



В списке pgsql-hackers по дате отправления:

Предыдущее
От: Matthias van de Meent
Дата:
Сообщение: Re: [PATCH] Improve error message when trying to lock virtual tuple.
Следующее
От: Andres Freund
Дата:
Сообщение: Re: FYI: LLVM Runtime Crash