8 Cosas que No Sabías que los Micro Frontends Pueden Hacer

Rate this content
Bookmark

¿Sabías que los micro frontends pueden ser mucho más rápidos que sus contrapartes monolíticas? ¿Qué tal los rollbacks de características específicas? En esta charla escucharás y verás 8 ejemplos de cosas que no solo te enseñarán un poco sobre los micro frontends, sino también en qué casos son más útiles.

This talk has been presented at React Summit US 2024, check out the latest edition of this React Conference.

Florian Rappl
Florian Rappl
22 min
22 Nov, 2024

Comments

Sign in or register to post your comment.
Video Summary and Transcription
Bienvenido a la sesión sobre microfrontends. Los microfrontends permiten implementaciones independientes y desarrollo local. Es posible desarrollar e integrar microfrontends localmente utilizando un emulador y lograr actualizaciones automáticas. La afinación de módulos y la experiencia del usuario se pueden realizar utilizando un servicio de descubrimiento. Se pueden crear reglas en el servicio de descubrimiento para cargar selectivamente microfrontends para navegadores específicos. La IA se puede aprovechar para generar variantes mejoradas por IA y compararlas con la implementación original. Los microfrontends son altamente portátiles y se pueden utilizar en diferentes aplicaciones. El aislamiento de código y el rendimiento mejorado son consideraciones importantes en los microfrontends. Los beneficios de los microfrontends incluyen mejoras en los cambios de nombres de archivos y la sobrecarga de rendimiento. La aplicación de Netflix es un estudio de caso para los microfrontends. En general, los microfrontends ofrecen diversos beneficios y oportunidades para discusiones arquitectónicas.

1. Introducción a los Microfrontends

Short description:

Bienvenidos a todos a la sesión, 8 Cosas que No Sabías que los Microfrontends Pueden Hacer. La sesión está dirigida a personas con poco o ningún contacto con los microfrontends. El orador, Flo, es un arquitecto de soluciones especializado en aplicaciones web distribuidas y microfrontends. Él proporcionará una definición general de los microfrontends, explicando su representación técnica de un subdominio empresarial y el patrón organizativo detrás de ellos.

Bienvenidos a todos a la sesión, 8 Cosas que No Sabías que los Microfrontends Pueden Hacer. La sesión está dirigida principalmente a personas que han tenido muy poco o incluso ningún contacto con los microfrontends, así que si te consideras un experto en microfrontends, asumiría que ya conoces una o dos cosas de esto, pero espero poder enseñarte, digamos, una variedad de cosas que deberían ser posibles.

Antes de sumergirnos en el tema, unas palabras sobre mí. Hola, mi nombre es Flo, soy un arquitecto de soluciones de una empresa más pequeña llamada SmartPio. Estamos ubicados en Múnich, Alemania, y nos ocupamos principalmente de plataformas de IoT, aplicaciones modulares, auditorías de seguridad y demás. Yo mismo estoy especializado en aplicaciones web distribuidas y microfrontends. También imparto talleres, hago revisiones de código y, por supuesto, ayudo a los equipos a escalar el desarrollo del frontend. Así que si algo de lo que acabo de decir tiene sentido para ti y quieres ponerte en contacto y potencialmente discutir cómo podemos, digamos, mejorar tu arquitectura, solo envíame un mensaje. El enlace de LinkedIn también está escrito en la parte inferior de todas las diapositivas. Muy bien, pero no tenemos mucho tiempo y hay ocho cosas que debemos cubrir, así que vamos a entrar directamente en el tema, y lo que quiero hacer es comenzar con una definición general, digamos, de los microfrontends, porque hay varias definiciones por ahí y es posible que estés un poco inseguro de qué son los microfrontends. Los microfrontends son la representación técnica de un subdominio empresarial. Lo que ya puedes, digamos, saber de esa definición es que no hay restricciones y tampoco directrices sobre qué debes hacer para una implementación técnica. Todo lo que he dicho aquí es que es más o menos un patrón organizativo que surge aquí que, por supuesto, está orientado hacia

2. Implementación y Desarrollo Local

Short description:

Los microfrontends permiten implementaciones independientes con la misma o diferente tecnología. Se pueden considerar como una extensión o el siguiente paso después de los microservicios, abarcando tanto el frontend como el backend. El objetivo es tener equipos autónomos, cada uno con microfrontends aislados. Un enfoque de implementación es el desarrollo local y sin conexión, utilizando herramientas de compilación y un emulador para trabajar en los microfrontends localmente. Esto permite actualizaciones automáticas e integración de otros microfrontends.

resolviendo un problema técnico. Ahora, si quieres profundizar un poco más, por supuesto, entonces necesitarías seguir leyendo porque permiten implementaciones independientes con la misma o diferente tecnología, lo que significa que puedes, por supuesto, usar, no sé, React para escribir tus componentes, pero también podrías usar algo más. Así que un poco de las promesas que ya conoces de los microservicios. En general, los microfrontends se pueden considerar como una extensión o, digamos, el siguiente paso después de los microservicios y también afectan al frontend. No necesariamente tienen que ser exclusivos del frontend. Ellos también pueden tener una parte del backend y las mejores soluciones escalables, digamos, son realmente full stack, lo que significa que hay, por supuesto, un fragmento de UI que se entrega, pero también hay fragmentos del backend que se entregan aquí desde estos equipos. Ahora, lo que deberían hacer para lograr eso es minimizar el código compartido, al igual que ya haces con tu backend. Y, por supuesto, no quieres, digamos, tener áreas entrelazadas con otros subdominios, es decir, otros equipos que también están creando microfrontends. Al final, el objetivo es tener equipos autónomos aquí. Entonces, un equipo también puede tener múltiples microfrontends, pero la parte realmente importante es que no haya un microfrontend compartido entre diferentes equipos. Por lo tanto, los microfrontends también representan realmente una unidad aislada de la que hablas. Ahora, como dije, hay varias cosas que puedes hacer para implementarlos. Esta no será una charla en la que repase todas estas cosas. Simplemente usaré, por supuesto, implementaciones de muestra para mostrarte las ocho cosas que puedes hacer en su lugar. Así que comencemos de inmediato con el desarrollo local y sin conexión. Muy a menudo, cuando te adentras en el área de los microfrontends, la gente dice, bueno, entonces necesitamos tener un entorno de agregación, y solo en ese entorno, ¿puedes decir, dejar que tus microfrontends se ejecuten? Siempre tendrás esa especie de sensación extraña de que simplemente no estás desarrollando algo. Ni siquiera sabemos cómo se ve cuando se integra y se utiliza realmente por los usuarios finales. Y eso no es realmente bueno. Entonces, en lugar de eso, y lo que siempre animamos a la gente a hacer es, tenemos una herramienta de compilación que, por supuesto, inicia tu sesión de desarrollo localmente contra tu microfrontend, pero también tiene en cuenta otras fuentes. Y muy a menudo estas fuentes ya se pueden instalar de antemano, por ejemplo, en forma de paquetes NPM pero también pueden residir en algún lugar en línea. Y luego, cuando inicias tu sesión de desarrollo, simplemente se obtiene o no, ¿verdad? Si ya tienes algo localmente, se podría utilizar la versión en caché, pero esto te permite actualizarlo automáticamente. Entonces ahora ejecutas un microfrontend de estudio, pero ahora se ejecuta en el contexto de esto, a lo que normalmente nos referimos como emulador. El nombre se eligió porque es la misma idea que tienes, por ejemplo, cuando desarrollas, por ejemplo, una aplicación Android, tampoco lo haces directamente en tu teléfono. No haces la integración, sino que trabajas contra este emulador. Y esto, por supuesto, puede darte algunos consejos útiles. Ahora, mirando este escenario aquí, tenemos un microfrontend, es solo un proyecto estándar de Node o NPM. Entonces, basado aquí, por supuesto, en React, y ves que ya tenemos muchas dependencias de desarrollo instaladas, pero la base de código es bastante pequeña. Si miras en las dependencias en profundidad, también tienes esta extraña, que es nuestro emulador. Ahora, si simplemente inicias esto, entonces, por supuesto, nuestro microfrontend se ejecutará, pero se ve bastante vacío, pero ya está en algo donde no vemos parpadeos. Así que esa es la demostración detrás. Tenemos esta estructura de Netflix, pero está bastante vacía porque estamos desarrollando de forma aislada, ¿verdad? Pero lo que puede hacer a través de una extensión del navegador, por ejemplo,

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.
Entendiendo la Arquitectura Fiber de React
React Advanced 2022React Advanced 2022
29 min
Entendiendo la Arquitectura Fiber de React
Top Content
This Talk explores React's internal jargon, specifically fiber, which is an internal unit of work for rendering and committing. Fibers facilitate efficient updates to elements and play a crucial role in the reconciliation process. The work loop, complete work, and commit phase are essential steps in the rendering process. Understanding React's internals can help with optimizing code and pull request reviews. React 18 introduces the work loop sync and async functions for concurrent features and prioritization. Fiber brings benefits like async rendering and the ability to discard work-in-progress trees, improving user experience.
Componentes de Full Stack
Remix Conf Europe 2022Remix Conf Europe 2022
37 min
Componentes de Full Stack
Top Content
RemixConf EU discussed full stack components and their benefits, such as marrying the backend and UI in the same file. The talk demonstrated the implementation of a combo box with search functionality using Remix and the Downshift library. It also highlighted the ease of creating resource routes in Remix and the importance of code organization and maintainability in full stack components. The speaker expressed gratitude towards the audience and discussed the future of Remix, including its acquisition by Shopify and the potential for collaboration with Hydrogen.
Composición vs Configuración: Cómo Construir Componentes Flexibles, Resilientes y a Prueba de Futuro
React Summit 2022React Summit 2022
17 min
Composición vs Configuración: Cómo Construir Componentes Flexibles, Resilientes y a Prueba de Futuro
Top Content
Today's Talk discusses building flexible, resilient, and future-proof React components using composition and configuration approaches. The composition approach allows for flexibility without excessive conditional logic by using multiple components and passing props. The context API can be used for variant styling, allowing for appropriate styling and class specification. Adding variants and icons is made easy by consuming the variant context. The composition and configuration approaches can be combined for the best of both worlds.
Patrones de Arquitectura Remix
Remix Conf Europe 2022Remix Conf Europe 2022
23 min
Patrones de Arquitectura Remix
Top Content
This Talk introduces the Remix architecture patterns for web applications, with over 50% of participants using Remix professionally. The migration from single page applications to Remix involves step-by-step refactoring and offers flexibility in deployment options. Scalability can be achieved by distributing the database layer and implementing application caching. The backend for frontend pattern simplifies data fetching, and Remix provides real-time capabilities for collaborative features through WebSocket servers and Server-SendEvents.

Workshops on related topic

IA a demanda: IA sin servidor
DevOps.js Conf 2024DevOps.js Conf 2024
163 min
IA a demanda: IA sin servidor
Top Content
Featured WorkshopFree
Nathan Disidore
Nathan Disidore
En esta masterclass, discutimos los méritos de la arquitectura sin servidor y cómo se puede aplicar al espacio de la IA. Exploraremos opciones para construir aplicaciones RAG sin servidor para un enfoque más lambda-esque a la IA. A continuación, nos pondremos manos a la obra y construiremos una aplicación CRUD de muestra que te permite almacenar información y consultarla utilizando un LLM con Workers AI, Vectorize, D1 y Cloudflare Workers.
Masterclass de alto rendimiento Next.js
React Summit 2022React Summit 2022
50 min
Masterclass de alto rendimiento Next.js
Workshop
Michele Riva
Michele Riva
Next.js es un marco convincente que facilita muchas tareas al proporcionar muchas soluciones listas para usar. Pero tan pronto como nuestra aplicación necesita escalar, es esencial mantener un alto rendimiento sin comprometer el mantenimiento y los costos del servidor. En este masterclass, veremos cómo analizar el rendimiento de Next.js, el uso de recursos, cómo escalarlo y cómo tomar las decisiones correctas al escribir la arquitectura de la aplicación.