Risolvere gli errori di migrazione
Il processo del job di migrazione potrebbe generare errori durante l'esecuzione.
- Alcuni errori, ad esempio una password errata nel database di origine, sono recuperabili, il che significa che possono essere corretti e il job di migrazione riprende automaticamente.
- Alcuni non sono recuperabili, ad esempio gli errori nella replica dei dati, il che significa che il job di migrazione deve essere riavviato dall'inizio.
Quando si verifica un errore, lo stato del job di migrazione diventa Failed
e lo stato secondario riflette l'ultimo stato prima dell'errore.
Per risolvere un problema, vai al job di migrazione non riuscito per visualizzare l'errore e segui i passaggi descritti nel messaggio di errore.
Per visualizzare ulteriori dettagli sull'errore, vai a Cloud Monitoring utilizzando il link nel job di migrazione. I log vengono filtrati in base al job di migrazione specifico.
Nella tabella seguente puoi trovare alcuni esempi di problemi e come risolverli:
Sintomo | Cause possibili | Cose da provare |
---|---|---|
Impossibile connettersi all'istanza del database di origine. | Si è verificato un problema di connettività tra l'istanza del database di origine e l'istanza di destinazione. | Segui i passaggi descritti in Eseguire il debug della connettività. |
Errore durante l'esecuzione del job di migrazione a causa di versioni del database di origine e di destinazione incompatibili. | Le versioni del database di origine e di destinazione non sono una combinazione supportata. Nello specifico, la versione del database di origine fornita non è compatibile con la versione del database di destinazione. | Assicurati che la versione del database di destinazione sia la stessa o una versione principale superiore alla versione del database di origine. Quindi, crea un nuovo job di migrazione. |
I linguaggi di definizione dei dati (DDL) o di manipolazione dei dati (DML) sono bloccati nell'origine. | I comandi DDL che richiedono il ACCESS EXCLUSIVE blocco e sono in esecuzione durante la fase di dump completo sono bloccati. |
Durante la procedura di sincronizzazione iniziale (dump completo), è consigliabile evitare DDL o programmi che richiedono blocchi Ad esempio, se una tabella è ancora in fase di sincronizzazione iniziale e viene eseguito un comando |
Messaggio di errore: No pglogical extension installed on databases (X)
|
In uno o più database di origine non è installato pglogical . |
Segui queste linee guida per installare pglogical nei database dell'istanza di origine. |
Messaggio di errore: Replication user 'x' doesn't have sufficient privileges.
|
L'utente che utilizza Database Migration Service non dispone dei privilegi necessari per eseguire l'operazione designata. | Segui queste linee guida per assicurarti che questo utente disponga dei privilegi richiesti. |
Messaggio di errore: Unable to connect to source database server.
|
Database Migration Service non riesce a stabilire una connessione al server del database di origine. | Assicurati che le istanze del database di origine e di destinazione possano comunicare tra loro e che tu abbia completato tutti i prerequisiti richiesti visualizzati quando hai definito le impostazioni per il job di migrazione. |
Messaggio di errore: The source database 'wal_level' configuration must be equal to 'logical'.
|
wal_level per il database di origine è impostato su un valore diverso da logical . |
Imposta wal_level su logical . |
Messaggio di errore: The source database 'max_replication_slots' configuration is not sufficient.
|
Il parametro max_replication_slots non è stato configurato correttamente. |
Segui queste linee guida per impostare correttamente questo parametro. |
Messaggio di errore: The source database 'max_wal_senders' configuration is not sufficient.
|
Il parametro max_wal_senders non è stato configurato correttamente. |
Segui queste linee guida per impostare correttamente questo parametro. |
Messaggio di errore: The source database 'max_worker_processes' configuration is not sufficient.
|
Il parametro max_worker_processes non è stato configurato correttamente. |
Segui queste linee guida per impostare correttamente questo parametro. |
Messaggio di errore: OPPURE
Messaggio di errore: |
Le impostazioni necessarie per la replica non possono essere eliminate durante la promozione di un job di migrazione. | Per ogni database, esegui i comandi come utente con il privilegio Per ulteriori informazioni sui comandi da eseguire, consulta Eseguire la pulizia degli slot di replica. |
Messaggio di errore: |
Il certificato CA di origine fornito a Database Migration Service potrebbe contenere solo il certificato radice. Tuttavia, il certificato di origine richiede sia il certificato radice sia eventuali certificati intermedi. Ad esempio, per Amazon Relational Database Service, l'utilizzo del certificato rds-ca-2019-root.pem potrebbe causare questo problema. |
Crea un certificato CA di origine combinato che contenga sia il certificato radice sia tutti i certificati intermedi richiesti. Per il caso d'uso di Amazon Relational Database Service, anziché il certificato rds-ca-2019-root.pem, utilizza il certificato rds-combined-ca-bundle.pem. |
Messaggio di errore: |
Il valore impostato per il parametro max_locks_per_transaction non è sufficiente. |
Imposta il valore di questo parametro su almeno {max_number_of_tables_per_database }/(max_connections + max_prepared_transactions ). |
Messaggio di errore: |
Il pacchetto pglogical non è installato correttamente nell'istanza di origine. | Per ulteriori informazioni su come installare correttamente questo pacchetto, consulta Installare il pacchetto pglogical sull'istanza di origine. |
Messaggio di errore: |
L'origine configurata è in modalità di recupero. | Configura un'origine non in modalità di recupero. |
Il dump completo è lento. | La destinazione AlloyDB potrebbe essere lenta nell'importare dati di grandi dimensioni dal database di origine. |
|
Messaggio di errore: subscriber {subscriber_name} initialization failed during nonrecoverable step (d), please try the setup again |
Il job di migrazione non è riuscito durante la fase di dump completo e non è recuperabile. L'istanza del database di origine è stata riavviata o è in modalità di recupero oppure le connessioni di replica sono terminate a causa di un valore insufficiente impostato per il parametro Per trovare la causa principale del problema:
|
|
Messaggio di errore: ERROR: unknown column name {column_name} |
Una colonna è stata aggiunta a una tabella replicata sul nodo principale, ma non sul nodo di replica. |
Solo le modifiche data manipulation language (DML) vengono aggiornate automaticamente durante le migrazioni continue. La gestione delle modifiche al linguaggio di definizione dei dati (DDL) in modo che i database di origine e di destinazione rimangano compatibili è responsabilità dell'utente e può essere eseguita in due modi:
Consulta Migrazione continua per trovare esempi di utilizzo di |
Messaggio di errore: ERROR: cannot truncate a table referenced in a foreign key constraint |
L'utente ha tentato di troncare una tabella con una limitazione della chiave esterna. |
Rimuovi prima la limitazione della chiave esterna e poi tronca la tabella. |
Messaggio di errore: ERROR: connection to other side has died |
La connessione di replica è terminata a causa di un valore insufficiente impostato per |
Valuta la possibilità di aumentare il valore parametro |
Eliminare gli slot di replica
Viene visualizzato uno dei seguenti messaggi:
Cleanup may have failed on source due to error: generic::unknown: failed to connect to on-premises database.
Error promoting EM replica: finished drop replication with errors.
Cause possibili
Quando promuovi un'istanza AlloyDB, se l'istanza di origine non è raggiungibile dall'istanza AlloyDB (ad esempio, l'istanza di origine non è in esecuzione o hai rimosso l'istanza AlloyDB dall'elenco consentiti delle istanze di origine), le impostazioni necessarie per la replica non possono essere eliminate durante la promozione di un job di migrazione. Devi ripulire gli slot di replica manualmente.
Cose da provare
Per ogni database, esegui i seguenti comandi come utente con il privilegio superuser
:
Recupera i nomi degli slot di replica dal messaggio di errore, quindi esegui il seguente comando per eliminarli uno per uno:
select pg_drop_replication_slot({slot_name});
-
Se i nomi degli slot di replica non sono disponibili nel messaggio di errore, esegui il seguente comando per eseguire una query sugli slot di replica esistenti:
select pg_drop_replication_slot(slot_name) from pg_replication_slots where slot_name like '%alloydb%' and active = 'f';
-
Se non sono presenti repliche AlloyDB che utilizzano l'istanza di origine, esegui il seguente comando per ripulire le impostazioni
pglogical
:select pglogical.drop_node(node_name) from pglogical.node where node_name like
'alloydb';
-
Se l'estensione
pglogical
non è più necessaria, esegui il seguente comando per disinstallarla:DROP EXTENSION IF EXISTS pglogical;
Eliminare i cluster AlloyDB orfani in modalità di bootstrap
In rari casi estremi, potresti scoprire che il job di migrazione è stato eliminato, mentre il cluster AlloyDB associato non è stato eliminato ed è ancora in modalità di bootstrap. È possibile eliminare il cluster utilizzando il comando gcloud di AlloyDB per l'eliminazione di un cluster, combinato con l'opzione --force
.
Tieni presente che l'eliminazione di un cluster di bootstrap mentre è in uso da un job di migrazione comporta un comportamento non definito.
Gestire utenti e ruoli
Esegui la migrazione degli utenti esistenti
Al momento, Database Migration Service non supporta la migrazione degli utenti esistenti da un'istanza di origine a un'istanza AlloyDB di destinazione. Puoi gestire questa migrazione creando manualmente gli utenti in AlloyDB.
Informazioni sull'utente alloydbexternalsync
Durante la migrazione, tutti gli oggetti nella principale AlloyDB sono di proprietà dell'utente alloydbexternalsync
. Dopo la migrazione dei dati, puoi modificare la proprietà degli oggetti per altri utenti completando i seguenti passaggi:
- Esegui il comando
GRANT alloydbexternalsync to {USER}
. - Su ogni database, esegui il comando
reassign owned by alloydbexternalsync to {USER};
. - Per rimuovere l'utente
alloydbexternalsync
, esegui il comandodrop role alloydbexternalsync
.