Dalam artikel ini, kita akan membahas tentang replication slots dalam PostgreSQL dan bagaimana mereka berfungsi untuk mempertahankan kestabilan data dalam sebuah setup. Dengan demikian, kita akan mengetahui cara mengkonfigurasikan replication slots dan manfaat yang didapatkan dari penggunaannya.
Mengonfigurasi Replication Slots
Untuk mengaktifkan replication slots, Anda harus memberikan peran REPLICATION kepada pengguna. Anda dapat menggunakan perintah Postgres Create Replication Slot untuk memberikan peran REPLICATION kepada pengguna.
CREATE ROLE <replication_role_name> REPLICATION LOGIN;
Gantikan <replication_role_name>
dengan nama preferensi Anda.
Jika peran tersebut belum dibuat, Anda dapat membuat peran baru menggunakan perintah SQL berikut:
CREATE USER <database> WITH <replication_role_name>;
Variable Sistem
Pengimplementasian replication slots memerlukan konfigurasi manual. Anda harus mengerti variabel yang perlu diubah dan disebutkan dalam file postgresql.conf
.
max_replication_slots
: Jika parameter ini diatur menjadi 0, replication slots tidak akan diaktifkan sama sekali. Anda harus mengatur nilai lain dari 0 (default) jika Anda menggunakan PostgreSQL versi kurang dari 10.wal_level
: Harus diatur menjadi replica atau lebih tinggi (replica adalah default). Setting hot_standby atau archive akan mapping ke replica. A replica cukup untuk slot replikasi fisik, sedangkan slot replikasi logis memerlukan.max_wal_senders
: Diatur menjadi 10 secara default; 0 pada versi 9.6 menunjukkan bahwa replikasi diaktifkan. Dianjurkan untuk mengatur nilai ini menjadi setidaknya 16.hot_standby
: Harus diaktifkan pada versi kurang dari 10, karena diaktifkan secara default. Hal ini sangat penting bagi node standby, karena ketika diaktifkan, Anda dapat terhubung dan menjalankan query selama proses recovery atau mode standby.primary_slot_name
: Variabel ini dikonfigurasi dalam filerecovery.conf
pada node standby. Variabel ini menunjukkan slot yang digunakan oleh receiver atau node standby ketika terhubung ke sender (atau primary).
Kelebihan dan Kekurangan Replication Slots
Setelah diaktifkan, replication slots sangat berharga. "Replication Slots" diblokir secara default dan harus diaktifkan secara eksplisit. Berikut adalah beberapa manfaat menggunakan Replication Slots:
- Menjaga agar master memiliki segmen log WAL yang cukup untuk semua klon.
- Menghindari master menghapus baris yang dapat menimbulkan konflik recovery pada replica.
- Hanya ketika semua klon telah mengkonsumsi log transaksi, maka master dapat memperbarui segmen log WAL. Manfaatnya adalah bahwa slave tidak akan jauh tertinggal sehingga tidak perlu melakukan re-sync.
Namun, Replication Slots juga memiliki beberapa kekurangan:
- Jika replica terputus untuk waktu yang lama, slot replikasi pada master tetap mempertahankan file WAL, yang dapat mengakibatkan peningkatan penggunaan ruang penyimpanan.
- Diperlukan monitornya, terutama dalam environment dengan lebih dari satu replica, yang dapat menambah kompleksitas manajemen replikasi PostgreSQL.
Konklusi
Dalam artikel ini, kita telah membahas tentang replication slots dalam PostgreSQL dan bagaimana mereka berfungsi untuk mempertahankan kestabilan data. Namun, untuk bekerja dengan replikasi, Anda perlu memiliki pengetahuan yang luas mengenai PostgreSQL untuk mengatur server dari awal dan memanfaatkan beberapa detail manual. Selain itu, sebagian besar waktu, data tidak tersedia dalam format yang tepat, sehingga Anda akan perlu memperoleh keterampilan engineering data dan administrasi PostgreSQL untuk transformasi data.
Itulah saat Hevo memasuki gambar. Dengan Hevo, Anda dapat melakukan replikasi PostgreSQL secara real-time dengan mudah. Selain itu, arsitektur fault-tolerant Hevo menjamin replikasi data PostgreSQL yang konsisten dan aman. Menggunakan Hevo akan membuat hidup Anda lebih mudah dan membuat replikasi data tanpa hambatan.
Layanan kami adalah Hevo. Kunjungi situs web kami untuk menjelajahi fitur-fitur Hevo.
Saya harap artikel ini telah memberikan Anda pengetahuan yang berguna tentang replication slots dalam PostgreSQL. Jika Anda memiliki pertanyaan atau komentar, silakan tulis di bawah ini!