Eine benutzerdefinierte JavaScript-Funktion (UDF) ist eine Art von Single Message Transform (SMT). UDFs bieten eine flexible Möglichkeit, benutzerdefinierte Transformationslogik in Pub/Sub zu implementieren, ähnlich wie BigQuery-JavaScript-UDFs.
UDFs akzeptieren eine einzelne Nachricht als Eingabe, führen die definierten Aktionen für die Eingabe aus und geben das Ergebnis des Prozesses zurück.
UDFs haben die folgenden wichtigen Eigenschaften:
Code:Der JavaScript-Code, der die Transformationslogik definiert.
Funktionsname:Der Name der JavaScript-Funktion im bereitgestellten Code, die Pub/Sub auf Nachrichten anwendet.
JavaScript-Funktion erstellen
Der UDF-Code muss eine Funktion mit der folgenden Signatur enthalten:
/**
* Transforms a Pub/Sub message.
* @return {(Object<string, (string | Object<string, string>)>|* null)} - To
* filter a message, return `null`. To transform a message, return a map with
* the following keys:
* - (required) 'data' : {string}
* - (optional) 'attributes' : {Object<string, string>}
* Returning empty `attributes` will remove all attributes from the message.
*
* @param {(Object<string, (string | Object<string, string>)>} - Pub/Sub
* message. Keys:
* - (required) 'data' : {string}
* - (required) 'attributes' : {Object<string, string>}
*
* @param {Object<string, any>} metadata - Pub/Sub message metadata.
* Keys:
* - (optional) 'message_id' : {string}
* - (optional) 'publish_time': {string} YYYY-MM-DDTHH:MM:SSZ format
* - (optional) 'ordering_key': {string}
*/
function <function_name>(message, metadata) {
// Perform custom transformation logic
return message; // to filter a message instead, return `null`
}
Eingaben
Die Funktion akzeptiert folgende Eingaben:
message-Argument:Ein JavaScript-Objekt, das die Pub/Sub-Nachricht darstellt. Sie enthält die folgenden Attribute:data: (String, erforderlich) Die Nachrichtennutzlast.attributes: (Object<String, String>, optional) Eine Zuordnung von Schlüssel-Wert-Paaren, die Nachrichtenattribute darstellen.
metadata-Argument:Ein JavaScript-Objekt, das unveränderliche Metadaten zur Pub/Sub-Nachricht enthält:message_id: (String, optional) Die eindeutige ID der Nachricht.publish_time: (String, optional) Die Veröffentlichungszeit der Nachricht im RFC 3339-Format (JJJJ-MM-TTTHH:mm:ssZ).ordering_key: (String, optional) Der Sortierschlüssel der Nachricht, falls zutreffend.
Ausgaben
Die Funktion muss einen der folgenden Werte zurückgeben:
Wenn Sie eine Nachricht transformieren möchten, bearbeiten Sie den Inhalt von
message.dataundmessage.attributesund geben Sie das geändertemessage-Objekt zurück.Wenn Sie eine Nachricht filtern möchten, geben Sie
nullzurück.
Anforderungen an Eingabe / Ausgabe
- Wenn die UDF die Nutzlast der Nachricht transformiert, müssen die Nutzlast-Ein- und -Ausgabe UTF-8-codierte Strings sein.
- Wenn die UDF die Nutzlast der Nachricht nicht transformiert, kann die Nutzlast eine beliebige Codierung verwenden.
- Attribut-Schlüssel/Wert-Paare müssen UTF-8-codierte Strings sein.
Wie UDFs eine Nachricht transformieren
Das Ergebnis der Ausführung einer UDF für eine Nachricht kann eines der folgenden sein:
Die UDF transformiert eine Nachricht.
Die UDF gibt
nullzurück.SMTs für Themen: Pub/Sub gibt „success“ an den Publisher zurück und enthält eine Nachrichten-ID in der Antwort für die gefilterten Nachrichten. Pub/Sub speichert die Nachricht nicht und sendet sie nicht an Abonnenten.
SMTs für Abos: Pub/Sub bestätigt die Nachrichtenzustellung, ohne die Nachricht an einen Abonnenten zu senden.
Die UDF gibt einen Fehler aus.
Themen-SMTs: Pub/Sub gibt den Fehler an den Publisher zurück und veröffentlicht keine der Nachrichten.
SMTs für Abos: Pub/Sub bestätigt die Nachricht negativ.
UDF-SMT erstellen
SMTs können für Pub/Sub-Themen oder ‑Abos konfiguriert werden.
- SMTs für Themen werden ausgeführt, bevor Pub/Sub die Nachricht speichert. Die Ergebnisse sind für alle Abonnenten verfügbar.
SMTs für Abos werden vor der Zustellung der Nachricht ausgeführt und die Ergebnisse sind nur für dieses Abo verfügbar.
Console
Rufen Sie in der Google Cloud Console die Pub/Sub-Seite Themen auf.
Erstellen Sie entweder ein Thema oder ein Abo.
Klicken Sie auf Thema erstellen, um ein Thema zu erstellen. Die Seite Thema erstellen wird geöffnet.
So erstellen Sie ein Abo:
Klicken Sie auf den Namen des Themas, das Sie abonnieren möchten.
Klicken Sie auf Abo erstellen. Die Seite Abo zum Thema hinzufügen wird geöffnet.
Klicken Sie unter Transformationen auf Transformation hinzufügen.
Wählen Sie als Transformationstyp die Option JavaScript-UDF aus.
Geben Sie im Feld Funktionsname den Namen der JavaScript-Funktion ein, die vom SMT aufgerufen wird. Beispiel:
redactSSN.Geben Sie den Code für die UDF in den Textbereich ein. Beispiel:
function redactSSN(message, metadata) { const data = JSON.parse(message.data); delete data['ssn']; message.data = JSON.stringify(data); return message; }Der Code muss eine Funktion enthalten, deren Name mit dem Feld Funktionsname übereinstimmt.
Wenn Sie nicht möchten, dass die SMT sofort aktiv ist, wählen Sie Transformation deaktivieren aus. Wenn diese Option ausgewählt ist, wird das SMT mit dem Thema erstellt, aber nicht für eingehende Nachrichten ausgeführt. Nachdem das Thema erstellt wurde, können Sie es bearbeiten, um die SMT zu aktivieren.
Klicken Sie auf Erstellen, um das Thema oder Abo zu erstellen.
gcloud
Definitionsdatei erstellen
Erstellen Sie eine YAML- oder JSON-Datei, in der die UDF-SMT definiert ist.
YAML
- javascriptUdf:
code: { FUNCTION_CODE }
functionName: FUNCTION_NAME
JSON
{
"javascriptUdf": {
"code": {
FUNCTION_CODE
}
"functionName": FUNCTION_NAME
}
}
Ersetzen Sie Folgendes:
FUNCTION_CODE: Der JavaScript-Code für die UDF. Der Code muss eine Funktion enthalten, deren Name mit dem Feld
functionNameübereinstimmt. Beispiel:function redactSSN(message, metadata) { const data = JSON.parse(message.data); delete data['ssn']; message.data = JSON.stringify(data); return message; }FUNCTION_NAME: Der Name der JavaScript-Funktion, die vom SMT aufgerufen wird. Beispiel:
redactSSN.
Thema oder Abo erstellen
Führen Sie den Befehl gcloud pubsub topics create aus, um ein Thema zu erstellen.
gcloud pubsub topics create TOPIC_ID \
--message-transforms-file=TRANSFORMS_FILE
Ersetzen Sie Folgendes:
- TOPIC_ID: Die ID oder der Name des Themas, das Sie erstellen möchten.
- TRANSFORMS_FILE: Der Pfad zur Definitionsdatei.
Führen Sie den Befehl gcloud pubsub subscriptions create aus, um ein Abo zu erstellen.
gcloud pubsub subscriptions create SUBSCRIPTION_ID \
--topic=projects/PROJECT_ID/topics/TOPIC_ID \
--message-transforms-file=TRANSFORMS_FILE
Ersetzen Sie Folgendes:
SUBSCRIPTION_ID: Die ID oder der Name des zu erstellenden Abos.
PROJECT_ID: Die ID des Projekts, das das Thema enthält.
TOPIC_ID: Die ID des Themas, das abonniert werden soll.
TRANSFORMS_FILE: Der Pfad zur Definitionsdatei.
Optional können Sie das SMT validieren und testen, bevor Sie es erstellen. Weitere Informationen finden Sie auf den folgenden Seiten:
Beschränkungen
In Pub/Sub gelten Ressourcenlimits für UDFs, um effiziente Transformationsvorgänge zu gewährleisten. Dazu gehören:
- Maximal 20 KB Code pro UDF
- Maximale Ausführungszeit von 500 ms pro Nachricht
- Unterstützung nur für integrierte ECMAScript-Standards
- Keine Aufrufe externer APIs
- Keine Importe externer Bibliotheken
Beispiel-UDFs
Hier sind einige Beispiel-UDFs für die Veröffentlichung und das Abonnieren. Weitere Beispiele finden Sie in der UDF-Bibliothek.
Funktion: Konvertiert eine Ganzzahl für einen Wochentag in den entsprechenden String.
Wenn Sie die folgende UDF einem Thema oder Abo hinzufügen, werden beim Veröffentlichen oder Zustellen von Nachrichten die folgenden Änderungen vorgenommen:
Pub/Sub wendet die Funktion auf die Nachricht an. Wenn die Nachricht keine JSON-Nutzlast hat, gibt die UDF einen Fehler aus.
Die benutzerdefinierte Funktion sucht nach einem Feld namens
dayOfWeek. Wenn der Wert dieses Felds eine Zahl zwischen 0 und 6 ist, wird er in den entsprechenden Wochentag wieMondayumgewandelt. Wenn das Feld nicht vorhanden ist oder die Zahl nicht im Bereich von 0 bis 6 liegt, wird das FelddayOfWeekim Code aufUnknowngesetzt.Die UDF serialisiert die geänderte Nutzlast zurück in die Nachricht.
Pub/Sub übergibt die aktualisierte Nachricht an den nächsten Schritt in Ihrer Pipeline.
function intToString(message, metadata) {
const data = JSON.parse(message.data);
switch(`data["dayOfWeek"]`) {
case 0:
data["dayOfWeek"] = "Sunday";
break;
case 1:
data["dayOfWeek"] = "Monday";
break;
case 2:
data["dayOfWeek"] = "Tuesday";
break;
case 3:
data["dayOfWeek"] = "Wednesday";
break;
case 4:
data["dayOfWeek"] = "Thursday";
break;
case 5:
data["dayOfWeek"] = "Friday";
break;
case 6:
data["dayOfWeek"] = "Saturday";
break;
default:
data["dayOfWeek"] = "Unknown";
}
message.data = JSON.stringify(data);
return message;
}
Funktion: Sozialversicherungsnummer unkenntlich machen
Wenn Sie die folgende UDF einem Thema oder Abo hinzufügen, werden beim Veröffentlichen oder Zustellen von Nachrichten die folgenden Änderungen vorgenommen:
Pub/Sub wendet die Funktion auf die Nachricht an. Wenn die Nachricht keine JSON-Nutzlast hat, gibt die UDF einen Fehler aus.
Mit der benutzerdefinierten Funktion wird das Feld
ssnaus der Nutzlast der Nachricht entfernt (falls es vorhanden ist).Die UDF serialisiert die geänderte Nutzlast zurück in die Nachricht.
Pub/Sub übergibt die aktualisierte Nachricht an den nächsten Schritt in Ihrer Pipeline.
function redactSSN(message, metadata) {
const data = JSON.parse(message.data);
delete data['ssn'];
message.data = JSON.stringify(data);
return message;
}
Funktion: Bestimmte Nachrichten herausfiltern und automatisch bestätigen
Wenn Sie die folgende UDF einem Thema oder Abo hinzufügen, werden beim Veröffentlichen oder Zustellen von Nachrichten die folgenden Änderungen vorgenommen:
Pub/Sub wendet die Funktion auf die Nachricht an. Wenn die Nachricht keine JSON-Nutzlast hat, gibt die UDF einen Fehler aus.
Die benutzerdefinierte Funktion prüft, ob die Nutzlast ein Feld namens
regionenthält.Wenn der Wert des Felds
regionnichtUSist, gibt die Funktion „null“ zurück. Dadurch wird die Nachricht von Pub/Sub gefiltert.Wenn der Wert des Felds
regionUSist, übergibt Pub/Sub die ursprüngliche Nachricht an den nächsten Schritt in Ihrer Pipeline.
function filterForUSRegion(message, metadata) {
const data = JSON.parse(message.data);
if (data["region"] !== "US") {
return null;
}
return message;
}
Funktion: Nachrichteninhalte validieren, um sicherzustellen, dass der Betrag nicht größer als 100 ist
Wenn Sie die folgende UDF einem Thema oder Abo hinzufügen, werden beim Veröffentlichen oder Zustellen von Nachrichten die folgenden Änderungen vorgenommen:
Pub/Sub wendet die Funktion auf die Nachricht an. Wenn die Nachricht keine JSON-Nutzlast hat, gibt die UDF einen Fehler aus.
Die UDF prüft, ob die Nachricht ein Feld namens
amountenthält.Wenn der Wert des Felds
amountgrößer als100ist, gibt die Funktion einen Fehler aus.Wenn der Wert des Felds
amountnicht größer als100ist, gibt die Funktion die ursprüngliche Nachricht zurück.Pub/Sub markiert die Nachricht dann entweder als fehlgeschlagen oder übergibt die ursprüngliche Nachricht an den nächsten Schritt in Ihrer Pipeline.
function validateAmount(message, metadata) {
const data = JSON.parse(message.data);
if (data["amount"] > 100) {
throw new Error("Amount is invalid");
}
return message;
}
Nächste Schritte
Weitere Beispiele finden Sie in der UDF-Bibliothek.