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.
Rubriques
Avantages offerts par l'utilisation d'Amazon SQS
-
Sécurité : vous pouvez contrôler qui peut envoyer et recevoir des messages à partir d'une file d'attente Amazon SQS. Vous pouvez choisir de transmettre des données sensibles en protégeant le contenu des messages dans les files d'attente grâce au chiffrement côté serveur (SSE) géré par Amazon SQS par défaut ou grâce aux clés SSE personnalisées gérées dans AWS Key Management Service (AWS KMS).
-
Durabilité : pour assurer la sécurité de vos messages, Amazon SQS les stocke sur plusieurs serveurs. Les files d'attente standard prennent en charge la livraison des at-least-once messages, tandis que les files d'attente FIFO prennent en charge le traitement des messages en une seule fois et le mode haut débit.
-
Disponibilité : Amazon SQS utilise une infrastructure redondante pour fournir un accès extrêmement simultané aux messages, et une haute disponibilité pour la production et la consommation des messages.
-
Capacité de mise à l'échelle : Amazon SQS peut traiter chaque demande mise en mémoire tampon de façon indépendante, en se mettant à l'échelle de manière transparente pour gérer les augmentations et les pics de charge sans aucune instruction de mise en service.
-
Fiabilité : Amazon SQS verrouille vos messages pendant le traitement pour que plusieurs producteurs puissent envoyer des messages et que plusieurs consommateurs puissent recevoir des messages en même temps.
-
Personnalisation : vos files d'attente n'ont pas à être parfaitement identiques. Par exemple, vous pouvez définir un retard par défaut sur une file d'attente. Vous pouvez stocker le contenu des messages d'une taille supérieure à 256 Ko avec Amazon Simple Storage Service (Amazon S3) ou Amazon DynamoDB, avec Amazon SQS pour maintenir un pointeur vers l'objet Amazon S3. Vous pouvez également fractionner un message volumineux en messages de plus petite taille.
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.
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.
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.
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é.
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
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
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.
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