Anda dapat mengonfigurasi database Oracle sumber untuk digunakan dengan metode CDC berikut:
Untuk mengetahui informasi selengkapnya tentang pembaca log biner dan LogMiner API, lihat Menggunakan file log pengulangan database Oracle.
Untuk mengetahui petunjuk mendetail tentang cara mengonfigurasi database Oracle sumber untuk setiap metode ini, lihat bagian berikut.
Mengonfigurasi database Amazon RDS Oracle untuk pembaca log biner
Untuk sumber Amazon RDS, Datastream hanya mendukung objek direktori database sebagai metode akses log untuk pembaca log biner. Anda harus membuat direktori database yang mengarah ke file log redo online dan file log yang diarsipkan. Nama direktori ini bersifat statis dan tidak dapat diubah nanti. Anda harus memberikan nama ini ke Datastream saat membuat aliran.
Hubungkan ke instance Amazon RDS sumber Anda.
Di terminal, atau menggunakan dasbor Amazon RDS, jalankan perintah berikut:
BEGIN rdsadmin.rdsadmin_master_util.create_archivelog_dir; END; BEGIN rdsadmin.rdsadmin_master_util.create_onlinelog_dir; END; COMMIT; GRANT READ ON DIRECTORY ONLINELOG_DIR TO USER_NAME; GRANT READ ON DIRECTORY ARCHIVELOG_DIR TO USER_NAME;
Pastikan database Anda berjalan dalam mode
ARCHIVELOG
. Untuk melakukannya, login ke database Oracle Anda dan jalankan perintah berikut pada perintah SQL:SELECT LOG_MODE FROM V$DATABASE;
- Jika hasilnya adalah
ARCHIVELOG
, lanjutkan ke langkah c. - Jika hasilnya adalah
NOARCHIVELOG
, Anda harus mengaktifkan modeARCHIVELOG
untuk database Anda. - File log yang diarsipkan menggunakan ruang disk, jadi Anda harus mengonfigurasi parameter DB_RECOVERY_FILE_DEST_SIZE untuk database Anda. Gunakan parameter ini untuk menentukan (dalam byte) batas ketat pada total ruang yang akan digunakan oleh file pemulihan database target. Dengan menyetel parameter ini, Anda dapat mengelola kompromi antara melindungi database agar tidak kehabisan ruang disk dan kegagalan streaming karena hilangnya posisi log.
- Tentukan kebijakan retensi data untuk database Anda dengan menjalankan perintah ini:
Sebaiknya Anda menyimpan cadangan dan log arsip minimal selama 4 hari, dan 7 hari adalah waktu yang direkomendasikan.exec rdsadmin.rdsadmin_util.set_configuration('archivelog retention hours',96);
- Konfigurasi kebijakan rotasi file log Oracle. Sebaiknya tetapkan ukuran file log maksimum ke nilai yang lebih rendah dari 1 GB.
- Jika hasilnya adalah
Aktifkan data log tambahan. Untuk melakukannya, aktifkan terlebih dahulu logging tambahan tingkat database minimal dengan menjalankan perintah berikut:
exec rdsadmin.rdsadmin_util.alter_supplemental_logging('ADD');
Selanjutnya, pilih apakah akan mengaktifkan logging untuk tabel tertentu atau seluruh database.
Untuk mencatat perubahan hanya untuk tabel tertentu, jalankan perintah berikut untuk setiap tabel yang ingin Anda replikasi:
ALTER TABLE SCHEMA.TABLE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Ganti kode berikut:
- SCHEMA: nama skema yang berisi tabel.
- TABLE: nama tabel yang ingin Anda catat perubahannya.
Untuk mereplikasi sebagian besar atau semua tabel dalam database, pertimbangkan untuk mengaktifkan logging untuk seluruh database. Di prompt SQL, jalankan perintah berikut untuk mengaktifkan data log tambahan untuk seluruh database:
exec rdsadmin.rdsadmin_util.alter_supplemental_logging('ADD','ALL');
Berikan hak istimewa berikut kepada pengguna database:
exec rdsadmin.rdsadmin_util.grant_sys_object('GV_$LOG','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('GV_$LOGFILE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('GV_$ARCHIVED_LOG','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('GV_$INSTANCE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('GV_$STANDBY_LOG','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$INSTANCE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$PDBS','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$TRANSPORTABLE_PLATFORM','USER_NAME',
'SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$DATABASE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$PARAMETER','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('COL$','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_OBJECTS','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_TABLESPACES','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_ENCRYPTED_COLUMNS','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_EXTENTS','USER_NAME','SELECT'); GRANT CONNECT TO USER_NAME; GRANT CREATE SESSION TO USER_NAME; GRANT SELECT ANY TABLE TO USER_NAME; Ganti USER_NAME dengan nama akun pengguna yang ingin Anda gunakan untuk terhubung ke database Anda.
Mengonfigurasi database Amazon RDS Oracle untuk LogMiner
Pastikan database Anda berjalan dalam mode
ARCHIVELOG
. Untuk melakukannya, login ke database Oracle Anda dan jalankan perintah berikut pada perintah SQL:SELECT LOG_MODE FROM V$DATABASE;
- Jika hasilnya adalah
ARCHIVELOG
, lanjutkan ke langkah c. Jika hasilnya adalah
NOARCHIVELOG
, Anda harus mengaktifkan modeARCHIVELOG
untuk database Anda.Poin penting: Agar database Anda dapat berjalan dalam mode
ARCHIVELOG
, Anda harus mengaktifkan pencadangan untuk database.File log yang diarsipkan menggunakan ruang disk, jadi Anda harus mengonfigurasi parameter DB_RECOVERY_FILE_DEST_SIZE untuk database Anda. Gunakan parameter ini untuk menentukan (dalam byte) batas ketat pada total ruang yang akan digunakan oleh file pemulihan database target. Dengan menyetel parameter ini, Anda dapat mengelola kompromi antara melindungi database agar tidak kehabisan ruang disk dan kegagalan streaming karena hilangnya posisi log.
Tentukan kebijakan retensi data untuk database Anda dengan menjalankan perintah ini:
exec rdsadmin.rdsadmin_util.set_configuration('archivelog retention hours',96);
Sebaiknya simpan cadangan dan log arsip minimal selama 4 hari, dan 7 hari adalah waktu yang direkomendasikan.
- Jika hasilnya adalah
Aktifkan data log tambahan. Untuk melakukannya, aktifkan terlebih dahulu logging tambahan tingkat database minimal dengan menjalankan perintah berikut:
exec rdsadmin.rdsadmin_util.alter_supplemental_logging('ADD');
Selanjutnya, pilih apakah akan mengaktifkan logging untuk tabel tertentu atau seluruh database.
Untuk mencatat perubahan hanya untuk tabel tertentu, jalankan perintah berikut untuk setiap tabel yang ingin Anda replikasi:
ALTER TABLE SCHEMA.TABLE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Ganti kode berikut:
- SCHEMA: nama skema yang berisi tabel.
- TABLE: nama tabel yang ingin Anda catat perubahannya.
Untuk mereplikasi sebagian besar atau semua tabel dalam database, pertimbangkan untuk mengaktifkan logging untuk seluruh database.
Di prompt SQL, jalankan perintah berikut untuk mengaktifkan data log tambahan untuk seluruh database:
exec rdsadmin.rdsadmin_util.alter_supplemental_logging('ADD','ALL');
Berikan hak istimewa yang sesuai ke akun pengguna yang akan digunakan untuk terhubung ke database Anda. Untuk melakukannya, jalankan perintah berikut:
GRANT EXECUTE_CATALOG_ROLE TO USER_NAME; GRANT CONNECT TO USER_NAME; GRANT CREATE SESSION TO USER_NAME; exec rdsadmin.rdsadmin_util.grant_sys_object('V_$DATABASE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$ARCHIVED_LOG','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$LOG','USER_NAME','SELECT'); -- for primary databases exec rdsadmin.rdsadmin_util.grant_sys_object('V_$STANDBY_LOG','USER_NAME','SELECT'); -- for standby databases exec rdsadmin.rdsadmin_util.grant_sys_object('V_$LOGFILE','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$LOGMNR_LOGS','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$LOGMNR_CONTENTS','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('V_$PARAMETER','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBMS_LOGMNR','USER_NAME','EXECUTE'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBMS_LOGMNR_D','USER_NAME','EXECUTE'); GRANT SELECT ANY TRANSACTION TO USER_NAME; GRANT SELECT ANY TABLE TO USER_NAME;
Jika database Anda menggunakan Enkripsi Data Transparan (TDE), berikan izin berikut:
exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_TABLESPACES','USER_NAME','SELECT'); exec rdsadmin.rdsadmin_util.grant_sys_object('DBA_ENCRYPTED_COLUMNS','USER_NAME','SELECT');
Jika organisasi Anda tidak mengizinkan pemberian izin
GRANT SELECT ANY TABLE
, gunakan solusi yang dijelaskan di bagian Oracle change data capture (CDC) di halaman FAQ Datastream.Jika database sumber Anda adalah Oracle 12c atau yang lebih baru, berikan hak istimewa tambahan berikut:
GRANT LOGMINING TO USER_NAME;
Beri akun pengguna akses
SELECT
ke tampilanDBA_EXTENTS
di database Anda. Dengan hak istimewa ini, Anda dapat menggunakan pengisian ulang berbasisROWID
untuk sumber Oracle Anda:GRANT SELECT ON DBA_EXTENTS TO USER_NAME;
Langkah berikutnya
- Pelajari lebih lanjut cara kerja Datastream dengan sumber Oracle.