Auf dieser Seite wird beschrieben, wie Sie Schnellstart-Migrationen für homogene PostgreSQL-Migrationen zu AlloyDB for PostgreSQL ausführen.
Übersicht
Schnellstart-Migrationen sind ein einfacher kontinuierlicher Migrationsablauf für homogene PostgreSQL-Szenarien. Bei Schnellstartmigrationen kann Database Migration Service automatisch alles einrichten, was Sie zum Migrieren Ihrer Datenbanken benötigen: Netzwerkkomponenten (Netzwerk-Attachments, Subnetze, Konfigurationen für private Verbindungen), Verbindungsprofile und Migrationsjobs.
Mit Schnellstartmigrationen können Sie Ihre Daten in ein vorhandenes AlloyDB for PostgreSQL-Cluster verschieben oder ein neues Cluster erstellen, während Sie die Migration konfigurieren. Schnellstart-Migrationen eignen sich am besten für:
- Einfache Migrationen, bei denen Sie die Parallelitätseinstellungen für Datendumps nicht genau steuern müssen.
- Migrieren Sie Ihre Datenbank von einem Google Cloud Projekt in ein anderes. Wenn Sie eine Schnellstartmigration konfigurieren, können Sie den Zielcluster in einem anderen Projekt als die Quelle erstellen und Database Migration Service so einrichten, dass der Netzwerkanhang und das Subnetz im VPC-Netzwerk (Virtual Private Cloud) eines anderen Projekts erstellt werden.
-
Migration von Quellen mit einer privaten IP-Adresse in Ihrem VPC-Netzwerk (Virtual Private Cloud), z. B. selbstverwaltete Datenbanken in Compute Engine oder Cloud SQL for PostgreSQL-Instanzen, die für private Netzwerke aktiviert sind. Google Cloud
Für Quellen, die außerhalb von Google Cloud gehostet werden, sind möglicherweise zusätzliche Netzwerkkomponenten (z. B. eine Cloud VPN-Verbindung) erforderlich, damit sie über eine private IP-Adresse in Ihrem VPC-Netzwerk erreicht werden können.
- Die einzige unterstützte Methode für die Datenbankverbindung sind Private Service Connect-Schnittstellen mit Konfigurationen für private Verbindungen von Database Migration Service. Ihrer Quelldatenbank muss im VPC-Netzwerk eine private IP-Adresse zugewiesen sein. Andere homogene Methoden für die Quellverbindung (z. B. Zulassungslisten für öffentliche IP-Adressen, umgekehrte SSH-Tunnel oder VPC-Peering) werden für Schnellstartmigrationen nicht unterstützt.
Weitere Informationen zu Schnellstart-Migrationen finden Sie in der Hauptdokumentation zum Database Migration Service unter Übersicht über Schnellstart-Migrationen.
Hinweis
- Prüfen Sie, ob Schnellstart-Migrationen Ihr Szenario vollständig unterstützen können. Weitere Informationen finden Sie unter Einschränkungen der Schnellstart-Migration.
-
Melden Sie sich in Ihrem Google-Konto an.
Wenn Sie noch kein Konto haben, melden Sie sich hier für ein neues Konto an.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
- Aktivieren Sie die Admin APIs für Database Migration Service, Compute Engine, Network Connectivity Center und AlloyDB for PostgreSQL.
Erforderliche Rollen
Wenn Sie die Berechtigungen benötigen, um mit dem Database Migration Service Schnellstartmigrationen zu AlloyDB for PostgreSQL auszuführen, bitten Sie Ihren Administrator, die erforderlichen IAM-Rollen (Identity and Access Management) für die an der Migration beteiligten Konten in den entsprechenden Projekten zu gewähren. Weitere Informationen zum Zuweisen von Rollen finden Sie in der IAM-Dokumentation unter Zugriff verwalten.
Rollen und Berechtigungen im Quellprojekt
Weisen Sie bestimmten Konten im Projekt Google Cloud , in dem sich Ihre Quelldatenbank befindet, die folgenden Rollen zu:
- Für das Nutzerkonto, mit dem die Migration durchgeführt wird:
Rolle „Compute Network Admin“ (
roles/compute.networkAdmin) - Für das Database Migration Service-Dienstkonto des Zielprojekts:
Compute-Netzwerkbetrachter (
roles/compute.networkViewer)Das Dienstkonto für Database Migration Service wird erstellt, wenn Sie die Database Migration Service API aktivieren. Die mit diesem Konto verknüpfte E‑Mail-Adresse wird automatisch generiert und kann nicht geändert werden. Diese E-Mail-Adresse hat das folgende Format:
service-DESTINATION_PROJECT_NUMBER@gcp-sa-datamigration.iam.gserviceaccount.com
Diese vordefinierten Rollen enthalten die Berechtigungen, die zum Einrichten der Konnektivität für Ihr Quelldatenbankprojekt im Rahmen einer Schnellstartmigration mit Database Migration Service erforderlich sind. Erweitern Sie den Abschnitt Erforderliche Berechtigungen (Quelle), um die erforderlichen Berechtigungen anzuzeigen:
Erforderliche Berechtigungen (Quelle)
Die folgenden Berechtigungen sind erforderlich, um homogene Schnellstartmigrationen mit Database Migration Service durchzuführen:
Für das Nutzerkonto, mit dem die Migration durchgeführt wird:
compute.networks.*compute.subnetworks.*compute.networkAttachments.*
Für das Database Migration Service-Dienstkonto des Zielprojekts:
compute.networkAttachments.get.
Rollen und Berechtigungen im Zielprojekt
Weisen Sie dem Nutzerkonto, das die Migration durchführt, die folgenden Rollen für das Google Cloud -Projekt zu, in dem sich Ihre Zieldatenbank befindet:
-
Administrator für die Datenbankmigration (
roles/datamigration.admin) -
AlloyDB Admin (
roles/alloydb.admin)
Diese vordefinierten Rollen enthalten die Berechtigungen, die zum Einrichten der erforderlichen Migrationskomponenten in Ihrem Ziel-Datenbankprojekt im Rahmen einer Schnellstartmigration mit Database Migration Service erforderlich sind. Erweitern Sie den Abschnitt Erforderliche Berechtigungen (Ziel), um die erforderlichen Berechtigungen anzuzeigen:
Erforderliche Berechtigungen (Ziel)
Die folgenden Berechtigungen sind erforderlich, um homogene Schnellstartmigrationen mit Database Migration Service durchzuführen:
datamigration.*alloydb.clusters.createalloydb.clusters.getalloydb.clusters.listalloydb.clusters.updatealloydb.clusters.deletealloydb.instances.createalloydb.instances.getalloydb.instances.listalloydb.instances.updatealloydb.instances.deletealloydb.instances.executeSqlalloydb.operations.getalloydb.users.listalloydb.users.getalloydb.users.createalloydb.users.updatealloydb.users.delete
Quelldatenbank konfigurieren
So konfigurieren Sie die PostgreSQL-Quelldatenbank:
- Erstellen Sie in Ihrer Instanz ein dediziertes Nutzerkonto für die Migration.
- Informationen zu Cloud SQL for PostgreSQL-Quellen finden Sie in der Cloud SQL-Dokumentation unter Nutzer erstellen.
- Informationen zu anderen Quellen finden Sie in der Dokumentation Ihres Datenbankanbieters oder unter Nutzer erstellen und verwalten in der PostgreSQL-Dokumentation.
- Weisen Sie dem dedizierten Migrationsnutzerkonto die erforderlichen Berechtigungen zu.
Führen Sie die folgenden Befehle für jede Datenbank aus, die Sie migrieren möchten:
-- Grant the REPLICATION attribute ALTER ROLE MIGRATION_USER REPLICATION; -- Grant database-level permissions. -- Repeat for each database you want to migrate. GRANT CONNECT, CREATE ON DATABASE DATABASE_NAME TO MIGRATION_USER; -- Grant schema-level usage. -- Repeat for each schema in each database you want to migrate. GRANT USAGE ON SCHEMA SCHEMA_NAME TO MIGRATION_USER;
Ersetzen Sie Folgendes:
- MIGRATION_USER durch den Namen des Migrationsnutzerkontos.
- Ersetzen Sie DATABASE_NAME durch den Namen der Datenbank, die Sie migrieren möchten.
- Ersetzen Sie SCHEMA_NAME durch den Namen des Schemas in der Datenbank, die Sie migrieren möchten.
- Das Migrationsnutzerkonto muss Inhaberzugriff auf die Tabellen haben, die Sie migrieren. Führen Sie einen der folgenden Schritte aus, um diese Zugriffsebene zu gewähren:
- Weisen Sie dem Migrationskonto die PostgreSQL-Rolle
SUPERUSERzu.- Weisen Sie für Cloud SQL for PostgreSQL-Quellen die Rolle
cloudsqlsuperuserzu. - Weisen Sie für andere Quellen die Rolle
SUPERUSERzu oder sehen Sie in der Dokumentation Ihres Datenbankanbieters nach einer entsprechenden Berechtigungsgruppe.
- Weisen Sie für Cloud SQL for PostgreSQL-Quellen die Rolle
- Fügen Sie das Migrationsnutzerkonto der Nutzergruppe hinzu, zu der die Tabellen gehören.
Führen Sie dazu diesen Befehl aus:
-- Grant table ownership. GRANT TABLE_OWNER_GROUP_NAME TO MIGRATION_USER;
Ersetzen Sie Folgendes:
- TABLE_OWNER_GROUP_NAME durch den Namen der Nutzergruppe, zu der jede Tabelle gehört, die Sie migrieren möchten.
- MIGRATION_USER durch den Namen des Migrationsnutzerkontos.
- Weisen Sie dem Migrationskonto die PostgreSQL-Rolle
- Bei Tabellen ohne Primärschlüssel: Database Migration Service repliziert während der CDC-Phase (Change Data Capture) keine
UPDATE- oderDELETE-Vorgänge für Tabellen ohne Primärschlüssel. Wenn Sie solche Vorgänge in Ihre Replikation einbeziehen möchten, ändern Sie Tabellen ohne Primärschlüssel mitREPLICA IDENTITY:ALTER TABLE TABLE_NAME REPLICA IDENTITY FULL; ALTER TABLE TABLE_NAME REPLICA IDENTITY USING INDEX INDEX_NAME;
Ersetzen Sie Folgendes:
- TABLE_NAME ist der Name der Tabelle ohne Primärschlüssel.
- INDEX_NAME ist der eindeutige Index, mit dem Zeilen aus Tabellen ohne Primärschlüssel verfolgt werden können.
- Konfigurieren Sie die Replikationseinstellungen mit Datenbank-Flags.
Selbstverwaltete Quellen
Wenn Sie Änderungen an Datenbank-Flags speichern, ist ein vollständiger Neustart der Datenbank erforderlich. In den folgenden Beispielen werden SQL-Abfragen zum Ändern von Flag-Werten verwendet. Wenn Sie SQL-Abfragen nicht direkt ausführen können, finden Sie in der Dokumentation Ihres Anbieters eine Anleitung zum Ändern dieser Flags.
- Setzen Sie den Parameter
wal_levelauflogical. Führen Sie dazu diesen Befehl aus:ALTER SYSTEM SET wal_level = 'logical';
- Setzen Sie den Parameter
wal_sender_timeoutauf0. Dieser Wert deaktiviert das Zeitlimit, das zum Beenden inaktiver Replikationsverbindungen verwendet wird. Führen Sie dazu diesen Befehl aus:ALTER SYSTEM SET wal_sender_timeout = 0;
- Konfigurieren Sie die maximale Anzahl von Replikations-Slots mit dem Parameter
max_replication_slots. Dieser Parameter muss mindestens auf die Anzahl der Datenbanken festgelegt werden, die Sie pro Migrationsjob migrieren, zuzüglich einiger Reserven für die Tabellensynchronisierung.Wenn Sie beispielsweise 5 Datenbanken migrieren und 2 Migrationsjobs für die Quellinstanz erstellt werden, muss die Anzahl der Replikations-Slots mindestens
5 * 2 = 10betragen, zuzüglich der Anzahl der Replikations-Slots, die Sie bereits verwenden.Führen Sie den folgenden Befehl aus, um diesen Parameter festzulegen:
Dabei steht NUMBER_OF_SLOTS für die maximale Anzahl von Replikations-Slots.ALTER SYSTEM SET max_replication_slots = NUMBER_OF_SLOTS;
- Konfigurieren Sie den Parameter
max_wal_sendersauf mindestens denselben Wert wiemax_replication_slots, zuzüglich der Anzahl der Absender, die bereits auf Ihrer Instanz verwendet werden.Wenn für den Parameter
max_replication_slotsbeispielsweise der Wert10festgelegt ist und Sie bereits zwei Absender verwenden, beträgt die Anzahl der gleichzeitig ausgeführten WAL-Senderprozesse10 + 2 = 12.Führen Sie den folgenden Befehl aus, um diesen Parameter festzulegen:
Dabei steht NUMBER_OF_SENDERS für die Anzahl der gleichzeitig ausgeführten WAL-Senderprozesse.ALTER SYSTEM SET max_wal_senders = NUMBER_OF_SENDERS;
- Legen Sie
max_worker_processesauf mindestens die Anzahl der Datenbanken fest, die Sie migrieren möchten, plus die Anzahl dermax_worker_processes, die bereits auf Ihrer Instanz verwendet werden. Führen Sie den folgenden Befehl aus, um diesen Parameter festzulegen: Dabei steht NUMBER_OF_PROCESSES für die Anzahl der Datenbanken, die migriert werden.ALTER SYSTEM SET max_worker_processes = NUMBER_OF_PROCESSES;
Cloud SQL for PostgreSQL-Quellen
Bei Cloud SQL-Quellen konfigurieren Sie Datenbank-Flags in der Google Cloud -Konsole. Sie müssen die Instanz neu starten, damit die Änderungen an den Datenbankkennzeichnungen wirksam werden. Weitere Informationen zum Festlegen von Datenbank-Flags in Cloud SQL finden Sie in der Cloud SQL-Dokumentation unter Datenbank-Flags konfigurieren.
- Legen Sie das Flag
cloudsql.logical_decodingaufonfest. - Setzen Sie den Parameter
wal_sender_timeoutauf0. Dieser Wert deaktiviert das Zeitlimit, das zum Beenden inaktiver Replikationsverbindungen verwendet wird. - Konfigurieren Sie die maximale Anzahl von Replikations-Slots mit dem Parameter
max_replication_slots. Dieser Parameter muss mindestens auf die Anzahl der Datenbanken festgelegt werden, die Sie pro Migrationsjob migrieren, zuzüglich einiger Reserven für die Tabellensynchronisierung.Wenn Sie beispielsweise 5 Datenbanken migrieren und 2 Migrationsjobs für die Quellinstanz erstellt werden, muss die Anzahl der Replikations-Slots mindestens
5 * 2 = 10betragen, zuzüglich der Anzahl der Replikations-Slots, die Sie bereits verwenden. - Konfigurieren Sie den Parameter
max_wal_sendersauf mindestens denselben Wert wiemax_replication_slotsplus die Anzahl der Absender, die bereits auf Ihrer Instanz verwendet werden.Wenn für den Parameter
max_replication_slotsbeispielsweise der Wert10festgelegt ist und Sie bereits zwei Absender verwenden, beträgt die Anzahl der gleichzeitig ausgeführten WAL-Senderprozesse10 + 2 = 12. - Setzen Sie
max_worker_processesauf mindestens die Anzahl der Datenbanken, die Sie migrieren möchten, plus die Anzahl dermax_worker_processes, die bereits auf Ihrer Instanz verwendet werden.
- Setzen Sie den Parameter
Schnellstart-Migration erstellen und ausführen
So erstellen und führen Sie eine Schnellstartmigration aus:
- Rufen Sie in der Google Cloud Console die Seite Erste Schritte auf.
- Wählen Sie im Menü Quellmodul die Option PostgreSQL aus.
- Wählen Sie im Menü Zielmodul die Option AlloyDB for PostgreSQL aus.
Der Abschnitt Neu: Schnellstart-Migration für PostgreSQL wird angezeigt.
- Klicken Sie im Bereich Neu: Schnellstart-Migration für PostgreSQL auf Migration starten.
Die Seite Zu AlloyDB for PostgreSQL migrieren wird geöffnet.
- Führen Sie im Abschnitt Migration konfigurieren die folgenden Schritte aus:
- Wählen Sie im Menü Zielregion die Region Ihres AlloyDB for PostgreSQL-Zielclusters aus.
- Geben Sie im Feld Migrationspräfix einen lesbaren String ein, der den Namen aller Migrationseinheiten hinzugefügt wird, die für die Schnellstartmigration erstellt werden: Verbindungsprofile, Konfiguration für private Verbindungen, Netzwerkanhang und zugehöriges Subnetz sowie Migrationsjob.
- Wählen Sie im Menü Konfigurationstyp eine der folgenden Optionen aus:
- Bestehende Konfiguration für Verbindungen: Wählen Sie diese Option aus, wenn Sie bereits einen Netzwerk-Anhang und eine Konfiguration für private Verbindungen haben, die die Methode „Private Service Connect-Schnittstellen“ verwendet. Diese Option eignet sich am besten, wenn Sie zuvor Schnellstartmigrationen verwendet haben und dieselben Netzwerkressourcen wiederverwenden möchten.
- Neue Konfiguration für die Verbindung: Wählen Sie diese Option aus, um einen neuen Netzwerkanhang und das Subnetz des Netzwerkanhangs im VPC-Netzwerk der Quelldatenbank zu erstellen. Die Konfiguration für private Verbindungen wird im selben Projekt wie Ihr Zielcluster erstellt.
Klicken Sie auf Weiter.
- Führen Sie im Abschnitt Quelle verbinden folgende Schritte aus:
- Geben Sie einen Hostnamen oder die private IP-Adresse Ihrer Quelldatenbank ein. Die Adresse der Quelldatenbank muss über Ihr Quell-VPC-Netzwerk erreichbar sein.
- Geben Sie den Port ein, der für den Zugriff auf den Host verwendet wird. Der PostgreSQL-Standardport ist
5432. - Geben Sie den Nutzernamen und das Passwort für das dedizierte Migrationskonto in Ihrer Quelldatenbank ein.
- Wählen Sie im Menü Verschlüsselungstyp eine der folgenden Optionen aus:
- Keine: Wenn für Ihre Quelldatenbank keine SSL/TLS-verschlüsselten Verbindungen erforderlich sind.
- Erforderlich: Wenn für Ihre Quelldatenbank SSL/TLS-verschlüsselte Verbindungen erforderlich sind. Für diese Option ist keine Zertifikatsüberprüfung erforderlich.
- Klicken Sie im Menü Zu migrierende Datenbanken auf Anpassen. Wählen Sie in der Seitenleiste nur die Datenbanken aus, die Sie zu AlloyDB for PostgreSQL migrieren möchten. Klicken Sie auf Weiter.
- Im Abschnitt Ziel konfigurieren können Sie einen neuen Zielcluster erstellen oder einen vorhandenen auswählen.
Neue Cluster
So erstellen Sie einen neuen Zielcluster:
- Wählen Sie im Menü Zielinstanztyp die Option Neuer Cluster aus.
Database Migration Service verwendet die AlloyDB for PostgreSQL-Standardkonfiguration für einen neuen Cluster. Klicken Sie auf Anpassen, um Clusterfunktionen wie den Maschinentyp, die zonale Verfügbarkeit oder die Datenschutzeinstellungen anzupassen. Weitere Informationen zur Clusterkonfiguration finden Sie in der AlloyDB for PostgreSQL-Dokumentation unter Cluster und zugehörige primäre Instanz erstellen.
- Geben Sie im Feld Passwort ein Passwort für den Standardadministratornutzer
postgresqlein. Database Migration Service stellt als dieser Nutzer eine Verbindung her, um Ihre Daten zu migrieren.
Vorhandene Cluster
Sie können Datenbanken zu einem vorhandenen Cluster migrieren. Achten Sie darauf, dass der Zielcluster für Private Service Connect aktiviert ist und keine gegenseitige TLS-Authentifizierung (mTLS) mit AlloyDB-Connectors erzwungen wird. Gehen Sie dazu so vor:
- Wählen Sie im Menü Zielinstanztyp die Option Vorhandener Cluster aus.
- Wählen Sie im Menü Vorhandene Cluster-ID die Cluster-ID aus.
- Wählen Sie im Menü Zielinstanztyp die Option Neuer Cluster aus.
- Klicken Sie auf Migration starten.
Database Migration Service erstellt jetzt den Migrationsjob und beginnt mit der Migration. Sie können den Migrationsfortschritt sowie den Zustand Ihres Zielclusters in AlloyDB for PostgreSQL überwachen. Weitere Informationen finden Sie in der AlloyDB for PostgreSQL-Dokumentation unter Instanzdetails ansehen.
Migration abschließen
Wenn Sie sich entscheiden, Ihre Anwendung auf die neue AlloyDB for PostgreSQL-Instanz umzustellen, schließen Sie die Migration mit den folgenden Schritten ab:
- Beenden Sie alle Schreibvorgänge in die Quelldatenbank. Sie können sie in den schreibgeschützten Modus versetzen, um die Betriebsfunktionen beizubehalten.
- Migrationsjob hochstufen
- Optional: Migrationsdaten auf Vollständigkeit prüfen