mirror of
https://github.com/postgres/postgres.git
synced 2025-06-11 20:28:21 +03:00
Add support for temporary replication slots
This allows creating temporary replication slots that are removed automatically at the end of the session or on error. From: Petr Jelinek <petr.jelinek@2ndquadrant.com>
This commit is contained in:
20
contrib/test_decoding/sql/slot.sql
Normal file
20
contrib/test_decoding/sql/slot.sql
Normal file
@ -0,0 +1,20 @@
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_p', 'test_decoding');
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_t', 'test_decoding', true);
|
||||
|
||||
SELECT pg_drop_replication_slot('regression_slot_p');
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot_p', 'test_decoding', false);
|
||||
|
||||
-- reconnect to clean temp slots
|
||||
\c
|
||||
|
||||
SELECT pg_drop_replication_slot('regression_slot_p');
|
||||
|
||||
-- should fail because the temporary slot was dropped automatically
|
||||
SELECT pg_drop_replication_slot('regression_slot_t');
|
||||
|
||||
|
||||
-- test switching between slots in a session
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot1', 'test_decoding', true);
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot2', 'test_decoding', true);
|
||||
SELECT * FROM pg_logical_slot_get_changes('regression_slot1', NULL, NULL);
|
||||
SELECT * FROM pg_logical_slot_get_changes('regression_slot2', NULL, NULL);
|
Reference in New Issue
Block a user