Datastream supporta l'architettura multitenant Oracle, in cui un singolo database container (CDB) contiene uno o più database modulari (PDB). Ogni database plug-in è un database autonomo con un ID e un nome univoci e può essere gestito in modo indipendente.
Puoi configurare il tuo database modulare Oracle per l'utilizzo con i seguenti metodi CDC:Per saperne di più sul lettore di log binari e sull'API LogMiner, consulta la pagina Utilizzo dei file di log di ripetizione del database Oracle.
Per istruzioni dettagliate su come configurare il database Oracle di origine per ciascuno di questi metodi, consulta le sezioni seguenti.
Configura il database modulare Oracle per il lettore di log binari
Per configurare il database Oracle pluggable per l'utilizzo con il metodo CDC del lettore di log binari, segui questi passaggi:
Seleziona uno dei seguenti metodi per accedere ai file di log:
- Automatic Storage Management (ASM): se selezioni questa opzione, devi creare una connessione ASM dedicata e fornire i relativi dettagli quando crei il profilo di connessione.
- Directory del database: se selezioni questa opzione, devi creare oggetti directory del database che puntano ai file di log di ripristino e ai file di log archiviati e concedere l'accesso
READ
alle directory all'utente del database:
CREATE DIRECTORY DIRECTORY_NAME_1 as 'ONLINE_REDO_LOGS_PATH'; CREATE DIRECTORY DIRECTORY_NAME_2 as 'ARCHIVED_REDO_LOGS_PATH'; GRANT READ ON DIRECTORY DIRECTORY_NAME_1 to USER_NAME; GRANT READ ON DIRECTORY DIRECTORY_NAME_2 to USER_NAME;
Sostituisci quanto segue:
- DIRECTORY_NAME_1: il nome della directory per i file di log di redo online.
- DIRECTORY_NAME_2: il nome della directory per i file di log di redo archiviati.
- ONLINE_REDO_LOGS_PATH: il percorso della directory in cui devono essere archiviati i file di log di ripristino online.
- ARCHIVED_REDO_LOGS_PATH: il percorso della directory in cui devono essere archiviati i file di log archiviati.
- USER_NAME: il nome dell'utente del database a cui vuoi concedere l'accesso
READ
.
Se selezioni il metodo di lettura dei log binari e utilizzi le directory del database, devi fornire i nomi delle directory dei redo log e dei log archiviati quando crei lo stream.
Verifica che il tuo database sia in esecuzione in modalità
ARCHIVELOG
.Per farlo, accedi al database Oracle ed esegui il seguente comando al prompt SQL:
SELECT LOG_MODE FROM V$DATABASE;
- Se il risultato è
ARCHIVELOG
, vai al passaggio successivo. - Se il risultato è
NOARCHIVELOG
, dovrai abilitare la modalitàARCHIVELOG
per il tuo database. Esegui i seguenti comandi dopo aver eseguito l'accesso come
SYSDBA
:SHUTDOWN IMMEDIATE; STARTUP MOUNT; ALTER DATABASE ARCHIVELOG; ALTER DATABASE OPEN;
I file di log archiviati consumano spazio su disco, quindi devi configurare il parametro
DB_RECOVERY_FILE_DEST_SIZE
per il tuo database. Utilizza questo parametro per specificare (in byte) il limite rigido dello spazio totale da utilizzare per i file di recupero del database di destinazione. Impostando questo parametro, puoi gestire il compromesso tra la protezione del database dall'esaurimento dello spazio su disco e l'interruzione dello stream a causa della perdita della posizione del log.
- Se il risultato è
Definisci una policy di conservazione dei dati per il tuo database eseguendo questi comandi Oracle Recovery Manager (RMAN):
TARGET / CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 4 DAYS;
Ti consigliamo di conservare i backup e i log di archiviazione per almeno 4 giorni, anche se 7 giorni è il periodo consigliato.
Torna al prompt SQL dello strumento di database che utilizzi per configurare il criterio di rotazione dei file di log Oracle. Ti consigliamo di impostare una dimensione massima del file di log non superiore a 512 MB.
Attiva dati di log supplementari. Per farlo, abilita innanzitutto il logging supplementare minimo a livello di database eseguendo il comando seguente:
ALTER DATABASE ADD SUPPLEMENTAL LOG DATA;
Poi scegli se attivare la registrazione per tabelle specifiche o per l'intero database.
Per registrare le modifiche solo per tabelle specifiche, esegui il seguente comando per ogni tabella da replicare:
ALTER TABLE SCHEMA.TABLE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Sostituisci quanto segue:
- SCHEMA: il nome dello schema che contiene la tabella.
- TABLE: il nome della tabella per cui vuoi registrare le modifiche.
Per replicare la maggior parte o tutte le tabelle del database, valuta la possibilità di attivare la registrazione per l'intero database. Esegui il comando seguente per abilitare dati di log supplementari per l'intero database:
ALTER DATABASE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Concedi i privilegi appropriati all'account utente che verrà utilizzato per la connessione al tuo database pluggable. Per farlo, esegui il comando seguente:
GRANT SELECT ON GV_$LOG TO USER_NAME; GRANT SELECT ON GV_$LOGFILE TO USER_NAME; GRANT SELECT ON GV_$ARCHIVED_LOG TO USER_NAME; GRANT SELECT ON GV_$INSTANCE TO USER_NAME; GRANT SELECT ON GV_$STANDBY_LOG TO USER_NAME; GRANT SELECT ON V_$INSTANCE TO USER_NAME; GRANT SELECT ON V_$PDBS TO USER_NAME; GRANT SELECT ON V_$TRANSPORTABLE_PLATFORM TO USER_NAME; GRANT SELECT ON V_$DATABASE TO USER_NAME; GRANT SELECT ON V_$PARAMETER TO USER_NAME; GRANT SELECT ON COL$ TO USER_NAME; GRANT SELECT ON DBA_OBJECTS TO USER_NAME; GRANT SELECT ON DBA_TABLESPACES TO USER_NAME; GRANT SELECT ON DBA_ENCRYPTED_COLUMNS TO USER_NAME; GRANT SELECT ON DBA_EXTENTS TO USER_NAME; GRANT CONNECT TO USER_NAME; GRANT CREATE SESSION TO USER_NAME; GRANT SELECT ANY TABLE TO USER_NAME; GRANT READ ON DIRECTORY ONLINELOG_DIR TO USER_NAME; GRANT READ ON DIRECTORY ARCHIVELOG_DIR TO USER_NAME;
Sostituisci USER_NAME con il nome dell'account utente che intendi utilizzare per connetterti al tuo database.
Configura il database modulare Oracle per LogMiner
Per configurare un database modulare Oracle self-hosted in modo da poterlo utilizzare con l'API LogMiner, segui questi passaggi:
Verifica che il tuo database sia in esecuzione in modalità
ARCHIVELOG
. Per farlo, esegui il comando seguente dal containerCDB$ROOT
:SELECT LOG_MODE FROM V$DATABASE;
- Se il risultato è
ARCHIVELOG
, vai al passaggio 2. - Se il risultato è
NOARCHIVELOG
, dovrai abilitare la modalitàARCHIVELOG
per il tuo database. Esegui i seguenti comandi dopo aver eseguito l'accesso come
SYSDBA
:SHUTDOWN IMMEDIATE; STARTUP MOUNT; ALTER DATABASE ARCHIVELOG; ALTER DATABASE OPEN;
I file di log archiviati consumano spazio su disco, quindi devi configurare il parametro
DB_RECOVERY_FILE_DEST_SIZE
per il tuo database. Utilizza questo parametro per specificare (in byte) il limite rigido dello spazio totale da utilizzare per i file di recupero del database di destinazione. Impostando questo parametro, puoi gestire il compromesso tra la protezione del database dall'esaurimento dello spazio su disco e l'interruzione dello stream a causa della perdita della posizione del log.
- Se il risultato è
Definisci una policy di conservazione dei dati per il tuo database eseguendo il seguente comando Oracle Recovery Manager (RMAN) dal container
CDB$ROOT
:CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 4 DAYS;
Il comando definisce il criterio di conservazione dei dati per tutti i database plug-in nel database contenitore.
Ti consigliamo di conservare i backup e i log di archiviazione per almeno 4 giorni, anche se 7 giorni è il periodo consigliato.
Torna al prompt SQL dello strumento di database che utilizzi per configurare il criterio di rotazione dei file di log Oracle. Ti consigliamo di impostare una dimensione massima del file di log non superiore a 512 MB.
Attiva dati di log supplementari. Per farlo, innanzitutto abilita il logging supplementare nel database a livello di container
CDB$ROOT
eseguendo il seguente comando:ALTER DATABASE ADD SUPPLEMENTAL LOG DATA;
Successivamente, scegli se attivare la registrazione per tabelle specifiche o per l'intero database pluggable.
Per registrare le modifiche solo per tabelle specifiche, connettiti al contenitore del database pluggable ed esegui il seguente comando per ogni tabella da replicare:
ALTER TABLE SCHEMA.TABLE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Sostituisci quanto segue:
- SCHEMA: il nome dello schema che contiene la tabella.
- TABLE: il nome della tabella per cui vuoi registrare le modifiche.
Per replicare più tabelle o tutte le tabelle del database, valuta la possibilità di attivare la registrazione per l'intero database.
Esegui il comando seguente per abilitare dati di log supplementari per l'intero database:
ALTER DATABASE ADD SUPPLEMENTAL LOG DATA (ALL) COLUMNS;
Crea un utente comune. Un utente comune ha la stessa identità nel container
CDB$ROOT
e nei database plug-in. Un utente comune può connettersi ed eseguire operazioni all'interno del contenitoreCDB$ROOT
e di qualsiasi database plug-in in cui dispone di privilegi. Il nome utente comune deve iniziare conC##
oc##
.Concedi i privilegi appropriati all'utente comune che verrà utilizzato per la connessione al tuo database. Sono necessarie autorizzazioni diverse a livello di contenitore
CDB$ROOT
e di database pluggable.- Connettiti al container
CDB$ROOT
ed esegui i seguenti comandi:
GRANT CREATE SESSION TO USER_NAME; GRANT SET CONTAINER TO USER_NAME; GRANT SELECT ON SYS.V_$DATABASE TO USER_NAME; GRANT SELECT ON SYS.V_$LOGMNR_CONTENTS TO USER_NAME; GRANT EXECUTE ON DBMS_LOGMNR TO USER_NAME; GRANT EXECUTE ON DBMS_LOGMNR_D TO USER_NAME; GRANT LOGMINING TO USER_NAME; GRANT EXECUTE_CATALOG_ROLE TO USER_NAME;
- Connettiti al database plug-in ed esegui i seguenti comandi:
GRANT CREATE SESSION TO USER_NAME; GRANT SET CONTAINER TO USER_NAME; GRANT SELECT ANY TABLE TO USER_NAME; GRANT SELECT ON SYS.V_$DATABASE TO USER_NAME; GRANT SELECT ON SYS.V_$LOG TO USER_NAME; -- for primary databases GRANT SELECT ON SYS.V_$STANDY_LOG TO USER_NAME; -- for standby databases GRANT SELECT ON SYS.V_$LOGFILE TO USER_NAME; GRANT SELECT ON SYS.V_$ARCHIVED_LOG TO USER_NAME; GRANT SELECT ON DBA_SUPPLEMENTAL_LOGGING TO USER_NAME; GRANT SELECT ON SYS.V_$PARAMETER TO USER_NAME;
- Connettiti al container
Concedi all'utente comune l'accesso
SELECT
alla visualizzazioneDBA_EXTENTS
nel tuo database. Questo privilegio ti consente di utilizzare il backfill basato suROWID
per l'origine Oracle:GRANT SELECT ON DBA_EXTENTS TO USER_NAME;
Se il tuo database utilizza Transparent Data Encryption (TDE), concedi le seguenti autorizzazioni:
GRANT SELECT ON DBA_TABLESPACES TO USER_NAME; GRANT SELECT ON DBA_ENCRYPTED_COLUMNS TO USER_NAME;
Passaggi successivi
- Scopri di più su come funziona Datastream con le origini Oracle.