Panoramica
Database Migration Service supporta migrazioni continue dai database di origine ai database Cloud SQL di destinazione.
I database di destinazione supportati per Cloud SQL per PostgreSQL includono le versioni:
- Cloud SQL per PostgreSQL 12, 13, 14, 15.
Configura il tuo database Cloud SQL per PostgreSQL di destinazione
Prima di poter utilizzare Database Migration Service per eseguire la migrazione dei dati nel tuo database di destinazione, devi configurare il database:
- Creazione di un'istanza. Consigliamo di utilizzare un tipo di macchina con almeno una CPU dual-core. Ad esempio, se il nome della macchina è
db-custom
e ha 2 CPU e 3840 MB di RAM, il formato del nome del tipo di macchina èdb-custom-2-3840
. - Se ti connetti all'istanza di destinazione utilizzando un indirizzo IP pubblico, Database Migration Service utilizza il proxy di autenticazione Cloud SQL per connettersi all'istanza. Sono necessari i seguenti requisiti:
- L'istanza deve avere un indirizzo IPv4 pubblico.
- L'indirizzo IP pubblico non deve essere accessibile da parte di nessun indirizzo esterno (non è necessario aggiungerlo come indirizzo di rete autorizzato).
- Se ti connetti all'istanza di destinazione utilizzando un indirizzo IP privato, Database Migration Service utilizza Private Service Connect per stabilire la connessione all'istanza. Per ulteriori informazioni, consulta Configurare Private Service Connect per un'istanza di destinazione.
Creazione di un account utente e di un database nell'istanza con lo stesso nome. Ad esempio, se utilizzi Database Migration Service per eseguire la migrazione dei dati nel database
myapp
, anche il nome dell'account utente deve esseremyapp
.- Imposta le seguenti autorizzazioni per l'utente nel database:
CREATE SCHEMA
CREATE TABLE
CREATE DATABASE
SELECT
INSERT
UPDATE
DELETE
TRUNCATE
(per tutte le tabelle)
- (Per i database che contengono chiavi esterne o trigger)
Ignora le chiavi esterne e gli trigger utilizzando l'opzione
REPLICATION
con il tuo account utente di migrazione. Esegui questo comando: Per ulteriori informazioni su come viene eseguita la migrazione di chiavi esterne e trigger, consulta Considerazioni per chiavi esterne e trigger.ALTER USER MIGRATION_USER_NAME WITH replication;
Considerazioni per chiavi esterne e attivatori
Le chiavi esterne e gli attivatori presenti nel database di origine potrebbero causare problemi di integrità dei dati o addirittura l'interruzione del job di migrazione.
Puoi evitare questi problemi se ignori le chiavi esterne e gli trigger utilizzando
l'opzione REPLICATION
per l'utente di migrazione. In alternativa, puoi anche eliminare tutte le chiavi esterne e gli trigger nel database di destinazione e ricrearli al termine della migrazione.
- Trigger
- I dati replicati da Database Migration Service incorporano già le modifiche apportate dagli attivatori nel database di origine. Se gli trigger sono abilitati nella destinazione, possono essere attivati di nuovo e potenzialmente manipolare i dati, causando problemi di integrità o duplicazione dei dati.
- Chiavi esterne
- Database Migration Service non esegue la replica dei dati in modo transazionale, pertanto la migrazione delle tabelle potrebbe non essere eseguita in ordine. Se sono presenti chiavi esterne e viene eseguita la migrazione di una tabella figlio che utilizza una chiave esterna prima della tabella principale, potresti riscontrare errori di replica.