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.

This talk has been presented at DevOps.js Conf 2022, check out the latest edition of this JavaScript Conference.

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.

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.

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.

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.

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.

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
This talk discusses the usage of Microfrontends in Remix and introduces the Tiny Frontend library. Kazoo, a used car buying platform, follows a domain-driven design approach and encountered issues with granular slicing. Tiny Frontend aims to solve the slicing problem and promotes type safety and compatibility of shared dependencies. The speaker demonstrates how Tiny Frontend works with server-side rendering and how Remix can consume and update components without redeploying the app. The talk also explores the usage of micro frontends and the future support for Webpack Module Federation in Remix.
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
NPM workspaces help manage multiple nested packages within a single top-level package, improving since the release of NPM CLI 7.0. You can easily add dependencies to workspaces and handle duplications. Running scripts and orchestration in a monorepo is made easier with NPM workspaces. The npm pkg command is useful for setting and retrieving keys and values from package.json files. NPM workspaces offer benefits compared to Lerna and future plans include better workspace linking and adding missing features.
De Monolito a Micro-Frontends
React Advanced 2022React Advanced 2022
22 min
De Monolito a Micro-Frontends
Top Content
Microfrontends are considered as a solution to the problems of exponential growth, code duplication, and unclear ownership in older applications. Transitioning from a monolith to microfrontends involves decoupling the system and exploring options like a modular monolith. Microfrontends enable independent deployments and runtime composition, but there is a discussion about the alternative of keeping an integrated application composed at runtime. Choosing a composition model and a router are crucial decisions in the technical plan. The Strangler pattern and the reverse Strangler pattern are used to gradually replace parts of the monolith with the new application.
Automatizando Todo el Código y las Pruebas con GitHub Actions
React Advanced 2021React Advanced 2021
19 min
Automatizando Todo el Código y las Pruebas con GitHub Actions
Top Content
We will learn how to automate code and testing with GitHub Actions, including linting, formatting, testing, and deployments. Automating deployments with scripts and Git hooks can help avoid mistakes. Popular CI-CD frameworks like Jenkins offer powerful orchestration but can be challenging to work with. GitHub Actions are flexible and approachable, allowing for environment setup, testing, deployment, and custom actions. A custom AppleTools Eyes GitHub action simplifies visual testing. Other examples include automating content reminders for sharing old content and tutorials.
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
DevOps is a journey that varies for each company, and remote work makes transformation challenging. Pull requests can be frustrating and slow, but success stories like Mateo Colia's company show the benefits of deploying every day. Challenges with tools and vulnerabilities require careful consideration and prioritization. Investing in documentation and people is important for efficient workflows and team growth. Trust is more important than excessive control when deploying to production.
¿Por qué es tan lento el CI?
DevOps.js Conf 2022DevOps.js Conf 2022
27 min
¿Por qué es tan lento el CI?
Slow CI has a negative impact on productivity and finances. Debugging CI workflows and tool slowness is even worse. Dependencies impact CI and waiting for NPM or YARN is frustrating. The ideal CI job involves native programs for static jobs and lightweight environments for dynamic jobs. Improving formatter performance and linting is a priority. Performance optimization and fast tools are essential for CI and developers using slower hardware.

Workshops on related topic

Micro Frontends with Module Federation and React
JSNation Live 2021JSNation Live 2021
113 min
Micro Frontends with Module Federation and React
Top Content
Workshop
Alex Lobera
Alex Lobera
¿Alguna vez trabajaste 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 de frontend en piezas más pequeñas para que cada equipo pueda construir y desplegar de manera independiente. En este masterclass, aprenderás cómo construir grandes aplicaciones de React 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.