git.postgresql.org Git - postgresql.git/commit

git projects / postgresql.git / commit
? search:
summary | shortlog | log | commit | commitdiff | tree
(parent: b618208) | patch
Dirty replication slots when using sql interface
Mon, 5 Sep 2016 08:44:38 +0000 (09:44 +0100)
Mon, 5 Sep 2016 08:44:38 +0000 (09:44 +0100)
commit d851bef2d60ff9345249ff67c053e37fe4b364cc
Dirty replication slots when using sql interface

When pg_logical_slot_get_changes(...) sets confirmed_flush_lsn to the point at
which replay stopped, it doesn't dirty the replication slot. So if the replay
didn't cause restart_lsn or catalog_xmin to change as well, this change will
not get written out to disk. Even on a clean shutdown.

If Pg crashes or restarts, a subsequent pg_logical_slot_get_changes(...) call
will see the same changes already replayed since it uses the slot's
confirmed_flush_lsn as the start point for fetching changes. The caller can't
specify a start LSN when using the SQL interface.

Mark the slot as dirty after reading changes using the SQL interface so that
users won't see repeated changes after a clean shutdown. Repeated changes still
occur when using the walsender interface or after an unclean shutdown.

Craig Ringer
src/backend/replication/logical/logicalfuncs.c diff | blob | blame | history
src/test/recovery/Makefile diff | blob | blame | history
src/test/recovery/t/006_logical_decoding.pl [new file with mode: 0644] blob
This is the main PostgreSQL git repository.
RSS Atom

AltStyle によって変換されたページ (->オリジナル) /