Múltiples aplicaciones, un código para gobernarlas a todas

Rate this content
Bookmark

Cada vez más, React se utiliza para aplicaciones complejas que acomodan numerosos tipos de usuarios, flujos de trabajo y mecánicas. A veces son personas diferentes las que utilizan cada parte de la aplicación, pero también es común un escenario de un solo usuario con múltiples flujos de trabajo.

En esta sesión, aprenderemos sobre nuestras opciones al construir múltiples experiencias dentro de una sola aplicación de React, sin perder la cordura. Utilizaré algunos ejemplos de lo que hacemos en Wilco.

FAQ

Jem Agnesi es el CTO y cofundador de Wilco, una plataforma de aprendizaje para ingenieros. Anteriormente, trabajó en WeWork y Meta como ingeniero senior y de personal.

Wilco es una plataforma de aprendizaje diseñada para que los ingenieros practiquen sus habilidades de desarrollo mediante escenarios de la vida real.

Los 'micro front-ends' son una técnica de desarrollo que divide una aplicación front-end en piezas más pequeñas y manejables. A pesar de su utilidad, pueden añadir complejidad en la implementación y en la gestión de la aplicación.

Wilco optó por una sola aplicación para facilitar el compartir estado y código entre las distintas partes de la aplicación, simplificar la gestión de análisis e informes, y reducir la sobrecarga de tener que mantener múltiples repositorios.

Una única aplicación permite compartir fácilmente el estado, manejar los análisis de errores y reportes de forma centralizada, y simplificar la gestión del código y las sesiones de usuario.

Wilco utiliza un subdominio dedicado para la autenticación que puede ser aprovechado por todas las aplicaciones, permitiendo una sincronización efectiva de sesiones y la autenticación de usuarios.

La ley de Conway propone que la estructura de un sistema de software reflejará la estructura de la organización que lo desarrolló. En Wilco, debido a su equipo pequeño y cohesionado, decidieron trabajar sobre una única aplicación para evitar la fragmentación del producto.

Shem Magnezi
Shem Magnezi
20 min
21 Jun, 2022

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Esta charla discute los beneficios de utilizar una sola aplicación para alojar múltiples experiencias o mini-aplicaciones, en lugar de una arquitectura de micro front-end. Al utilizar una sola aplicación, se vuelve más fácil compartir estado, simplificar el intercambio de código, manejar análisis y errores, y desplegar y monitorear la aplicación. La charla también aborda el manejo de la aplicación principal, enrutamiento, autenticación y subdominios para autenticación.

1. Introducción a las Aplicaciones Múltiples

Short description:

Hola a todos y bienvenidos a mi charla, múltiples aplicaciones, un código para gobernarlos a todos. Hoy voy a hablar un poco sobre un caso de uso interesante que tuvimos en Wilco cuando comenzamos. En Wilco, teníamos un par de pantallas, un par de experiencias. Necesitábamos crear dos experiencias para el usuario, que se mueve entre ellas. Una es una micro front-end, y podemos jugar con las últimas novedades que siempre están de moda en JavaScript. Pero antes de implementar esta arquitectura tan complicada, quiero decirle a nuestro equipo que espere un minuto y piense en esta arquitectura, si es realmente lo que queremos hacer. Porque no quiero que esto sea una crítica contra el micro front-end, me encanta el micro front-end, entiendo el valor. En esta charla, quiero convencerlos y tal vez detenerlos antes de que sigan por este camino.

Hola a todos y bienvenidos a mi charla, múltiples aplicaciones, un código para gobernarlos a todos.

Hoy voy a hablar un poco sobre un caso de uso, uno muy interesante del que podemos aprender. Pero antes de comenzar, quiero hablar un poco sobre mí.

Me llamo Jem Agnesi, soy el CTO y cofundador de Wilco. En Wilco, estamos tratando de construir una plataforma de aprendizaje donde cada ingeniero pueda practicar sus habilidades de desarrollo y obtener escenarios de la vida real para practicar. Antes de Wilco, trabajé como ingeniero senior y ingeniero de personal en WeWork y Meta. Pueden encontrarme en Twitter con este nombre de usuario.

Y como dije, hoy quiero hablar un poco sobre un caso de uso interesante que tuvimos en Wilco cuando comenzamos. En Wilco, teníamos un par de pantallas, un par de experiencias.

Entonces, como dije, estamos construyendo una especie de plataforma que permite a los usuarios y desarrolladores realizar una especie de búsqueda, donde cada búsqueda es una práctica para las habilidades de desarrollo.

Una experiencia es la plataforma Wilco, como se llama. Y como pueden ver, tenemos un feed de búsquedas del stack del futuro, la búsqueda futura, la búsqueda anterior que el usuario hizo, la búsqueda actual que está en curso, el perfil del usuario, las habilidades, la cantidad de monedas y los puntos que obtuvieron.

Esto es, como pueden ver, muy elegante, con un aspecto y una sensación de tema oscuro.

Por otro lado, teníamos el juego. Cuando comienzas el juego, ingresas a una especie de portal de una empresa muy antigua y cooperativa. Nuevamente, puedes ver tu búsqueda actual, lo que necesitas hacer. Tienes todo tipo de enlaces. Tienes tus usuarios.

Estas dos experiencias son muy, muy diferentes. Este es uno de los primeros requisitos que recibimos de nuestra gestión de productos. Necesitamos crear dos experiencias para el usuario, que se mueve entre ellas. Sé lo que piensan de inmediato si tenemos un elemento.

Entonces, esta es una micro front-end, y podemos dividirla en micro front-end, y podemos jugar con las últimas novedades que siempre están de moda en JavaScript.

Y entiendan, esto es lo que teníamos en mente cuando pensamos por primera vez en ello desde nuestra gestión de productos. Y antes de implementar esta arquitectura tan complicada, quiero decirle a nuestro equipo que espere un minuto y piense en esta arquitectura, si es realmente lo que queremos hacer. Porque no quiero que esto sea una crítica contra el micro front-end, me encanta el micro front-end, entiendo el valor. Incluso di una charla al respecto, como pueden ver. Y como alguien que ha jugado con el micro front-end y ha visto todo tipo de soluciones que tenemos allí, realmente necesitamos entender que el micro front-end puede introducir mucha complejidad en la implementación y en cómo trabajamos con esas aplicaciones. Hay muchas cosas en las que debes pensar antes de sumergirte en la implementación de este tipo de arquitecturas. Y en esta charla, quiero convencerlos y tal vez detenerlos antes de que sigan adelante.

2. Beneficios de una Aplicación Única

Short description:

Cuando elegimos una sola aplicación que aloja múltiples experiencias o mini-aplicaciones, podemos compartir fácilmente el estado entre ellas. Esto simplifica el intercambio de datos y el progreso del usuario, lo cual requeriría mucho trabajo en una arquitectura de micro front-end.

antes de seguir este camino. Porque una vez que te adentras en el camino del micro front-end, hay muchas cosas que hacer. Y realmente no es tan fácil revertirlo. Entonces, ¿por qué elegirías, por qué alguien elegiría una sola aplicación para crear este tipo de solución de dos experiencias muy diferentes? Cuando elegimos una sola aplicación que aloja esas dos o más experiencias o mini-aplicaciones, podemos compartir el estado entre esas aplicaciones. ¿De acuerdo? Como viste antes, tenemos dos aplicaciones muy, muy similares, tal vez no en la apariencia pero sí en los data que muestran, la búsqueda actual, el usuario, dónde se encuentran, qué pueden hacer, en qué estado se encuentran. Y una vez que lo haces en una aplicación React, puedes compartirlo fácilmente. No es que no puedas compartir el estado entre micro front-end, pero eso requiere mucho trabajo y no lo obtienes de forma predeterminada.

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.
Componentes de Full Stack
Remix Conf Europe 2022Remix Conf Europe 2022
37 min
Componentes de Full Stack
Top Content
Remix es un marco de trabajo web que te ofrece el modelo mental simple de una aplicación de múltiples páginas (MPA) pero el poder y las capacidades de una aplicación de una sola página (SPA). Uno de los grandes desafíos de las SPA es la gestión de la red que resulta en una gran cantidad de indirecciones y código defectuoso. Esto es especialmente notable en el estado de la aplicación que Remix elimina por completo, pero también es un problema en los componentes individuales que se comunican con un punto final de backend de un solo propósito (como una búsqueda de combobox, por ejemplo).
En esta charla, Kent demostrará cómo Remix te permite construir componentes de interfaz de usuario complejos que están conectados a un backend de la manera más simple y poderosa que hayas visto. Dejándote tiempo para relajarte con tu familia o lo que sea que hagas para divertirte.
Entendiendo la Arquitectura Fiber de React
React Advanced Conference 2022React Advanced Conference 2022
29 min
Entendiendo la Arquitectura Fiber de React
Top Content
Hemos escuchado mucho sobre la Arquitectura Fiber de React, pero parece que pocos de nosotros la entendemos en profundidad (o tenemos el tiempo para hacerlo). En esta charla, Tejas repasará su mejor intento de entender Fiber (revisado por otros expertos), y lo presentará de una manera 'explicar-como-si-tuviera-cinco años'.
Un Marco para Gestionar la Deuda Técnica
TechLead Conference 2023TechLead Conference 2023
35 min
Un Marco para Gestionar la Deuda Técnica
Top Content
Seamos realistas: la deuda técnica es inevitable y reescribir tu código cada 6 meses no es una opción. La refactorización es un tema complejo que no tiene una solución única para todos. Las aplicaciones de frontend son particularmente sensibles debido a los frecuentes cambios de requisitos y flujos de usuario. Nuevas abstracciones, patrones actualizados y limpieza de esas viejas funciones - todo suena genial en papel, pero a menudo falla en la práctica: los todos se acumulan, los tickets terminan pudriéndose en el backlog y el código legado aparece en cada rincón de tu base de código. Por lo tanto, un proceso de refactorización continua es la única arma que tienes contra la deuda técnica.En los últimos tres años, he estado explorando diferentes estrategias y procesos para refactorizar el código. En esta charla describiré los componentes clave de un marco para abordar la refactorización y compartiré algunos de los aprendizajes acumulados en el camino. Espero que esto te ayude en tu búsqueda de mejorar la calidad del código de tus bases de código.

Depuración de JS
React Summit 2023React Summit 2023
24 min
Depuración de JS
Top Content
Como desarrolladores, pasamos gran parte de nuestro tiempo depurando aplicaciones, a menudo código que ni siquiera escribimos. Lamentablemente, a pocos desarrolladores se les ha enseñado cómo abordar la depuración, es algo que la mayoría de nosotros aprendemos a través de la experiencia dolorosa. La buena noticia es que _puedes_ aprender a depurar de manera efectiva, y hay varias técnicas y herramientas clave que puedes usar para depurar aplicaciones de JS y React.
Luchando contra la Deuda Técnica con la Refactorización Continua
React Day Berlin 2022React Day Berlin 2022
29 min
Luchando contra la Deuda Técnica con la Refactorización Continua
Top Content
Afrontémoslo: la deuda técnica es inevitable y reescribir tu código cada 6 meses no es una opción. La refactorización es un tema complejo que no tiene una solución única para todos. Las aplicaciones de Frontend son particularmente sensibles debido a los frecuentes cambios de requisitos y flujos de usuario. Nuevas abstracciones, patrones actualizados y limpieza de esas viejas funciones - todo suena genial en papel, pero a menudo falla en la práctica: los todos se acumulan, los tickets terminan pudriéndose en el backlog y el código legado aparece en cada rincón de tu base de código. Por lo tanto, un proceso de refactorización continua es la única arma que tienes contra la deuda técnica. En los últimos tres años, he estado explorando diferentes estrategias y procesos para refactorizar el código. En esta charla describiré los componentes clave de un marco para abordar la refactorización y compartiré algunos de los aprendizajes acumulados en el camino. Espero que esto te ayude en tu búsqueda de mejorar la calidad del código de tus bases de código.

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.
Construyendo una Aplicación de Shopify con React & Node
React Summit Remote Edition 2021React Summit Remote Edition 2021
87 min
Construyendo una Aplicación de Shopify con React & Node
Top Content
WorkshopFree
Jennifer Gray
Hanna Chen
2 authors
Los comerciantes de Shopify tienen un conjunto diverso de necesidades, y los desarrolladores tienen una oportunidad única para satisfacer esas necesidades construyendo aplicaciones. Construir una aplicación puede ser un trabajo duro, pero Shopify ha creado un conjunto de herramientas y recursos para ayudarte a construir una experiencia de aplicación sin problemas lo más rápido posible. Obtén experiencia práctica construyendo una aplicación integrada de Shopify utilizando el CLI de la aplicación Shopify, Polaris y Shopify App Bridge.Te mostraremos cómo crear una aplicación que acceda a la información de una tienda de desarrollo y pueda ejecutarse en tu entorno local.
Construye una sala de chat con Appwrite y React
JSNation 2022JSNation 2022
41 min
Construye una sala de chat con Appwrite y React
WorkshopFree
Wess Cope
Wess Cope
Las API/Backends son difíciles y necesitamos websockets. Utilizarás VS Code como tu editor, Parcel.js, Chakra-ui, React, React Icons y Appwrite. Al final de este masterclass, tendrás los conocimientos para construir una aplicación en tiempo real utilizando Appwrite y sin necesidad de desarrollar una API. ¡Sigue los pasos y tendrás una increíble aplicación de chat para presumir!
Problemas difíciles de GraphQL en Shopify
GraphQL Galaxy 2021GraphQL Galaxy 2021
164 min
Problemas difíciles de GraphQL en Shopify
WorkshopFree
Rebecca Friedman
Jonathan Baker
Alex Ackerman
Théo Ben Hassen
 Greg MacWilliam
5 authors
En Shopify a gran escala, resolvemos algunos problemas bastante difíciles. En este masterclass, cinco oradores diferentes describirán algunos de los desafíos que hemos enfrentado y cómo los hemos superado.

Tabla de contenidos:
1 - El infame problema "N+1": Jonathan Baker - Vamos a hablar sobre qué es, por qué es un problema y cómo Shopify lo maneja a gran escala en varios APIs de GraphQL.
2 - Contextualizando APIs de GraphQL: Alex Ackerman - Cómo y por qué decidimos usar directivas. Compartiré qué son las directivas, qué directivas están disponibles de forma predeterminada y cómo crear directivas personalizadas.
3 - Consultas de GraphQL más rápidas para clientes móviles: Theo Ben Hassen - A medida que tu aplicación móvil crece, también lo harán tus consultas de GraphQL. En esta charla, repasaré diversas estrategias para hacer que tus consultas sean más rápidas y efectivas.
4 - Construyendo el producto del futuro hoy: Greg MacWilliam - Cómo Shopify adopta las características futuras en el código actual.
5 - Gestión efectiva de APIs grandes: Rebecca Friedman - Tenemos miles de desarrolladores en Shopify. Veamos cómo estamos asegurando la calidad y consistencia de nuestras APIs de GraphQL con tantos colaboradores.
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.
De 0 a Autenticación en una Hora para tu Aplicación JavaScript
JSNation 2023JSNation 2023
57 min
De 0 a Autenticación en una Hora para tu Aplicación JavaScript
WorkshopFree
Asaf Shen
Asaf Shen
La autenticación sin contraseña puede parecer compleja, pero es fácil de agregar a cualquier aplicación utilizando la herramienta adecuada.
Mejoraremos una aplicación JS de pila completa (backend Node.js + frontend Vanilla JS) para autenticar usuarios con contraseñas de un solo uso (correo electrónico) y OAuth, incluyendo:
- Autenticación de usuario: Gestión de interacciones de usuario, devolución de JWT de sesión / actualización- Gestión y validación de sesiones: Almacenamiento seguro de la sesión para solicitudes posteriores del cliente, validación / actualización de sesiones
Al final del masterclass, también abordaremos otro enfoque para la autenticación de código utilizando Flujos de Descope en el frontend (flujos de arrastrar y soltar), manteniendo solo la validación de sesión en el backend. Con esto, también mostraremos lo fácil que es habilitar la biometría y otros métodos de autenticación sin contraseña.