Nachdem Sie ein Abo erstellt haben, können Sie die Zustellungsmethode in Push, Pull oder Export ändern.
Hinweis
- Erstellen Sie eines der unterstützten Abos.
Erforderliche Rollen und Berechtigungen
Bitten Sie Ihren Administrator, Ihnen die IAM-Rolle „Pub/Sub-Bearbeiter “ (roles/pubsub.editor) für das Abo zuzuweisen, um die Berechtigung zum Ändern eines Abotyps zu erhalten.
Weitere Informationen zum Zuweisen von Rollen finden Sie unter Zugriff auf Projekte, Ordner und Organisationen verwalten.
Diese vordefinierte Rolle enthält die
Berechtigung,
die zum
Ändern eines Abotyps erforderlich ist.
pubsub.subscriptions.update
Sie können diese Berechtigung auch mit benutzerdefinierten Rollen oder anderen vordefinierten Rollen erhalten.
Sie können die Zugriffssteuerung auf Projektebene und auf der Ebene einzelner Ressourcen konfigurieren. Sie können ein Abo in einem Projekt erstellen und es an ein Thema anhängen, das sich in einem anderen Projekt befindet. Achten Sie darauf, dass Sie die erforderlichen Berechtigungen für jedes Projekt haben.
Zustellungstyp eines Abos ändern
Führen Sie die folgenden Schritte aus, um den Zustellungstyp eines Abos zu ändern.
Console
Rufen Sie in der Google Cloud Console die Abos Seite auf.
Klicken Sie auf den Namen des Abos, das Sie aktualisieren möchten.
Klicken Sie auf der Seite mit den Abodetails auf Bearbeiten.
Wählen Sie unter Zustellungstyp den neuen Zustellungstyp aus.
Geben Sie die Attribute für den neuen Abotyp ein. Weitere Informationen finden Sie in den folgenden Themen:
Optional. Aktualisieren Sie bei Bedarf weitere Aboattribute.
Klicken Sie auf Aktualisieren.
gcloud
Verwenden Sie den
gcloud pubsub subscriptions update
Befehl, um den Zustellungstyp zu ändern. Löschen Sie die Konfiguration für den aktuellen Zustellungstyp und legen Sie die Konfiguration für den neuen Typ fest:
gcloud pubsub subscriptions update SUBSCRIPTION_ID \
CLEAR_CONFIG_FLAG \
NEW_CONFIG_FLAGS
Ersetzen Sie Folgendes:
SUBSCRIPTION_ID: Der Name des Abos, das aktualisiert werden soll.
CLEAR_CONFIG_FLAG: Ein Flag zum Löschen der vorhandenen Konfiguration für den Zustellungstyp. Verwenden Sie je nach aktuellem Zustellungstyp eines der folgenden Flags:
Pull-Abo:
--no-enable-exactly-once-deliveryPush-Abo:
--push-endpoint=""BigQuery-Abo:
--clear-bigquery-configCloud Storage-Abo:
--clear-cloud-storage-config
NEW_CONFIG_FLAGS: Flags zum Konfigurieren des neuen Zustellungstyps. Weitere Informationen finden Sie in der Dokumentation zum
gcloud pubsub subscriptions updateBefehl.
Beispiele
BigQuery-Abo in ein Pull-Abo ändern:
gcloud pubsub subscriptions update SUBSCRIPTION_ID \
--clear-bigquery-config
Push-Abo in ein BigQuery-Abo ändern:
gcloud pubsub subscriptions update SUBSCRIPTION_ID \
--push-endpoint="" \
--bigquery-table=BIGQUERY_TABLE
Endpunkt eines Push-Abos aktualisieren
Führen Sie die folgenden Schritte aus, um die Endpunkt-URL für ein Push-Abo zu aktualisieren.
Console
Führen Sie die folgenden Schritte aus, um die Endpunkt-URL zu ändern.
- Rufen Sie in der Google Cloud Console die Abos Seite auf.
- Klicken Sie neben dem Abo, das Sie aktualisieren möchten, auf more_vert.
- Wählen Sie unter Zustellungstyp eine Zustellungsoption aus.
- Geben Sie bei Bedarf weitere Aboattribute ein.
- Klicken Sie auf Aktualisieren.
gcloud
-
Aktivieren Sie Cloud Shell in der Google Cloud Console.
Unten in der Google Cloud Console wird eine Cloud Shell Sitzung gestartet und eine Befehlszeilenaufforderung angezeigt. Cloud Shell ist eine Shell-Umgebung in der das Google Cloud CLI bereits installiert ist und Werte für Ihr aktuelles Projekt bereits festgelegt sind. Das Initialisieren der Sitzung kann einige Sekunden dauern.
-
Führen Sie den
gcloud pubsub subscriptions modify-push-configBefehl aus, um die Endpunkt-URL zu ändern:gcloud pubsub subscriptions modify-push-config SUBSCRIPTION_ID \ --push-endpoint=PUSH_ENDPOINT
Wenn das Abo bereits die Pull-Zustellung verwendet, wird durch die Festlegung des Push-Endpunkts die Zustellungsmethode auf Push-Zustellung umgestellt.
Sie können von Push- zu Pull-Zustellung wechseln, indem Sie den Push-Endpunkt in einen leeren String ändern.
REST
Verwenden Sie die
projects.subscriptions.modifyPushConfig
Methode, um die Push-Konfigurationen eines Abos zu ändern:
Anfrage:
Die Anfrage muss mit einem Zugriffstoken im
Authorization Header authentifiziert werden. So rufen Sie ein Zugriffstoken für die aktuellen
Standardanmeldedaten für Anwendungen ab: gcloud auth application-default print-access-token.
POST https://pubsub.googleapis.com/v1/projects/PROJECT_ID/subscriptions/SUBSCRIPTION_ID:modifyPushConfig Authorization: Bearer ACCESS_TOKEN
Anfragetext:
{
"pushConfig": {
"pushEndpoint": "PUSH_ENDPOINT"
}
}Wobei:
https://myproject.appspot.com/myhandler.Response:
Wenn die Anfrage erfolgreich ist, ist die Antwort ein leeres JSON-Objekt.
C++
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für C++ in der Kurzanleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zur Pub/Sub C++ API.
C#
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für C# in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub C# API.
Go
Im folgenden Beispiel wird die Hauptversion der Go Pub/Sub-Clientbibliothek (Version 2) verwendet. Wenn Sie noch die Version 1 verwenden, lesen Sie den Migrationsleitfaden zu Version 2. Eine Liste der Codebeispiele für Version 1 finden Sie unter Veraltete Codebeispiele.
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für Go in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub Go API.
Java
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für Java in der Kurzanleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub Java API.
Node.js
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für PHP in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub Node.js API.
Node.ts
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für Node.js in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub Node.js API.
Python
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für Python in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zu Pub/Sub Python API.
Ruby
Im folgenden Beispiel wird die Ruby Pub/Sub-Clientbibliothek Version 3 verwendet. Wenn Sie noch die Version 2 verwenden, lesen Sie den Migrationsleitfaden zu Version 3. Eine Liste der Codebeispiele für Ruby Version 2 finden Sie unter Veraltete Codebeispiele.
Bevor Sie dieses Beispiel testen, folgen Sie der Einrichtungsanleitung für Ruby in der Schnellstart-Anleitung: Clientbibliotheken verwenden. Weitere Informationen finden Sie in der Referenzdokumentation zur Pub/Sub Ruby API.
Nächste Schritte
- Abo mit
gcloudBefehlen erstellen oder ändern - Abo mit REST APIs erstellen oder ändern