Memecahkan masalah Amazon RDS nol- ETL integrasi dengan Amazon Redshift - 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.

Memecahkan masalah Amazon RDS nol- ETL integrasi dengan Amazon Redshift

Anda dapat memeriksa status ETL integrasi nol dengan menanyakan tabel INTEGRATION sistem SVV_ di Amazon Redshift. Jika kolom state memiliki nilai ErrorState, artinya ada sesuatu yang salah. Untuk informasi selengkapnya, lihat Memantau integrasi menggunakan tabel sistem.

Gunakan informasi berikut untuk memecahkan masalah umum dengan integrasi nol Amazon RDS ETL dengan Amazon Redshift.

Saya tidak dapat membuat ETL integrasi nol

Jika Anda tidak dapat membuat ETL integrasi nol, pastikan bahwa berikut ini benar untuk basis data sumber Anda:

Selain itu, pastikan hal-hal berikut ini sudah benar untuk gudang data target Anda:

Integrasi saya terjebak dalam keadaan Syncing

Integrasi Anda mungkin secara konsisten menunjukkan status Syncing jika Anda mengubah nilai salah satu parameter DB yang diperlukan.

Untuk memperbaiki masalah ini, periksa nilai parameter dalam grup parameter yang terkait dengan database sumber, dan pastikan bahwa mereka cocok dengan nilai yang diperlukan. Untuk informasi selengkapnya, lihat Langkah 1: Buat grup parameter DB kustom.

Jika Anda memodifikasi parameter apa pun, pastikan untuk me-reboot database untuk menerapkan perubahan.

Tabel saya tidak bereplikasi ke Amazon Redshift

Jika Anda tidak melihat satu atau beberapa tabel yang tercermin di Amazon Redshift, Anda dapat menjalankan perintah berikut untuk menyinkronkan ulang tabel tersebut:

ALTER DATABASE dbname INTEGRATION REFRESH TABLES table1, table2;

Untuk informasi lebih lanjut, lihat ALTERDATABASEdi referensi Amazon RedshiftSQL.

Data Anda mungkin tidak mereplikasi karena satu atau beberapa tabel sumber Anda tidak memiliki kunci utama. Dasbor pemantauan di Amazon Redshift menampilkan status tabel ini sebagaiFailed, dan status ETL integrasi nol keseluruhan berubah menjadi. Needs attention Untuk mengatasi masalah ini, Anda dapat mengidentifikasi kunci yang ada di tabel Anda yang dapat menjadi kunci utama, atau Anda dapat menambahkan kunci primer sintetis. Untuk solusi mendetail, lihat Menangani tabel tanpa kunci utama saat membuat Amazon Aurora My atau SQL Amazon RDS untuk ETL integrasi SQL nol Saya dengan Amazon Redshift.

Satu atau beberapa tabel Amazon Redshift saya memerlukan sinkronisasi ulang

Menjalankan perintah tertentu pada database sumber Anda mungkin memerlukan tabel Anda untuk disinkronkan ulang. Dalam kasus ini, tampilan STATE sistem SVVINTEGRATION_ TABLE _ _ menunjukkan table_state dariResyncRequired, yang berarti bahwa integrasi harus memuat ulang data sepenuhnya untuk tabel tertentu dari Pergeseran Merah Saya SQL ke Amazon.

Ketika tabel mulai disinkronkan ulang, tabel ini akan beralih ke status Syncing. Anda tidak perlu mengambil tindakan manual apa pun untuk menyinkronkan ulang tabel. Saat data tabel disinkronkan ulang, Anda tidak dapat mengaksesnya di Amazon Redshift.

Berikut ini adalah beberapa contoh operasi yang dapat menempatkan tabel ke dalam status ResyncRequired, dan beberapa kemungkinan alternatif untuk dipertimbangkan.

Operasi Contoh Alternatif
Menambahkan kolom ke posisi tertentu
ALTER TABLE table_name ADD COLUMN column_name INTEGER NOT NULL first;
Amazon Redshift tidak mendukung penambahan kolom ke posisi tertentu menggunakan kata kunci first atau after. Jika urutan kolom dalam tabel target tidak penting, tambahkan kolom ke akhir tabel menggunakan perintah yang lebih sederhana:
ALTER TABLE table_name ADD COLUMN column_name column_type;
Menambahkan kolom stempel waktu dengan CURRENT_TIMESTAMP default
ALTER TABLE table_name ADD COLUMN column_name TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP;
CURRENT_TIMESTAMPNilai untuk baris tabel yang ada dihitung oleh RDSuntuk My SQL dan tidak dapat disimulasikan di Amazon Redshift tanpa sinkronisasi ulang data tabel lengkap.

Jika memungkinkan, alihkan nilai default ke konstanta literal seperti 2023-01-01 00:00:15 untuk menghindari latensi dalam ketersediaan tabel.

Melakukan beberapa operasi kolom dalam satu perintah
ALTER TABLE table_name ADD COLUMN column_1, RENAME COLUMN column_2 TO column_3;
Pertimbangkan untuk membagi perintah menjadi dua operasi terpisah, ADD dan RENAME, yang tidak memerlukan sinkronisasi ulang.