Cloud Composer 3 | Cloud Composer 2 | Cloud Composer 1
Apache Airflow bietet eine REST API-Schnittstelle, mit der Sie Aufgaben wie das Abrufen von Informationen zu DAG-Ausführungen und -Aufgaben, das Aktualisieren von DAGs, das Abrufen von Airflow-Konfigurationen, das Hinzufügen und Löschen von Verbindungen und das Auflisten von Nutzern ausführen können.
Ein Beispiel für die Verwendung der Airflow REST API mit Cloud Run-Funktionen finden Sie unter DAGs mit Cloud Run-Funktionen auslösen.
Airflow REST API-Versionen
- Airflow 2 verwendet die stabile REST API.
- Die experimentelle REST API wurde von Airflow verworfen.
Stabile Airflow REST API konfigurieren
Die stabile REST API ist in Airflow 2 standardmäßig aktiviert. Cloud Composer verwendet ein eigenes API-Authentifizierungs-Backend.
Die Autorisierung funktioniert wie gewohnt von Airflow. Wenn ein neuer Nutzer über die API autorisiert wird, erhält das Nutzerkonto standardmäßig die Rolle Op
.
Sie können die stabile REST API aktivieren oder deaktivieren oder die Standardnutzerrolle ändern. Dazu überschreiben die folgenden Airflow-Konfigurationsoptionen:
Bereich | Schlüssel | Wert | Hinweise |
---|---|---|---|
api
|
auth_backends
|
airflow.composer.api.backend.composer_auth
|
Ändern Sie zum Deaktivieren der stabilen REST API auf airflow.api.auth.backend.deny_all . |
api
|
composer_auth_user_registration_role
|
Op
|
Sie können eine beliebige andere Rolle angeben |
API-Aufrufe an die Airflow REST API über die Webserver-Zugriffssteuerung zulassen
Je nach Methode, die zum Aufrufen der Airflow REST API verwendet wird, kann die Aufrufmethode entweder eine IPv4- oder IPv6-Adresse verwenden. Denken Sie daran, den IP-Traffic zur Airflow REST API mithilfe der Webserver-Zugriffssteuerung zu entsperren.
Verwenden Sie die Standardkonfigurationsoption All IP addresses have access (default)
, wenn Sie nicht sicher sind, von welchen IP-Adressen Ihre Aufrufe an die Airflow REST API gesendet werden.
Aufrufe an Airflow REST API senden
Dieser Abschnitt enthält ein Beispielskript in Python, mit dem Sie DAGs mit der stabilen Airflow REST API auslösen können.
Fügen Sie den Inhalt des folgenden Beispiels in eine Datei mit dem Namen composer2_airflow_rest_api.py
ein und legen Sie dann die folgenden Variablen fest:
dag_id
: Name eines DAG, wie in der DAG-Quelldatei definiert.dag_config
: Konfiguration für die DAG-Ausführung.web_server_url
: Die URL Ihres Airflow-Webservers. Das Format isthttps://<web-server-id>.composer.googleusercontent.com
.
Mit einem Dienstkonto auf die Airflow REST API zugreifen
In der Airflow-Datenbank ist die Länge des E-Mail-Felds auf 64 Zeichen begrenzt. Dienstkonten haben manchmal E-Mail-Adressen, die länger als 64 Zeichen sind. Es ist nicht möglich, Airflow-Nutzer für solche Dienstkonten auf die übliche Weise zu erstellen. Wenn für ein solches Dienstkonto kein Airflow-Nutzer vorhanden ist, führt der Zugriff auf die Airflow REST API zu den HTTP-Fehlern 401 und 403.
Als Problemumgehung können Sie einen Airflow-Nutzer für ein Dienstkonto registrieren. Verwenden Sie dazu accounts.google.com:NUMERIC_USER_ID
als Nutzernamen und einen beliebigen eindeutigen String als E-Mail-Adresse.
Führen Sie Folgendes aus, um
NUMERIC_USER_ID
für ein Dienstkonto abzurufen:gcloud iam service-accounts describe \ SA_NAME@PROJECT_ID.iam.gserviceaccount.com \ --format="value(oauth2ClientId)"
Ersetzen Sie:
SA_NAME
durch den Namen des Dienstkontos.PROJECT_ID
durch die Projekt-ID.
Erstellen Sie einen Airflow-Nutzer mit der Rolle
Op
für das Dienstkonto:Airflow-UI
Klicken Sie auf Sicherheit > Nutzer auflisten und dann auf Neuen Eintrag hinzufügen. Ihr Airflow-Nutzer muss die Rolle
Admin
haben, um diese Seite zu öffnen.Geben Sie
accounts.google.com:NUMERIC_USER_ID
als Nutzernamen an. Ersetzen SieNUMERIC_USER_ID
durch die Nutzer-ID, die Sie im vorherigen Schritt ermittelt haben.Geben Sie als E-Mail-Adresse eine eindeutige Kennung an. Sie können einen beliebigen eindeutigen String verwenden.
Geben Sie die Rolle für den Nutzer an. Beispiel:
Op
.Das Kästchen Ist aktiv? muss angeklickt sein.
Geben Sie den Vor- und Nachnamen des Nutzers an. Sie können jeden String verwenden.
Klicken Sie auf Speichern.
gcloud
Führen Sie den folgenden Airflow-Befehl aus:
gcloud composer environments run ENVIRONMENT_NAME \ --location LOCATION \ users create -- \ -u accounts.google.com:NUMERIC_USER_ID \ -e UNIQUE_ID \ -f UNIQUE_ID \ -l - -r Op --use-random-password
Ersetzen Sie:
ENVIRONMENT_NAME
durch den Namen der Umgebung.LOCATION
durch die Region, in der sich die Umgebung befindet.NUMERIC_USER_ID
durch die Nutzer-ID, die Sie im vorherigen Schritt ermittelt haben.UNIQUE_ID
durch die Kennung für den Airflow-Nutzer. Sie können einen beliebigen eindeutigen String verwenden.
Nachdem Sie einen Airflow-Nutzer für ein Dienstkonto erstellt haben, wird ein als Dienstkonto authentifizierter Aufrufer als vorab registrierter Nutzer erkannt und in Airflow angemeldet.
Airflow REST API-Komponente skalieren
Die Endpunkte der Airflow REST API und der Airflow-Benutzeroberfläche werden auf dem Airflow-Webserver ausgeführt. Wenn Sie die REST API intensiv verwenden, sollten Sie die für den Airflow-Webserver verfügbare CPU- und Arbeitsspeichermenge entsprechend der erwarteten Auslastung erhöhen.