pgsql: Release memory allocated by dependency_degree

Поиск
Список
Период
Сортировка
От Tomas Vondra
Тема pgsql: Release memory allocated by dependency_degree
Дата
Msg-id E1mTRbB-00055o-HQ@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Release memory allocated by dependency_degree

Calculating degree of a functional dependency may allocate a lot of
memory - we have released mot of the explicitly allocated memory, but
e.g. detoasted varlena values were left behind. That may be an issue,
because we consider a lot of dependencies (all combinations), and the
detoasting may happen for each one again.

Fixed by calling dependency_degree() in a dedicated context, and
resetting it after each call. We only need the calculated dependency
degree, so we don't need to copy anything.

Backpatch to PostgreSQL 10, where extended statistics were introduced.

Backpatch-through: 10
Discussion: https://www.postgresql.org/message-id/20210915200928.GP831%40telsasoft.com

Branch
------
REL_14_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/abb2f9144ba1b7ac806f3779f53ae2f6174cd2d9

Modified Files
--------------
src/backend/statistics/dependencies.c | 22 ++++++++++++++++------
1 file changed, 16 insertions(+), 6 deletions(-)


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

Предыдущее
От: Tomas Vondra
Дата:
Сообщение: pgsql: Free memory after building each statistics object
Следующее
От: Tomas Vondra
Дата:
Сообщение: pgsql: Free memory after building each statistics object