45.1. ÐÑимеÑÑ Ð»Ð¾Ð³Ð¸ÑеÑкого декодиÑованиÑ
СледÑÑÑий пÑÐ¸Ð¼ÐµÑ Ð´ÐµÐ¼Ð¾Ð½ÑÑÑиÑÑÐµÑ ÑпÑавление логиÑеÑким декодиÑованием на ÑÑовне SQL.
ÐÑежде Ñем Ð²Ñ ÑможеÑе иÑполÑзоваÑÑ Ð»Ð¾Ð³Ð¸ÑеÑкое декодиÑование, Ð²Ñ Ð´Ð¾Ð»Ð¶Ð½Ñ ÑÑÑановиÑÑ Ð² wal_level знаÑение logical, а в max_replication_slots знаÑение, не менÑÑее 1. ÐоÑле ÑÑого Ð²Ñ Ð´Ð¾Ð»Ð¶Ð½Ñ Ð¿Ð¾Ð´ÐºÐ»ÑÑиÑÑÑÑ Ðº Ñелевой базе даннÑÑ
(в ÑледÑÑÑем пÑимеÑе, ÑÑо postgres) как ÑÑпеÑполÑзоваÑелÑ.
postgres=# -- СоздаÑÑ ÑÐ»Ð¾Ñ Ñ Ð¸Ð¼ÐµÐ½ÐµÐ¼ 'regression_slot', иÑполÑзÑÑÑий модÑÐ»Ñ Ð²Ñвода 'test_decoding'
postgres=# SELECT * FROM pg_create_logical_replication_slot('regression_slot', 'test_decoding');
slot_name | xlog_position
-----------------+---------------
regression_slot | 0/16B1970
(1 row)
postgres=# SELECT slot_name, plugin, slot_type, database, active, restart_lsn, confirmed_flush_lsn FROM pg_replication_slots;
slot_name | plugin | slot_type | database | active | restart_lsn | confirmed_flush_lsn
-----------------+---------------+-----------+----------+--------+-------------+-----------------
regression_slot | test_decoding | logical | postgres | f | 0/16A4408 | 0/16A4440
(1 row)
postgres=# -- Ðока никакие Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð½Ðµ виднÑ
postgres=# SELECT * FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL);
location | xid | data
----------+-----+------
(0 rows)
postgres=# CREATE TABLE data(id serial primary key, data text);
CREATE TABLE
postgres=# -- DDL не ÑеплиÑиÑÑеÑÑÑ, поÑÑÐ¾Ð¼Ñ Ð²Ð¸Ð´Ð½Ð° ÑолÑко ÑÑанзакÑиÑ
postgres=# SELECT * FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL);
location | xid | data
-----------+-----+------------
0/16D5D48 | 688 | BEGIN 688
0/16E0380 | 688 | COMMIT 688
(2 rows)
postgres=# -- Ðогда Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð¿ÑоÑиÑанÑ, они ÑÑиÑаÑÑÑÑ Ð¾Ð±ÑабоÑаннÑми и Ñже не вÑдаÑÑÑÑ
postgres=# -- в поÑледÑÑÑем вÑзове:
postgres=# SELECT * FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL);
location | xid | data
----------+-----+------
(0 rows)
postgres=# BEGIN;
postgres=# INSERT INTO data(data) VALUES('1');
postgres=# INSERT INTO data(data) VALUES('2');
postgres=# COMMIT;
postgres=# SELECT * FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL);
location | xid | data
-----------+-----+-----------------------------------------------
0/16E0478 | 689 | BEGIN 689
0/16E0478 | 689 | table public.data: INSERT: id[integer]:1 data[text]:'1'
0/16E0580 | 689 | table public.data: INSERT: id[integer]:2 data[text]:'2'
0/16E0650 | 689 | COMMIT 689
(4 rows)
postgres=# INSERT INTO data(data) VALUES('3');
postgres=# -- Также можно заглÑнÑÑÑ Ð²Ð¿ÐµÑÑд в поÑоке изменений, не ÑÑиÑÑÐ²Ð°Ñ ÑÑи изменениÑ
postgres=# SELECT * FROM pg_logical_slot_peek_changes('regression_slot', NULL, NULL);
location | xid | data
-----------+-----+-----------------------------------------------
0/16E09C0 | 690 | BEGIN 690
0/16E09C0 | 690 | table public.data: INSERT: id[integer]:3 data[text]:'3'
0/16E0B90 | 690 | COMMIT 690
(3 rows)
postgres=# -- СледÑÑÑий вÑзов pg_logical_slot_peek_changes() Ñнова возвÑаÑÐ°ÐµÑ Ñе же изменениÑ
postgres=# SELECT * FROM pg_logical_slot_peek_changes('regression_slot', NULL, NULL);
location | xid | data
-----------+-----+-----------------------------------------------
0/16E09C0 | 690 | BEGIN 690
0/16E09C0 | 690 | table public.data: INSERT: id[integer]:3 data[text]:'3'
0/16E0B90 | 690 | COMMIT 690
(3 rows)
postgres=# -- ÐодÑÐ»Ñ Ð²Ñвода можно пеÑедаÑÑ Ð¿Ð°ÑамеÑÑÑ, влиÑÑÑие на ÑоÑмаÑиÑование
postgres=# SELECT * FROM pg_logical_slot_peek_changes('regression_slot', NULL, NULL, 'include-timestamp', 'on');
location | xid | data
-----------+-----+-----------------------------------------------
0/16E09C0 | 690 | BEGIN 690
0/16E09C0 | 690 | table public.data: INSERT: id[integer]:3 data[text]:'3'
0/16E0B90 | 690 | COMMIT 690 (at 2014-02-27 16:41:51.863092+01)
(3 rows)
postgres=# -- Ðе забÑдÑÑе ÑдалиÑÑ ÑлоÑ, коÑоÑÑй вам болÑÑе не нÑжен, ÑÑÐ¾Ð±Ñ Ð¾Ð½
postgres=# -- не поÑÑеблÑл ÑеÑÑÑÑÑ ÑеÑвеÑа:
postgres=# SELECT pg_drop_replication_slot('regression_slot');
pg_drop_replication_slot
-----------------------
(1 row)СледÑÑÑий пÑÐ¸Ð¼ÐµÑ Ð¿Ð¾ÐºÐ°Ð·ÑваеÑ, как можно ÑпÑавлÑÑÑ Ð»Ð¾Ð³Ð¸ÑеÑким декодиÑованием ÑÑедÑÑвами пÑоÑокола поÑоковой ÑепликаÑии, иÑполÑзÑÑ Ð¿ÑогÑÐ°Ð¼Ð¼Ñ pg_recvlogical, вклÑÑÑннÑÑ Ð² диÑÑÑибÑÑив Postgres Pro. ÐÐ»Ñ ÑÑого нÑжно, ÑÑÐ¾Ð±Ñ ÐºÐ¾Ð½ÑигÑÑаÑÐ¸Ñ Ð°ÑÑенÑиÑикаÑии клиенÑов допÑÑкала подклÑÑÐµÐ½Ð¸Ñ Ð´Ð»Ñ ÑепликаÑии (Ñм. ÐодÑаздел 25.2.5.1) и ÑÑÐ¾Ð±Ñ Ð·Ð½Ð°Ñение max_wal_senders бÑло доÑÑаÑоÑно болÑÑим и позволило ÑÑÑановиÑÑ Ð´Ð¾Ð¿Ð¾Ð»Ð½Ð¸ÑелÑное подклÑÑение.
$ pg_recvlogical -d postgres --slot test --create-slot $ pg_recvlogical -d postgres --slot test --start -f - Control+Z $ psql -d postgres -c "INSERT INTO data(data) VALUES('4');" $ fg BEGIN 693 table public.data: INSERT: id[integer]:4 data[text]:'4' COMMIT 693 Control+C $ pg_recvlogical -d postgres --slot test --drop-slot