REL05-BP06 Crear sistemas sin estado cuando sea posible
Los sistemas deben o bien no requerir estado o bien descargar el estado, de forma que entre solicitudes de clientes distintos no haya dependencia en los datos almacenados localmente en disco y en memoria. Esto permite reemplazar los servidores a voluntad sin que la disponibilidad resulte afectada.
Cuando los usuarios o los servicios interactúan con una aplicación, suelen realizar una serie de interacciones que constituyen una sesión. Una sesión es un dato único para los usuarios que persiste entre las solicitudes mientras utilizan la aplicación. Una aplicación sin estado es aquella que no necesita conocer las interacciones anteriores y no almacena la información de la sesión.
Una vez se ha diseñado para no tener estado, puede utilizar servicios de computación sin servidor, como AWS Lambda o AWS Fargate.
Además del reemplazo del servidor, otro beneficio de las aplicaciones sin estado es que pueden escalar horizontalmente porque cualquiera de los recursos de computación disponibles (como las instancias de EC2 y las funciones de AWS Lambda) puede dar servicio a cualquier solicitud.
Beneficios de establecer esta práctica recomendada: los sistemas que se han diseñado para no tener estado se adaptan mejor al escalamiento horizontal, lo que permite añadir o eliminar capacidad en función de la fluctuación del tráfico y la demanda. También son intrínsecamente resistentes a los errores y proporcionan flexibilidad y agilidad en el desarrollo de aplicaciones.
Nivel de riesgo expuesto si no se establece esta práctica recomendada: medio
Guía para la implementación
Cree aplicaciones sin estado. Las aplicaciones sin estado permiten el escalamiento horizontal y toleran el error de un nodo individual. Analice y comprenda los componentes de la aplicación que mantienen el estado dentro de la arquitectura. Esto le ayuda a evaluar el posible impacto de la transición a un diseño sin estado. Una arquitectura sin estado desacopla los datos del usuario y descarga los datos de la sesión. Esto proporciona la flexibilidad para escalar cada componente de forma independiente para cumplir con las diferentes demandas de carga de trabajo y optimizar la utilización de los recursos.
Pasos para la implementación
-
Identifique y comprenda los componentes con estado de la aplicación.
-
Desacople los datos separando y administrando los datos de usuario de la lógica principal de la aplicación.
-
Amazon Cognito
puede desacoplar los datos de usuario del código de la aplicación mediante características, tales como grupos de identidades, grupos de usuarios y Amazon Cognito Sync. -
Puede usar AWS Secrets Manager
para desacoplar los datos de usuario almacenando los secretos en una ubicación segura y centralizada. Esto significa que el código de la aplicación no necesita almacenar secretos, lo que la hace más segura. -
Plantéese utilizar Amazon S3
para almacenar datos no estructurados y de gran volumen, como imágenes y documentos. La aplicación puede recuperar estos datos cuando sea necesario, lo que elimina la necesidad de almacenarlos en la memoria. -
Utilice Amazon DynamoDB
para almacenar información, como, por ejemplo, perfiles de usuario. La aplicación puede consultar estos datos prácticamente en tiempo real.
-
-
Descargue los datos de la sesión en una base de datos, caché o archivos externos.
-
Amazon ElastiCache
, Amazon DynamoDB, Amazon Elastic File System (Amazon EFS) y Amazon MemoryDB son ejemplos de servicios de AWS que puede usar para descargar datos de sesión.
-
-
Diseñe una arquitectura sin estado después de identificar qué datos de estado y de usuario deben conservarse con la solución de almacenamiento que elija.
Recursos
Prácticas recomendadas relacionadas:
Documentos relacionados: