Cloud Composer 1 Cloud Composer 2
Auf dieser Seite wird erläutert, wie Sie DAGs, Daten und Konfigurationen aus Ihren vorhandenen Cloud Composer 1-Umgebungen (Airflow 2) zu Cloud Composer 2 (Airflow 2) übertragen.
In dieser Migrationsanleitung wird die Funktion Snapshots verwendet.
Weitere Migrationsleitfäden
Von | Heute | Methode | Leitfaden |
---|---|---|---|
Cloud Composer 1, Airflow 2 | Cloud Composer 2, Airflow 2 | Seite an Seite, mit Snapshots | Dieser Leitfaden (Snapshots) |
Cloud Composer 1, Airflow 1 | Cloud Composer 2, Airflow 2 | Seite an Seite, mit Snapshots | Migrationsanleitung (Snapshots) |
Cloud Composer 1, Airflow 2 | Cloud Composer 2, Airflow 2 | Parallele, manuelle Übertragung | Anleitung für die manuelle Migration |
Cloud Composer 1, Airflow 1 | Cloud Composer 2, Airflow 2 | Parallele, manuelle Übertragung | Anleitung für die manuelle Migration |
Airflow 1 | Airflow 2 | Parallele, manuelle Übertragung | Anleitung für die manuelle Migration |
Hinweise
Snapshots werden in Cloud Composer 2 ab Version 2.0.9 unterstützt. Cloud Composer 1 unterstützt das Speichern von Umgebungs-Snapshots in 1.18.5.
Cloud Composer unterstützt die parallele Migration von Cloud Composer 1 zu Cloud Composer 2. Es ist nicht möglich, ein direktes Upgrade von Cloud Composer 1 auf Cloud Composer 2 durchzuführen.
Weitere Informationen finden Sie in der Liste der Unterschiede zwischen Cloud Composer 1 und Cloud Composer 2.
Die maximale Größe der Airflow-Datenbank, die Snapshots unterstützt, beträgt 20 GB. Wenn die Datenbank Ihrer Umgebung mehr als 20 GB benötigt, verkleinern Sie die Größe der Airflow-Datenbank.
Schritt 1: DAGs in der Cloud Composer 1-Umgebung pausieren
Halten Sie alle DAGs in Ihrer Cloud Composer 1-Umgebung an, bevor Sie den Snapshot speichern, um doppelte DAG-Ausführungen zu vermeiden.
Sie können eine der folgenden Optionen verwenden:
Rufen Sie in der Airflow-Weboberfläche DAGs auf und pausieren Sie alle DAGs manuell.
Verwenden Sie das Skript composer_dags, um alle DAGs anzuhalten:
python3 composer_dags.py --environment COMPOSER_1_ENV \ --project PROJECT_ID \ --location COMPOSER_1_LOCATION \ --operation pause
Ersetzen Sie:
COMPOSER_1_ENV
durch den Namen der Cloud Composer 1-Umgebung.PROJECT_ID
durch die Projekt-ID.COMPOSER_1_LOCATION
durch die Region, in der sich die Umgebung befindet.
Schritt 2: Snapshot der Cloud Composer 1-Umgebung speichern
Console
Erstellen Sie einen Snapshot Ihrer Umgebung:
Rufen Sie in der Google Cloud Console die Seite Umgebungen auf.
Klicken Sie in der Liste der Umgebungen auf den Namen Ihrer Cloud Composer 1-Umgebung. Die Seite Umgebungsdetails wird geöffnet.
Klicken Sie auf Snapshot erstellen.
Klicken Sie im Dialogfeld Snapshot erstellen auf Senden. In dieser Anleitung speichern Sie den Snapshot im Bucket der Cloud Composer 1-Umgebung. Sie können aber bei Bedarf auch einen anderen Speicherort auswählen.
Warten Sie, bis Cloud Composer den Snapshot erstellt hat.
gcloud
Rufen Sie den Bucket-URI Ihrer Cloud Composer 1-Umgebung ab:
Führen Sie dazu diesen Befehl aus:
gcloud composer environments describe COMPOSER_1_ENV \ --location COMPOSER_1_LOCATION \ --format="value(config.dagGcsPrefix)"
Ersetzen Sie:
COMPOSER_1_ENV
durch den Namen Ihrer Cloud Composer 1-Umgebung.COMPOSER_1_LOCATION
durch die Region, in der sich die Umgebung befindet.
Entfernen Sie in der Ausgabe den Ordner
/dags
. Das Ergebnis ist der URI des Buckets Ihrer Cloud Composer 1-Umgebung.Ändern Sie beispielsweise
gs://us-central1-example-916807e1-bucket/dags
ings://us-central1-example-916807e1-bucket
.
Erstellen Sie einen Snapshot Ihrer Cloud Composer 1-Umgebung:
gcloud beta composer environments snapshots save \ COMPOSER_1_ENV \ --location COMPOSER_1_LOCATION \ --snapshot-location "COMPOSER_1_SNAPSHOTS_FOLDER"
Ersetzen Sie:
COMPOSER_1_ENV
durch den Namen der Cloud Composer 1-Umgebung.COMPOSER_1_LOCATION
durch die Region, in der sich die Cloud Composer 1-Umgebung befindet.COMPOSER_1_SNAPSHOTS_FOLDER
durch den URI des Buckets Ihrer Cloud Composer 1-Umgebung. In dieser Anleitung speichern Sie den Snapshot im Bucket der Cloud Composer 1-Umgebung. Sie können aber bei Bedarf auch einen anderen Speicherort auswählen. Wenn Sie einen benutzerdefinierten Speicherort angeben, müssen die Dienstkonten beider Umgebungen Lese- und Schreibberechtigungen für den angegebenen Speicherort haben.
Schritt 3: Cloud Composer 2-Umgebung erstellen
Erstellen Sie eine Cloud Composer 2-Umgebung. Sie können mit einer Umgebungsvoreinstellung beginnen, die Ihren erwarteten Ressourcenanforderungen entspricht, und Ihre Umgebung später weiter skalieren und optimieren.
Sie müssen keine Konfigurationsüberschreibungen und Umgebungsvariablen angeben, da Sie diese später beim Laden des Snapshots Ihrer Cloud Composer 1-Umgebung ersetzen.
Schritt 4: Snapshot in die Cloud Composer 2-Umgebung laden
Console
So laden Sie den Snapshot in Ihre Cloud Composer 2-Umgebung:
Rufen Sie in der Google Cloud Console die Seite Umgebungen auf.
Klicken Sie in der Liste der Umgebungen auf den Namen Ihrer Cloud Composer 2-Umgebung. Die Seite Umgebungsdetails wird geöffnet.
Klicken Sie auf Snapshot laden.
Klicken Sie im Dialogfeld Snapshot laden auf Durchsuchen.
Wählen Sie den Ordner mit dem Snapshot aus. Wenn Sie den Standardspeicherort für diese Anleitung verwenden, befindet sich dieser Ordner in Ihrem Cloud Composer 1-Umgebungs-Bucket im Ordner
/snapshots
. Sein Name ist der Zeitstempel des Snapshot-Speichervorgangs. Beispiel:us-central1-example-916807e1-bucket/snapshots_example-project_us-central1_example-environment/2022-01-05T18-59-00
Klicken Sie auf Load (Laden) und warten Sie, bis Cloud Composer den Snapshot lädt.
gcloud
Laden Sie den Snapshot Ihrer Cloud Composer 1-Umgebung in Ihre Cloud Composer 2-Umgebung:
gcloud beta composer environments snapshots load \
COMPOSER_2_ENV \
--location COMPOSER_2_LOCATION \
--snapshot-path "SNAPSHOT_PATH"
Ersetzen Sie:
COMPOSER_2_ENV
durch den Namen der Cloud Composer 2-Umgebung.COMPOSER_2_LOCATION
durch die Region, in der sich die Cloud Composer 2-Umgebung befindet.SNAPSHOT_PATH
durch den URI des Buckets Ihrer Cloud Composer 1-Umgebung, gefolgt vom Pfad zum Snapshot. Beispiel:gs://us-central1-example-916807e1-bucket/snapshots/example-project_us-central1_example-environment_2022-01-05T18-59-00
Schritt 5: Pausierung von DAGs in der Cloud Composer 2-Umgebung aufheben
Sie können eine der folgenden Optionen verwenden:
Rufen Sie in der Airflow-Weboberfläche DAGs auf und heben Sie die Pausierung aller DAGs nach und nach manuell auf.
Heben Sie die Pausierung aller DAGs mit dem Skript composer_dags auf:
python3 composer_dags.py --environment COMPOSER_2_ENV \ --project PROJECT_ID \ --location COMPOSER_2_LOCATION \ --operation unpause
Ersetzen Sie:
COMPOSER_2_ENV
durch den Namen der Cloud Composer 2-Umgebung.PROJECT_ID
durch die Projekt-ID.COMPOSER_2_LOCATION
durch die Region, in der sich die Umgebung befindet.
Schritt 6: Auf DAG-Fehler prüfen
Wechseln Sie in der Airflow-Weboberfläche zu DAGs und suchen Sie nach gemeldeten DAG-Syntaxfehlern.
Prüfen Sie, ob DAG-Ausführungen zum richtigen Zeitpunkt geplant sind.
Warten Sie, bis die DAG-Ausführungen in der Cloud Composer 2-Umgebung erfolgt sind, und prüfen Sie, ob sie erfolgreich waren. Wenn eine DAG-Ausführung erfolgreich war, haben Sie ihre Pausierung in der Cloud Composer 1-Umgebung nicht auf. Andernfalls wird in der Cloud Composer 1-Umgebung ein DAG zur selben Zeit und am selben Datum ausgeführt.
Wenn die Ausführung eines bestimmten DAG fehlschlägt, versuchen Sie, Fehler am DAG zu beheben, bis er erfolgreich in Cloud Composer 2 ausgeführt wird.
Schritt 7: Cloud Composer 2-Umgebung überwachen
Nachdem Sie alle DAGs und Konfigurationen in die Cloud Composer 2-Umgebung übertragen haben, überwachen Sie diese auf potenzielle Probleme, fehlgeschlagene DAG-Ausführungen und den allgemeinen Umgebungsstatus.
Wenn die Cloud Composer 2-Umgebung für einen ausreichend langen Zeitraum problemlos ausgeführt wird, sollten Sie die Cloud Composer 1-Umgebung vielleicht löschen.
Nächste Schritte
- Fehlerbehebung bei DAGs
- Fehlerbehebung beim Erstellen der Umgebung
- Fehlerbehebung bei Umgebungsupdates
- Backport-Pakete verwenden