Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.
Integre Amazon API Gateway con Amazon SQS para gestionar el REST asíncrono APIs
Natalia Colantonio Favero y Gustavo Martim, Amazon Web Services
Resumen
Al implementar REST APIs, a veces es necesario exponer una cola de mensajes que las aplicaciones cliente puedan publicar. Por ejemplo, es posible que tenga problemas con la latencia de terceros APIs y que se produzcan retrasos en las respuestas, o puede que desee evitar el tiempo de respuesta de las consultas a la base de datos o escalar el servidor cuando hay un gran número de consultas APIs simultáneas. En estos escenarios, las aplicaciones cliente que publican en la cola solo necesitan saber que la API ha recibido los datos, no lo que ocurre después de recibirlos.
Este patrón crea un punto de conexión de la API de REST mediante Amazon API Gateway
Requisitos previos y limitaciones
Arquitectura

En el siguiente diagrama se muestran estos pasos:
Solicite un punto de conexión de la API de REST POST mediante una herramienta como Postman, otra API u otras tecnologías.
API Gateway publica un mensaje, que se recibe en el cuerpo de la solicitud, en la cola.
Amazon SQS recibe el mensaje y envía una respuesta a API Gateway con un código de éxito o error.
Tools (Herramientas)
Amazon API Gateway le ayuda a crear, publicar, mantener, supervisar y proteger REST, HTTP y WebSocket APIs a cualquier escala.
AWS Identity and Access Management (IAM) le ayuda a administrar de forma segura el acceso a sus AWS recursos al controlar quién está autenticado y autorizado a usarlos.
Amazon Simple Queue Service (Amazon SQS) ofrece una cola alojada segura, duradera y disponible que le permite integrar y desacoplar sistemas y componentes de software distribuidos.
Epics
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Creación de una cola. | Para crear una cola de SQS que reciba los mensajes de la API de REST:
| Desarrollador de aplicaciones |
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Crear un rol de IAM. | Este rol de IAM proporciona a los recursos de API Gateway acceso completo a Amazon SQS.
| Desarrollador de aplicaciones, administrador de AWS |
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Crear una API de REST. | Esta es la API de REST a la que se envían las solicitudes HTTP.
| Desarrollador de aplicaciones |
Conectar API Gateway a Amazon SQS. | Este paso permite que el mensaje fluya desde el cuerpo de la solicitud HTTP hasta Amazon SQS.
| Desarrollador de aplicaciones |
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Probar la API de REST. | Ejecute una prueba para comprobar si falta alguna configuración:
| Desarrollador de aplicaciones |
Cambiar la integración de la API para reenviar la solicitud correctamente a Amazon SQS. | Complete la configuración para corregir el error de integración:
| Desarrollador de aplicaciones |
Probar y validar el mensaje en Amazon SQS. | Ejecute una prueba para confirmar que la prueba se haya completado correctamente:
| Desarrollador de aplicaciones |
Probar API Gateway con un carácter especial. | Ejecute una prueba que incluya caracteres especiales (como &) que no sean aceptables en un mensaje:
Esto se debe a que los caracteres especiales no se admiten de forma predeterminada en el cuerpo del mensaje. En el siguiente paso, configurará API Gateway para que admita caracteres especiales. Para obtener más información sobre las conversiones de tipos de contenido, consulte la documentación de API Gateway. | Desarrollador de aplicaciones |
Cambiar la configuración de la API para que admita caracteres especiales. | Ajuste la configuración para que acepte caracteres especiales en el mensaje:
El nuevo mensaje debe incluir el carácter especial. | Desarrollador de aplicaciones |
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Implementar la API. |
Para implementar la API de REST:
| Desarrollador de aplicaciones |
Probar con una herramienta externa. | Ejecute una prueba con una herramienta externa para confirmar que el mensaje se ha recibido correctamente:
| Desarrollador de aplicaciones |
| Tarea | Descripción | Habilidades requeridas |
|---|---|---|
Eliminar la API. | En la consola de API Gateway | Desarrollador de aplicaciones |
Eliminación del rol de IAM. | En la consola de IAM | Desarrollador de aplicaciones |
Eliminar la cola de SQS. | En la consola de Amazon SQS | Desarrollador de aplicaciones |
Recursos relacionados
SQS- SendMessage (documentación de API Gateway)
Conversiones de tipo de contenido en API Gateway (documentación de API Gateway)
Variables $util (documentación de API Gateway)
¿Cómo puedo integrar una API REST de API Gateway con Amazon SQS y resolver los errores más comunes?
(Artículo de AWS Re:POST)