Qu'est-ce qu'Amazon Simple Queue Service - Amazon Simple Queue Service

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Qu'est-ce qu'Amazon Simple Queue Service

Amazon Simple Queue Service (Amazon SQS) offre une file d'attente hébergée sécurisée, durable et disponible qui vous permet d'intégrer et de découpler les systèmes et les composants de logiciels distribués. Amazon SQS propose des structures communes, telles que des files d'attente de lettres mortes et des balises de répartition des coûts. Il fournit une API de services Web générique à laquelle vous pouvez accéder à l'aide de n'importe quel langage de programmation pris en charge par le AWS SDK.

Avantages offerts par l'utilisation d'Amazon SQS

Architecture de base Amazon SQS

Cette section décrit les composants d'un système de messagerie distribué et explique le cycle de vie d'un message Amazon SQS.

Files d'attente distribuées

Un système de messagerie distribué comprend trois éléments principaux : les composants de votre système distribué, votre file d'attente (distribuée sur des serveurs Amazon SQS) et les messages de la file d'attente.

Dans le scénario suivant, le système comprend plusieurs producteurs (composants qui envoient des messages à la file d'attente) et plusieurs consommateurs (composants qui reçoivent des messages de la file d'attente). La file d'attente (qui contient les messages A à E) stocke les messages de manière redondante sur plusieurs serveurs Amazon SQS.

Trois éléments principaux d'un système de messagerie distribué : les composants de votre système distribué, votre file d'attente (distribuée sur les serveurs Amazon SQS) et les messages de la file d'attente.

Cycle de vie des messages

Le scénario suivant décrit le cycle de vie d'un message Amazon SQS dans une file d'attente, de sa création à sa suppression.

Le cycle de vie d'un message Amazon SQS dans une file d'attente, de sa création à sa suppression.

Section one description for the previous lifecycle diagram. Un producteur (composant 1) envoie un message A à une file d'attente, et le message est distribué de façon redondante entre les serveurs Amazon SQS.

Section two description for the previous lifecycle diagram. Lorsqu'un consommateur (composant 2) est prêt à traiter des messages, il consomme les messages dans la file d'attente et le message A est renvoyé. Pendant son traitement, le message A reste dans la file d'attente et n'est pas renvoyé aux demandes de réception suivantes pendant la durée du délai de visibilité.

Section three description for the previous lifecycle diagram. Le consommateur (composant 2) supprime le message A de la file d'attente afin d'éviter que le message ne soit de nouveau reçu et traité à l'expiration du délai de visibilité.

Note

Amazon SQS supprime automatiquement d'une file d'attente les messages qui dépassent la période maximale de conservation des messages. La période de conservation des messages par défaut est de 4 jours. Cependant, vous pouvez configurer la période de rétention des messages sur une valeur allant de 60 secondes à 1 209 600 secondes (14 jours) avec SetQueueAttributes

Différences entre Amazon SQS, Amazon MQ et Amazon SNS

Amazon SQS, Amazon SNS et Amazon MQ proposent des services de messagerie gérés easy-to-use et hautement évolutifs, chacun étant conçu pour des rôles spécifiques au sein de systèmes distribués. Voici un aperçu détaillé des différences entre ces services :

Amazon SQS dissocie et fait évoluer les systèmes et composants logiciels distribués en tant que service de file d'attente. Il traite généralement les messages par l'intermédiaire d'un seul abonné, ce qui est idéal pour les flux de travail où la prévention des commandes et des pertes est essentielle. Pour une distribution plus large, l'intégration d'Amazon SQS à Amazon SNS permet d'utiliser un modèle de messagerie en fanout, transmettant efficacement les messages à plusieurs abonnés à la fois.

Amazon SNS permet aux éditeurs d'envoyer des messages à plusieurs abonnés par le biais de rubriques servant de canaux de communication. Les abonnés reçoivent les messages publiés via un type de point de terminaison compatible Amazon Data Firehose, tel qu'Amazon SQS, Lambda, HTTP, les e-mails, les notifications push mobiles et les SMS. Ce service est idéal pour les scénarios nécessitant des notifications immédiates, tels que l'engagement des utilisateurs en temps réel ou les systèmes d'alarme. Pour éviter la perte de messages lorsque les abonnés sont hors ligne, l'intégration d'Amazon SNS aux messages de file d'attente Amazon SQS garantit une diffusion cohérente.

Amazon MQ convient parfaitement aux entreprises qui souhaitent migrer depuis des courtiers de messages traditionnels, prenant en charge les protocoles de messagerie standard tels que AMQP et MQTT, ainsi qu'Apache ActiveMQ et RabbitMQ. Il est compatible avec les systèmes existants nécessitant une messagerie stable et fiable sans reconfiguration importante.

Le tableau suivant donne un aperçu du type de ressource de chaque service :

Type de ressource Amazon SNS Amazon SQS Amazon MQ
Synchrone Non Non Oui
asynchrone Oui Oui Oui
Files d'attente Non Oui Oui
Messagerie par publication-abonnement Oui Non Oui
Agents de messages Non Non Oui

Amazon SQS et Amazon SNS sont recommandés pour les nouvelles applications qui peuvent bénéficier d'une capacité de mise à l'échelle presque illimitée et d'API simples. Ils proposent généralement des solutions plus rentables pour les applications à volume élevé grâce à leurs pay-as-you-go prix. Nous recommandons Amazon MQ pour la migration d'applications provenant de courtiers de messages existants qui reposent sur la compatibilité avec des API telles que JMS ou des protocoles tels que le protocole AMQP (Advanced Message Queuing Protocol), le MQTT et le protocole STOMP (Simple Text Oriented Message Protocol). OpenWire