Bagian berikut membahas cara mengonfigurasi database PostgreSQL yang dikelola sendiri.
Mengaktifkan replikasi logis pada database
Setel parameter
wal_level
dalam database Anda dengan menambahkanwal_level=logical
ke filepostgresql.conf
.Mulai ulang server.
Membuat slot publikasi dan replikasi
Login ke konsol PostgreSQL sebagai superuser.
Membuat publikasi. Sebaiknya buat publikasi hanya untuk tabel yang ingin Anda replikasi. Hal ini memungkinkan Datastream untuk hanya membaca data yang relevan, dan menurunkan beban pada database dan Datastream:
CREATE PUBLICATION PUBLICATION_NAME FOR TABLE SCHEMA1.TABLE1, SCHEMA2.TABLE2;
Ganti kode berikut:
- PUBLICATION_NAME: Nama publikasi Anda. Anda harus memberikan nama ini saat membuat aliran data di wizard pembuatan aliran data Datastream.
- SCHEMA: Nama skema yang berisi tabel.
- TABLE: Nama tabel yang ingin direplikasi.
Anda dapat membuat publikasi untuk semua tabel dalam skema. Pendekatan ini memungkinkan Anda mereplikasi perubahan untuk tabel dalam daftar skema yang ditentukan, termasuk tabel yang Anda buat pada masa mendatang:
CREATE PUBLICATION PUBLICATION_NAME FOR TABLES IN SCHEMA1, SCHEMA2;
Anda juga dapat membuat publikasi untuk semua tabel di database. Perhatikan bahwa pendekatan ini akan meningkatkan beban pada database sumber dan Datastream:
CREATE PUBLICATION PUBLICATION_NAME FOR ALL TABLES;
Buat slot replikasi dengan memasukkan perintah SQL berikut:
SELECT PG_CREATE_LOGICAL_REPLICATION_SLOT('REPLICATION_SLOT_NAME', 'pgoutput');
Ganti kode berikut:
- REPLICATION_SLOT_NAME: Nama slot replikasi Anda. Anda harus memberikan nama ini saat membuat aliran data di wizard pembuatan aliran Datastream.
Membuat pengguna Datastream
Untuk membuat pengguna Datastream, masukkan perintah SQL berikut:
CREATE USER USER_NAME WITH ENCRYPTED PASSWORD 'USER_PASSWORD';
Ganti kode berikut:
- USER_NAME: Nama pengguna Datastream yang ingin Anda buat.
- USER_PASSWORD: Sandi login untuk pengguna Datastream yang ingin Anda buat.
Berikan hak istimewa berikut kepada pengguna yang Anda buat:
ALTER ROLE USER_NAME WITH REPLICATION; GRANT SELECT ON ALL TABLES IN SCHEMA SCHEMA_NAME TO USER_NAME; GRANT USAGE ON SCHEMA SCHEMA_NAME TO USER_NAME; ALTER DEFAULT PRIVILEGES IN SCHEMA SCHEMA_NAME GRANT SELECT ON TABLES TO USER_NAME;
Ganti kode berikut:
- USER_NAME: Pengguna yang ingin Anda beri hak istimewa.
- SCHEMA_NAME: Nama skema tempat Anda ingin memberikan hak istimewa.