Fehler bei der Migration beheben
Beim Migrationsjob können während der Laufzeit Fehler auftreten.
- Einige Fehler, wie z. B. ein ungültiges Passwort in der Quelldatenbank, sind wiederherstellbar. Dies bedeutet, dass diese Fehler behoben werden können und der Migrationsjob anschließend automatisch fortgesetzt wird.
- Einige Fehler sind nicht wiederherstellbar, z. B. Fehler bei der Datenreplikation. In diesem Fall muss der Migrationsjob von Anfang an neu gestartet werden.
Wenn ein Fehler auftritt, ändert sich der Status des Migrationsjobs in Failed und der Unterstatus spiegelt den letzten Status vor dem Fehler wider.
Zum Beheben eines Fehlers rufen Sie den fehlgeschlagenen Migrationsjob auf, um den Fehler anzuzeigen, und folgen dann den Schritten in der Fehlermeldung.
Weitere Informationen zum Fehler finden Sie in Cloud Monitoring. Klicken Sie dazu auf den Link im Migrationsjob. Die Logs werden nach dem jeweiligen Migrationsjob gefiltert.
In der folgenden Tabelle finden Sie einige Beispiele für Probleme und deren Lösungsmöglichkeiten:
| Symptom | Mögliche Ursachen | Lösungsvorschlag |
|---|---|---|
| Fehler beim Herstellen einer Verbindung zur Quelldatenbankinstanz. | Es gab ein Verbindungsproblem zwischen der Quelldatenbankinstanz und der Zielinstanz. | Folgen Sie der Anleitung unter Verbindungsprobleme beheben. |
| Fehler beim Ausführen des Migrationsjobs aufgrund inkompatibler Versionen von Quelldatenbank und Ziel. | Die Versionen der Quell- und Zieldatenbank sind keine unterstützte Kombination. Insbesondere ist die angegebene Version der Quelldatenbank nicht mit der Version der Zieldatenbank kompatibel. | Achten Sie darauf, dass die Version der Zieldatenbank mit der Version der Quelldatenbank identisch ist oder eine Hauptversion höher liegt. Erstellen Sie dann einen neuen Migrationsjob. |
| Datendefinitionssprachen (DDLs) oder Datenbearbeitungssprachen (DMLs) sind in der Quelle blockiert. | DDLs, für die die ACCESS EXCLUSIVE Sperre erforderlich ist und die während der vollständigen Dump-Phase ausgeführt werden, sind blockiert. |
Während der ersten Synchronisierung (vollständiger Dump) sollten DDLs oder Programme, für die Wenn sich eine Tabelle beispielsweise noch in der ersten Synchronisierung befindet und ein |
Fehlermeldung: No pglogical extension installed on databases (X)
|
Auf einer oder mehreren Quelldatenbanken ist pglogical nicht installiert. |
Folgen Sie dieser Anleitung, um pglogical auf den Datenbanken der Quellinstanz zu installieren. |
Fehlermeldung: Replication user 'x' doesn't have sufficient privileges.
|
Der Nutzer, der den Database Migration Service verwendet, hat nicht die erforderlichen Berechtigungen, um den angegebenen Vorgang auszuführen. | Folgen Sie dieser Anleitung, um sicherzustellen, dass dieser Nutzer die erforderlichen Berechtigungen hat. |
Fehlermeldung: Unable to connect to source database server.
|
Database Migration Service kann keine Verbindung zum Quelldatenbankserver herstellen. | Achten Sie darauf, dass die Quell- und Zieldatenbankinstanzen miteinander kommunizieren können und dass Sie alle erforderlichen Voraussetzungen erfüllt haben, die beim Definieren der Einstellungen für den Migrationsjob angezeigt wurden. |
Fehlermeldung: The source database 'wal_level' configuration must be equal to 'logical'.
|
Der wal_level für die Quelldatenbank ist auf einen anderen Wert als logical festgelegt. |
Legen Sie wal_level auf logical fest. |
Fehlermeldung: The source database 'max_replication_slots' configuration is not sufficient.
|
Der Parameter max_replication_slots wurde nicht richtig konfiguriert. |
Folgen Sie dieser Anleitung, um diesen Parameter richtig festzulegen. |
Fehlermeldung: The source database 'max_wal_senders' configuration is not sufficient.
|
Der Parameter max_wal_senders wurde nicht richtig konfiguriert. |
Folgen Sie dieser Anleitung, um diesen Parameter richtig festzulegen. |
Fehlermeldung: The source database 'max_worker_processes' configuration is not sufficient.
|
Der Parameter max_worker_processes wurde nicht richtig konfiguriert. |
Folgen Sie dieser Anleitung, um diesen Parameter richtig festzulegen. |
|
Fehlermeldung: ODER
Fehlermeldung: |
Die für die Replikation erforderlichen Einstellungen können während der Hochstufung eines Migrationsjobs nicht bereinigt werden. | Führen Sie für jede Datenbank Befehle als Nutzer mit der Berechtigung Weitere Informationen zu den auszuführenden Befehlen finden Sie unter Replikationsslots bereinigen. |
|
Fehlermeldung: |
Das für Database Migration Service bereitgestellte CA-Zertifikat der Quelle enthält möglicherweise nur das Root-Zertifikat. Für das Quellzertifikat sind jedoch sowohl das Root-Zertifikat als auch alle Zwischenzertifikate erforderlich. Bei Amazon Relational Database Service kann beispielsweise die Verwendung des Zertifikats rds-ca-2019-root.pem zu diesem Problem führen. |
Erstellen Sie ein kombiniertes CA-Zertifikat der Quelle, das sowohl das Root-Zertifikat als auch alle erforderlichen Zwischenzertifikate enthält. Verwenden Sie für den Anwendungsfall von Amazon Relational Database Service anstelle des Zertifikats rds-ca-2019-root.pem das Zertifikat rds-combined-ca-bundle.pem. |
|
Fehlermeldung: |
Der für den Parameter max_locks_per_transaction festgelegte Wert ist nicht ausreichend. |
Legen Sie den Wert für diesen Parameter auf mindestens {max_number_of_tables_per_database}/(max_connections + max_prepared_transactions) fest. |
|
Fehlermeldung: |
Das pglogical-Paket ist nicht richtig auf der Quellinstanz installiert. | Weitere Informationen zur korrekten Installation dieses Pakets finden Sie unter pglogical-Paket auf der Quellinstanz installieren. |
|
Fehlermeldung: |
Die konfigurierte Quelle befindet sich im Wiederherstellungsmodus. | Konfigurieren Sie eine Quelle, die sich nicht im Wiederherstellungsmodus befindet. |
| Der vollständige Dump ist langsam. | Der Import großer Datenmengen aus der Quelldatenbank in das AlloyDB-Ziel kann langsam sein. |
|
Fehlermeldung: subscriber {subscriber_name} initialization failed during nonrecoverable step (d), please try the setup again |
Der Migrationsjob ist während der vollständigen Dump-Phase fehlgeschlagen und kann nicht wiederhergestellt werden. Die Quelldatenbankinstanz wurde neu gestartet oder befindet sich im Wiederherstellungsmodus. Alternativ wurden die Replikationsverbindungen aufgrund eines zu niedrigen Werts für den So finden Sie die Ursache des Problems:
|
|
Fehlermeldung: ERROR: unknown column name {column_name} |
Eine Spalte wurde einer replizierten Tabelle auf dem primären Knoten, aber nicht auf dem Replikatknoten hinzugefügt. |
Bei kontinuierlichen Migrationen werden nur Änderungen der Datenbearbeitungssprache (DML) automatisch aktualisiert. Der Nutzer ist für die Verwaltung von Änderungen der Datendefinitionssprache (DDL) verantwortlich, damit die Quell- und Zieldatenbanken kompatibel bleiben. Dies kann auf zwei Arten erreicht werden:
Beispiele für die Verwendung von |
Fehlermeldung: ERROR: cannot truncate a table referenced in a foreign key constraint |
Der Nutzer hat versucht, eine Tabelle mit einer Fremdschlüsseleinschränkung zu kürzen. |
Entfernen Sie zuerst die Fremdschlüsseleinschränkung und kürzen Sie dann die Tabelle. |
Fehlermeldung: ERROR: connection to other side has died |
Die Replikationsverbindung wurde aufgrund eines zu niedrigen Werts für den |
Erwägen Sie, den |
| Wenn Sie ausgewählte Datenbanken migrieren und der Migrationsjob Daten nicht in eine oder mehrere Datenbanken replizieren kann, wird in der Liste der Datenbanken der Status Fehlgeschlagen angezeigt. | Verschiedene Fehler beim Migrationsjob. | Klicken Sie in der Spalte Fehler auf Fehler ansehen und beheben Sie die Fehler. Sie können die fehlgeschlagenen Datenbanken auch aus dem Migrationsjob entfernen. Weitere Informationen zum Entfernen einer fehlgeschlagenen Datenbank aus einem Migrationsjob finden Sie unter Migrationsjobs verwalten. |
Replikationsslots bereinigen
Eine der folgenden Meldungen wird angezeigt:
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.
Mögliche Ursachen
Wenn Sie eine AlloyDB-Instanz hochstufen und die Quellinstanz von der AlloyDB-Instanz aus nicht erreichbar ist (z. B. die Quellinstanz wird nicht ausgeführt oder Sie haben die AlloyDB-Instanz aus der Zulassungsliste der Quellinstanzen entfernt), können die für die Replikation erforderlichen Einstellungen während der Hochstufung eines Migrationsjobs nicht bereinigt werden. Sie müssen die Replikationsslots manuell bereinigen.
Lösungsvorschlag
Führen Sie für jede Datenbank die folgenden Befehle als Nutzer mit der Berechtigung superuser aus:
Rufen Sie die Namen der Replikationsslots aus der Fehlermeldung ab und führen Sie dann den folgenden Befehl aus, um die Slots einzeln zu löschen:
select pg_drop_replication_slot({slot_name});-
Wenn die Namen der Replikationsslots in der Fehlermeldung nicht verfügbar sind, führen Sie den folgenden Befehl aus, um die vorhandenen Replikationsslots abzufragen:
select pg_drop_replication_slot(slot_name) from pg_replication_slots where slot_name like '%alloydb%' and active = 'f';
-
Wenn keine AlloyDB-Replikate die Quellinstanz verwenden, führen Sie den folgenden Befehl aus, um die
pglogical-Einstellungen zu bereinigen:select pglogical.drop_node(node_name) from pglogical.node where node_name like
'alloydb'; -
Wenn die
pglogical-Erweiterung nicht mehr benötigt wird, führen Sie den folgenden Befehl aus, um die Erweiterung zu deinstallieren:DROP EXTENSION IF EXISTS pglogical;
Verwaiste AlloyDB-Cluster im Bootstrapping-Modus löschen
In seltenen Fällen kann es vorkommen, dass Ihr Migrationsjob gelöscht wurde, der zugehörige AlloyDB-Cluster jedoch nicht und sich noch im Bootstrapping-Modus befindet. Sie können den Cluster mit dem gcloud-Befehl von AlloyDB zum Löschen eines Clusters in Kombination mit der --force Option löschen.
Das Löschen eines Bootstrapping-Clusters, während er von einem Migrationsjob verwendet wird, führt zu undefiniertem Verhalten.
Nutzer und Rollen verwalten
Vorhandene Nutzer migrieren
Der Database Migration Service unterstützt derzeit nicht die Migration vorhandener Nutzer von einer Quellinstanz zu einer AlloyDB-Zielinstanz. Sie können diese Migration verwalten, indem Sie die Nutzer manuell in AlloyDB erstellen.
Informationen zum Nutzer alloydbexternalsync
Während der Migration gehören alle Objekte auf der primären AlloyDB-Instanz dem Nutzer alloydbexternalsync. Nachdem die Daten migriert wurden, können Sie den Eigentümer der Objekte ändern. Führen Sie dazu die folgenden Schritte aus:
- Führen Sie den
GRANT alloydbexternalsync to {USER}Befehl aus. - Führen Sie in jeder Datenbank den
reassign owned by alloydbexternalsync to {USER};Befehl aus. - Führen Sie den Befehl
drop role alloydbexternalsyncaus, um den Nutzeralloydbexternalsynczu entfernen.