Praktik terbaik untuk Amazon RDS Aurora penerapan biru/hijau - Layanan Basis Data Relasional Amazon

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

Praktik terbaik untuk Amazon RDS Aurora penerapan biru/hijau

Berikut ini adalah praktik terbaik untuk penerapan biru/hijau.

Praktik terbaik umum untuk penerapan biru/hijau

Pertimbangkan praktik terbaik umum berikut saat Anda membuat penerapan biru/hijau.

  • Uji instans DB secara menyeluruh di lingkungan hijau sebelum switchover.

  • Simpan basis data Anda di lingkungan hijau dengan kondisi hanya baca. Sebaiknya Anda mengaktifkan operasi tulis di lingkungan hijau dengan hati-hati karena dapat mengakibatkan konflik replikasi. Hal ini juga dapat menghasilkan data yang tidak diinginkan dalam basis data produksi setelah switchover.

  • Jika Anda menggunakan penerapan biru/hijau untuk menerapkan perubahan skema, buat hanya perubahan yang kompatibel dengan replikasi.

    Misalnya, Anda dapat menambahkan kolom baru di akhir tabel tanpa mengganggu replikasi dari penerapan biru ke penerapan hijau. Namun, perubahan skema, seperti penggantian nama kolom atau nama tabel, memecah replikasi ke deployment hijau.

    Untuk informasi selengkapnya tentang perubahan yang kompatibel dengan replikasi, lihat Replication with Differing Table Definitions on Source and Replica di dokumentasi MySQL dan Restrictions dalam dokumentasi replikasi logis PostgreSQL.

    catatan

    Batasan ini tidak berlaku untuk RDS untuk penyebaran biru/hijau PostgreSQL yang menggunakan replikasi fisik. Untuk informasi selengkapnya, lihat RDS untuk batasan PostgreSQL untuk penerapan biru/hijau dengan replikasi fisik.

  • Setelah Anda membuat deployment blue/green, tangani pemuatan lambat jika perlu. Pastikan pemuatan data selesai sebelum switchover. Untuk informasi selengkapnya, lihat Pemuatan malas dan inisialisasi penyimpanan untuk penerapan biru/hijau.

  • Saat Anda mengalihkan deployment blue/green, ikuti praktik terbaik switchover. Untuk informasi selengkapnya, lihat Praktik terbaik switchover.

RDS untuk MySQL MySQL praktik terbaik MySQL untuk penerapan biru/hijau

  • Hindari menggunakan mesin penyimpanan non-transaksional, seperti MyISAM, yang tidak dioptimalkan untuk replikasi.

  • Optimalkan replika baca dan lingkungan hijau untuk replikasi log biner. Jika didukung oleh mesin DB Anda, aktifkan replikasi GTID, parallel, dan crash-safe untuk memastikan konsistensi dan daya tahan data sebelum Anda membuat penerapan biru/hijau. Untuk informasi selengkapnya, lihat Menggunakan replikasi GTID berbasis.

  • Jika lingkungan hijau mengalami kelambatan replika, pertimbangkan hal berikut:

    • Setel sementara innodb_flush_log_at_trx_commit parameter ke 2dalam kelompok parameter DB hijau. Setelah replikasi menyusul, kembalikan ke nilai default sebelum peralihan. 1 Jika terjadi shutdown atau crash yang tidak terduga dengan nilai parameter sementara, bangun kembali lingkungan hijau untuk menghindari kerusakan data yang tidak terdeteksi.

    • Untuk mengurangi latensi tulis dan meningkatkan throughput replikasi, ubah sementara instans DB multi-AZ hijau menjadi instans DB AZ tunggal. Aktifkan kembali Multi-AZ tepat sebelum peralihan.

RDS untuk PostgreSQL praktik terbaik untuk penerapan biru/hijau

Pertimbangkan praktik terbaik berikut saat Anda membuat penerapan biru/hijau dari RDS untuk instans PostgreSQL DB.

RDS untuk PostgreSQL praktik terbaik umum untuk penerapan biru/hijau

Pertimbangkan praktik terbaik umum berikut saat Anda membuat penerapan biru/hijau dari RDS untuk instans PostgreSQL DB.

  • Perbarui semua ekstensi PostgreSQL Anda ke versi terbaru sebelum membuat deployment blue/green. Untuk informasi selengkapnya, lihat Meningkatkan SQL ekstensi Postgre untuk database Postgre RDS SQL.

  • Transaksi yang berjalan lama dapat menyebabkan kelambatan replika yang signifikan. Untuk mengurangi lag replika, pertimbangkan untuk melakukan hal berikut:

    • Kurangi transaksi jangka panjang yang dapat ditunda hingga setelah lingkungan hijau menyusul lingkungan biru.

    • Kurangi operasi massal di lingkungan biru sampai setelah lingkungan hijau mengejar lingkungan biru.

    • Memulai operasi pembekuan vakum manual pada tabel sibuk sebelum membuat penerapan biru/hijau.

    • Untuk PostgreSQL versi 12 dan lebih tinggi, nonaktifkan parameter index_cleanup pada tabel besar atau sibuk untuk meningkatkan tingkat pemeliharaan normal pada database biru. Untuk informasi selengkapnya, lihat Melakukan vakum di tabel secepat mungkin.

      catatan

      Melewatkan pembersihan indeks secara teratur selama menyedot debu dapat menyebabkan indeks kembung, yang dapat menurunkan kinerja pemindaian. Sebagai praktik terbaik, gunakan pendekatan ini hanya saat menggunakan penerapan biru/hijau. Setelah penerapan selesai, kami sarankan untuk melanjutkan pemeliharaan dan pembersihan indeks reguler.

  • Replikasi yang lambat dapat menyebabkan pengirim dan penerima sering memulai ulang, yang menunda sinkronisasi. Untuk memastikan bahwa mereka tetap aktif, nonaktifkan batas waktu dengan menyetel wal_sender_timeout parameter ke 0 dalam lingkungan biru, dan wal_receiver_timeout parameter ke 0 dalam lingkungan hijau.

  • Untuk mencegah segmen write-ahead log (WAL) dihapus dari lingkungan biru, atur wal_keep_segments parameter ke 15625 untuk PostgreSQL versi 13 dan yang lebih rendah. Untuk versi 14 dan lebih tinggi, atur wal_keep_size parameternya juga 1 TiB, jika ada cukup ruang penyimpanan kosong.

RDS untuk PostgreSQL praktik terbaik untuk penerapan biru/hijau dengan replikasi fisik

Dengan replikasi fisik, Amazon RDS membuat replika baca instans DB sumber. Untuk parameter terkait, pemantauan, penyetelan, dan pemecahan masalah, lihat. Menggunakan replika baca untuk Amazon RDS for PostgreSQL

Untuk penjelasan kapan penerapan biru/hijau menggunakan replikasi fisik alih-alih replikasi logis, lihat. Metode SQL replikasi Postgre untuk penerapan biru/hijau

RDS untuk PostgreSQL praktik terbaik untuk penerapan biru/hijau dengan replikasi logis

Pertimbangkan praktik terbaik berikut saat Anda membuat blue/green deployment that uses logical replication. For an explanation of when blue/green penerapan menggunakan replikasi logis alih-alih replikasi fisik, lihat. Metode SQL replikasi Postgre untuk penerapan biru/hijau

  • Jika database Anda memiliki memori freeable yang cukup, tingkatkan nilai parameter logical_decoding_work_mem DB di lingkungan biru. Tindakan ini memungkinkan lebih sedikit decoding pada disk, alih-alih menggunakan memori. Untuk informasi selengkapnya, lihat Dokumentasi PostgreSQL.

    • Anda dapat memantau overflow transaksi yang ditulis ke disk menggunakan ReplicationSlotDiskUsage CloudWatch metrik. Metrik ini menawarkan wawasan tentang penggunaan disk slot replikasi, membantu mengidentifikasi kapan data transaksi melebihi kapasitas memori dan disimpan di disk. Anda dapat memantau memori yang dapat dibebaskan dengan FreeableMemory CloudWatch metrik. Untuk informasi selengkapnya, lihat Metrik CloudWatch tingkat instans Amazon untuk Amazon RDS.

    • Dalam RDS untuk PostgreSQL versi 14 dan lebih tinggi, Anda dapat memantau ukuran file luapan logis menggunakan tampilan sistem. pg_stat_replication_slots

  • Jika Anda menggunakan aws_s3 ekstensi, berikan akses instans DB hijau ke Amazon S3 melalui peran IAM setelah lingkungan hijau dibuat. Hal ini memungkinkan perintah impor dan ekspor untuk terus berfungsi setelah switchover. Untuk petunjuknya, lihat Menyiapkan akses ke bucket Amazon S3.

  • Tinjau kinerja pernyataan UPDATE dan DELETE Anda dan evaluasi apakah membuat indeks pada kolom yang digunakan dalam klausa WHERE dapat mengoptimalkan kueri ini. Ini dapat meningkatkan kinerja saat operasi diputar ulang di lingkungan hijau.

  • Jika Anda menggunakan pemicu, pastikan mereka tidak mengganggu pembuatan, pembaruan, dan penghapusan, pg_catalog.pg_publicationpg_catalog.pg_subscription, dan pg_catalog.pg_replication_slots objek yang namanya dimulai dengan 'rds'.

  • Jika Anda menentukan versi engine yang lebih tinggi untuk lingkungan hijau, jalankan ANALYZE operasi di semua database untuk menyegarkan pg_statistic tabel. Statistik pengoptimal tidak ditransfer selama peningkatan versi utama, jadi Anda harus membuat ulang semua statistik untuk menghindari masalah kinerja. Untuk praktik terbaik tambahan selama peningkatan versi utama, lihatCara melakukan upgrade versi utama RDS untuk Postgre SQL.

  • Hindari mengonfigurasi pemicu sebagai ENABLE REPLICA atau ENABLE ALWAYS jika pemicu digunakan pada sumber untuk memanipulasi data. Jika tidak, sistem replikasi menyebarkan perubahan dan mengeksekusi pemicu, yang mengarah ke duplikasi.