Temario del curso
Día 1: Fundamentos de la Arquitectura Dirigida por Eventos en Go
- Introducción a EDA
- ¿Qué es la Arquitectura Dirigida por Eventos?
- Comparación entre sistemas monolíticos, de microservicios y dirigidos por eventos.
- Cómo el modelo de concurrencia de Go y las gorutinas ligeras lo hacen ideal para EDA.
- Conceptos clave y beneficios
- Desacoplamiento, escalabilidad y resiliencia en sistemas empresariales.
- Definición de eventos, productores, consumidores y brokers de eventos.
- Ejemplos del mundo real y estudios de casos donde Go impulsa sistemas de eventos de alto rendimiento.
- Teorema CAP y compensaciones en EDA
- Visión general de consistencia, disponibilidad y tolerancia a particiones.
- Impacto de EDA en estas propiedades.
- Estrategias para equilibrar consistencia y disponibilidad en sistemas basados en Go.
Día 2: Eventos, mensajes y patrones de comunicación en Go
- Comprensión de tipos de eventos
- Eventos de dominio vs. eventos de integración.
- Eventos síncronos frente a asíncronos en aplicaciones Go.
- Patrones de mensajería en la práctica
- Publish-Subscribe (Pub/Sub) en Go.
- Cómo diseñar y estructurar cargas útiles de eventos utilizando JSON, Protocol Buffers o Avro en Go.
- Implementación del manejo de eventos en Go
- Visión general de las bibliotecas y marcos de trabajo populares para mensajería en Go.
- Ejemplos de código: envío y procesamiento de eventos utilizando patrones idiomáticos de Go.
- Sesión práctica: construcción de un servicio sencillo dirigido por eventos en Go.
Día 3: Sistemas de mensajería y brokers de eventos con Go
- Selección e integración de brokers de eventos
- Visión general de los brokers populares: Apache Kafka, RabbitMQ y NATS.
- Comparación de casos de uso y mejores prácticas para sistemas basados en Go.
- Configuración de la infraestructura de mensajería
- Configuración con Docker Compose para Kafka, RabbitMQ o NATS.
- Configuración de temas (topics), intercambios (exchanges), colas y canales.
- Visión general de las bibliotecas cliente de Go.
- Taller práctico
- Construcción de un microservicio de muestra en Go que produzca y consuma eventos.
- Integración del servicio con el broker de eventos elegido.
- Depuración y prueba de los flujos de eventos.
Día 4: Despliegue, monitoreo y temas avanzados en EDA con Go
- Despliegue de aplicaciones dirigidas por eventos en Go sobre Kubernetes
- Contenerización de aplicaciones Go para producción.
- Despliegue de Kafka (u otros brokers) en clústeres de Kubernetes.
- Introducción a KEDA (Kubernetes Event-Driven Autoscaling) para escalar consumidores de eventos.
- Manejo de errores y monitoreo
- Manejo de fallos de eventos con estrategias adecuadas.
- Implementación de observabilidad en servicios Go.
- Temas avanzados y preguntas y respuestas
- Exploración de arquitecturas serverless dirigidas por eventos con Go.
- Estrategia coreografía vs. orquestación: casos de uso y consideraciones de diseño.
- Pitfalls comunes, lecciones aprendidas y mejores prácticas.
- Sesión abierta de preguntas y respuestas y resolución interactiva de problemas.
Requerimientos
- Dominio de Go (Golang), incluyendo el uso de gorutinas y canales.
- Comprensión básica de modelos de arquitectura de software como monolitos y microservicios.
- Familiaridad con Docker y Docker Compose.
- Conocimientos básicos de APIs REST y conceptos de redes.
- Experiencia con herramientas de línea de comandos y Git.
- Opcional pero útil: exposición previa a Kubernetes y sistemas de mensajería como Kafka, RabbitMQ o NATS.
Público objetivo
- Desarrolladores de Go que construyen aplicaciones escalables y dirigidas por eventos.
- Ingenieros de software que transicionan de arquitecturas monolíticas o basadas en REST hacia sistemas asíncronos.
- Ingenieros de DevOps y nube que trabajan con microservicios contenerizados o distribuidos.
- Arquitectos técnicos y diseñadores de sistemas que exploran patrones de EDA utilizando Go.
Testimonios (7)
escribimos algunos códigos en Go y aprendemos conceptos relacionados con EDA, como eventos, cuándo y cómo utilizarlos.
Alin
Curso - Event Driven Architecture Custom
Traducción Automática
Fue un curso interactivo, ¡sin tiempo para dormir :)). También fue agradable trabajar en equipos y luego debatir según cada resultado.
Alina
Curso - Event Driven Architecture Custom
Traducción Automática
Disfruté mucho de las discusiones y los ejemplos que se proporcionaron para que pudiéramos llegar por nosotros mismos a las conclusiones que quería compartir con nosotros. Me gustó el ritmo, el inglés, la paciencia; incluso cuando no dábamos la mejor respuesta, no decía que estaba mal, sino que nos ofrecía ejemplos de lo que podría ser mejor.
Simona
Curso - Event Driven Architecture Custom
Traducción Automática
Las discusiones abiertas y el paso de comprender los problemas/razones (el `por qué`) a `EDA`.
Constantin
Curso - Event Driven Architecture Custom
Traducción Automática
el enfoque de presentar las cosas basándose fuertemente en la interacción y los ejemplos
Virgil
Curso - Event Driven Architecture Custom
Traducción Automática
La naturaleza interactiva del curso El enfoque de aprendizaje por autodescubrimiento donde encontrasteis las respuestas vosotros mismos El enfoque práctico con ejemplos de la vida real que hicieron los conceptos más cercanos
Roxana Sandu
Curso - Event Driven Architecture Custom
Traducción Automática
Muy interactivo. El formador era muy conocedor y paciente.
Robert
Curso - Event Driven Architecture Custom
Traducción Automática