Membuat penyiapan ketersediaan tinggi

Halaman ini menjelaskan cara menyiapkan konfigurasi ketersediaan tinggi untuk AlloyDB Omni. Halaman ini hanya membahas pembuatan instance AlloyDB Omni baru dalam konfigurasi ketersediaan tinggi. Panduan ini tidak membahas cara mengonversi instance yang ada ke ketersediaan tinggi.

Sebelum memulai

  1. Baca artikel Ketersediaan tinggi dan ketahanan data.

  2. Jika Anda belum memilikinya, buat project Google Cloud .

  3. Pastikan penagihan diaktifkan untuk project Anda.

  4. Buka Cloud Shell di konsol Google Cloud.

  5. Di konsol Google Cloud, clone repositori sumber berikut.

    git clone https://github.com/GoogleCloudPlatform/cloud-solutions.git
    

Penginstalan

Dalam panduan ini, kita akan men-deploy cluster Patroni tiga node dengan AlloDB Omni dan cluster tiga node etcd sebagai penyimpanan konfigurasi. Di bagian depan cluster, kita menggunakan HAProxy dalam grup instance terkelola untuk alamat IP floating sehingga failover bersifat transparan bagi klien.

Konfigurasi awal untuk penyiapan ini ditampilkan dalam diagram berikut:

Konfigurasi tempat HAProxy mengelola koneksi antara klien dan node utama

Gambar 1. Konfigurasi tempat HAProxy mengelola koneksi antara klien dan node utama.

Jika terjadi pemadaman, konfigurasi akan berubah menjadi diagram berikut:

Konfigurasi yang diperbarui saat node utama yang gagal diganti oleh node standby

Gambar 2. Konfigurasi yang diperbarui saat node utama yang gagal diganti dengan node standby.

Jika jumlah klien yang terhubung ke database menjadi masalah dan Anda mengalami masalah performa karena banyaknya koneksi database serentak, sebaiknya tambahkan pengumpulan koneksi sisi aplikasi. Jika tidak dapat melakukannya, Anda dapat menambahkan pengumpulan koneksi sisi database menggunakan alat seperti PgBouncer.

Deployment

  1. Di Cloud Shell dan setelah meng-clone repositori Cloud Solutions, buka direktori terraform.

    cd cloud-solutions/projects/alloydbomni-ha-patroni-etcd/terraform
    
  2. Buat dan edit file terraform.tfvars. Dalam file, tetapkan nilai untuk variabel berikut.

    project_id                   = "PROJECT_ID"
    region                       = "REGION"
    zones                        = "ZONES"
    node_count                   = 3
    cluster_name                 = "CLUSTER_NAME"
    replication_user_password    = "REPLICATION_USER_PASSWORD"
    postgres_super_user_password = "PG_SUPER_USER_PASSWORD"
    

    Deskripsi untuk setiap variabel dapat ditemukan di GitHub dalam file konfigurasi variabel.

  3. Jalankan skrip Terraform untuk membuat semua resource.

    terraform init && terraform apply
    

    Skrip ini membuat dan mengonfigurasi hal berikut:

    • Tiga node untuk cluster etcd Anda

    • Tiga node untuk cluster Patroni Anda

    • Satu node untuk HAProxy

Mengonfigurasi Patroni agar sinkron

Agar Patroni hanya menggunakan replikasi sinkron di cluster tiga node, tambahkan item konfigurasi seperti synchronous_mode, synchronous_node_count, synchronous_commit, dan synchronous_standby_names di bagian bootstrap dalam file konfigurasi Patroni. Konfigurasi Patroni ditentukan dalam template skrip startup dan dalam file /alloydb/config/patroni.yml di node Patroni. Untuk menggunakan replikasi sinkron, konfigurasi bootstrap Patroni Anda akan terlihat seperti berikut:

bootstrap:
  dcs:
    ttl: 30
    loop_wait: 10
    retry_timeout: 10
    maximum_lag_on_failover: 1048576
    synchronous_mode: true
    synchronous_node_count: 2
    postgresql:
      use_pg_rewind: true
      use_slots: true
      parameters:
        hot_standby: "on"
        wal_keep_segments: 20
        max_wal_senders: 8
        max_replication_slots: 8
        synchronous_commit: remote_apply
        synchronous_standby_names: '*'

Jika synchronous_mode diaktifkan, Patroni akan menggunakan replikasi sinkron antara replika utama dan replika lainnya. Parameter synchronous_node_count digunakan oleh Patroni untuk mengelola jumlah replika standby sinkron. Patroni mengelola jumlah replika standby sinkron yang tepat berdasarkan parameter synchronous_node_count dan menyesuaikan status di penyimpanan konfigurasi dan di synchronous_standby_names saat anggota bergabung dan keluar. Untuk informasi selengkapnya tentang replikasi sinkron, lihat bagian Mode replikasi dalam dokumentasi Patroni.

Langkah berikutnya