前端架构成长之路——微前端架构理论篇

简介: 最近项目开发中使用了qiankun框架去做微前端,我是属于半懂不懂的状态,大概了解过微前端是什么,可以解决什么问题,但是没有并系统的认识和从0实战过。

背景


最近项目开发中使用了qiankun框架去做微前端,我是属于半懂不懂的状态,大概了解过微前端是什么,可以解决什么问题,但是没有并系统的认识和从0实战过。


所以希望通过几篇文章去重新认识微前端这一架构,主要会从几个方面:

  • 是什么,以及为什么会出现
  • 实现原理,以及主流框架
  • 项目实战

发展历程


微服务


在说微前端之前,我们需要先了解一下后端的微服务,因为微前端本身就是吸取微服务理念而产生的,所以我们先对微服务做一个简单的认识:

2014年,Martin Fowler 与 James Lewis 共同提出了微服务的概念,定义了微服务是由以单一应用程序构成的小服务,自己拥有自己的进程与轻量化处理,服务依业务功能设计,以全自动的方式部署,与其他服务使用HTTP API通信。同时服务会使用最小的规模的集中管理 (例如 Docker) 能力,服务可以用不同的编程语言与数据库等组件实现 —— 维基百科 微服务

微服务架构,通常拿来对比的架构是单体软件架构,单体软件存在以下几个问题:

  • 所有功能耦合在一起,互相影响,最终难以管理
  • 哪怕只修改一行代码,整个软件就要重新构建和部署,成本非常高
  • 不可能每个功能单独开发和测试,只能整体开发和测试,导致必须采用瀑布式开发模型


因此开始出现将单体软件拆成一个个功能单元服务+通讯协议组成,这种叫面向服务(service-oriented architecture,简称 SOA)架构,也是微服务的雏形。

因此微服务架构的等于面向服务架构,它有多种实现方案,其中最佳实践是基于Docker容器实现的。


微服务的几大特性:

  • 敏捷性, 可快速迭代自己的微服务
  • 弹性部署,快速持续集成与部署,服务独立性增加了应用程序应对故障的弹性
  • 技术自由,可以自由选择最佳工具来解决他们的具体问题
  • 可重复使用的代码,可以将专为某项功能编写的服务可以用作另一项功能的构建块


Ok,微服务了解到这里基本上就有大概的认知,微服务当然不只是这些,还有一些其他技术点,如:服务发现、事件传播等。

微前端


了解完微服务,那么微前端概念是什么开始提出的呢?

微前端 这个名词,第一次被提出还是在2016年底,那是在 ThoughtWorks Technology Radar。这个概念将微服务这个被广泛应用于服务端的技术范式扩展到前端领域。 微前端是一种多个团队通过独立发布功能的方式来共同构建现代化 web 应用的技术手段及方法策略。 —— 微前端的完整介绍

简单的说,微前端架构是从微服务理念扩展而来的,一个适用于前端的微服务架构。

微前端


是什么


从上面发展历程我们对微前端架构有个简单认知和它的定义,接下来我们通过不同类型的做比较去对微前端做更深的认知。

单体巨石 VS 微前端


用单体巨石架构和微前端架构做一个比较,能更好的理解微前端架构,具体如下图所示:

a439bb903b7d2dc37e8f530aa96f806.png

简单的讲,就是将原本耦合在一起的单体巨石应用按照一定原则拆分成各种微前端小应用,最简单的拆分方案就是和微服务做一一映射。

组件 VS 微前端


我们再从另外一个角度的去看待微前端,假设将微前端看做组件,是不是就好理解多了,只不过这个组件有点大,功能比较齐全,没有对外提供参数配置。


但是从两者的实际应用场景来说,还是有很多不同的地方,具体如下:

  • 从应用场景来看,组件是不可运行,被调用的,是应用中一部分,而微前端是完整可运行的一个应用
  • 从技术上来看,组件是基于某个框架实现的,而微前端应用不依赖任何框架,但是微前端架构会依赖某个框架实现

总结


微前端架构,就是把复杂问题简单化,每个微前端项目都只需要关心自己的事情。因此微前端架构的核心思维如下:

  • 技术不可知,每个微前端都应该选择自己的技术栈和技术进化路线,而不是和其他团队保持一致,同时架构师应该考虑的是如何高效的提供可复用的WebComponent会成为核心问题
  • 环境隔离微前端架构中每个子项目不共享运行时环境,即是:不依赖共享状态或全局变量,同时也可以通过命名规范(如:前缀)或命名空间,去隔离每个微前端应用
  • 原生API优先,使用 用于通信的原生浏览器事件机制 ,而不是自己构建一个PubSub系统
  • 独立性微前端架构中每个子项目是完整的,可以独立运行、独立开发、独立部署
  • 高可用微前端架构是高可用的,即使某个子应用异常也不会影响其他子应用的访问


以上就是要实现微前端架构所需要考虑的点,同时也是架构中的核心思维。

缺点


微前端架构在上面描述了很多优势,但是如果没做好架构设计,它也可能会带来一些问题,因此我们需要提前了解微前端架构可能会带来的缺陷:

  • 增加运维成本,因为由原本只需要发布一个应用,变成需要发布N个应用
  • 拆分粒度越小,架构越复杂,开发维护成本越高
  • 微前端支持不同技术栈,那么也带来了不同技术栈带来技术栈混乱的风险,同时也提高了开发维护成本
  • 微前端架构本身就是将项目完全独立,可能导致部分公共代码无法通用
  • 还有一些其他问题,如:当采用某类微前端框架增加开发成本等


上面这些问题,在项目是否要用微前端架构都需要考虑的事情,但是也有一句话可以提供给大家参考。

工程就是权衡的艺术,而微服务(microframeworks)架构给你提供了一个可以权衡的维度。

了解完是什么,接下来就当项目中要实施微前端架构的时候要怎么做了。

怎么做


在项目要实施微前端架构,主要有几个工作项:

  • 首先,就是需要搞清楚如何将项目拆分一个个微前端子项目
  • 其次,选型,采用哪种微前端框架去实施
  • 最后,使用渐进式方案去实施,而不是一口气全切换,如果是新项目直接采用微前端架构,那么这里推荐采用Monorepo大仓+微前端,这里会让极大降低项目的管理成本。

如何拆分


微前端架构主要工作就是拆分,那么问题来了,我们应该依据什么样的标准去拆分呢?我们大体可以从下几点去考虑:

  • 第一,拆分条件,项目是否适合微前端架构
  • 第二,拆分原则,项目拆分时候需要遵循的设计原则
  • 第三,拆分方法,项目拆分可以依据哪些因素进行拆分

拆分条件


我们要对项目进行微前端架构设计的时候,我们应该从下面几方面去考虑是否适合:

  • 是否有快速迭代的需求,如果有快速迭代需求,则表示业务需要快速响应,那么采用微前端架构去拆分,不仅支持快速迭代,还支持业务快速试错
  • 是否有代码提交出现大量冲突,如果有,则表示代码管理成本较高,微前端架构可以降低项目的管理成本
  • 是否小功能需要等待大版本的场景,如果有,则表示小功能会影响到大版本的功能,这个时候微前端架构的独立发布特性,可随时回滚,风险变小,时间变短,影响面小,从而降低大版本发布延期风险

从上面几个方面,我们可以很清晰的判断当前项目是否需要做微前端架构调整,只有这个时候,微前端的拆分才是有确定收益的,增加的运维成本才是值得的。

拆分原则


当我们面对需要拆分微前端的时候,以下几个原则可以作为参考:

  • 单一职责原则,每个微前端只需关心自己的业务规则,确保职责单一,避免职责交叉
  • 服务自治原则,每个微前端的开发,必须拥有开发、测试、运维、部署等整个过程,表示该应用可以独立运行而不需要依赖其他应用
  • 持续演进原则,单体架构向微服务架构拆分过程中,无法做到一蹴而就,应逐步拆分细化,持续演进,避免微服务数量的瞬间爆炸性增长
  • 服务粒度适中,先粗后细的原则,再按照拆分条件判断粗粒度的微前端是否需要拆分
  • 避免循环依赖,循环依赖的情况会导致微前端在迭代发布的时候不知道优先发布哪个,在拆分的时候需要考虑,针对依赖部分进行下沉,拆分成公共模块
  • 横向拆分原则,拆分微前端应该按照依赖层次的横向去拆,而不是纵向拆分,因为拆分越深,维护成本越高

拆分方法


以上两个主要针对拆分的假设条件,当真正去拆分操作的时候,我们应当从这些方面去入手:

  • 按照业务领域,参考领域模型,将同类业务归为同一个微前端,按照单一职责原则、功能完整性进行拆分
  • 按照组织架构,应尽量避免对组织架构和团队的调整,避免由于功能的重新划分,而增加大量且不必要的团队之间的沟通成本
  • 按照技术栈,简单点说React的技术栈放一个微前端,Vue的技术栈放另外一个微前端
  • 按需求迭代频率,将迭代频率高的放在一个微前端,频率低放在另外一个微前端


学会了拆分方法,里面的优先级应该有大概排序,业务领域 > 组织架构 > 技术栈 > 需求迭代频率,我推荐的做法如下:

  • 先按照业务领域去拆分
  • 拆分的粒度不够,还要再拆分就按照组织结构再拆分
  • 再往下,就是按照技术栈拆分
  • 再往下,就是需求迭代频率

微前端框架


了解完如何拆分,那么接下来就是对微前端架构实现的框架进行选型,下面是我从网上收集目前市场主流的几大微前端框架:

  • single-spa,将多个单页面应用聚合为一个整体应用的 JavaScript 微前端框架
  • qiankun,基于single-spa,能更简单、无痛构建可用微前端架构的框架
  • 无界,基于iframe,实现路由同步机制的微前端架构框架
  • micro-app,借鉴WebComponent思想,结合自定义的ShadowDom,将微前端封装成一个类WebComponent组件的微前端框架
  • webpack 模块联邦,在webpack构建时候加载远程应用而实现的微前端架构方案


以上,就是目前实现微前端架构的主流框架,当然每个框架都自己的优缺点,我们在选型的时候主要还是通过以下几点去判断是否适合:

  • 对现有项目是否需要改造,改造成本多少
  • 是否有学习成本,学习成本有多复杂
  • 未来是否足够的扩展性
  • 团队内是否有熟悉、精通该选型的人,否则遇到问题,容易入坑
  • 项目维护的情况,issue 是否有响应,迭代是否在正常进行


到了这里,本篇介绍微前端架构基本上就结束了,虽然很多理论知识,但是我们可以再次回顾一下,总结一下要点:

  • 微前端架构源自微服务架构,两者主要都是为了解决巨石应用的痛点,迭代慢、开发复杂
  • 微前端架构拆分需要注意几个点:拆分条件、拆分原则和拆分方法
  • 微前端架构主流框架:single-spaqiankun无界micro-appwebpack 模块联邦


当然,我不会只写理论知识点,后面我会针对每个框架的写一篇深入实战文章,从背后原理,适用场景去一一描述,前端架构之路不好走,希望大家一起努力加油。

其他概念


领域驱动设计


要了解一个新的东西,首先弄明白它解决了什么问题?领域驱动设计主要是为了解决:

  • 帮助团队更好理解业务世界
  • 能协助开发构建良好的设计
  • 降低业务逻辑与开发逻辑的耦合,降低复杂性


那么现在,我们就明白领域驱动设计是什么了?它是强调业务概念、专业术语的开发设计理念。以下是一些官方解释,后面在前端架构系列文里,会写专门文章做深入介绍:

领域驱动设计(Domain-Driven Design,简称DDD)是一种强调业务概念、专业术语以及原则的开发范式,旨在帮助用户,团队和软件开发者来解决复杂的信息系统和软件。它使用图形模型作为核心,其目标是使开发者能够理解、分析和把握业务概念,并将这些概念转化为可操作的软件。—— 【ChatGPT回答】

领域模型


领域模型,来自领域驱动架构(DDD)中的一个概念,与开发模型(解决实际问题所抽象出来的概念模型) 设计模型(描述了所要构建的系统)不同的是, 领域模型是表达与业务相关的事实,它更加关注业务知识,能否显性化、清晰的表达业务语义。

参考资料


目录
相关文章
|
1月前
|
前端开发 JavaScript
探索现代Web应用的微前端架构
【10月更文挑战第40天】在数字时代的浪潮中,Web应用的发展日益复杂多变。微前端架构作为一种新兴的设计理念,正逐步改变着传统的单一前端开发模式。本文将深入探讨微前端的核心概念、实现原理及其在实际项目中的应用,同时通过一个简单的代码示例,揭示如何将一个庞大的前端工程拆分成小而美的模块,进而提升项目的可维护性、可扩展性和开发效率。
|
1月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
117 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
9天前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
38 3
|
7天前
|
前端开发 搜索推荐 安全
陪玩系统架构设计陪玩系统前后端开发,陪玩前端设计是如何让人眼前一亮的?
陪玩系统的架构设计、前后端开发及前端设计是构建吸引用户、功能完善的平台关键。架构需考虑用户需求、技术选型、安全性等,确保稳定性和扩展性。前端可选用React、Vue或Uniapp,后端用Spring Boot或Django,数据库结合MySQL和MongoDB。功能涵盖用户管理、陪玩者管理、订单处理、智能匹配与通讯。安全性方面采用SSL加密和定期漏洞扫描。前端设计注重美观、易用及个性化推荐,提升用户体验和平台粘性。
34 0
|
1月前
|
消息中间件 前端开发 JavaScript
探索微前端架构:构建现代Web应用的新策略
本文探讨了微前端架构的概念、优势及实施策略,旨在解决传统单体应用难以快速迭代和团队协作的问题。微前端允许不同团队独立开发、部署应用的各部分,提升灵活性与可维护性。文中还讨论了技术栈灵活性、独立部署、团队自治等优势,并提出了定义清晰接口、使用Web组件、状态管理和样式隔离等实施策略。
|
1月前
|
监控 前端开发 JavaScript
探索微前端架构:构建可扩展的现代Web应用
【10月更文挑战第29天】本文探讨了微前端架构的核心概念、优势及实施策略,通过将大型前端应用拆分为多个独立的微应用,提高开发效率、增强可维护性,并支持灵活的技术选型。实际案例包括Spotify和Zalando的成功应用。
|
1月前
|
前端开发 API UED
深入理解微前端架构:构建灵活、高效的前端应用
【10月更文挑战第23天】微前端架构是一种将前端应用分解为多个小型、独立、可复用的服务的方法。每个服务独立开发和部署,但共同提供一致的用户体验。本文探讨了微前端架构的核心概念、优势及实施方法,包括定义服务边界、建立通信机制、共享UI组件库和版本控制等。通过实际案例和职业心得,帮助读者更好地理解和应用微前端架构。
|
22天前
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。
|
1月前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
43 3
|
1月前
|
Cloud Native 安全 数据安全/隐私保护
云原生架构下的微服务治理与挑战####
随着云计算技术的飞速发展,云原生架构以其高效、灵活、可扩展的特性成为现代企业IT架构的首选。本文聚焦于云原生环境下的微服务治理问题,探讨其在促进业务敏捷性的同时所面临的挑战及应对策略。通过分析微服务拆分、服务间通信、故障隔离与恢复等关键环节,本文旨在为读者提供一个关于如何在云原生环境中有效实施微服务治理的全面视角,助力企业在数字化转型的道路上稳健前行。 ####