mirror of
https://github.com/postgres/postgres.git
synced 2025-06-25 01:02:05 +03:00
Block replication slot advance for these not yet reserving WAL
Such replication slots are physical slots freshly created without WAL being reserved, which is the default behavior, which have not been used yet as WAL consumption resources to retain WAL. This prevents advancing a slot to a position older than any WAL available, which could falsify calculations for WAL segment recycling. This also cleans up a bit the code, as ReplicationSlotRelease() would be called on ERROR, and improves error messages. Reported-by: Kyotaro Horiguchi Author: Michael Paquier Reviewed-by: Andres Freund, Álvaro Herrera, Kyotaro Horiguchi Discussion: https://postgr.es/m/20180626071305.GH31353@paquier.xyz
This commit is contained in:
@ -68,3 +68,9 @@ SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot1', 'test_
|
||||
-- both should error as they should be dropped on error
|
||||
SELECT pg_drop_replication_slot('regression_slot1');
|
||||
SELECT pg_drop_replication_slot('regression_slot2');
|
||||
|
||||
-- slot advance with physical slot, error with non-reserved slot
|
||||
SELECT slot_name FROM pg_create_physical_replication_slot('regression_slot3');
|
||||
SELECT pg_replication_slot_advance('regression_slot3', '0/0'); -- invalid LSN
|
||||
SELECT pg_replication_slot_advance('regression_slot3', '0/1'); -- error
|
||||
SELECT pg_drop_replication_slot('regression_slot3');
|
||||
|
Reference in New Issue
Block a user