网站建设维护公司,虚拟货币交易网站建设,网站查看,中国苏州官网微服务架构通常采用前后端分离的设计方式。作为企业级的中台#xff0c;在完成单体应用拆分和微服务建设后#xff0c;前端项目团队会同时面对多个中台微服务项目团队#xff0c;这时候的前端人员就犹如维修电工一样了。
面对如此多的微服务暴露出来的 API 服务#xff0c…微服务架构通常采用前后端分离的设计方式。作为企业级的中台在完成单体应用拆分和微服务建设后前端项目团队会同时面对多个中台微服务项目团队这时候的前端人员就犹如维修电工一样了。
面对如此多的微服务暴露出来的 API 服务如何进行正确的连接和拼装才能保证不出错这显然不是一件很容易的事情。而当服务出现变更时又如何通知所有受影响的项目团队这里面的沟通成本相信也不小。
相应的要从一定程度上解决上述问题我们是不是可以考虑先有效降低前端集成的复杂度呢先做到前端聚合后端解耦——这是一个很有意思的话题。今天我们就一起来聊聊微前端Micro Frontend的设计思想探讨一下中台微服务后前后端的设计和集成方式。
单体前端的困境
传统企业在完成中台转型后虽然后台的业务完成了微服务架构的升级但前端仍然是单体模式由一个团队创建并维护一个前端应用。随着时间推移和业务发展前端会变得越来越臃肿越来越难维护。而随着 5G 和移动互联技术的应用企业业务活动将会进一步移动化和线上化。过去很多企业的做法是为不同的业务开发出独立的 APP。但很显然用户并不想装那么多的 APP
为了提高用户体验实现统一运营很多企业开始缩减和整合 APP将企业内所有的业务能力都尽量集中到一个 APP 中。试想如果仍然沿用单体前端的设计模式。前端项目团队将面对多个中台微服务团队需要集成成千上万的 API 服务这就需要相当高的沟通成本和技术要求。这绝对会是一场灾难。
相对互联网企业而言传统企业的渠道应用更加多样化有面向内部人员的门店类应用、面向外部客户的互联网电商平台或移动 APP还有面向第三方的 API 集成。由于渠道的差异前端将更加多样化和复杂化。那如何有效降低前端集成的复杂度呢
从单体前端到微前端
为了解决单体前端的问题我们可以借鉴微服务的设计思想引入微前端概念。将微服务理念扩展到前端解决中台微服务化后前端由于仍为单体而存在的逻辑复杂和臃肿的问题。
在前端设计时我们需要遵循单一职责和复用原则按照领域模型和微服务边界将前端页面进行拆分。同时构建多个可以独立部署、完全自治、松耦合的页面组合其中每个组合只负责特定业务单元的 UI 元素和功能这些页面组合就是微前端。
微前端与微服务一样都是希望将单体应用按照规则拆分并重组为多个可以独立开发、独立测试、独立部署和独立运维松耦合的微前端或者微服务。以适应业务快速变化及分布式多团队并行开发的要求。
微前端页面只包括业务单元前端操作必需的页面要素它只是企业级完整业务流程中的一个业务拼图块不包含页面导航等内容。微前端除了可以实现前端页面的解耦外还可实现页面复用这也与中台服务共享理念是一脉相承的。
业务单元的组合形态
我们可以参照领域模型和微服务边界建立与微服务对应的前端操作界面将它与微服务组成业务单元以业务组件的方式对外提供服务。业务单元包括微前端和微服务可以独立开发、测试、部署和运维可以自包含地完成领域模型中部分或全部的业务功能。
我们看一下下面这个图。一个虚框就是一个业务单元微前端和微服务独立部署业务单元内的微前端和微服务已完成前后端集成。你可以将这个业务单元理解为一个特定业务领域的组件。业务单元可以有多种组合方式以实现不同的业务目标。 1. 单一业务单元
一个微前端和一个微服务组成单一业务单元。微前端和微服务分别实现同一个领域模型从前端到后端的功能。
2. 组合业务单元
一个微前端与多个微服务组成组合业务单元。微前端具有多个微服务的前端功能完成较复杂的页面和操作。多个微服务实现各自领域模型的功能向微前端提供可组合的服务。记住一点微前端不宜与过多的微服务组合否则容易变成单体前端。
3. 通用共享业务单元
一个微前端与一个或多个通用中台微服务组合为通用共享业务单元。通用共享微前端以共享页面的方式与其它微前端页面协作完成业务流程。很多通用中台微服务的微前端是共享的比如订单和支付等微服务对应的订单和支付微前端界面。
所有业务单元的功能都应该自包含业务单元之间的边界清晰。业务单元之间要避免功能交叉而出现耦合一旦出现就会影响项目团队职责边界进而影响到业务单元独立开发、测试、部署和运维等。
微前端的集成方式
我们看一下下面这个图微前端位于前端主页面和微服务之间它需要与两者完成集成。 1. 微前端与前端主页面的集成
前端主页面是企业级的前端页面微前端是业务单元的前端页面。微前端通过主页面的微前端加载器利用页面路由和动态加载等技术将特定业务单元的微前端页面动态加载到前端主页面实现前端主页面与微前端页面的“拼图式”集成。
微前端完成开发、集成和部署后在前端主页面完成微前端注册以及页面路由配置即可实现动态加载微前端页面。
2. 微前端与微服务的集成
微前端与微服务独立开发独立部署。在微前端注册到前端主页面前微前端需要与微服务完成集成。它的集成方式与传统前后端分离的集成方式没有差异。微服务将服务发布到 API 网关微前端调用发布在 API 网关中的服务即完成业务单元内的前后端集成。
团队职责边界
当你采用业务单元化的开发方式后前后端项目团队职责和应用边界会更清晰可以降低前后端集成的复杂度。我们看一下前中台团队的职责分工。
前端项目团队专注于前端集成主页面与微前端的集成完成前端主页面的企业级主流程的页面和流程编排以及微前端页面的动态加载确保主流程业务逻辑和流程正确。前端项目除了要负责企业内页面风格的整体风格设计、业务流程的流转和控制外还需要负责微前端页面动态加载、微前端注册、页面路由和页面数据共享等前端技术的实现。
中台项目团队完成业务单元组件的开发、测试和集成确保业务单元内的业务逻辑、页面和流程正确向外提供包含页面逻辑和业务逻辑的业务单元组件。
这样前端项目团队只需要完成企业级前端主页面与业务单元的融合前端只关注前端主页面与微前端页面之间的集成。这样就可以降低前端团队的技术敏感度、团队的沟通成本和集成复杂度提高交付效率和用户体验。
中台项目团队关注业务单元功能的完整性和自包含能力完成业务单元内微服务和微前端开发、集成和部署提供业务单元组件。
这样业务单元的微前端与微服务的集成就会由一个中台团队完成熟悉的人干熟悉的事情可以降低集成过程中的沟通和技术成本加快开发效率。
一个有关保险微前端设计的案例
保险公司有很多面向不同场景的保险产品由于业务场景不同其核心领域模型就会有差异在页面要素、业务规则和流程等方面前端界面也会不同。为了避免领域模型差异较大的产品之间的相互影响和干扰我们可以将相似的领域模型的保险产品聚合在一起完成核心中台设计。
那有的保险集团为了统一运营会实现寿险、财险等集团化的全险种销售。这样前端项目团队就需要用一个前端应用集成非常多的不同产品的核心中台微服务前端应用与中台微服务之间的集成将会更复杂。
如果仍然采用传统的单体前端模式将会面临比较大的困难。
第一是前端页面开发和设计的复杂性。以录单前端为例如果用一个前端页面来适配全险种由于不同产品的前端页面要素不同需要妥协并兼容所有产品界面的差异这会增加前端开发的复杂度也影响用户体验。而如果为每类产品开发不同的前端前端项目团队需要在页面开发和设计上投入巨大的工作量。第二是前端与微服务集成的复杂性。在前端与微服务集成时前端项目团队需要了解所有产品的 API 详细信息完成前端与微服务的集成还要根据主页面流程实现不同产品的 API 服务路由。大量的 API 服务集成和服务路由会增加系统集成的复杂度和出错的概率。第三是前后端软件版本的协同发布。关联的应用多了以后一旦某一个中台微服务的 API 服务出现重大调整就需要协调所有受影响的应用同时完成版本发布频繁的版本发布会影响不同产品的正常运营。
那如何用一个前端应用实现全险种产品销售呢怎样设计才能降低集成的复杂度实现前端界面融合后端中台解耦呢
我们看一下下面这个图。我们借鉴了电商的订单模式实现保险产品的全险种订单化销售在一个前端主页面可以将所有业务流程和业务操作无缝串联起来。虽然后端有很多业务单元包含微服务和微前端但用户始终感觉是在一个前端应用中操作。
要在一个前端应用中实现全险种销售需要完成以下内容的设计。 1. 微服务
微服务分为两类一类是核心中台微服务包括投保微服务实现核心出单业务逻辑另一类是通用中台微服务包括如商品、订单、购物车和支付等微服务实现通用共享业务逻辑。
2. 微前端
每个微服务都有自己的微前端页面实现领域模型的微服务前端页面操作。核心中台投保微服务有出单微前端。订单、商品以及支付微服务都有自己的微前端页面。
3. 业务单元微服务
与微前端组合为一个业务单元。由一个中台团队完成业务单元的开发、集成、测试和部署确保业务单元内页面操作和业务逻辑正确。比如投保微服务和出单微前端组合为投保业务单元独立完成保险产品从前端到后端的投保业务。
4. 前端主页面
前端主页面类似门户包括页面导航以及部分通用的常驻主页面的共享页面比如购物车。前端主页面和所有微前端应统一界面风格符合统一的前端集成规范。按照正确的业务逻辑和规则动态加载不同业务单元的微前端页面。前端主页面作为一个整体协调核心和通用业务单元的微前端页面完成业务操作和业务流程提供全险种销售接触界面包括商品目录、录单、购物车、订单、支付等操作。
5. 业务流程说明
我来简要说明一下用户在前端主页面的投保的主要业务流程。
第 1 步用户在前端主页面从商品目录微前端页面选择保险产品。第 2 步前端主页面根据选择的产品从主页面配置数据中获取产品出单微前端路由地址。加载出单微前端页面完成录单投保微服务实现投保业务逻辑在业务单元内生成投保单。第 3 步加载购物车微前端将投保单加入购物车。第 4 步重复 1-3 步生成多个投保单。第 5 步从购物车微前端中选择多个投保单加载订单微前端生成订单。第 6 步加载支付微前端完成支付。第 7 步在投保微服务中将订单中的投保单生成保单。
虽然后端有很多业务单元在支持但用户所有的页面操作和流转是在一个前端主页面完成的。在进行全险种的订单化销售时用户始终感觉是在操作一个系统。这种设计方式很好地体现了前端的融合和中台的解耦。
总结
今天我们主要探讨了微前端的设计方法。虽然微前端和微服务也采用前后端分离的设计方式但在业务单元内它们是在同一个领域模型下分别实现前端和后端的业务逻辑对外提供组件化的服务。
微前端和业务单元化的设计模式可以减轻企业级中台前后端应用开发和集成的复杂度真正实现前端融合和中台解耦。它的主要价值和意义如下
1. 前端集成简单前端项目只需关注前端集成主页面与微前端的集成实现模块化集成和拼图式的开发降低前端集成的复杂度和成本。
2. 项目职责专一中台项目从数据库、中台微服务到微前端界面端到端地完成领域逻辑功能开发以业务组件的方式整体提供服务。在业务单元内由团队自己完成前后端集成可以降低开发和集成团队的沟通成本和集成复杂度。
3. 隔离和依赖性业务单元在代码、逻辑和物理边界都是隔离的可降低应用之间的依赖性。出现问题时可快速定位和修复问题可以控制在一个业务单元内。业务单元之间相互无影响。
4. 降低沟通和测试成本中台团队实现从微前端页面到中台微服务的业务单元逻辑实现业务单元的开发、测试、集成和部署的全流程和全生命周期管理降低前后端集成的测试和沟通成本。
5. 更敏捷地发布业务单元之间有很好的隔离性和依赖性低业务单元的变化都可以被控制在业务单元内。项目团队可以独立按照自己的步调进行迭代开发实现更快的发布周期。版本发布时不会影响其它业务单元的正常运行。
6. 降低技术敏感性前端项目关注前端主页面与微前端的集成。降低了前端项目团队对中台微服务技术的敏感性。中台项目团队可以更独立地尝试新技术和架构实现架构的演进。
7. 高度复用性微前端和中台微服务都有高度的复用性。微前端可快速加载到多个 APP还可以将一个微前端直接发布为 APP 或微信小程序实现灵活的前端组合、复用和快速发布。