谈谈大家对微前端的看法

104 天前
 JefZ

一个项目,有首页,搜索页,购买流程,账号页面,售后流程。 总代码 40 万行。除掉单测,快照,大概 20 万行。几十个前端开发协同工作。 React 项目,有完善的懒加载机制,服务端渲染。Router + Redux 。 由于公司收购,新公司的架构变更,这个项目要迁移到新的仓库,新的云供应商,新的项目外部依赖。 有人提议使用微服务来重新按 domain (首页,搜索这些)对这个项目使用微前端的概念来重构基础框架。 虽然是不同的 domain ,但是它们有相同的基础组件依赖,有公共逻辑依赖,状态在 Redux 。传统,规规矩矩。

下面是我个人在团队内提出的看法:

学识尚浅,有核心的东西没有考虑到吗?我不知道该用什么来作为辅助验证我说法的东西。

2754 次点击
所在节点    程序员
23 条回复
guiyumin
104 天前
module federation
stew5566
104 天前
菜鸡求解,好奇这种情况下,会使用 mitt 这样的事件对象做一个大的管线吗
shunia
104 天前
直接把微前端框架调研一遍就知道了吧?在 issue 列表里面找几个万年不改的关键性问题拿出来给大家展示展示,要是有人拍板说都能接受。那就啥也别说了,改呗。

状态共享,内存/性能管理,加载优化是三个比较大的问题,据我调研的结果来看,没有哪个微前端是真正提供了解决方案的,本身它们也并不承担这部分责任。

状态共享相对简单一点,写代码就能解决的事情不是事情。

内存/性能管理在于要根据不同的微前端框架进行调整,还会增加所有人写代码的心智负担。你测试写的很好的情况下,对测试也会带来更多成本,单测之外肯定要为性能而考虑做页面的压力测试。

加载优化我也没想到好办法。对于首页来说加载问题是必须要解决的,首页的子页面越多,加载的文件量和渲染性能都有可能线性增长。尤其如果同时启动多个框架进行初始化或者渲染,想想都会头大。不过你只有 React ,会好解决一点。但是这个也会影响首页的指标啊,这责任谁承担呢?
laommmm
104 天前
微前端一开始就设计架构来做还行,统一规范。
后面集成的,最后只会变成非常庞大的工程,揉在一起。
并且基座会有非常多的问题等着解决,甚至有很多问题无法解决。
shadowyue
104 天前
不管前端后端,一个项目最初的技术架构选型基本上决定了它的上限。
可见的未来也不会改,很难改的动。
JefZ
104 天前
@guiyumin
老哥提到模块联邦。
模块联邦对于我们有个贼麻烦的点

* 我们的项目的基础组件是一个单独的仓库,本质上,当基础组件库升级,希望所有依赖它的仓库都升级,虽然我们可以使用 bot 实现,你懂的,就是增加复杂度。
* 本质上 domain 之间还是有依赖的,使用模块联邦给本地开发和部署也可能会带来一些心智负担。

该怎么决策呢,综合微前端和模块联邦的好处,我们似乎一个都没用到[doge]

GPT 对于这种决策问题也没办法。
shakukansp
104 天前
vue
模块联邦和 qiankun 都用过
建议还是模块联邦……
微前端一个是 vue 的 keep-alive 要弄的和单体应用效果一样没弄成功过,也可能实是我那项目有魔改的 vue-router 的原因

模块联邦相对的问题少点
rockey1997
104 天前
你这种很适合用 monorepo
zy0829
104 天前
@JefZ 那你们为啥不试试 monorepo + micro web?的方式
yimov2
104 天前
在团队内折腾过,实践下来发现:

之前考虑的各个子应用独立开发优势完全没有展现。因为在实际业务中,一个需求经常会出现跨子应用开发,多个子应用经常共用一些状态、数据、依赖。

反而页面性能、数据传输、依赖共享、心智负担都会成为隐性的技术债。

在最开始得到的一点点小好处,最终都会成为架构上的大麻烦。
lee88688
104 天前
@JefZ 使用 mono repo 的方式组织呢,这样模块联邦用起来会好一些。我们这边就是 mono repo 都在一个仓库(不过我们没有用模块联邦),团队按照模块开发自己部分,外部依赖升级统一在最外层统一完成,对于主依赖模块内部不允有不同的版本。
beq
104 天前
我一直用的 qiankun ,做的后台系统
讲讲微前端在我司的应用场景吧,先说说公司基建,我们前端有自己的工程化平台,每一个项目都能申请一个 appid ,或者多个项目分配一个 appid ,appid 的作用是分配一个二级域名,类似 xx.baidu.com/你的库名
二级域名又是区分 pre prd 等环境的,关于发布,上线,灰度都能在平台上操作,所以维护,迁移方面都不用关心,只需要修改下数据库内存储的子应用映射路径就可。
由于业务持续发展,产品迭代,不断细化,会有越来越多的内容更新,单个项目过于臃肿,于是根据功能将其划分多个子系统,基座应用主要用于承载,子系统脱离基座也能独立运行( qiankun 自带)。
后台系统大部分是配置相关的,模块之间依赖很小,即使有数据依赖,接口层面也能解决。
...
总之,微前端 是 iframe 的替代方案,是巨石应用的拆分方案之一,关于通信方面,微服务通过 rpc 通信,前端也可以通过 tsrpc 类似通信调用,通过 store/redux 这种方案,反而增加了心智负担,后续维护的人怎么知道 xxx 方法是 a, b,c 还是基座呢?如果你能携带一些来源信息也可以,这就涉及通信方式的设计了
hispy
104 天前
没看懂拆分的必要性。是因为项目体积太大,成员太多?
mygao666
104 天前
首先技术没有银弹
你们统一技术栈,没必要上微前端
Monorepo + pnpm ,感觉就可以了
almon123
104 天前
微前端目前我用下来最大的优势就是:基本不用操心兄弟部门写的代码,连框架用啥都随他们(只要是主流框架),他们的模块线上挂了完全不影响我们其他模块运行。实现到这种效果要求你的基座应用必须精雕细刻,文档也得详细。
微前端最适合的场景就是几个完全不搭边的团队,但开发出的产品需要放在一个系统里。
tianzi123
104 天前
能不碰就不碰
tianzi123
104 天前
我们项目为了刷新网页数据缓存,用无界,是缓存了,但随即一堆各种问题
foolishcrab
104 天前
微前端这种东西只能做无奈之选,根本不适合你们这种精益求精的重构。
aikilan
104 天前
https://www.v2ex.com/t/935103#reply26
一年前对微前端的疑问
jones2000
103 天前
不同的 domain ,微服务,先要考虑的是后台有一个聚合网关, 可以把接口 1+接口 2 聚合成一个新的接口 3 , 返回需要的数据。 然后根据前端显示定义好后台数据接口, 涉及到多个接口的,使用聚合网关,变成一个新的接口。总之前端要什么数据,后台就给什么数据,请求 1 次获取到。来回 3 ,4 次才能获取的完成数据的,然后后台重新开发。
状态共享直接用 share worker

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1071651

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX