PostgreSQL 9.6.2 문서 | |||
---|---|---|---|
이전 | 위로 | 장 47. 논리적 디코딩 | 다음 |
다음은 논리적 디코딩을 사용하는 예제다.
논리적 디코딩을 사용하려면, 먼저 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=# SELECT pg_drop_replication_slot('regression_slot'); pg_drop_replication_slot ----------------------- (1 row)
다음 예제는 pg_recvlogical 프로그램을 이용한 서버 외부에서 변경 자료를 활용하는 방법이다. 이 프로그램은 PostgreSQL 배포판에 포함되어 있으며, 이때 자료를 전달하는 기법은 스트리밍 복제 프로토콜을 이용한다. 이 때는 해당 프로그램이 스트리밍 복제를 위해 해당 데이터베이스에 접속할 수 있어야 하며 (26.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