Ce document explique comment mettre à jour une transformation de message unique (SMT) pour un abonnement Pub/Sub. Les modifications apportées aux SMT prennent effet en quelques minutes. Pour les SMT d'abonnement, les modifications prennent effet pour les nouveaux messages envoyés à l'abonnement après la mise à jour de la fonction définie par l'utilisateur.
Pour mettre à jour les SMT d'abonnement, vous pouvez utiliser la console Google Cloud , la Google Cloud CLI, la bibliothèque cliente ou l'API Pub/Sub.
Rôles et autorisations requis
Pour obtenir les autorisations nécessaires pour mettre à jour les SMT d'abonnement, demandez à votre administrateur de vous accorder le rôle IAM Éditeur Pub/Sub (roles/pubsub.editor
) sur votre projet.
Pour en savoir plus sur l'attribution de rôles, consultez la page Gérer l'accès aux projets, aux dossiers et aux organisations.
Ce rôle prédéfini contient les autorisations requises pour mettre à jour les SMT d'un abonnement. Pour connaître les autorisations exactes requises, développez la section Autorisations requises :
Autorisations requises
Les autorisations suivantes sont requises pour mettre à jour les SMT d'abonnement :
-
Accordez l'autorisation de modifier un abonnement :
projects.subscriptions.patch
-
Accorder à la vue une autorisation d'abonnement sur le projet. Cette autorisation n'est requise que si vous utilisez la console Google Cloud :
pubsub.subscriptions.view
Vous pouvez également obtenir ces autorisations avec des rôles personnalisés ou d'autres rôles prédéfinis.
Vous pouvez configurer le contrôle des accès au niveau du projet et au niveau de chaque ressource.
Mettre à jour les SMT d'abonnement
Pour mettre à jour les SMT d'un abonnement, procédez comme suit :
Console
-
Dans la console Google Cloud , accédez à la page Abonnements de Pub/Sub.
-
Cliquez sur l'abonnement pour lequel vous souhaitez modifier les SMT.
-
Sur la page des détails de l'abonnement, cliquez sur Modifier.
L'onglet Transformations liste tous les SMT associés à l'abonnement.
-
Sur la page "Modifier l'abonnement", vous pouvez effectuer les tâches suivantes :
-
Ajoutez un nouveau SMT. Cliquez sur Ajouter une transformation.
-
Modifiez un SMT existant. Développez une transformation de message unique pour la modifier.
-
Réorganisez les SMT. Utilisez les flèches vers le haut et vers le bas.
-
Supprimez un SMT. Cliquez sur le bouton de suppression.
-
-
Cliquez sur Mettre à jour.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
-
Exécutez la commande
gcloud pubsub subscriptions update
:gcloud pubsub subscriptions update SUBSCRIPTION_ID \ --message-transforms-file=TRANSFORMS_FILE
Remplacez les éléments suivants :
-
SUBSCRIPTION_ID : ID ou nom de l'abonnement que vous souhaitez modifier.
-
TRANSFORMS_FILE : chemin d'accès au fichier YAML ou JSON contenant les SMT mis à jour.
Voici un exemple de fichier de transformations YAML :
- javascriptUdf: code: > function redactSSN(message, metadata) { const data = JSON.parse(message.data); delete data['ssn']; message.data = JSON.stringify(data); return message; } functionName: redactSSN - javascriptUdf: code: > function filterHighAmount(message, metadata) { const data = JSON.parse(message.data); if (data['amount'] > 100 ) { return null; } return message; } functionName: filterHighAmount
Pour effacer tous les SMT de l'abonnement, utilisez la commande suivante :
gcloud pubsub subscriptions update SUBSCRIPTION_ID --clear-message-transforms
Remplacez SUBSCRIPTION_ID par l'ID ou le nom de l'abonnement que vous souhaitez modifier.
-