ExecForceStoreMinimalTuple leaks memory like there's no tomorrow

Поиск
Список
Период
Сортировка
От Tom Lane
Тема ExecForceStoreMinimalTuple leaks memory like there's no tomorrow
Дата
Msg-id 366.1555382816@sss.pgh.pa.us
обсуждение исходный текст
Ответы Re: ExecForceStoreMinimalTuple leaks memory like there's no tomorrow  (Michael Paquier <michael@paquier.xyz>)
Re: ExecForceStoreMinimalTuple leaks memory like there's no tomorrow  (Andres Freund <andres@anarazel.de>)
Список pgsql-hackers
Using HEAD,

create table t1 as select generate_series(1,40000000) id;
vacuum analyze t1;
explain select * from t1, t1 t1b where t1.id = t1b.id;
-- should indicate a hash join
explain analyze select * from t1, t1 t1b where t1.id = t1b.id;

... watch the process's memory consumption bloat.  (It runs for
awhile before that starts to happen, but eventually it goes to
a couple of GB.)

It looks to me like the problem is that ExecHashJoinGetSavedTuple
calls ExecForceStoreMinimalTuple with shouldFree = true, and
ExecForceStoreMinimalTuple's second code branch simply ignores
the requirement to free the supplied tuple.

            regards, tom lane



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

Предыдущее
От: Alexander Korotkov
Дата:
Сообщение: Improve search for missing parent downlinks in amcheck
Следующее
От: Michael Paquier
Дата:
Сообщение: Re: ExecForceStoreMinimalTuple leaks memory like there's no tomorrow