REL05-BP06 Rendre les services sans état dans la mesure du possible - AWS Well-Architected Framework

REL05-BP06 Rendre les services sans état dans la mesure du possible

Les services ne doivent pas exiger d'état ou doivent décharger un état de telle sorte qu'entre les différentes demandes client, il n'y ait pas de dépendance vis-à-vis des données stockées localement sur disque et en mémoire. Cela permet aux serveurs d'être remplacés à volonté sans avoir d'impact sur la disponibilité. Amazon ElastiCache ou Amazon DynamoDB sont de bonnes destinations pour l'état déchargé.

Dans cette application Web sans état, l'état de la session est déchargé vers Amazon ElastiCache.

Figure 7 : Dans cette application Web sans état, l'état de la session est déchargé vers Amazon ElastiCache.

Lorsque des utilisateurs ou des services interagissent avec une application, ils exécutent souvent une série d'interactions qui forment une session. Une session correspond aux données uniques des utilisateurs qui persistent entre les requêtes pendant l’utilisation de l'application. Une application sans état n'a pas besoin de connaître les interactions précédentes et ne stocke pas d'informations de session.

Lorsqu'une application est conçue pour être sans état, vous pouvez utiliser des services de calcul sans serveur, comme AWS Lambda ou AWS Fargate.

Outre le remplacement du serveur, les applications sans état ont également pour avantage de pouvoir être mises à l'échelle horizontalement, car toutes les ressources de calcul disponibles (telles que les instances EC2 et les fonctions AWS Lambda) peuvent répondre à n'importe quelle requête.

Niveau de risque exposé si cette bonne pratique n'est pas respectée : Moyenne entreprise

Directives d'implémentation

  • Rendre vos applications sans état. Les applications sans état permettent une mise à l'échelle horizontale et tolèrent la défaillance d'un nœud individuel.

    • Supprimez les états qui peuvent être stockés dans les paramètres de demande.

    • Après avoir vérifié si l'état est requis, déplacez n'importe quel suivi d'état vers un cache ou un magasin de données multizone résistant comme Amazon ElastiCache, Amazon RDS, Amazon DynamoDB ou une autre solution de données distribuée. Enregistrez un état qui n'a pas pu être déplacés vers des magasins de données résilient.

      • Certaines données (comme les cookies) peuvent être transmises dans les en-têtes ou les paramètres de requête

      • Réfactorisez afin de supprimer l'état qui peut rapidement être transmis dans les requêtes

      • Certaines données ne sont pas forcément nécessaires pour certaines requêtes et peuvent être récupérées à la demande.

      • Supprimez les données qui peuvent être récupérées de manière asynchrone.

      • Choisissez un magasin de donnée qui répond aux exigences relatives à l'état requis.

      • Pensez à avoir une base de données NoSQL pour les données non relationnelles.

Ressources

Documents connexes :