Conexión de Productores y Consumidores con Colas de Mensajes
Clase 29 de 43 • Curso Profesional de Arquitectura de Software
Contenido del curso
- 2

Atributos de Calidad en Sistemas: Definición y Medición
01:49 - 3

Idoneidad Funcional: Completitud, Exactitud y Pertinencia
02:52 - 4

Eficiencia de Ejecución en Sistemas Informáticos
04:14 - 5

Compatibilidad en Sistemas: Interoperabilidad y Coexistencia
03:49 - 6

Subcaracterísticas de Usabilidad en Desarrollo de Software
08:14 - 7

Confiabilidad de Sistemas: Madurez, Disponibilidad, Resiliencia y Recuperación
05:38 - 8

Seguridad de Usuarios en Desarrollo de Software
04:01 - 9

Subcaracterísticas de Mantenibilidad en Sistemas de Software
06:28 - 10

Medición de Adaptabilidad en Sistemas de Software
02:48 - 11

Relación y Tensión entre Atributos de Calidad en Sistemas de Software
04:04 - 12

Atributos de Calidad en Arquitectura de Software
07:00
- 13

Patrones de Arquitectura Monolítica y Distribuida
02:50 - 14

Modelo Vista Controlador: Separación de Responsabilidades en Aplicaciones
05:38 - 15

Arquitectura de Capas: Diseño y Comunicación entre Niveles
03:14 - 16

Patrones de Arquitectura Orientada a Eventos y Event Sourcing
06:17 - 17

Patrón de Arquitectura MicroKernel y su Implementación en IDEs
01:52 - 18

Arquitectura "Comparte Nada": Optimización y Procesamiento de Datos
02:29 - 19

Patrón de Microservicios en Arquitectura de Software
03:57 - 20

Patrón CQRS para Separación de Consultas y Comandos
03:24 - 21

Arquitectura Hexagonal: Diseño y Aplicación Práctica
04:10 - 22

Diseño Orientado al Dominio: Conceptos y Aplicaciones Prácticas
05:34 - 23

Patrones de Arquitectura para Aplicaciones Escalables y Modulares
09:22 - 24

Patrones de Arquitectura en Proyectos de Crecimiento Empresarial
07:59
- 25

Diseño de Arquitecturas a Medida: Herramientas y Estrategias
02:18 - 26

Tipos de Conectores en Arquitectura de Software
06:18 - 27

Conectores Asíncronos y Sincrónicos: Implementación y Uso Práctico
03:05 - 28

Diferencias entre Enrutadores y Difusores en Comunicación de Mensajes
01:55 - 29

Conexión de Productores y Consumidores con Colas de Mensajes
03:52 - 30

Framework de Diseño Orientado a Atributos: Escenarios y Tácticas
01:55 - 31

Tácticas para Mejorar la Disponibilidad de Sistemas
05:59 - 32

Tácticas para Mejorar la Disponibilidad del Sistema
04:10 - 33

Tácticas para Mejorar la Mantenibilidad del Software
06:16 - 34

Prevención de Efectos Dominó en Mantenibilidad de Software
12:17 - 35

Estrategias para Mejorar la Eficiencia de Ejecución en Sistemas
09:15 - 36

Tácticas de Seguridad Informática para Detectar, Resistir y Recuperarse de Ataques
09:03 - 37

Estrategias para Mejorar la Capacidad de Prueba de Software
05:14 - 38

Tácticas de Usabilidad en Diseño de Interfaces de Usuario
08:20 - 39

Validación de Arquitectura con ATAM y Métricas de Calidad
06:34 - 40

Diseño de Arquitectura para Startups y Empresas Escalables
10:30
¿Cómo conectar un productor de tipo cola?
Cuando nos enfrentamos a situaciones en las que un productor genera datos mucho más rápido que un consumidor puede procesarlos, el uso de un conector de tipo cola se vuelve esencial. Este conector permite encolar, es decir, agendar el procesamiento de cada mensaje producido, para que el consumidor los lea a su ritmo.
- Imagine que está leyendo un archivo grande en memoria. Cada línea leída necesita ser procesada por otro componente, una tarea que podría involucrar operaciones costosas como comunicación de red o cálculos complejos. Al encolar estas líneas, el consumidor puede ir procesándolas según su capacidad, como en una cola de trabajo.
¿Qué son los conectores de tipo repositorio o pizarra?
Los conectores de tipo repositorio o pizarra se utilizan para interactuar con componentes que funcionan como bases de datos.
- Estos conectores aseguran la transaccionalidad y la consistencia de los datos escritos. Por ejemplo, en una base de datos relacional, garantizan que todos los datos de una transacción se escriban de manera atómica y consistente.
- A nivel de lectura, estos conectores pueden asegurar que la información sea consistente durante toda la operación de lectura. Además, permiten realizar operaciones de escritura y lectura dentro de la misma conexión con la base, manteniendo la integridad y consistencia.
¿Qué función cumple el conector de tipo PubSub?
El conector de tipo publicar/subscribir (PubSub) es crucial en sistemas y aplicaciones distribuidas. Introduce un patrón de comunicación donde los componentes que publican eventos y los que los reciben (o suscriptores) no necesitan conocerse entre sí directamente.
-
Se conecta con un publicador para recibir eventos y los distribuye a los suscriptores interesados. Esencialmente, cuando ocurre un evento, el conector PubSub se encarga de entregarlo a cada suscriptor que lo requiera.
-
En una aplicación de microservicios, este patrón permite que diferentes componentes, como interfaces web o APIs, interactúen y se mantengan informados sobre los cambios sin necesidad de estar acoplados directamente. Por ejemplo, un componente puede manejar notificaciones y otro puede gestionar reportes sin interferir en su funcionamiento mutuo.
Estos ejemplos destacan cómo los conectores facilitan la integración de sistemas, optimizando el flujo de información en aplicaciones modernas. Incentivamos a seguir explorando estos temas, pues forman el núcleo de la arquitectura de software actual.