pgsql: Fix overflow with pgstats DSA reference count

Поиск
Список
Период
Сортировка
От Michael Paquier
Тема pgsql: Fix overflow with pgstats DSA reference count
Дата
Msg-id E1sMdGI-003AZ5-73@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Fix overflow with pgstats DSA reference count

When pgstats is initialized for a backend, it uses dsa_attach_in_place()
without a "segment" provided.  Hence, no callback is registered to
automatically release the DSA attached once a backend exits.  Not doing
any cleanup causes the reference count of the pgstats DSA to
continuously increment, at some point overflowing it (the more the
number of connections, the faster it is to reach this state).  Once the
reference count overflows and then gets back to 0, new backends are not
able to attach to the pgstats DSA, failing startup.

This issue is resolved by adding in the pgstats shutdown hook a call to
dsa_release_in_place(), ensuring that the DSA attached at backend
startup is correctly released, keeping the reference count at bay.

The author of this patch has been able to see this issue on a server
with a long uptime and a high connection turnover.

Issue introduced by 5891c7a8ed8f, so backpatch down to 15.

Author: Anthonin Bonnefoy
Discussion: https://postgr.es/m/CAO6_XqqJbJBL=M7Ym13TcB4Xnq58vRa2jcC+gwEPBgbAda6B1Q@mail.gmail.com
Backpatch-through: 15

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/7467939ea226ebc5608285486501b136b642c02b

Modified Files
--------------
src/backend/utils/activity/pgstat_shmem.c | 8 ++++++++
1 file changed, 8 insertions(+)


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

Предыдущее
От: Heikki Linnakangas
Дата:
Сообщение: pgsql: Fix bugs in MultiXact truncation
Следующее
От: Amit Kapila
Дата:
Сообщение: pgsql: Drop the temporary tuple slots allocated by pgoutput.