pgsql: Fix handling of synchronous replication for stopping WALsenders
От | Michael Paquier |
---|---|
Тема | pgsql: Fix handling of synchronous replication for stopping WALsenders |
Дата | |
Msg-id | E1gS9yw-0005bq-QH@gemulon.postgresql.org обсуждение исходный текст |
Список | pgsql-committers |
Fix handling of synchronous replication for stopping WAL senders This fixes an oversight from c6c3334 which has introduced a more strict ordering in the way WAL senders are stopped to prevent current WAL activity when a shutdown checkpoint is created. After all backends are stopped, all WAL senders are requested to stop which makes them stop any activity, and switching their state as stopping. Once the checkpointer knows that all WAL senders are in a stopping state, the shutdown checkpoint can begin, with all WAL senders activated, waiting for their clients to flush the shutdown checkpoint record. If a subset of WAL senders are stopping and in a sync state, other WAL senders could still be waiting for a WAL position to be synced while committing a transaction, however the subset of stopping senders would not release waiters, potentially breaking synchronous replication guarantees. This commit makes sure that even WAL senders stopping are able to release waiters properly. On 9.4, this can also trigger an assertion failure when setting for example max_wal_senders to 1 where a WAL sender is not able to find itself as in synchronous state when the instance stops. Reported-by: Paul Guo Author: Paul Guo, Michael Paquier Discussion: https://postgr.es/m/CAEET0ZEv8VFqT3C-cQm6byOB4r4VYWcef1J21dOX-gcVhCSpmA@mail.gmail.com Backpatch-through: 9.4 Branch ------ REL9_4_STABLE Details ------- https://git.postgresql.org/pg/commitdiff/b81d08d6001068040a5c0da9bc03473feaae11c1 Modified Files -------------- src/backend/replication/syncrep.c | 9 ++++++--- src/backend/replication/walsender.c | 6 ++++-- 2 files changed, 10 insertions(+), 5 deletions(-)
В списке pgsql-committers по дате отправления: