Cette page explique comment recevoir et confirmer des messages à l'aide de la fonctionnalité de traitement de type "exactement une fois" de Pub/Sub, qui vous permet de suivre et d'éviter le traitement en double des messages. Lorsque la fonctionnalité est activée, Pub/Sub fournit la sémantique suivante :
Les abonnés peuvent déterminer si les accusés de réception des messages ont abouti.
Aucune nouvelle diffusion n'est effectuée une fois le message confirmé.
Aucune nouvelle distribution n'est effectuée tant qu'un message est en attente. Un message est considéré en attente jusqu'à l'expiration du délai de confirmation ou jusqu'à ce que le message soit confirmé.
En cas de distribution multiple valide, en raison de l'expiration du délai d'accusé de réception ou d'un accusé de réception négatif déclenché par le client, seul le dernier ID d'accusé de réception peut être utilisé pour accuser réception du message. Toutes les requêtes avec un ID de confirmation précédent échouent.
Lorsque cette option est activée, les abonnés peuvent s'assurer que les messages sont traités un en suivant ces consignes:
Confirmez les messages dans le délai de confirmation.
Conservez les informations sur l'avancement du traitement d'un message jusqu'à ce qu'il soit confirmé.
Utilisez les informations sur la progression du traitement d'un message pour éviter les doublons lorsque l'acquittement échoue.
Seul le type d'abonnement pull est compatible avec la distribution "exactement une fois", y compris les abonnés qui utilisent l'API StreamingPull. Transférer et exporter des abonnements ne prennent pas en charge la distribution de type "exactement une fois".
Pub/Sub permet la distribution "exactement une fois" dans une région cloud, en fonction d'une règle de pare-feu unique définie par Pub/Sub ID du message.
Versions recommandées de la bibliothèque cliente
- Pour de meilleures performances, utilisez la dernière version de la bibliothèque cliente, Python v2.13.6 ou version ultérieure, Java v1.120.11 ou version ultérieure, PHP v1.39.0 ou version ultérieure, C# v3.2.0 ou version ultérieure, C++ v2.1.0, Go v1.25.1 ou version ultérieure, Node v3.2.0 ou version ultérieure et Ruby v2.12.1 ou version ultérieure.
Nouvel envoi par rapport à un doublon
Il est important de comprendre la différence entre les prévisions et les imprévus à nouveau.
Une nouvelle livraison peut se produire en cas de refus à l'initiative du client accusé de réception d'un message ou lorsque le client n'étend pas l'accusé de réception délai du message avant l'expiration du délai d'accusé de réception. Les nouvelles livraisons sont considérées comme valides et le système fonctionne comme prévu.
Pour résoudre les problèmes liés aux renvois, consultez la section Gérer les doublons.
Un doublon se produit lorsqu'un message est renvoyé après un accusé de réception réussi ou avant l'expiration du délai d'accusé de réception.
Un message réexpédié conserve le même ID de message entre les tentatives de réexpédition.
Les abonnements pour lesquels la distribution de type "exactement une fois" est activée ne reçoivent pas de diffusions en double.
Compatibilité avec la distribution de type "exactement une fois" dans les bibliothèques clientes
Les bibliothèques clientes compatibles disposent d'une interface pour l'acquittement avec réponse (par exemple, Go). Vous pouvez utiliser cette interface pour vérifier si la requête d'acquittement a réussi. Si la demande d'accusé de réception aboutit, les clients sont assurés de ne pas recevoir de nouvelle livraison. Si la demande d'accusé de réception échoue, les clients peuvent s'attendre à une nouvelle livraison.
Les clients peuvent également utiliser les bibliothèques clientes compatibles sans utiliser d'accusé de réception. Toutefois, dans ce cas, les échecs de confirmation peuvent entraîner des nouvelles diffusions silencieuses des messages.
Les bibliothèques clientes compatibles disposent d'interfaces permettant de définir la durée minimale de prolongation du bail (par exemple, Go). Vous devez définir une valeur élevée pour l'extension de location minimale. pour éviter toute expiration d'accusé de réception liée au réseau. La valeur maximale est définie sur 600 secondes.
Les valeurs et la plage par défaut des variables liées à la diffusion exactement une fois, ainsi que les noms des variables, peuvent varier d'une bibliothèque cliente à l'autre. Pour exemple, dans la bibliothèque cliente Java, les variables suivantes contrôlent une distribution de type "exactement une fois".
Variable | Description | Valeur |
---|---|---|
setEnableExactlyOnceDelivery |
Active ou désactive la distribution "exactement une fois". | "true" ou "false" (par défaut : "false") |
minDurationPerAckExtension |
Durée minimale, en secondes, pour prolonger le délai d'accusé de réception des modifications. | Plage=0 à 600 Par défaut=aucun |
maxDurationPerAckExtension |
Durée maximale (en secondes) à utiliser pour prolonger le délai de confirmation de la modification. | Plage : 0 à 600 ; valeur par défaut : aucune |
Dans le cas d'une distribution de type "exactement une fois", modifyAckDeadline
ou acknowledgment
La requête envoyée à Pub/Sub échoue lorsque l'ID d'accusé de réception a déjà expiré. Dans ces
le service considère l'ID d'accusé de réception expiré comme non valide,
une livraison plus récente
est peut-être déjà en cours. C'est la conception pour une fois
la livraison. Vous voyez ensuite que les requêtes acknowledgment
et ModifyAckDeadline
renvoient une réponse INVALID_ARGUMENT
. Lorsque la diffusion de type "exactement une fois" est désactivée, ces requêtes renvoient OK
en cas d'ID de confirmation expirés.
Pour vous assurer que les requêtes acknowledgment
et ModifyAckDeadline
disposent d'ID de confirmation valides, envisagez de définir la valeur de minDurationPerAckExtension
sur un nombre élevé.
Points à prendre en compte concernant les régions
La garantie de distribution de type "exactement une fois" ne s'applique que lorsque les abonnés se connectent au service dans la même région. Si votre application d'abonné est répartie sur plusieurs régions, cela peut entraîner la distribution de messages en double, même lorsque la distribution de type "exactement une fois" est activée. Les éditeurs peuvent envoyer des messages à n'importe quelle région, et la garantie d'envoi exact est toujours maintenue.
Par défaut, lorsque vous exécutez votre application dans Google Cloud, se connecte au point de terminaison Pub/Sub dans la même région. Par conséquent, votre application dans une seule région de Google Cloud garantit généralement que vous interagissez avec une seule région.
Lorsque vous exécutez votre application d'abonné en dehors de Google Cloud ou dans plusieurs régions, vous pouvez vous assurer de vous connecter à une seule région à l'aide d'un point de terminaison localisé lors de la configuration client. Tous les points de terminaison de l'emplacement pour Pub/Sub pointent vers un seul point de terminaison dans différentes régions. Pour en savoir plus sur les points de terminaison locaux, consultez la page Points de terminaison Pub/Sub. Pour obtenir la liste de tous les points de terminaison localisés pour Pub/Sub, consultez la section Liste des points de terminaison localisés.
Créer des abonnements avec la distribution de type "exactement une fois"
Vous pouvez créer un abonnement avec distribution de type "exactement une fois" à l'aide de la console Google Cloud, de Google Cloud CLI, de la bibliothèque cliente ou de l'API Pub/Sub.
Abonnement pull
Console
Pour créer un abonnement pull avec distribution de type "exactement une fois", procédez comme suit:
Dans la console Google Cloud, accédez à la page Abonnements.
Cliquez sur Créer un abonnement.
Saisissez l'ID de l'abonnement.
Choisissez ou créez un sujet dans le menu déroulant.
L'abonnement reçoit les messages du sujet.
Dans la section Distribution de type "exactement une fois", sélectionnez Activer la distribution de type "exactement une fois".
Cliquez sur Créer.
gcloud
Pour créer un abonnement pull avec distribution de type "exactement une fois", utilisez la méthode
gcloud pubsub subscriptions create
avec l'option --enable-exactly-once-delivery
:
gcloud pubsub subscriptions create SUBSCRIPTION_ID \ --topic=TOPIC_ID \ --enable-exactly-once-delivery
Remplacez les éléments suivants :
- SUBSCRIPTION_ID : ID de l'abonnement à créer
- TOPIC_ID : ID du sujet à associer à l'abonnement
REST
Pour créer un abonnement avec distribution de type "exactement une fois", utilisez la méthode
projects.subscriptions.create
.
PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/subscriptions/SUBSCRIPTION_ID Authorization: Bearer $(gcloud auth print-access-token)
Remplacez les éléments suivants :
- PROJECT_ID : ID du projet dans lequel créer l'abonnement
- SUBSCRIPTION_ID : ID de l'abonnement à créer
Pour créer un abonnement pull avec une distribution "exactly-once", spécifiez-le dans le corps de la requête :
{ "topic": "projects/PROJECT_ID/topics/TOPIC_ID", "enableExactlyOnceDelivery": true, }
Remplacez les éléments suivants :
- PROJECT_ID : ID du projet contenant le sujet.
- TOPIC_ID : ID du sujet à associer à l'abonnement
C++
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage C++ qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour C++.
C#
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage C# qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour C#.
Go
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Go qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Go.
Java
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Java qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Java.
Python
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Python qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Python.
Node.js
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Node.js qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Node.js.
Node.js
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Node.js qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Node.js.
Ruby
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage Ruby qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Ruby.
PHP
Avant d'essayer cet exemple, suivez les instructions d'installation dans le langage PHP qui se trouvent sur la page Démarrage rapide : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour PHP.
S'abonner avec la distribution de messages de type "exactement une fois"
Vous trouverez ci-dessous quelques exemples de code pour vous abonner avec une diffusion exactement une fois à l'aide de la bibliothèque cliente.
Abonnement pull
Go
Avant d'essayer cet exemple, suivez les instructions de configuration de Go dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez les API Go Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Java
Avant d'essayer cet exemple, suivez les instructions de configuration pour Java du guide de démarrage rapide de Pub/Sub : utiliser les bibliothèques clientes. Pour en savoir plus, consultez les API Java Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Node.js
Avant d'essayer cet exemple, suivez les instructions de configuration de Node.js dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez les API Node.js Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
PHP
Avant d'essayer cet exemple, suivez les instructions de configuration de PHP dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub PHP.
Pour vous authentifier auprès de Pub/Sub, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Python
Avant d'essayer cet exemple, suivez les instructions de configuration de Python dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez les API Python Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Ruby
Avant d'essayer cet exemple, suivez les instructions de configuration de Ruby dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez les API Ruby Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
C++
Avant d'essayer cet exemple, suivez les instructions de configuration de C++ dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez les API C++ Pub/Sub documentation de référence.
Pour vous authentifier auprès de Pub/Sub, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
C#
Avant d'essayer cet exemple, suivez les instructions de configuration de C# dans le Guide de démarrage rapide de Pub/Sub bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub C#.
Pour vous authentifier auprès de Pub/Sub, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Node.js (TypeScript)
Avant d'essayer cet exemple, suivez les instructions de configuration de Node.js décrites dans le guide de démarrage rapide de Pub/Sub : utiliser des bibliothèques clientes. Pour en savoir plus, consultez la documentation de référence sur l'API Pub/Sub pour Node.js.
Pour vous authentifier auprès de Pub/Sub, configurez le service Identifiants par défaut de l'application. Pour en savoir plus, consultez Configurer l'authentification pour un environnement de développement local.
Surveiller les abonnements à distribution de type "exactement une fois"
La métrique subscription/exactly_once_warning_count
enregistre le nombre d'événements pouvant entraîner des nouvelles diffusions (valides ou en double). Cette métrique comptabilise les
fois où Pub/Sub ne parvient pas à traiter les requêtes associées à
ID d'accusé de réception (requête ModifyAckDeadline
ou acknowledgment
). Les raisons de l'échec peuvent être liées au serveur ou au client. Par exemple, si la couche de persistance utilisée pour gérer les informations de diffusion "exactement une fois" n'est pas disponible, il s'agit d'un événement basé sur le serveur. Si le client tente d'accuser réception d'un message avec
un ID d'accusé de réception non valide, il s'agit d'un événement basé sur le client.
Comprendre la métrique
subscription/exactly_once_warning_count
capture des événements qui peuvent ou non
de nouvelles livraisons et peut générer
du bruit en fonction du comportement du client. Par exemple, les requêtes acknowledgment
ou ModifyAckDeadline
répétées avec des ID de confirmation non valides incrémentent la métrique à plusieurs reprises.
Les métriques suivantes sont également utiles pour comprendre le comportement des clients :
La métrique
subscription/expired_ack_deadlines_count
indique le nombre d'expirations d'ID de confirmation. Reconnaissance L'expiration des ID peut entraîner des échecs pourModifyAckDeadline
et Requêtesacknowledgment
.service.serviceruntime.googleapis.com/api/request_count
peut être utilisée pour capturer les défaillances deModifyAckDeadline
ouacknowledgment
lorsqu'elles parviennent à Google Cloud, mais pas atteindre Pub/Sub. Il existe des échecs que cette métrique ne capturera pas, par exemple lorsque les clients sont déconnectés de Google Cloud.
Dans la plupart des cas d'événements d'échec pouvant être réessayés, les bibliothèques clientes compatibles relancent automatiquement la requête.
Quotas
Les abonnements de distribution de type "exactement une fois" sont soumis à des exigences de quota supplémentaires. Ces quotas s'appliquent aux éléments suivants :
- Nombre de messages consommés par des abonnements avec distribution de type "exactement une fois" activées par région.
- Nombre de messages confirmés ou dont l'échéance est prolongée lorsque vous utilisez des abonnements avec distribution "exactement une fois" activée par région.
Pour en savoir plus sur ces quotas, consultez le tableau de la section Quotas.
Diffusion de type "exactement une fois" et abonnements ordonnés
Pub/Sub est compatible avec la distribution de type "exactement une fois" avec la distribution ordonnée.
Lorsque vous utilisez la distribution de type "exactement une fois", Pub/Sub s'attend à ce que les accusés de réception soient dans l'ordre. Si les accusés de réception sont dans le désordre, le service échoue les requêtes avec des erreurs temporaires. Si le délai de confirmation avant qu'un accusé de réception de la livraison ne soit envoyé, le client que le message soit distribué à nouveau. C'est pourquoi, lorsque vous utilisez la commande distribution "exactement une fois", le débit du client est limité à un million messages par seconde.
Diffusion de type "exactement une fois" et abonnements push
Pub/Sub n'est compatible avec la distribution de type "exactement une fois" que pour les abonnements pull.
Les clients qui consomment des messages provenant des abonnements push confirment les messages en répondant aux requêtes push par une réponse de réussite. Toutefois, les clients ne savent pas si l'abonnement Pub/Sub a reçu la réponse et l'a traitée. Cela diffère des abonnements pull, où l'accusé de réception sont initiées par les clients et l'abonnement Pub/Sub répond si la requête a été correctement traitée. Par conséquent, la sémantique de distribution de type "exactement une fois" ne correspond pas bien aux abonnements push.
Bon à savoir
Si le délai d'acquittement n'est pas spécifié au moment de la création de l'abonnement, le délai d'acquittement par défaut des abonnements pour lesquels la diffusion de type "exactement une fois" est activée est de 60 secondes.
Les délais de confirmation par défaut plus longs sont utiles pour éviter la nouvelle diffusion causée par des événements réseau. Les bibliothèques clientes compatibles n'utilisent pas le délai de confirmation d'abonnement par défaut.
Les abonnements avec distribution de type "exactement une fois" ont une latence de publication vers l'abonnement nettement plus élevée que les abonnements standards.
Si vous avez besoin d'un débit élevé, vos clients de distribution de type "exactement une fois" doivent également utiliser le traitement pull en flux continu.
Un abonnement peut recevoir plusieurs copies du même message en raison de doublons côté publication, même si la diffusion de type "exactement une fois" est activée. Les doublons côté publication peuvent être dus à plusieurs tentatives de publication uniques ou le service Pub/Sub. Plusieurs publications uniques par le client de publication, lors des nouvelles tentatives, entraînent des nouvelles diffusions avec différents ID de message. Les publications uniques multiples par le service Pub/Sub, pour répondre à une requête de publication client, entraînent de nouvelles livraisons avec les mêmes ID de message.
Vous pouvez relancer les échecs dans
subscription/exactly_once_warning_count
, et les bibliothèques clientes compatibles relancent ces automatiquement. Toutefois, les échecs liés à des ID de confirmation non valides ne peuvent pas être réessayés.