Cómo construir tuberías de CI/CD para una aplicación de microservicios

Rate this content
Bookmark

Los microservicios presentan muchas ventajas para ejecutar software moderno, pero también traen nuevos desafíos tanto para las tareas de despliegue como operativas. Esta sesión discutirá las ventajas y desafíos de los microservicios y revisará las mejores prácticas para desarrollar una arquitectura basada en microservicios.

Discutiremos cómo la orquestación de contenedores usando Kubernetes o Red Hat OpenShift puede ayudarnos y lo uniremos todo con un ejemplo de tuberías de Integración Continua y Entrega Continua (CI/CD) en OpenShift.

FAQ

Los microservices se definen como un patrón de arquitectura de colección de servicios que están sueltos acoplados, desplegables de forma independiente, organizados por capacidades empresariales y propiedad de pequeños equipos.

Los microservicios permiten la agilidad en el desarrollo y despliegue de aplicaciones, facilitan el uso de diferentes pilas tecnológicas para distintos servicios y permiten escalar los servicios de manera independiente.

Los contenedores facilitan la implementación de microservicios porque permiten empaquetar y desplegar servicios de manera eficiente, asegurando la portabilidad y la consistencia entre diferentes entornos de ejecución.

Al trabajar con microservicios, los desafíos incluyen la gestión de la integridad entre servicios independientes, manejo de fallos en la red, y la complejidad en el monitoreo y depuración de múltiples servicios.

Se manejan múltiples versiones de API manteniendo la compatibilidad hacia atrás y definiendo claramente las versiones en los contratos de API, permitiendo a los servicios consumidores elegir la versión con la que pueden trabajar.

Kubernetes es una plataforma de orquestación que facilita el despliegue, mantenimiento y escalado de aplicaciones basadas en microservicios, proporcionando herramientas y recursos para manejar contenedores de forma eficiente.

CI-CD se refiere a la integración continua y la entrega continua, procesos automatizados que permiten actualizar aplicaciones de microservicios de forma rápida y confiable, usando herramientas como Jenkins, Azure DevOps o Tacton en entornos como Kubernetes.

Sasha Rosenbaum
Sasha Rosenbaum
33 min
01 Jul, 2021

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Esta charla discute los beneficios de los microservicios y contenedores para construir tuberías de CI-CD. Explica cómo la tecnología de contenedores permite la portabilidad y escalabilidad. Los desafíos de los microservicios incluyen la comunicación de red y las pruebas en aislamiento. La charla presenta Tacton, una tubería CICD nativa de la nube para Kubernetes, y destaca el uso de GitOps y Argo CD. También discute la importancia de mantener la integridad referencial entre los microservicios y el papel en evolución de los operadores en el mundo DevOps.

1. Introducción y Antecedentes

Short description:

Hola, soy Sasha Rosenbaum, y hoy estoy presentando sobre la construcción de CI-CD para aplicaciones de microservicios. He estado en desarrollo, operaciones, ruta de desarrollo y éxito del cliente. He estado involucrado en los días de DevOps desde 2014. Puedes encontrarme en Twitter como devineops.

Hola, soy Sasha Rosenbaum, y hoy estoy presentando sobre la construcción de CI-CD para aplicaciones de microservices. Así que primero, solo una pequeña introducción sobre mí. Actualmente soy Líder de Equipo en un equipo de OpenShift BlackBell administrado en Red Hat. Y en mi career, he estado en desarrollo, en operaciones, brevemente en ruta de desarrollo, y he pasado bastante tiempo en éxito del cliente. Todavía me considero un desarrollador. Pero como puedes ver, he hecho muchas cosas diferentes a lo largo de los 15 años que he estado en esta industria.

He estado involucrado en los días de DevOps desde 2014. También puedes verlo en el gráfico. Y puedes encontrarme en Twitter como devineops. Publico muchas fotos de gatos y algunos Twitter, algunas opiniones técnicas candentes. Así que por favor siéntete libre de seguirme en Twitter.

2. Microservicios y Sus Beneficios

Short description:

Hablemos de microservicios. Hubo una vez un monolito, y era más fácil de manejar porque tenías control total. Sin embargo, había desafíos, como la colaboración entre diferentes equipos y la necesidad de pruebas de regresión. La solución a estos desafíos se convirtió en microservicios, que implican modularizar diferentes partes de la aplicación y dividirlas en servicios separados. Cada microservicio idealmente debería tener sus propios datos. Los microservicios se separan por lógica de negocio.

Entonces, hablemos de microservices. Mientras construía esta presentación, pensaba que además de cómo hacer las cosas, también es importante hablar de por qué estamos haciendo las cosas. Y especialmente si estamos hablando desde el punto de vista de un desarrollador, es importante hablar de por qué incluso usamos microservices, por qué usamos containers, y profundizar en una especie de visión general de toda la architecture.

Entonces, comencemos con esto. Hubo una vez un monolito, ¿verdad? Y el monolito era bonito, y realmente disfrutábamos trabajando con un monolito, y todo estaba relativamente bien. Y para contarte un pequeño secreto que a nadie le gusta hablar más, es que el monolito era en realidad más fácil de manejar, porque con el monolito, tenías control total sobre todas las partes de tu aplicación, todas tus dependencias, y todas tus cosas. Y también porque los sistemas distribuidos son difíciles, y eso es simplemente una verdad universal.

Pero el monolito también tenía desafíos y estos desafíos eran entre muchos. Así que muchos equipos diferentes necesitaban colaborar. Así que tenías que colaborar a través de diferentes partes de una empresa. Y si la empresa era grande, eso a menudo significaba que algo como una gran aerolínea.com se convertía en un gigante, se convertía en una bestia enorme y todos los equipos diferentes tenían que participar en la construcción de esa enorme aplicación. Todos tenían que usar la misma tecnología. Así que si a un equipo le gustaba mucho Java y a otro equipo le gustaba mucho C-sharp, tenían que elegir entre ellos. Tenían que usar ambos, o lo mismo con diferentes tipos de SO y cosas así. Cada cambio requería una regresión testing de todo el sistema, lo cual puede ser bastante consumidor de tiempo. Por lo tanto, el despliegue era lento, ¿verdad? Porque los equipos a menudo se encontraban en un infierno de fusión y scaling era difícil. Así que scaling una bestia enorme de una aplicación generalmente no es un picnic. Entonces, porque teníamos desafíos donde hay desafíos, siempre hay soluciones. Y en este caso particular la solución se convirtió en microservices.

Entonces, ¿qué son realmente los microservices? Comenzamos con una aplicación, y luego comenzamos a hablar de los patterns de desarrollo adecuados. Así que modularizamos diferentes partes de la aplicación. Y luego comenzamos a hablar de dividir estos diferentes modules en diferentes servicios. Y a medida que avanzábamos, se convirtió en una red de servicios. En una implementación adecuada, cada microservice también se supone que debe tener sus propios data. En la práctica, esto no siempre sucede, pero esta es la mejor práctica de implementación para cada microservice también posee la database. Así que a menudo escucho preguntas sobre la architecture orientada a servicios versus microservices. Entonces, si estás a la izquierda de este diagrama, y tienes una capa de data, y tienes una capa de lógica de negocio, y tienes una capa web, incluso si estas tres capas están separadas, estás en microservices. Separar por preocupaciones verticales todavía no es microservices. Microservices se separa por lógica de negocio. Entonces, en este caso, por ejemplo, authentication sería un microservice separado.

QnA

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Elevando Monorepos con los Espacios de Trabajo de npm
DevOps.js Conf 2022DevOps.js Conf 2022
33 min
Elevando Monorepos con los Espacios de Trabajo de npm
Top Content
Aprenda más sobre cómo aprovechar las características predeterminadas de los espacios de trabajo de npm para ayudarlo a administrar su proyecto monorepo, mientras también explora algunas de las nuevas características de npm cli.
Automatizando Todo el Código y las Pruebas con GitHub Actions
React Advanced Conference 2021React Advanced Conference 2021
19 min
Automatizando Todo el Código y las Pruebas con GitHub Actions
Top Content
Las tareas de código como linting y pruebas son partes críticas del flujo de trabajo de un desarrollador que nos ayudan a mantenernos cuerdos, como prevenir problemas de sintaxis o estilo y fortalecer nuestra lógica de negocio central. Hablaremos de cómo podemos usar GitHub Actions para automatizar estas tareas y ayudar a mantener nuestros proyectos funcionando sin problemas.
Ajustando DevOps para las Personas sobre la Perfección
DevOps.js Conf 2022DevOps.js Conf 2022
33 min
Ajustando DevOps para las Personas sobre la Perfección
Top Content
La demanda de DevOps ha aumentado en los últimos años a medida que más organizaciones adoptan tecnologías nativas de la nube. La complejidad también ha aumentado y una mentalidad de "cero a héroe" deja a muchas personas persiguiendo la perfección y FOMO. Esta sesión se centra en cambio en por qué tal vez no deberíamos adoptar una práctica tecnológica y cómo a veces los equipos pueden lograr los mismos resultados priorizando a las personas sobre la automatización y controles de operaciones. Veamos las cantidades y el ajuste fino de todo como código, solicitudes de extracción, DevSecOps, Monitoreo y más para priorizar el bienestar del desarrollador sobre la perfección de la optimización. Puede ser una decisión válida desplegar menos y dormir mejor. Y finalmente examinaremos cómo la práctica manual y la disciplina pueden ser la clave para productos y experiencias superiores.
¿Por qué es tan lento el CI?
DevOps.js Conf 2022DevOps.js Conf 2022
27 min
¿Por qué es tan lento el CI?
Todos nos hemos preguntado esto mientras esperamos una eternidad a que termine nuestro trabajo de CI. Un CI lento no solo arruina la productividad del desarrollador, rompiendo nuestra concentración, sino que también cuesta dinero en tarifas de computación en la nube y desperdicia enormes cantidades de electricidad. Vamos a adentrarnos en por qué ocurre esto y cómo podemos solucionarlo con herramientas mejores y más rápidas.
La filosofía de Yarn
DevOps.js Conf 2022DevOps.js Conf 2022
31 min
La filosofía de Yarn
En los últimos años, Yarn se ha convertido en una de las herramientas más comunes utilizadas para desarrollar proyectos de JavaScript, en gran parte gracias a un conjunto de principios rectores. Pero, ¿cuáles son? ¿Cómo se aplican en la práctica a Yarn? Y, lo que es igual de importante, ¿cómo te benefician a ti y a tus proyectos?
En esta charla no nos adentraremos en pruebas de rendimiento o conjuntos de características: en su lugar, aprenderás cómo abordamos el desarrollo de Yarn, cómo exploramos nuevos caminos, cómo mantenemos nuestro código saludable y, en general, por qué creemos que Yarn se mantendrá firmemente establecido en nuestro ecosistema en los próximos años.
Poner fin al dolor: Repensando CI para Monorepos Grandes
DevOps.js Conf 2024DevOps.js Conf 2024
25 min
Poner fin al dolor: Repensando CI para Monorepos Grandes
Escalar bases de código grandes, especialmente monorepos, puede ser una pesadilla en los sistemas de Integración Continua (CI). El panorama actual de las herramientas de CI tiende a ser orientado a máquinas, de bajo nivel y exigente en términos de mantenimiento. Lo peor es que a menudo están desconectadas de las necesidades y el flujo de trabajo real del desarrollador.¿Por qué es un obstáculo el CI? Porque los sistemas de CI actuales son comodines, sin una comprensión específica de tu base de código. No pueden aprovechar el contexto en el que operan para ofrecer optimizaciones.En esta charla, exploraremos el futuro del CI, diseñado específicamente para bases de código grandes y monorepos. Imagina un sistema de CI que comprenda la estructura de tu espacio de trabajo, paralelice dinámicamente las tareas en máquinas utilizando datos históricos, y haga todo esto con una configuración mínima y de alto nivel. Repensemos el CI, haciéndolo más inteligente, eficiente y alineado con las necesidades del desarrollador.

Workshops on related topic

Descomponiendo Monolito NestJS API en Microservicios GRPC
Node Congress 2023Node Congress 2023
119 min
Descomponiendo Monolito NestJS API en Microservicios GRPC
Workshop
Alex Korzhikov
Alex Korzhikov
El masterclass se centra en conceptos, algoritmos y prácticas para descomponer una aplicación monolítica en microservicios GRPC. Presenta una visión general de los principios de arquitectura, patrones de diseño y tecnologías utilizadas para construir microservicios. Cubre la teoría del marco de trabajo GRPC y el mecanismo de protocol buffers, así como técnicas y especificidades de la construcción de servicios TypeScript aislados en el stack de Node.js. El masterclass incluye una demostración en vivo de un caso de uso de descomposición de una aplicación API en un conjunto de microservicios. Es adecuado para arquitectos, líderes técnicos y desarrolladores que deseen aprender patrones de microservicios.
Nivel: AvanzadoPatrones: DDD, MicroserviciosTecnologías: GRPC, Protocol Buffers, Node.js, TypeScript, NestJS, Express.js, PostgreSQL, TurborepoEstructura de ejemplo: configuración de monorepo, configuración de paquetes, utilidades comunes, servicio de demostraciónEjercicio práctico: refactorizar la aplicación monolítica
Despliegue de aplicaciones React Native en la nube
React Summit 2023React Summit 2023
88 min
Despliegue de aplicaciones React Native en la nube
WorkshopFree
Cecelia Martinez
Cecelia Martinez
Desplegar aplicaciones React Native manualmente en una máquina local puede ser complejo. Las diferencias entre Android e iOS requieren que los desarrolladores utilicen herramientas y procesos específicos para cada plataforma, incluidos los requisitos de hardware para iOS. Los despliegues manuales también dificultan la gestión de las credenciales de firma, las configuraciones de entorno, el seguimiento de las versiones y la colaboración en equipo.
Appflow es la plataforma de DevOps móvil en la nube creada por Ionic. Utilizar un servicio como Appflow para construir aplicaciones React Native no solo proporciona acceso a potentes recursos informáticos, sino que también simplifica el proceso de despliegue al proporcionar un entorno centralizado para gestionar y distribuir tu aplicación en múltiples plataformas. Esto puede ahorrar tiempo y recursos, permitir la colaboración, así como mejorar la confiabilidad y escalabilidad general de una aplicación.
En este masterclass, desplegarás una aplicación React Native para su entrega en dispositivos de prueba Android e iOS utilizando Appflow. También aprenderás los pasos para publicar en Google Play y Apple App Stores. No se requiere experiencia previa en el despliegue de aplicaciones nativas, y obtendrás una comprensión más profunda del proceso de despliegue móvil y las mejores prácticas para utilizar una plataforma de DevOps móvil en la nube para enviar rápidamente a gran escala.
Desacoplamiento en Práctica
Node Congress 2023Node Congress 2023
102 min
Desacoplamiento en Práctica
WorkshopFree
Chad Carlson
Chad Carlson
Desplegar aplicaciones desacopladas y de microservicios no es solo un problema que se resuelve el día de la migración. Avanzar con estas arquitecturas depende completamente de cómo será la experiencia del flujo de trabajo de su equipo día a día después de la migración.
La parte más difícil de esto a menudo es la cantidad de proveedores involucrados. Algunos objetivos son más adecuados para frameworks frontend específicos, mientras que otros son más adecuados para CMS y APIs personalizadas. Desafortunadamente, sus suposiciones, flujos de trabajo, APIs y conceptos de seguridad pueden ser bastante diferentes. Si bien hay ciertas ventajas en confiar en un contrato estricto entre aplicaciones, donde el trabajo del equipo backend y frontend se limita a un solo proveedor, esto no siempre es realista. Esto podría ser porque aún están experimentando, o simplemente porque el tamaño de su organización aún no permite este tipo de especialización.
En este masterclass, tendrás la oportunidad de explorar un enfoque diferente y de un solo proveedor para microservicios utilizando Strapi y Next.js como ejemplo. Desplegarás cada aplicación individualmente, estableciendo un flujo de trabajo desde el principio que simplifica la personalización, introduce nuevas características, investiga problemas de rendimiento e incluso permite la intercambiabilidad de frameworks desde el principio.
Estructura:- Comenzando- Descripción general de Strapi- Descripción general del flujo de trabajo de Platform.sh- Desplegar el proyecto- Cambiar servicios- Agregar el frontend
Requisitos previos:- Crear una cuenta de prueba en Platform.sh- Instalar la CLI de Platform.sh
Despliegue de Aplicación MERN Stack en Kubernetes
DevOps.js Conf 2022DevOps.js Conf 2022
152 min
Despliegue de Aplicación MERN Stack en Kubernetes
Workshop
Joel Lord
Joel Lord
Desplegar y gestionar aplicaciones JavaScript en Kubernetes puede volverse complicado. Especialmente cuando una base de datos también debe formar parte del despliegue. MongoDB Atlas ha facilitado mucho la vida de los desarrolladores, sin embargo, ¿cómo se integra un producto SaaS con su clúster de Kubernetes existente? Aquí es donde entra en juego el Operador de MongoDB Atlas. En este masterclass, los asistentes aprenderán cómo crear una aplicación MERN (MongoDB, Express, React, Node.js) localmente y cómo desplegar todo en un clúster de Kubernetes con el Operador de Atlas.
Azure Static Web Apps (SWA) con Azure DevOps
DevOps.js Conf 2022DevOps.js Conf 2022
13 min
Azure Static Web Apps (SWA) con Azure DevOps
WorkshopFree
Juarez Barbosa Junior
Juarez Barbosa Junior
Las Azure Static Web Apps se lanzaron a principios de 2021 y, de forma predeterminada, pueden integrar su repositorio existente y implementar su aplicación web estática desde Azure DevOps. Este masterclass demuestra cómo publicar una Azure Static Web App con Azure DevOps.