MICRO - FRONTEND con Angular y Module Federation, Multi Repo 🤯

  Рет қаралды 8,604

LogiDev

LogiDev

Күн бұрын

Пікірлер: 83
@jesusorozco294
@jesusorozco294 Жыл бұрын
Video y ejercicio completado! ya hice el de monorepo y ahora este de multirepo, hasta ahora todo muy claro, gracias!
@LogiDev
@LogiDev Жыл бұрын
Genial 🙌🏻
@frochaol
@frochaol Жыл бұрын
Muchas gracias por el video, fue de mucha ayuda !!!
@LogiDev
@LogiDev Жыл бұрын
Gracias por el apoyo 🙌🏻
@santiiza
@santiiza 10 ай бұрын
Excelente, queria sabr como cambia la codificacion con los stanalone component, donde ya no existen modulos para hacer referencias
@LogiDev
@LogiDev 10 ай бұрын
Los modulos no desaparecieron :v la unica diferencia con el standalone component es que tendra sus propias importaciones, a nivel de MF en vez de cargar un modulo ahora cargas un standalone component, no hay problema, el ejemplo esta en el MF-PAYMENT, revisa el repositorio.
@eivanmtzleal9547
@eivanmtzleal9547 Жыл бұрын
Gracias Jimmy... excelente contenido !
@LogiDev
@LogiDev Жыл бұрын
Gracias por el apoyo 🙌🏻
@oscarperez-kp3qd
@oscarperez-kp3qd Жыл бұрын
Como siempre, excelente video Jimy
@LogiDev
@LogiDev Жыл бұрын
Hola, gracias por tu apoyo 🙌🏻
@WalterRemache-u7z
@WalterRemache-u7z 11 ай бұрын
Muy buen video, excelente explicacion, que configuracion tendria que hacer si unos de los mf tiene rutas hijas ?
@drackp2m
@drackp2m Жыл бұрын
Me flipa todo lo que explicas, y cómo lo haces. He visto en tu enlace para invitarte a un café que tienes seis años de experiencia. ¡¡Parece más cuando se te oye hablar!! Aunque no lo hubiera pensado nunca por lo joven que aparentas ser. ¿Sería muy indiscreto si te preguntara tu edad? 😜 Por cierto, he echado de menos conocer si hay forma de tener estos micro-frontends combinados en un proyecto a la hora de compilar, de modo que mantengas la ventaja de poderlos arrancar por separado para desarrollar, pero que no haya que hacer muchas peticiones para cargar estas "partes" una vez desplegado. Además, si controlas del tema, creo que estaría guay una sesión informativa sobre cómo añadir colas a las notificaciones y alertas y tratamiento de dead letters. ¡¡Un saludo muy grande, eres un crack!!
@LogiDev
@LogiDev Жыл бұрын
Hola! gracias por las palabras, no soy tan Joven como aprento, tengo 31 años . Respecto a los microfront, los puedes levantar por separado sin necesidad de ejecutar el Shell y poder seguir desarrollando; gracias por las sugerencias, saludos y gracias.🙌
@UrielGuillen-i5z
@UrielGuillen-i5z Ай бұрын
@LogiDev muy buen video! me ha quedado claro como funciona el multi repo, solo tengo una duda, a nivel desarrollo, si tengo mi shell y por ejemplo 8 remotes, la idea seria solo correr el remote sobre el que quiero desarrollar por lo que los otros 7 no es necesario tenerlos corriendo, con ese approach, como podria configurarse el shell para que no dependa de tener corriendo los 8 multi repos?? al final cada MF tendra su ruta de acceso y mientras no acceda a esa ruta, el shell no deberia romperse porque no depende de los MF para funcionar, saludos!
11 ай бұрын
Muy buena explicacion. tengo una duda, ¿como se comparten el token entre microfrontend?
@LogiDev
@LogiDev 11 ай бұрын
Hola eso dependera de que tecnologia estas usando para la autenticación, pero te recomiendo que tengas un MF encargado de todo el AUT; si estas usando Auth0 puede usar su SDK que hace el trabajo de compartir la autenticacion entre MF: auth0.com/docs/libraries/auth0-single-page-app-sdk Si estas administrando la sesion por tu propio servidor (tu creas el token) lo idea seria que al iniciar sesion guardes ese token en una cookie, luego cada vez que un usuario intente golpear a algun servicio, esa cookie viajara al servidor de manera automatica, y desde el servidor haces la validacion de autenticacion
@LogiDev
@LogiDev Жыл бұрын
Link del repositorio: github.com/jimyhdolores/demo-microfrontend-multirepo-angular-modulefederation
@dromeroSL
@dromeroSL Жыл бұрын
Jimmy puede ser que el repo no sea publico?
@dromeroSL
@dromeroSL Жыл бұрын
no dije nada el link tomaba el emoji :D
@LogiDev
@LogiDev Жыл бұрын
@@dromeroSL acabo de actualizarlo, vuelve a probar porfa
@zerilanka
@zerilanka Жыл бұрын
@LogiDev he tratado de hacer un ejemplo con un proyecto multireport con un (mf-shell, mf-login, mf-sidemenu) he logrado que cuando el login sea correcto redirecione al mf-sidemenu, pero tengo un problema y es que las rutas del sidemenu (about, profile etc) al momento de dar click me dice (Cannot match any routes. URL Segment: 'dashboard/about') no se que pueda estar haciendo mal, ejecutando el proyecto mf-sidemenu individual funciona correctamente.
@LogiDev
@LogiDev Жыл бұрын
Hola, si tú repositorio es publico pásame el Link para repositorio y hacer un pull request con la solución
@jesusorozco294
@jesusorozco294 Жыл бұрын
@@LogiDev Amigo seria genial un video haciendo un login con multirepo y microfrontend, la sacarias del estadio!!!
@LogiDev
@LogiDev Жыл бұрын
@@jesusorozco294 gracias por la recomendación, espero sacar pronto un video al respecto
@jesusorozco294
@jesusorozco294 Жыл бұрын
@@LogiDev gracias amigazo, tu puedes!
@jesusorozco294
@jesusorozco294 Жыл бұрын
@@LogiDev una pregunta es recomendable usar la librería PubSubJs? No está obsoleta o algo por el estilo? Que alternativas hay? En la empresa debemos hacer un proyecto Microfrontend multirepo solo con aplicaciones en Angular y la librería de componentes qué vamos a utilizar es PrimeNg
@jpaulsondev
@jpaulsondev Жыл бұрын
Excelente video
@LogiDev
@LogiDev Жыл бұрын
Gracias por el apoyo
@CarlosEduardoHincapieHidalgo
@CarlosEduardoHincapieHidalgo 10 ай бұрын
Hola Jimmy de nuevo por acá paso para agradecerte este material tan valioso y segundo me podrías explicar por que es una mala practica compartir el estado entre los micro-frontend utilizando un patrón para el manejo de estados como redux con ngrx y la otra pregunta es como seria la implementación si de un determinado micro-frontend tipo remote yo quiero exponer varios módulos
@LogiDev
@LogiDev 10 ай бұрын
Si quieres exportar varios modulo simplemente lo exportas desde el webpack.config en la sección de exports, no hay un limite. Es una mala practica estar compartiendo el estado por muchas razones, por ejemplo el compartir el estado entre múltiplesMF, se crea un acoplamiento entre ellos, lo que puede dificultar la independencia y la evolución independiente de cada uno. Esto viola el principio de separación de preocupaciones y puede dificultar la escalabilidad del sistema. Compartir el estado entre MF a través de un Store centralizado puede afectar el rendimiento debido a la necesidad de sincronizar y mantener el estado en múltiples lugares. Esto puede causar latencia adicional en la aplicación y degradación del rendimiento. Recuerda que los MF busca "independizar" cada parte de la app.
@carloseduardohincapiehidal4107
@carloseduardohincapiehidal4107 10 ай бұрын
Super claro muchas gracias, entonces debemos de buscar siempre que los componentes sean independientes en cuanto al estado y buscar que cuando se requiera compartir información entre ellos sea algo muy puntual y utilizar un patrón de mensajería sencillo de publicación y suscripción, como el que utilizaste en el ejemplo. Super Jimmy aquí seguiré a la espera de más material de calidad ❤
@LogiDev
@LogiDev 10 ай бұрын
@@carloseduardohincapiehidal4107 gracias bro, lo entendiste muy bien, espero darme tiempo para sacar cosas avanzadas sobre la web, ahora ando con el curso de Angular para los chicos que recien se inicia, gracias por tu apoyo, un abrazo a la distancia.🙌
@carlosh9732
@carlosh9732 Жыл бұрын
me sirvio mucho tu explicación, aún me falta ver si con monorepo las librerias pueden ser independientes, por eso de problemas de compatibilidad, por eso me decante por el multirepo saludos
@LogiDev
@LogiDev Жыл бұрын
Hola! gracias por tu apoyo!🙌
@JesusOrtega-nx3eb
@JesusOrtega-nx3eb Жыл бұрын
Excelente video, solo me quedo con una duda en un ambiente donde se realiza un deploy en un contenedor docker de manera independiente como se realizaria la configuracion de cors?
@LogiDev
@LogiDev Жыл бұрын
Hola, eso ya depende del servidor que estés usando (azure, aws, iis, apache,etc) pero todas te dan la opción de configurar los CORS; lo que puedes hacer es crear un gateway que valide los CORS y demás permisos y haga el redireccionamiento al recurso solicitado
@dromeroSL
@dromeroSL Жыл бұрын
Gran aporte Jimmy. Seria bueno implementar un login y ver como compartir ese token de autenticación. Otro video seria interesante ver la manera de que la carga de microfronts en el shell sea dinámico con el uso de un manifest y variables de entorno. Saludos, tienes un gran canal
@LogiDev
@LogiDev Жыл бұрын
Hola gracias por las recomendaciones, lo tendre muy en cuenta 🤗
@dromeroSL
@dromeroSL Жыл бұрын
@@LogiDev excelente :D saludos!
@edwardvargas4605
@edwardvargas4605 Жыл бұрын
Saludos excelente explicación. Sin embargo tengo un tema con los ASSETS y CSS del MF en el SHELL , no me cargan. Estoy trabajando como un MultiRepo
@LogiDev
@LogiDev Жыл бұрын
Hola Edwar, te sale algún error?
@FranciscoJavierOrozcoRamír-h8t
@FranciscoJavierOrozcoRamír-h8t Жыл бұрын
Tendras un enlace de como se hacen los deploy ?
@LogiDev
@LogiDev Жыл бұрын
Hola, aún no saco un video al respecto, pero es sencillo, despliegas cada proyecto en tu server o alguna nube, luego la url donde estén desplegados los agregas en el MFShell
@braianezequielrosales3982
@braianezequielrosales3982 3 ай бұрын
Consulta! ¿Como haces para manejar un sharedModule en una arquitectura multi-repo? copias y pegas el sharedModule en cada microfrontend? gracias genio
@LogiDev
@LogiDev 3 ай бұрын
Lo mejor es crear una librería que exponga todo lo que necesitas, esa librería la instalas en cada microfrontend, luego en cada webpack.config estableces que lalibrería es STANDALONE, de esa manera solo se descargara tu librería una sola vez
@LogiDev
@LogiDev 3 ай бұрын
@@braianezequielrosales3982 éxitos y gracias por el apoyo
@braianezequielrosales3982
@braianezequielrosales3982 3 ай бұрын
@LogiDev Que genio, a la velocidad de la luz me contestaste, voy a optar por esa opcion y voy a seguir tus pasos, estamos migrando a una arquitectura microfront y no sabiamos que hacer con el sharedModule. Abrazo! gracias!
@naseddinoufallah628
@naseddinoufallah628 Жыл бұрын
Hola Jimmy,Quiero preguntarte si te functiona cuando lo displiguies en local?
@LogiDev
@LogiDev Жыл бұрын
Hola, funciona localmente, asegurate de usar la versiones correctas de las librerías para tu versión de Angular
@anthonygayoso9113
@anthonygayoso9113 2 ай бұрын
Excelente video, tengo una duda, yo tengo una libreria en el microfrontend que solo se necesita ahi , mas no en otro lado. Cuando levanto el microfrontend de manera independiente funciona, pero cuando lo abro desde el host no, esa libreria tiene que estar tambien instalado en el host ? y luego aplicarle el singleton ? o como se haria eso. Muchas gracias
@LogiDev
@LogiDev 2 ай бұрын
Ponlo en el host y que sea singleton
@juanfalcon9507
@juanfalcon9507 Жыл бұрын
Muy buen video seria interesante ver un video donde este integrado un mf de angular y otro mf de react saludos y gracias por la gran explicación!!!🙂
@LogiDev
@LogiDev Жыл бұрын
Hola Juan, gracias por la recomendación 🙌🏻
@NicolasSantiagoNaranjo
@NicolasSantiagoNaranjo 3 ай бұрын
Este vídeo me ha ayudado mucho para un proyecto en el que estoy trabajando. El manejador de eventos lo estoy realizando con RXjs, pero no me es claro ¿cómo puedo acceder a él por medio de la aplicación host? ¿Podrías ayudarme con eso?
@LogiDev
@LogiDev 3 ай бұрын
Todo recurso que quieras utilizas en diferentes microfrontends debe ir en el shell
@jarethnn
@jarethnn Жыл бұрын
Muy buen video. Me gustaría comentarte sobre una situación que me ocurre con proyecto, Tengo un proyecto padre y uno hijo, que se carga al iniciar. Pero cuando se pincha para abrir el proyecto hijo desde otra página, se refresca en ambas páginas. Muchas gracias por todos los videos! Me ayudaron mucho
@anacarolinaaristizabal5607
@anacarolinaaristizabal5607 7 ай бұрын
si yo tengo una carpeta shared dentro de mf-products con componentes compartidos como hago para poder usar esos componentes en mf-shopping?
@LogiDev
@LogiDev 7 ай бұрын
Tienes que exponerlos en tu webpack.config
@deymerh
@deymerh Жыл бұрын
Hola Jimmy, estoy en un proyecto con microfrontends usando multi repo, como se podría abordar el tema para no tener código duplicado en diferentes micro?. Por poner un ejemplo: el servicio que meneja el localStorage que puede necesitarse en varios microfrontends. Saludos y gracias por compartirnos tu conocimiento.
@LogiDev
@LogiDev Жыл бұрын
Hola Deymer, puedes crea una librería con las funcionalidades que necesites, esa librería la instalas en cada uno de tus MF, luego en tu webpack-config lo agregas al Shared para mantener una sola instancia de la librería
@NgOliver11
@NgOliver11 Жыл бұрын
Hola @@LogiDev , tienes algun video de como crear una libreria para implementar en algun proyecto?
@deymerh
@deymerh Жыл бұрын
@@LogiDev Gracias Jimmy por tomarte el tiempo de responder, voy a revisar como hacer esa implementaciòn.
@ricardotovar4597
@ricardotovar4597 6 ай бұрын
Hola como seria para cargar un microfront por una acción y no por ruta ? , por ejemplo si en el navbar hay un botón que carga los productos agregados y este aparece como un div flotante
@LogiDev
@LogiDev 6 ай бұрын
Usa la función loadRemoteModule, recuerda revisar la documentación según la versión que estés usando de la librería
@NgOliver11
@NgOliver11 Жыл бұрын
Hola Jimmy, queria saber como subistes los proyectos al github dentro de una carpeta principal me ayudarias si me indicas como es el proceso
@LogiDev
@LogiDev Жыл бұрын
Los proyectos estan en una sola carpeta, dentro de esa carpeta ejecutas el comando "git init" esto prepara la carpeta para que sea subido a un repositorio, luego solo tienes que agregar la ul de repositorio, cuando creas un repositorio en github te salen las instrucciones, espero esto te ayudem gracias,
@alonsobenites2386
@alonsobenites2386 Жыл бұрын
Hola jimmy una consulta, segui todos tus pasos pero no puedo visualizar el modulo remoto en el host, cual podria ser la causa?
@LogiDev
@LogiDev Жыл бұрын
Hola Alonso, asegurate de instalar la versión de la librería @angular-architect/module-federation correspondiente para tu version de angular de tu proyecto; las configuraciones varian según la versión que uses, lee el readme : www.npmjs.com/package/@angular-architects/module-federation
@chawuala
@chawuala Жыл бұрын
Seguí tu video y me sale en el routing que no reconoce el modulo, que puede ser?
@LogiDev
@LogiDev Жыл бұрын
Asegurate de usar la versión correspondiente de @angular-architects para tu versión de Angular, revisa que estes exportando un modulo o un standalone component en tu webpackconfig,puedes revisar el repositorio y guiarte.
@assetdev1859
@assetdev1859 Жыл бұрын
and how to deploy it?
@FranciscoJavierOrozcoRamír-h8t
@FranciscoJavierOrozcoRamír-h8t Жыл бұрын
No puedo ver bien el video
@MuhammadZeeshan-xf3qy
@MuhammadZeeshan-xf3qy Жыл бұрын
Hello, Could you please post the whole lesson for multi-repo projects in Micro-Frontend in English as soon as possible?
@juanmanuelvalderramarengif9633
@juanmanuelvalderramarengif9633 4 ай бұрын
Hola que tal, super tus videos los segui tal como los muestras en el video y funciona de maravilla. Pero al implementarlo en un proyecto propio y usando una libreria de diseño de terceros me pasa este error, te agradeceria tu ayuda. Muchas gracias Error: Uncaught (in promise): TypeError: _angular_core__WEBPACK_IMPORTED_MODULE_0__.ɵɵtemplate(...) is not a function TypeError: _angular_core__WEBPACK_IMPORTED_MODULE_0__.ɵɵtemplate(...) is not a function at LeftComponent (design-system.mjs:153:685) at executeTemplate (core.mjs:12003:13) at renderView (core.mjs:13201:13) at renderComponent (core.mjs:13148:5) at renderChildComponents (core.mjs:13246:9) at renderView (core.mjs:13226:13) at renderComponent (core.mjs:13148:5) at renderChildComponents (core.mjs:13246:9) at renderView (core.mjs:13226:13) at ComponentFactory.create (core.mjs:14138:13) at resolvePromise (zone.js:1193:31) at resolvePromise (zone.js:1147:17) at zone.js:1260:17 at _ZoneDelegate.invokeTask (zone.js:402:31) at core.mjs:10757:55 at AsyncStackTaggingZoneSpec.onInvokeTask (core.mjs:10757:36) at _ZoneDelegate.invokeTask (zone.js:401:60) at Object.onInvokeTask (core.mjs:11070:33) at _ZoneDelegate.invokeTask (zone.js:401:60) at Zone.runTask (zone.js:173:47)
@LogiDev
@LogiDev 4 ай бұрын
Es problemas de versiones, primer revisa hasta que versión de Angular tiene soporte la libreria de terceros, eso influye en la versión de la libreria angular-architect y tu version de angular de angular, recuerda que cada version de angular usa internamente una versión distinta de webpack, saludos.
@juanmanuelvalderramarengif9633
@juanmanuelvalderramarengif9633 4 ай бұрын
@@LogiDev Efectivamente el error era por dependencias de paquetes con diferentes versiones, por lo tanto ejecute este comando: npm ls @angular/core y me di cuenta que el paquete ngx-build-plus por alguna razón queda en la versión mas reciente de angular (18), lo actualize con este comando npm install @angular-architects/module-federation@16.x ngx-build-plus@16.x a la version 16 y listo funciono.
@LogiDev
@LogiDev 4 ай бұрын
@@juanmanuelvalderramarengif9633 exitos
@FranciscoJavierOrozcoRamír-h8t
@FranciscoJavierOrozcoRamír-h8t Жыл бұрын
la configuracion que haces en esta linea moduleFederationConfig.output.publicPath = "localhost:4201/"; tendria que modificarla tambien cuando hago el deploy ? o solo es configuracion para trabajar localmente
@LogiDev
@LogiDev Жыл бұрын
tienes que modificarla para tu deploy
@osc902202
@osc902202 2 ай бұрын
@@LogiDev hola amigo una consulta, iba a preguntar algo similar, estoy desplegando en un vps, yo uso docker y jenkins, y tengo la duda, cuando se despliega en si el proyecto se buildea y se levanta en un puerto, es la ip y el puerto lo que se pondria en la configuracion del path?
MICRO - FRONTEND con Angular y Module Federation
1:02:13
LogiDev
Рет қаралды 9 М.
When you have a very capricious child 😂😘👍
00:16
Like Asiya
Рет қаралды 18 МЛН
Арыстанның айқасы, Тәуіржанның шайқасы!
25:51
QosLike / ҚосЛайк / Косылайық
Рет қаралды 700 М.
Quilt Challenge, No Skills, Just Luck#Funnyfamily #Partygames #Funny
00:32
Family Games Media
Рет қаралды 55 МЛН
State Management for Module Federation Four Ways
31:23
Jack Herrington
Рет қаралды 42 М.
8 Consejos para el uso de Micro frontend (feat. Ruben Casas) | Episodio #76
51:02
Introducing Module Federation in Webpack 5
10:39
Jack Herrington
Рет қаралды 89 М.
Angular Microfrontends with NX and Module Federation
25:44
Sebastian Persson
Рет қаралды 18 М.
Preguntas de entrevista para ANGULAR DEVELOPER
43:27
Kevin Davila
Рет қаралды 16 М.
Microfrontend con Single-SPA & Module Federation (charla)
57:02
Domini Code
Рет қаралды 12 М.
Angular Module Federation Micro-FE Speed Run
14:41
Jack Herrington
Рет қаралды 17 М.
When you have a very capricious child 😂😘👍
00:16
Like Asiya
Рет қаралды 18 МЛН