Temario del curso
Día 1: Fundamentos de la Arquitectura Orientada a Eventos en Go
- Introducción a EDA
- ¿Qué es la Arquitectura Orientada a Eventos?
- Comparación entre sistemas Monolíticos, Microservicios y Basados en Eventos
- Cómo el modelo de concurrencia y las goroutines ligeras de Go 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 vs. Asincrónicos en aplicaciones de Go
- Patrones de Mensajería en la Práctica
- Publicación-Subscripción (Pub/Sub) en Go
- Cómo diseñar y estructurar cargas útiles de eventos usando JSON, Protocol Buffers o Avro en Go
- Implementación de Manejo de Eventos en Go
- Visión general de bibliotecas y frameworks populares para mensajería en Go
- Ejemplos de código: despacho y procesamiento de eventos usando patrones idiomáticos de Go
- Sesión hands-on: Construcción de un servicio orientado a eventos simple 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 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 Infraestructura de Mensajería
- Configuración de Docker Compose para Kafka, RabbitMQ o NATS
- Configuración de temas, intercambios, colas y canales
- Visión general de bibliotecas cliente en Go
- Taller Hands-On
- Construcción de un microservicio de Go de muestra que produce y consume eventos
- Integración del servicio con el broker de eventos elegido
- Depuración y pruebas de flujos de eventos
Día 4: Implementación, Monitoreo y Temas Avanzados en EDA con Go
- Implementación de Aplicaciones Orientadas a Eventos de Go en Kubernetes
- Contenerización de aplicaciones de Go para producción
- Implementación 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
- Implementación de observabilidad en servicios de Go
- Temas Avanzados y Q&A
- Exploración de Arquitecturas Orientadas a Eventos Serverless con Go
- Coreografía vs. Orquestación de Eventos: Casos de uso y consideraciones de diseño
- Pitfalls comunes, lecciones aprendidas y mejores prácticas
- Sesión de Q&A abierta y solución de problemas interactiva
Requerimientos
- Dominio de Go (Golang), incluyendo el uso de goroutines 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 REST APIs y conceptos de red
- 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 orientadas a eventos
- Ingenieros de software que transicionan de arquitecturas monolíticas o basadas en REST a sistemas asíncronos
- Ingenieros DevOps y de la nube que trabajan con microservicios contenerizados o distribuidos
- Arquitectos técnicos y diseñadores de sistemas que exploran patrones 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