In diesem Dokument wird beschrieben, wie Sie den automatischen Export Pub/Sub Lite-Nachrichten an Pub/Sub
Im Folgenden finden Sie einige Szenarien, in denen Sie diese Funktion verwenden können:
- Interoperabilität zwischen Arbeitslasten, die eine Mischung aus Pub/Sub Lite verwenden und Pub/Sub.
- Pub/Sub Lite-Arbeitslast zu Pub/Sub migrieren
- Erweiterte Pub/Sub-Funktionen wie Push-Abos und Filterung in einer vorhandenen Anwendung verwenden, die auf Pub/Sub Lite basiert
- Mehrere Datenpipelines konsolidieren
Übersicht
So exportieren Sie Nachrichten von Pub/Sub Lite nach Pub/Sub: erstellen Sie einen speziellen Abotyp, das sogenannte Exportabo. Ein Exportabo empfängt Nachrichten von einem Lite-Thema, konvertiert sie in Pub/Sub-Nachrichten und sendet die konvertierten Nachrichten an ein Ziel-Pub/Sub-Thema.
Ein Lite-Thema kann eine Kombination aus Exportabos und Standardabos enthalten Abos. Die beiden Abotypen sind hinsichtlich Kontingentnutzung und Reservierungsdurchsatz identisch. Ein Exportabo verbraucht Durchsatzkapazität im Lite-Abo und wird berechnet für Durchsatz der Pub/Sub-Veröffentlichung.
Ein Exportabo verbindet ein Lite-Thema mit genau einem Pub/Sub-Thema. Für ein Lite-Thema sind jedoch mehrere Exportvorgänge möglich. Abos, die mit verschiedenen Pub/Sub-Themen verbunden sind (Fan-Out-Architektur). Sie können auch aus mehreren Lite-Themen in das Pub/Sub-Thema (Fan-in-Architektur) erstellt.
Authentifizierung
Ein Exportabo greift sowohl auf Pub/Sub Lite- als auch auf Pub/Sub-Ressourcen zu. Zum Erstellen eines Exportabos benötigen Sie die folgenden Berechtigungen:
pubsublite.subscriptions.create
Die folgenden vordefinierten Rollen enthalten Folgendes: Berechtigung:roles/pubsublite.admin
roles/pubsublite.editor
Weitere Informationen finden Sie unter Zugriffssteuerung für Pub/Sub Lite.
pubsub.topics.get
Die folgenden vordefinierten Rollen enthalten diese Berechtigung:roles/pubsub.admin
roles/pubsub.editor
roles/pubsub.viewer
Weitere Informationen finden Sie unter Zugriffssteuerung für Pub/Sub.
Kundenservicemitarbeiter
Ein Exportabo veröffentlicht ein Pub/Sub-Thema auf Ihrem Dazu wird ein Dienst-Agent verwendet.
Nachdem Sie das erste Exportabo in einem Projekt erstellt haben, wird ein
Der Pub/Sub Lite-Dienst-Agent wird automatisch erstellt. Wenn Sie im selben Projekt zusätzliche Exportabos erstellen, wird für diese derselbe Dienstmitarbeiter verwendet. Der Dienst-Agent hat folgendes Namensschema:
service-<your_project_number>@gcp-sa-pubsublite.iam.gserviceaccount.com
Der Dienst-Agent wurde mit Berechtigungen zum Veröffentlichen für alle erstellt
Pub/Sub- und Pub/Sub Lite-Themen innerhalb derselben
Projekt als Exportabo festlegen. Wenn sich das Ziel-Pub/Sub-Thema in einem anderen Projekt als das Exportabo befindet, müssen Sie dem Kundenservicemitarbeiter zusätzliche Berechtigungen gewähren, indem Sie ihm die Rolle Pub/Sub-Publisher (roles/pubsub.publisher
) zuweisen. Sie können Berechtigungen für ein ganzes Projekt oder ein einzelnes Thema gewähren. Wir empfehlen, Berechtigungen auf Themenebene zu gewähren, gemäß dem Prinzip der geringsten Berechtigung.
Weitere Informationen finden Sie unter Zugriff über die Google Cloud Console steuern.
Sie können auch den Befehl gcloud projects add-iam-policy-binding
verwenden, um IAM-Rollen hinzuzufügen:
gcloud pubsub topics add-iam-policy-binding TOPIC_NAME \ --member=serviceAccount:service-PROJECT_NUMBER@gcp-sa-pubsublite.iam.gserviceaccount.com --role=roles/pubsub.publisher
Ersetzen Sie Folgendes:
- TOPIC_NAME: der Name des Pub/Sub-Ziels Thema, um die IAM-Richtlinienbindung hinzuzufügen.
- PROJECT_NUMBER: Die Projektnummer des Projekts, zu dem das Pub/Sub Lite-Exportabo gehört.
Exportabo erstellen
Sie können ein Lite-Exportabo mit der Google Cloud Console, der Google Cloud CLI oder der Pub/Sub Lite API erstellen.
Das Abo für den Lite-Export muss sich im selben Projekt und am selben Standort befinden wie das Abo für Lite-Exporte. an das sie angehängt ist. Weitere Informationen zum Erstellen eines Lite-Themas finden Sie unter Lite-Themen erstellen und verwalten.
Wenn Sie einem Lite-Thema ein Exportabo zuweisen, müssen alle im Lite-Thema veröffentlichten Nachrichten mit Pub/Sub kompatibel sein. Weitere Informationen finden Sie unter Nachrichtenkompatibilität.
Nachdem ein Exportabo erstellt wurde, können Sie es nicht mehr in ein Standardabo umwandeln und umgekehrt.
Console
Rufen Sie die Seite Lite-Abos auf.
Klicken Sie auf Lite-Abo erstellen.
Geben Sie eine Lite-Abo-ID ein.
Wählen Sie ein Lite-Thema aus, von dem Nachrichten empfangen werden sollen.
Wählen Sie Nachrichten sofort senden oder Nachrichten nach dem Speichern senden aus.
Wählen Sie als Typ Anfangsversatz aus.
Wählen Sie In Pub/Sub-Thema exportieren aus.
Wählen Sie in der Liste Destination topic (Zielthema) ein Pub/Sub-Thema aus, um die exportierten Lite-Nachrichten zu empfangen.
Optional. Geben Sie ein Thema für unzustellbare Nachrichten an.
- Klicken Sie das Kästchen Unzustellbare Nachrichten aktivieren an.
- Wählen Sie ein Lite-Thema aus, das als Thema für unzustellbare Nachrichten verwendet werden soll, oder klicken Sie auf Lite-Thema erstellen, um ein neues Thema für unzustellbare Nachrichten zu erstellen. Das Thema für unzustellbare Nachrichten muss sich am selben Standort (Zone oder Region) und Projekt wie der Export befinden Abo.
Klicken Sie auf Erstellen.
gcloud
Verwenden Sie den Befehl gcloud pubsub lite-subscriptions create
, um ein Exportabo zu erstellen:
gcloud pubsub lite-subscriptions create SUBSCRIPTION_ID \ --location=LOCATION \ --topic=TOPIC_ID \ --export-pubsub-topic=PUBSUB_TOPIC_NAME \ --export-dead-letter-topic=DEAD_LETTER_TOPIC_ID \ --export-desired-state=DESIRED_STATE
Ersetzen Sie Folgendes:
- SUBSCRIPTION_ID: Die ID des zu erstellenden Lite-Abos.
- LOCATION: Der Standort des Lite-Abos.
- TOPIC_ID: Die ID des Lite-Themas, das an das Lite-Abo angehängt werden soll.
- PUBSUB_TOPIC_NAME: Der Name des Pub/Sub-Themas, in das exportiert werden soll. Geben Sie den vollständigen Namen an, wenn sich das Thema in einem anderen Projekt befindet:
projects/my-project-id/topics/my-topic-id
. - DEAD_LETTER_TOPIC_ID: Optional. Die ID eines Lite-Themas, das als Thema für unzustellbare Nachrichten. Das Dead-Letter-Thema muss sich am selben Standort (Zone oder Region) und im selben Projekt wie das Exportabo befinden.
- DESIRED_STATE: Optional. Der Startstatus des Abos.
Folgende Werte werden unterstützt:
active
: Das Abo exportiert Lite-Nachrichten nach Pub/Sub. (Standardeinstellung.)paused
: Der Export von Lite-Nachrichten wurde ausgesetzt.
Wenn die Anfrage erfolgreich ist, wird in der Befehlszeile eine Bestätigung angezeigt:
Created [SUBSCRIPTION_ID].
Protokoll
Senden Sie eine POST
-Anfrage wie die folgende, um ein Lite-Exportabo zu erstellen:
Folgendes:
POST https://REGION-pubsublite.googleapis.com/v1/admin/projects/PROJECT_NUMBER/locations/LOCATION/subscriptions/SUBSCRIPTION_ID Authorization: Bearer $(gcloud auth print-access-token)
Ersetzen Sie Folgendes:
- REGION: Die Region, in der das Lite-Abo gespeichert werden soll.
- PROJECT_NUMBER: Die Projektnummer des Projekts, in dem das Lite-Abo erstellt werden soll.
- LOCATION: Der Name eines Standorts, den Pub/Sub Lite unterstützt.
- SUBSCRIPTION_ID: Die ID des Lite-Abos.
Geben Sie im Anfragetext die folgenden Felder an:
{ "topic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/TOPIC_ID", "deliveryConfig": { "deliveryRequirement": "DELIVERY_REQUIREMENT", }, "exportConfig": { "desiredState": "DESIRED_STATE", "deadLetterTopic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/DEAD_LETTER_TOPIC_ID", "pubsubConfig": { "topic": "PUBSUB_TOPIC_NAME" } } }
Ersetzen Sie Folgendes:
- DELIVERY_REQUIREMENT: Die Lieferanforderung, entweder
DELIVER_AFTER_STORED
oderDELIVER_IMMEDIATELY
. - DESIRED_STATE: Der Startstatus des Abos. Die
folgende Werte werden unterstützt:
ACTIVE
: Das Abo exportiert Lite-Nachrichten nach Pub/SubPAUSED
: Der Export von Lite-Nachrichten ist ausgesetzt.
- DEAD_LETTER_TOPIC_ID: die ID eines vorhandenen Lite-Themas, das verwendet werden soll als Thema für unzustellbare Nachrichten. Das Thema muss im selben Standort (Zone oder Region) und das Projekt als Exportabo selbst.
- PUBSUB_TOPIC_NAME: Der Name des Pub/Sub-Themas, in das exportiert werden soll. Beispielformat:
projects/my-project-id/topics/my-topic-id
.
Wenn die Anfrage erfolgreich ist, ist die Antwort das Lite-Abo im JSON-Format:
{ "deliveryConfig": { "deliveryRequirement": "DELIVERY_REQUIREMENT", }, "exportConfig": { "desiredState": "DESIRED_STATE", "deadLetterTopic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/DEAD_LETTER_TOPIC_ID", "pubsubConfig": { "topic": "PUBSUB_TOPIC_NAME" }, "name": "projects/PROJECT_NUMBER/locations/LOCATION/subscriptions/SUBSCRIPTION_ID", "topic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/TOPIC_ID", }
Go
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 ausführen, folgen Sie den Schritten zur Einrichtung von Java in Pub/Sub Lite-Clientbibliotheken.
Python
Bevor Sie dieses Beispiel ausführen, folgen Sie den Schritten zur Einrichtung von Java in Pub/Sub Lite-Clientbibliotheken.
Exportabo aktualisieren
Sie können Lite-Abos mit der Google Cloud Console, der Google Cloud CLI oder der Pub/Sub Lite API aktualisieren. Es kann bis zu 30 Sekunden dauern, bis die neuen Einstellungen übernommen werden.
Console
Rufe die Seite Lite-Abos auf.
Klicken Sie auf die Lite-Abo-ID.
Klicken Sie auf der Seite Lite-Abonnementdetails auf Bearbeiten.
gCloud
Verwenden Sie zum Aktualisieren eines Lite-Abos den Befehl gcloud pubsub lite-subscriptions update
:
gcloud pubsub lite-subscriptions update SUBSCRIPTION_ID \ --location=LOCATION \ --delivery-requirement=DELIVERY_REQUIREMENT \ --export-pubsub-topic=PUBSUB_TOPIC_NAME \ --export-dead-letter-topic=DEAD_LETTER_TOPIC_ID \ --export-desired-state=DESIRED_STATE
Ersetzen Sie Folgendes:
- SUBSCRIPTION_ID: Die ID des Lite-Abos
- LOCATION: Der Standort des Lite-Abos.
- DELIVERY_REQUIREMENT: Optional. Die Lieferanforderung, entweder
deliver-after-stored
oderdeliver-immediately
. - PUBSUB_TOPIC_NAME: Optional. Der Name des
Pub/Sub-Thema, in das exportiert werden soll. Geben Sie den vollständigen Namen an, wenn sich das Thema in einem anderen Projekt befindet:
projects/my-project-id/topics/my-topic-id
- DEAD_LETTER_TOPIC_ID: die ID eines vorhandenen Lite-Themas, das verwendet werden soll als Thema für unzustellbare Nachrichten. Das Thema muss sich am selben Speicherort (Zone oder Region) und im selben Projekt wie das Exportabo befinden.
- DESIRED_STATE: Optional. Der gewünschte Status des Abos.
Die folgenden Werte werden unterstützt:
active
: Das Abo exportiert Lite-Nachrichten nach Pub/Sub. (Standardeinstellung.)paused
: Der Export von Lite-Nachrichten ist ausgesetzt.
Wenn die Anfrage erfolgreich ist, wird in der Befehlszeile das Lite-Abo angezeigt:
Updated subscription [SUBSCRIPTION_ID]. deliveryConfig: deliveryRequirement: DELIVERY_REQUIREMENT exportConfig: currentState: DESIRED_STATE deadLetterTopic: projects/PROJECT_NUMBER/locations/LOCATION/topics/DEAD_LETTER_TOPIC_ID desiredState: DESIRED_STATE pubsubConfig: topic: PUBSUB_TOPIC_NAME name: projects/PROJECT_NUMBER/locations/LOCATION/subscriptions/SUBSCRIPTION_ID topic: projects/PROJECT_NUMBER/locations/LOCATION/topics/TOPIC_ID
Protokoll
Um ein Lite-Abo zu aktualisieren, senden Sie eine PATCH
-Anfrage wie die folgende:
PATCH https://REGION-pubsublite.googleapis.com/v1/admin/projects/PROJECT_NUMBER/locations/LOCATION/subscriptions/SUBSCRIPTION_ID?updateMask=deliveryConfig.deliveryRequirement,exportConfig Authorization: Bearer $(gcloud auth print-access-token)
Ersetzen Sie Folgendes:
- REGION: Die Region, in der das Lite-Abo erstellt wurde.
- PROJECT_NUMBER: Die Projektnummer des Projekts, in dem das Lite-Abo erstellt wurde.
- LOCATION: Der Standort, an dem das Lite-Abo erstellt wurde.
- SUBSCRIPTION_ID: Die ID des Lite-Abos.
Geben Sie im Anfragetext die folgenden Felder an:
{ "deliveryConfig": { "deliveryRequirement": "DELIVERY_REQUIREMENT", }, "exportConfig": { "desiredState": "DESIRED_STATE", "deadLetterTopic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/DEAD_LETTER_TOPIC_ID", "pubsubConfig": { "topic": "PUBSUB_TOPIC_NAME" } } }
Ersetzen Sie Folgendes:
- DELIVERY_REQUIREMENT: Die Lieferanforderung, entweder
DELIVER_AFTER_STORED
oderDELIVER_IMMEDIATELY
. - DESIRED_STATE: Der gewünschte Status für das Abo. Folgende Werte werden unterstützt:
ACTIVE
: Das Abo exportiert Lite-Nachrichten nach Pub/SubPAUSED
: Der Export von Lite-Nachrichten ist ausgesetzt.
- DEAD_LETTER_TOPIC_ID: Die ID eines vorhandenen Lite-Themas, das als Thema für nicht übermittelbare Nachrichten verwendet werden soll. Das Thema muss im selben Standort (Zone oder Region) und das Projekt als Exportabo selbst.
- PUBSUB_TOPIC_NAME: Der Name des Ziel-Pub/Sub-Themas. Beispielformat:
projects/my-project-id/topics/my-topic-id
.
Wenn die Anfrage erfolgreich ist, ist die Antwort das Lite-Abo im JSON-Format:
{ "deliveryConfig": { "deliveryRequirement": "DELIVERY_REQUIREMENT", }, "exportConfig": { "desiredState": "DESIRED_STATE", "deadLetterTopic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/DEAD_LETTER_TOPIC_ID", "pubsubConfig": { "topic": "PUBSUB_TOPIC_NAME" } }, "name": "projects/PROJECT_NUMBER/locations/LOCATION/subscriptions/SUBSCRIPTION_ID", "topic": "projects/PROJECT_NUMBER/locations/LOCATION/topics/TOPIC_ID", }
Exportabo pausieren oder starten
Für den Export von Abos gibt es die Einstellung Gewünschter Status mit einer der folgenden Werte: zwei Werte:
- Aktiv: Das Abo exportiert Lite-Nachrichten nach Pub/Sub.
- Pausiert: Der Export von Lite-Nachrichten wird ausgesetzt.
So ändern Sie den gewünschten Status in der Google Cloud Console:
Rufen Sie die Seite Lite-Abos auf.
Klicken Sie auf die Lite-Abo-ID.
Klicken Sie auf der Seite Lite-Abonnementdetails auf Pausieren oder Starten.
Sie können den gewünschten Status auch mit der Google Cloud CLI oder der Pub/Sub Lite API. Weitere Informationen finden Sie unter Exportabo aktualisieren
Best Practices
In diesem Abschnitt werden einige Best Practices für die Verwendung von Exportabos beschrieben.
Reservierungen
Wir empfehlen die Verwendung eines Exportabos mit einer reservation-Objekt, anstatt explizit die Durchsatzkapazität des Abos.
Nachrichtenkompatibilität
Wenn eine Pub/Sub Lite-Nachricht nicht kompatibel ist mit Pub/Sub nicht veröffentlicht, wird die Nachricht vom Exportabo Pub/Sub Stattdessen wird die Nachricht in das Thema für unzustellbare Nachrichten verschoben, falls eine zugewiesen wurde. Wenn kein Thema für unzustellbare Nachrichten zugewiesen wurde, werden inkompatible Nachrichten einfach verworfen.
Beachten Sie beim Veröffentlichen von Nachrichten im Lite-Thema die folgenden Kompatibilitätsprobleme:
Tasten. Pub/Sub Lite-Schlüssel haben den Typ
bytes
, während Pub/Sub-Reihenfolgeschlüssel den Typstring
haben. Zur Gewährleistung der Kompatibilität Der Pub/Sub Lite-Schlüssel darf nur UTF-8-Zeichen enthalten.Attribute: Für Nachrichtenattribute gelten die folgenden Anforderungen:
- Für die Kompatibilität müssen alle Pub/Sub Lite-Nachrichtenattribute muss einen einzelnen Wert haben. Pub/Sub Lite unterstützt Nachrichten mit mehreren Werten, aber Pub/Sub unterstützt Einzelwertattributen.
- Die Nachrichtenattribute dürfen die Pub/Sub-Nachrichtenlimits einschließlich der maximalen Attribute pro Nachricht und der maximalen Schlüssel- und Wertgröße pro Nachricht .
Thema für unzustellbare Nachrichten
Wir empfehlen, ein Thema für unzustellbare Nachrichten zu verwenden, um inkompatible Nachrichten zu speichern und zu verarbeiten. Sie können ein Thema für unzustellbare Nachrichten beim Erstellen des Export-Abos zuweisen oder ein vorhandenes Export-Abo aktualisieren, um ein Thema für unzustellbare Nachrichten zu verwenden. Wenn das Abo eine inkompatible Nachricht erhält mit Pub/Sub wird die Nachricht im Thema für unzustellbare Nachrichten veröffentlicht.
Ein Thema für unzustellbare Nachrichten ist ein reguläres Pub/Sub Lite-Thema. Sie muss in denselben Speicherort und dasselbe Projekt wie das Exportabo. Außerdem muss es sich um als ein anderes als das Quellthema.
Normalerweise ist die Durchsatzauslastung eines Themas für unzustellbare Nachrichten gering. Wir empfehlen daher, dem Thema für unzustellbare Nachrichten eine Reservierung zuzuweisen, anstatt dem Thema einen Durchsatz zuzuweisen.
Übermittlungsfehler
Bei einem Exportabo wird versucht, alle kompatiblen Nachrichten an das Ziel-Pub/Sub-Thema zuzustellen. Wenn die Nachrichtenübermittlung fehlschlägt, wird das Exportabo ausgesetzt. Die Fehlerkategorie finden Sie im Messwert subscription/export_status
. Die folgenden Werte weisen auf einen Fehler hin:
PERMISSION_DENIED
: Unzureichende Berechtigungen zum Exportieren von Nachrichten.NOT_FOUND
: Mindestens eine Ressource wurde nicht gefunden. Beispielsweise gibt es das Zielthema nicht.
Weitere Informationen zur Fehlerbehebung finden Sie unter Fehlerbehebung bei Exportabos.
Nachdem Sie den Fehler behoben haben, wird das Abo für den Export automatisch neu gestartet durch regelmäßige Wiederholungsversuche.
Preise
Pub/Sub Lite und Pub/Sub werden Ihnen in Rechnung gestellt. Ressourcen, die das Exportabo verbraucht. Sie werden insbesondere für den zugewiesenen Durchsatz und Speicherplatz des Pub/Sub Lite-Abos in Rechnung gestellt, die für das Pub/Sub Lite-Thema konfiguriert sind. Außerdem werden Ihnen die Kosten für die Veröffentlichung im Ziel-Pub/Sub-Thema in Rechnung gestellt. Weitere Informationen finden Sie unter Pub/Sub – Preise
Für die Nutzung der Exportfunktion fallen keine zusätzlichen Kosten an. Außerdem gibt es keinen Preisunterschied zwischen Pub/Sub Lite-Exportabos und Standardabos.
Probleme beim Exportieren von Abos beheben
In diesem Abschnitt finden Sie einige Tipps zur Fehlerbehebung bei Exportabos.
Das Exportabo ist pausiert
Wenn das Abo pausiert ist, werden keine Nachrichten exportiert.
So erkennen Sie dieses Problem:
Google Cloud Console: Rufen Sie die Abodetails auf. Wenn das Abo pausiert ist, sind Gewünschter Status und Aktueller Status
Paused
.Messwerte: Der Messwert
subscription/export_status
istPAUSED
.
Starten Sie das Abo, um das Problem zu beheben.
Das Zielthema oder das Thema für unzustellbare Nachrichten wurde gelöscht
Wenn Sie das an einen Export angehängte Pub/Sub-Thema löschen oder das Thema für unzustellbare Nachrichten löschen, tritt ein Fehler auf.
So erkennen Sie dieses Problem:
Google Cloud Console: Rufen Sie die Abodetails auf. Wenn das Thema gelöscht wurde, ist der Aktueller Status
Not found
.Messwerte: Der Messwert
subscription/export_status
. Wenn das Thema gelöscht wurde, ist der WertNOT_FOUND
.
Prüfen Sie zur Behebung dieses Problems das Ziel-Pub/Sub-Thema und das Thema mit dem toten Buchstaben (falls konfiguriert).
Wenn das Ziel-Pub/Sub-Thema gelöscht wurde, erstellen Sie es mit demselben Namen neu. Die Veröffentlichung des Exportabonnements wird fortgesetzt, sofern sich die Berechtigungen nicht geändert haben.
Wenn das Thema für unzustellbare Nachrichten gelöscht wurde, erstellen Sie ein neues Thema für unzustellbare Nachrichten und aktualisieren Sie es das Exportabo, um darauf zu verweisen.
Inkompatible Nachrichten
Wenn Nachrichten nicht mit Pub/Sub kompatibel sind, werden sie nicht exportiert.
So erkennen Sie dieses Problem:
- Messwerte: Der Messwert
subscription/unexportable_message_count
gibt die Anzahl der inkompatiblen Nachrichten an, die nicht exportiert werden konnten.
Verwenden Sie ein Thema für unzustellbare Nachrichten, um die inkompatiblen Nachrichten zu speichern. Prüfen Sie die Nachrichten, um die Ursache zu ermitteln, und transformieren Sie sie bei Bedarf und veröffentlichen Sie sie dann noch einmal. Weitere Informationen finden Sie unter Nachrichtenkompatibilität.
Export wurde gedrosselt
So erkennen Sie dieses Problem:
- Messwerte: Der Messwert
subscription/flow_control_status
zeigt eine Ablaufsteuerung. Grund vonNO_CLIENT_TOKENS
, der angibt, dass das Limit pro Partition von Ausstehende Bytes oder Nachrichten wurden erreicht. Bis das Problem behoben ist, erhöht sich der Rückstand für zugehörige Exportabos.
Dieser Fehler kann mehrere Ursachen haben. Die meisten möglichen Ursachen treten im Backend auf. Prüfe aber Folgendes:
- Achten Sie darauf, dass Sie Lite-Nachrichten mit demselben Schlüssel mit einer Rate von weniger als 1 MiB/s pro Schlüssel veröffentlichen. Das Exportabo schreibt Lite-Nachrichtenschlüssel als Pub/Sub-Sortierschlüssel und Pub/Sub hat 1 MiB/s limit für jeden Reihenfolgeschlüssel. Das Überschreiten dieses Limits kann zu einer Drosselung führen.
Der Nutzer ist nicht berechtigt, diese Aktion auszuführen
Der Pub/Sub Lite-Dienst-Agent muss folgende Voraussetzungen erfüllen: Berechtigungen zum Veröffentlichen im Pub/Sub-Zielthema.
So erkennen Sie dieses Problem:
Google Cloud Console: Sehen Sie sich die Abodetails Wenn es Berechtigungsfehler gibt, ist der aktuelle Status
Permission denied
.Messwerte: Der Messwert
subscription/export_status
istPERMISSON_DENIED
.
Dieser Fehler kann beispielsweise in folgenden Situationen auftreten:
- Dem Pub/Sub Lite-Dienst-Agent fehlt die richtige Berechtigung oder Rolle zum Veröffentlichen von Nachrichten im Pub/Sub-Zielthema in ein anderes Projekt ein.
- Der Dienst-Agent wurde aus der IAM-Richtlinie des übergeordneten Projekts des Exportabonnements entfernt.
- Der Pub/Sub Lite-Dienst-Agent wird noch eingerichtet. Ein Dienst-Agent wird automatisch erstellt, wenn Sie das erste Exportabo in einem Projekt erstellen. Der Berechtigungsfehler sollte innerhalb von 10 Minuten automatisch behoben werden.
Prüfen Sie, ob dem Dienst-Agent die richtige Berechtigung erteilt wurde, um das Problem zu beheben Berechtigung oder Rolle haben. Siehe Dienstmitarbeiter.
Nächste Schritte
Wählen Sie zwischen Pub/Sub und Pub/Sub Lite aus.