Observabilidad para Microfrontends

Rate this content
Bookmark

Los equipos están creciendo cada vez más siguiendo la arquitectura de microfrontends. La observabilidad para los equipos a gran escala se vuelve aún más importante para poder identificar posibles problemas en tiempo de ejecución, así como separar las responsabilidades. En esta presentación aprenderemos cómo lograrlo.

FAQ

Los micro-frontends son una forma de escalar software y equipos, permitiendo estructurar mejor los equipos para enfocarse en un dominio comercial específico y resolver problemas particulares del negocio.

Los micro-frontends siguen el paradigma de los microservicios, separando una aplicación monolítica en partes más pequeñas, cada una enfocada en un aspecto específico del negocio, similar a cómo los microservicios dividen la lógica de backend.

La observabilidad permite inferir los estados internos de un sistema a partir de sus salidas externas y es crucial para monitorizar y resolver problemas en aplicaciones distribuidas como los micro-frontends.

La alta cardinalidad se refiere a la gran cantidad de valores únicos que puede tener un atributo, lo que ayuda a identificar y aislar problemas específicos en un sistema.

Se puede aplicar observabilidad utilizando herramientas que permiten consultar datos de alta cardinalidad y configurando componentes como límites de error para gestionar y reportar errores en tiempo real.

DAZN utiliza New Relic para registrar y monitorear problemas de producción en tiempo real, ayudando a los equipos a identificar y resolver incidencias de forma eficiente.

Un límite de error es un componente que maneja los errores en sub-componentes, permitiendo que la aplicación continúe funcionando y presentando una interfaz alternativa en lugar de colapsar completamente.

En DAZN, se utilizan micro-frontends para estructurar equipos alrededor de dominios comerciales específicos, con cada equipo trabajando en módulos distintos que forman parte de la plataforma de transmisión.

Konstantinos Leimonis
Konstantinos Leimonis
24 min
25 Mar, 2022

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Los microfrontends siguen el paradigma de los microservicios y la observabilidad es crucial para depurar problemas de producción en tiempo de ejecución. Los límites de error y el seguimiento de errores ayudan a identificar y resolver problemas. La automatización de las alertas mejora la respuesta a incidentes. La observabilidad puede ayudar a minimizar el tiempo que se tarda en comprender y resolver problemas de producción. Capturar errores del cliente e implementar límites se puede hacer con herramientas como OpenTelemetry.

Available in English: Observability for Microfrontends

1. Introducción a la Observabilidad para Micro-frontends

Short description:

Hola a todos. Mi nombre es Konstantinos y soy un ingeniero de software con sede en Londres. Hoy hablaré sobre la observabilidad para micro-frontends. Exploraremos qué son los micro-frontends, su relación con la observabilidad y por qué los ingenieros frontend deberían preocuparse por ello. También tendremos una demostración aplicando la observabilidad a los micro-frontends. En DAZN, invertimos mucho en micro frontends, creando equipos que se centran en dominios comerciales específicos. Comencemos con los microservicios, que se introdujeron para separar el monolito backend en piezas más pequeñas de lógica y datos. Aplicamos la misma arquitectura a las aplicaciones frontend, dando origen a las aplicaciones de microfrontend.

Hola a todos. Mi nombre es Konstantinos y soy un ingeniero de software con sede en Londres. El tema que me gustaría compartir con ustedes hoy es sobre la observabilidad para micro-frontends.

Una agenda rápida para hoy, hablaré sobre los micro-frontends y la observabilidad para entender qué son, si pueden encajar juntos y cómo pueden coexistir. ¿Deberíamos, como ingenieros frontend, preocuparnos por la observabilidad? Y finalmente, una demostración para aplicar la observabilidad a los micro-frontends. Algunos objetivos para hoy. Vamos a definir el camino hacia la observabilidad. Este será nuestro punto de partida y cómo podemos crecer a partir de ahí. Veremos algunos patrones útiles que mi equipo y yo encontramos realmente útiles durante nuestro viaje para identificar problemas en tiempo de ejecución en producción y automatizaremos cómo recibimos notificaciones y alertas para incidentes de producción. Así que empecemos. Micro-frontends. En primer lugar, si te preguntas si existen, puedo decirte que sí existen. No son un unicornio mágico, en realidad no son una herramienta, no son una tecnología, son una forma de escalar software y equipos. Nos ayudan a estructurar mejor nuestros equipos para centrarnos en un dominio comercial y ayudar a un equipo a resolver y ser dueño de un problema específico del negocio. En DAZN, donde trabajo actualmente, aplicamos micro-frontends, pero primero déjame darte una visión general. Este video te dará más contexto. DAZN es una plataforma de transmisión de deportes en vivo y a pedido, que brinda a los fanáticos del deporte el control y la flexibilidad para ver sus deportes a su manera. No necesitas un cable o una antena parabólica para verlo, por lo que la configuración es bastante rápida y sencilla. Puedes descargar la aplicación DAZN y verla en múltiples dispositivos en casa o mientras te desplazas. Estamos implementando software en múltiples plataformas como web, móvil y televisores. En DAZN, invertimos mucho en micro frontends, creando equipos frontend que se centran en un dominio comercial específico. Comencemos con los microservicios. Hace algunos años, nos dimos cuenta de que queríamos comenzar a construir equipos en torno a un problema específico del negocio. Los microservicios se introdujeron como una forma de separar el monolito backend en piezas más pequeñas de lógica y datos. Como puedes ver aquí, tenemos el servicio de descubrimiento, el servicio de autenticación, mi cuenta y el servicio de preferencias. Estos servicios se centran en un dominio específico, en un dominio comercial específico. A veces, tenemos una capa de agregación frente a ellos, como puede ser un backend para frontend o una API de GraphQL. Esto es lo que las aplicaciones frontend utilizan para consumir estos servicios si no los consumen directamente. Y en ese momento, el frontend todavía era un monolito. Y dijimos, ¿por qué no aplicar la misma arquitectura?

2. Microfrontends y Observabilidad

Short description:

Los microfrontends siguen el paradigma de microservicios, separan el monolito y la aplicación frontend en partes más pequeñas. Ahora tenemos equipos de extremo a extremo con una misión específica, enfocándose en una parte del negocio. En cualquier caso, los microfrontends deben seguir los mismos principios que los microservicios. Pero por ahora, quiero que nos centremos en los microfrontends como sistemas altamente observables. La observabilidad es una forma de democratizar este proceso. Les brinda a todos los miembros del equipo, especialmente a los más curiosos, la capacidad de solucionar estos problemas. La observabilidad es la condición de estar capacitado para preguntar por qué, dándote la flexibilidad de investigar lo desconocido sobre la marcha.

¿Qué son los microfrontends en aplicaciones frontend? Así es como nacieron las aplicaciones de microfrontends. Los microfrontends siguen el paradigma de microservicios, separan el monolito y la aplicación frontend en partes más pequeñas. Ahora tenemos equipos de extremo a extremo con una misión específica, enfocándose en una parte del negocio. Como aquí, puedes ver que tenemos el equipo de descubrimiento, el equipo de autenticación, el equipo de Mi Cuenta o el equipo de preferencias, y expanden el equipo en toda la pila. Tenemos equipos de frontend, backend y base de datos que se han enfocado en esta misión específica del negocio. Los equipos aquí pueden parecer muy bien definidos, pero a veces puede que no haya una separación clara. Si nos acercamos, uno de estos microfrontends, podemos encontrar más microfrontends, y es cuando las cosas comienzan a volverse un poco confusas y la separación de responsabilidades puede volverse un poco borrosa. Aquí, por ejemplo, podemos tener un equipo A responsable del encabezado y el pie de página, pero podemos tener un equipo B responsable de los detalles de Mi Cuenta. Estos son diferentes módulos en este microfrontend, pero diferentes equipos pueden tener diferentes responsabilidades. En cualquier caso, los microfrontends deben seguir los mismos principios que los microservicios. Pero por ahora, quiero que nos centremos en los microfrontends como sistemas altamente observables. En los microfrontends, es más fácil observar un sistema único que un sistema dividido en múltiples módulos. Pero ¿cómo podemos proporcionar una alta observabilidad en este último caso de microfrontend? Pero para hacer eso, intentemos entender qué es la observabilidad. La observabilidad como término puede ser bastante abstracta, así que intentemos limitarla a una definición más específica. El monitoreo no es observabilidad. Es posible que hayas visto paneles y métricas que rastrean un sistema en vivo. El monitoreo ha sido el enfoque por defecto durante mucho tiempo. Las personas tienden a pensar que es la única forma de comprender sus sistemas en lugar de ser solo una forma de comprenderlos. El monitoreo te dice cuándo algo está mal. Necesitas saber de antemano qué señales quieres monitorear, tus incógnitas conocidas. De manera similar, la intuición no es observabilidad. Es posible que hayas estado en un caso en el que en tu equipo tienes un problema de producción y uno de los ingenieros más experimentados del equipo puede depurar y descubrir la causa raíz de ese problema y finalmente resolverlo. La observabilidad es una forma de democratizar este proceso. Les brinda a todos los miembros del equipo, especialmente a los más curiosos, la capacidad de solucionar estos problemas. Kalman dijo que la observabilidad es una medida de cuán bien se pueden inferir los estados internos de un sistema a partir del conocimiento de sus salidas externas. Kalman fue un ingeniero en los años 60 y definió la observabilidad. La observabilidad tiene sus raíces en la teoría del control y para comprender esta definición necesitaríamos sumergirnos en álgebra lineal y métodos formales, pero no lo haremos. Ahora significa cosas diferentes en diferentes comunidades y también se puede aplicar a sistemas de software modernos. Pero un aspecto importante de la observabilidad es esto. La observabilidad es la condición de estar capacitado para preguntar por qué, dándote la flexibilidad de investigar lo desconocido sobre la marcha. ¿Cómo podemos lograr esto? Podemos hacerlo con alta cardinalidad.

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

Escalando con Remix y Micro Frontends
Remix Conf Europe 2022Remix Conf Europe 2022
23 min
Escalando con Remix y Micro Frontends
Top Content
¿Tienes un producto grande construido por muchos equipos? ¿Estás luchando para lanzar a menudo? ¿Se convirtió tu frontend en un monolito inmantenible masivo? Si, como yo, has respondido sí a cualquiera de esas preguntas, ¡esta charla es para ti! Te mostraré exactamente cómo puedes construir una arquitectura de micro frontend con Remix para resolver esos desafíos.
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.
De Monolito a Micro-Frontends
React Advanced Conference 2022React Advanced Conference 2022
22 min
De Monolito a Micro-Frontends
Top Content
Muchas empresas en todo el mundo están considerando adoptar Micro-Frontends para mejorar la agilidad empresarial y la escala, sin embargo, hay muchas incógnitas cuando se trata de cómo se ve en la práctica el camino de migración. En esta charla, discutiré los pasos necesarios para migrar con éxito una aplicación React monolítica a una arquitectura de frontend más modular y desacoplada.
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.

Workshops on related topic

Micro Frontends con Module Federation y React
JSNation Live 2021JSNation Live 2021
113 min
Micro Frontends con Module Federation y React
Workshop
Alex Lobera
Alex Lobera
¿Alguna vez has trabajado en una aplicación monolítica de Next.js? Yo sí, y escalar una gran aplicación de React para que muchos equipos puedan trabajar simultáneamente no es fácil. Con micro frontends, puedes dividir un monolito frontend en piezas más pequeñas para que cada equipo pueda construir e implementar de forma independiente. En este masterclass aprenderás cómo construir aplicaciones de React grandes que escalen utilizando micro frontends.
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.
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.