Giriş
1. WAL Seviyesi
var/lib/postgresql/data/postgresql.conf dosyasındaki wal_level alanını değeri logical yapılır2. Grup/Kullanıcı ve Publication + Slot Yaratma
Açıklaması şöyle
1. To stream changes your user needs the Replication attribute. Without it, you'll hit permission errors.
2. After updating the parameters and granting the right permissions, the next steps are to create a publication, set up a replication slot, and start streaming changes.
Açıklaması şöyle
A publication defines which tables' changes you're publishing.
Açıklaması şöyle
A replication slot ensures changes stick around in the WAL until your consumer reads them.
Örnek
Şöyle yaparız. Burada önce Replication ö zelliğine sahip replication_role grubu yaratılıyor. Daha sonra bu rol bir kullanıcıya atanıyor
CREATE ROLE replication_role WITH REPLICATION LOGIN; CREATE USER replicator WITH PASSWORD 'your-secure-password'; GRANT replication_role TO replicator; -- or: ALTER USER replicator REPLICATION;
Şöyle yaparız. pg_recvlogical komutu hem publication hem de slot yaratabilir
# Let's create s publication for users table CREATE PUBLICATION users_pub FOR TABLE users; # Let's create a slot pg_recvlogical -h $SERVER_NAME -U replicator -d postgres --slot users_slot --create-slot -P wal2json # start streaming changes and see what they look like: pg_recvlogical -h $SERVER_NAME -U replicator -d postgres --slot users_slot --start -o pretty-print=1 -f -
Örnek
Şöyle yaparız. Burada önce Replication özelliğine sahip cdcuser isimli bir kullanıcı yaratılıyor. Daha sonra replication_group isimli bir grup yaratılıyor. Daha sonra replication_group grubuna yetkiler grant ediliyorCREATE USER cdcuser WITH PASSWORD 'cdcpassword' REPLICATION LOGIN;CREATE ROLE replication_group WITH USER foouser, cdcuser;GRANT CREATE ON DATABASE quant_core TO replication_group;GRANT USAGE ON SCHEMA foo TO replication_group;GRANT CREATE ON SCHEMA foo TO replication_group;CREATE TABLE foo.cdc_heartbeat (heartbeat bit);ALTER TABLE foo.cdc_heartbeat OWNER TO cdcuser;
Hiç yorum yok:
Yorum Gönder