Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
postgres_get_av_diag()
Fungsi ini menyediakan pesan PEMBERITAHUAN berikut:
- Ketika usia belum mencapai ambang pemantauan
-
Ambang batas pemantauan
postgres_get_av_diag()
untuk mengidentifikasi pemblokir adalah 500 juta transaksi secara default. Jikapostgres_get_av_diag()
menghasilkan PEMBERITAHUAN berikut, ini menunjukkan bahwa usia transaksi belum mencapai ambang batas ini.NOTICE:
postgres_get_av_diag()
checks for blockers that prevent aggressive vacuums only, it does so only after exceedingdvb_threshold
which is 500,000,000 and age of this PostgreSQL cluster is currently at 2. - Tidak terhubung ke database dengan usia ID transaksi tertua
-
postgres_get_av_diag()
Fungsi ini memberikan output paling akurat saat terhubung ke database dengan usia ID transaksi tertua. Database dengan usia ID transaksi tertua yang dilaporkan olehpostgres_get_av_diag()
akan berbeda dari “my_database” dalam kasus Anda. Jika Anda tidak terhubung ke database yang benar, PEMBERITAHUAN berikut akan dibuat:NOTICE: You are not connected to the database with the age of oldest transaction ID. Connect to my_database database and run postgres_get_av_diag() for accurate reporting.
Menghubungkan ke database dengan usia transaksi tertua penting karena alasan berikut:
-
Mengidentifikasi pemblokir tabel sementara: Karena metadata untuk tabel sementara khusus untuk setiap database, mereka biasanya ditemukan dalam database tempat mereka dibuat. Namun, jika tabel sementara kebetulan menjadi pemblokir teratas dan berada di database dengan transaksi tertua, ini bisa menyesatkan. Menghubungkan ke database yang benar memastikan identifikasi akurat dari pemblokir tabel sementara.
-
Mendiagnosis vakum lambat: Metadata indeks dan informasi jumlah tabel bersifat spesifik basis data dan diperlukan untuk mendiagnosis masalah vakum lambat.
-
- Database dengan transaksi tertua berdasarkan usia ada pada database rdsadmin atau template0
-
Dalam kasus tertentu,
rdsadmin
atautemplate0
database dapat diidentifikasi sebagai database dengan usia ID transaksi tertua. Jika ini terjadi,postgres_get_av_diag()
akan mengeluarkan PEMBERITAHUAN berikut:NOTICE: The database with the age of oldest transaction ID is
rdsadmin
ortemplate0
, reach out to support if the reported blocker is inrdsadmin
ortemplate0
.Verifikasi bahwa pemblokir yang terdaftar tidak berasal dari salah satu dari dua database ini. Jika pemblokir dilaporkan ada di salah satu
rdsadmin
atautemplate0
, hubungi dukungan karena basis data ini tidak dapat diakses pengguna dan memerlukan intervensi.Sangat tidak mungkin bagi
template0
databaserdsadmin
atau untuk berisi pemblokir teratas. - Saat vakum agresif sudah berjalan
-
postgres_get_av_diag()
Fungsi ini dirancang untuk melaporkan ketika proses vakum agresif berjalan, tetapi hanya memicu keluaran ini setelah vakum aktif setidaknya selama 1 menit. Penundaan yang disengaja ini membantu mengurangi kemungkinan positif palsu. Dengan menunggu, fungsi memastikan bahwa hanya penyedot debu yang efektif dan signifikan yang dilaporkan, yang mengarah pada pemantauan aktivitas vakum yang lebih akurat dan andal.postgres_get_av_diag()
Fungsi ini menghasilkan PEMBERITAHUAN berikut ketika mendeteksi satu atau lebih vakum agresif yang sedang berlangsung.NOTICE: Your database is currently running aggressive vacuum to prevent wraparound, monitor autovacuum performance.
Sebagaimana ditunjukkan dalam PEMBERITAHUAN, terus memantau kinerja vakum. Untuk informasi lebih lanjut tentang vakum agresif lihat Vakum agresif (untuk mencegah pembungkus) sedang berjalan
- Saat autovacuum dimatikan
-
postgres_get_av_diag()
Fungsi ini menghasilkan PEMBERITAHUAN berikut jika autovacuum dinonaktifkan pada instance database Anda:NOTICE: Autovacuum is OFF, we strongly recommend to enable it, no restart is necessary.
Autovacuum adalah fitur penting dari RDS Anda untuk PostgreSQL PostgreSQL PostgreSQL DB instance yang memastikan kelancaran operasi database. Ini secara otomatis menghapus versi baris lama, merebut kembali ruang penyimpanan, dan mencegah kembung tabel, membantu menjaga tabel dan indeks tetap efisien untuk kinerja optimal. Selain itu, ini melindungi terhadap sampul ID transaksi, yang dapat menghentikan transaksi di instans Amazon RDS Anda. Menonaktifkan autovacuum dapat menyebabkan penurunan jangka panjang dalam kinerja dan stabilitas database. Kami menyarankan Anda untuk tetap menggunakannya setiap saat.
catatan
Mematikan autovacuum tidak menghentikan penyedot debu agresif. Ini masih akan terjadi setelah tabel Anda mencapai
autovacuum_freeze_max_age
ambang batas. - Jumlah transaksi yang tersisa sangat rendah
-
postgres_get_av_diag()
Fungsi ini menghasilkan PEMBERITAHUAN berikut ketika vakum sampul sudah dekat. PEMBERITAHUAN ini dikeluarkan ketika instans Amazon RDS Anda berjarak 100 juta transaksi dari kemungkinan menolak transaksi baru.WARNING: Number of transactions remaining is critically low, resolve issues with autovacuum or perform manual
VACUUM FREEZE
before your instance stops accepting transactions.Tindakan segera Anda diperlukan untuk menghindari downtime database. Anda harus memonitor operasi penyedot debu Anda dan mempertimbangkan secara manual memulai database yang
VACUUM FREEZE
terpengaruh untuk mencegah kegagalan transaksi.