Temario del curso
Módulo 1: Diseño de Microservicios
• Un buen límite de Microservicio
• Uso del Diseño Dirigido por el Dominio (DDD)
• Alternativas a los Límites del Dominio de Negocio (Volatilidad, Datos, Tecnología, Organizacional)
• Descomposición del Monolito
• Descomposición prematura
• Descomposición por Capa
• Uso de Patrones de Descomposición (Strangler, Ejecución Paralela, Cambios de Funcionalidad)
• Consideraciones sobre la Descomposición de Datos (Rendimiento, Integridad, Transacciones)
Módulo 2: Optimización de Docker y el Entorno de Ejecución
• Elegir la imagen base adecuada
• Minimizar el número de capas
• Uso de compilaciones multietapa
• Optimización de imágenes (ordenar argumentos multilinea, etc.)
• Aprovechar la caché de compilación
• Bloqueo de versiones de imágenes
• Ajuste fino de la asignación de recursos
• Prácticas seguras de contenedores
• Configuración del entorno de ejecución para el rendimiento
Módulo 3: Kubernetes y Estrategias de Lanzamiento
Descripción General de los Despliegues en Kubernetes
• Creación y ejecución de un Despliegue Inicial
• Opciones de Despliegue de Kubernetes
Realización de Despliegues con Actualizaciones Progresivas
• Comprensión de las Actualizaciones Progresivas
• Creación y ejecución de una Actualización Progresiva
• Reversión del Despliegue
Realización de Despliegues Canario
• Comprensión de los Despliegues Canario
• Creación y ejecución de un Despliegue Canario
Realización de Despliegues Azul-Verde
• Comprensión de los Despliegues Azul-Verde
• Creación y ejecución de un Despliegue Azul-Verde
Ejecución de Trabajos y CronJobs
• Creación de un Trabajo y CronJob
Realización de Tareas de Monitoreo y Resolución de Problemas
• Técnicas de resolución de problemas con kubectl
Módulo 4: Automatización y Eficiencia Operativa
Uso de Python para Automatizar Tareas Comunes en Kubernetes
• Uso de Python para realizar operaciones administrativas en Kubernetes
• Uso de Python para definir objetos de Configuración
• Uso de Python para crear objetos de Despliegue
• Observación de Eventos de Kubernetes usando Python
• Escalado de un Despliegue usando Python
Comprensión de los Desafíos de la Automatización de Despliegues
• Configuración Declarativa con Kubernetes
• Gestión de la Integridad de la Configuración
Uso del Enfoque GitOps para Automatizar Despliegues
• Principios de GitOps
• Introducción a Flux
• Instalación de Flux en un Clúster de Kubernetes
Configuración de Flux para Despliegues Automatizados
• Uso de Notificaciones
• Estructura del Repositorio de Origen
Manejo de Actualizaciones de Aplicaciones con Automatización de Imágenes
• Actualización de un Despliegue de Aplicación con Flux
• Exploración de Repositorios de Imágenes de Contenedores en busca de Etiquetas
• Definición de Políticas para la selección de la Última Imagen
• Configuración de Flux para Realizar Actualizaciones Automáticas de Imágenes
Módulo 5: Observabilidad y Claridad en la Causa Raíz
Capacidades de Registro y Rastreo en Kubernetes
• Por qué son importantes el registro y el rastreo
• Acceso a los Registros de Kubernetes
• Registros de Pods y Contenedores
• Registros del Plano de Control
• Uso de Recursos de Nodos y Pods
Recopilación y Análisis de Registros
• Agregación de Registros
• Visualización de Registros
Rastreo Distribuido en Kubernetes
• Qué es el rastreo distribuido
• Uso de OpenTelemetry
• Herramientas de Rastreo Distribuido
• Instrumentación de una Aplicación
• Uso del Rastreo para Encontrar Problemas de Rendimiento
Monitoreo con Prometheus y Grafana
• Conceptos de Observabilidad
• Herramientas de Monitoreo
• Uso de Instrumentación de Prometheus
Casos de Uso Avanzados para Registros
• Procesamiento de Registros
• Filtrado y Enriquecimiento de Registros
• Origen de Eventos
Módulo 6: Simulación de Crisis en el Clúster y Respuesta a Incidentes
• Comprensión de los diferentes tipos de fallos en un entorno de clúster
• Simulación de Fallos de Nodos
• Evicción de Pods y Escenario de Agotamiento de Recursos
• Problemas de Red
• Fallos de DNS para el manejo de tiempo de espera de aplicaciones
• Simulación de una Interrupción del Servidor de API
• Simulación de Alto Tráfico para la Estabilidad del Sistema
• Fallos de Almacenamiento
• Errores de Configuración
• Comprensión de los procedimientos de reporte de incidentes
Módulo 7: IA para Apoyar la Resolución de Problemas
• Beneficios de la IA Generativa para Kubernetes
• Arquitectura de la CLI de K8sGPT
• Instalación de la CLI de K8sGPT
• Comandos y Uso de K8sGPT
• Uso de Analizadores de K8sGPT (podAnalyzer, pvcAnalyzer, rsAnalyzer, etc.)
• Análisis del Clúster usando K8sGPT
• Análisis de Problemas en Tiempo Real usando K8sGPT
• Operador In-Cluster para K8sGPT
Requerimientos
- Conocimientos básicos de la línea de comandos de Linux
- Experiencia en desarrollo de aplicaciones o administración de sistemas
- Familiaridad con contenedores (conceptos de Docker)
- Comprensión básica de conceptos de Kubernetes (pods, despliegues, servicios)
- Comprensión general de la arquitectura de software (por ejemplo, APIs, servicios)
Público objetivo:
- Ingenieros de DevOps
- Ingenieros de Fiabilidad del Sitio (SREs)
- Desarrolladores de Backend / Software que trabajan con microservicios
- Ingenieros de la Nube y Ingenieros de Plataforma
-
Administradores de Sistemas que transicionan hacia entornos de Kubernetes
Testimonios (2)
El conocimiento y experiencia del consultor ya que se abordan los temas teóricos aplicándolos a la realidad de los procesos. El curso contiene un programa de mucho valor en la gestión de las tecnologías de información.
Luis Castro Gamboa - Cooperativa De Ahorro Y Credito Ande No. 1 R.L.
Curso - Site Reliability Engineering (SRE) Foundation®
Que fue muy claro en cada especificación