架构-初识BFF

引言

在最近的一次公司技术分享会上,我们深入探讨了公司的项目架构。核心议题是BFF架构,这是一种在微服务架构之上增加的额外层级。此外,我们还讨论了DDD(领域驱动设计)理念,它在订单、用户等业务中台中扮演着关键角色。

这是我对架构领域的初步探索,虽然理解尚浅,但我还是尝试着将所学内容进行了整理。

BFF

定义

BFF,即Backend For Frontend,是一种专为前端服务的后端架构。它位于客户端和服务端之间,充当中间件的角色,我更愿意将其视作前端与后端之间的桥梁。

应用动机

BFF是近年来新兴的一种开发模式,也可以看作是一种适配系统。它的出现是为了解决微服务架构下前端和后端接口调用混乱的问题。

在微服务大行其道的今天,大型系统被划分为数十个服务模块,如商品、门店、运费、红包、订单、优惠券、CMS、用户、搜索、推荐、广告等,而前端则包括小程序、APP、网页等多种形式。这种架构带来了诸多挑战:

  • 前端挑战:前端开发需要与多个系统对接,以确认接口信息,不同数据来源需要访问不同的系统,导致开发和调试效率极低。
  • 后端挑战:后端同样需要包装数据以供前端使用,重心转向如何为前端提供数据,需要根据不同版本、客户端、用户、定位等特征进行判断,导致大量时间浪费在展示层,而非业务逻辑处理。各后端系统各自为战,接口规则不一,历史版本问题难以统一,导致系统间严重耦合。
  • 变更困难:产品需求更新时,小改动可能需要在多个系统间协调,大部分系统都需要重新上线。

下图展示了未使用BFF架构时,前后端沟通的复杂性。
bff1

BFF的网关角色

针对上述问题,我们引入了中间层BFF,它统一调用所有下游后端接口,这些接口只需提供RPC接口供网关使用。BFF网关提供Web接口供前端调用,并根据前端需求组装数据。

因此,BFF的核心角色是:“统一下游接口,服务前端”。

只有深刻理解服务的本质,才能构建有效的BFF网关系统。其他系统或许可以推诿责任,但BFF网关不行。它的使命是连接前后端,处理所有不合理、不合适、繁琐的逻辑。后端只需专注于业务逻辑,前端专注于展示,其他任务都可交给BFF网关。
bff2

BFF网关的特性

作为特殊的网关,BFF具有以下特点:

复杂性

BFF网关主要服务于前端,前端不关心版本、客户端、定位、用户身份等细节,只接收渲染数据。这些逻辑都需要集成到BFF网关中,以版本、客户端、定位、用户等特征为基础,其中版本分支最为复杂,可能需要兼容数十个版本类型,同时还要满足不同客户端的展示要求和用户特征,因此BFF网关中必然包含大量判断分支,根据上百种情况组合生成唯一的数据结构。

数据管理

BFF不需要数据库,这一点将在下文解释。因此,许多数据需要以静态变量的形式存储在代码中,或使用配置中心动态配置,如图片地址、颜色值、模块固定文本、处理标识等。这些琐碎的数据都存储在BFF网关中进行维护。如果放在前端,修改时必须发版,周期过长;而放在后端,则会分散数据,无法集中管理。

逻辑处理

如前所述,BFF网关作为下游接口的聚合器,每次流程需要调用数十个后端接口,再根据版本、端、用户进行逻辑处理。历史逻辑与新需求交织在一起,实现新功能的同时要不断考虑历史逻辑,导致大量分支判断,最终形成复杂的逻辑结构,或使用策略模式进行优化,但无论如何包装,都无法掩盖其复杂性。

性能考量

BFF网关的耗时主要分为两部分:

  • 内部处理耗时
  • 下游RPC接口耗时

作为与前端直接交互的接口,BFF的耗时直接影响用户体验。因此,

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/4382.html

(0)
LomuLomu
上一篇 2024 年 12 月 26 日 上午12:48
下一篇 2024 年 12 月 26 日

相关推荐

  • 深入理解 Java 接口的回调机制

    前言 回调是一种非常重要的编程技术,它广泛应用于事件驱动的编程、异步任务和框架设计中。在 Java 中,回调机制通常通过 接口 来实现。本篇博客将详细解析 Java 接口的回调原理、实现方式,以及实际开发中的应用场景。 泪崩了,期末JAVA编程考了回调,小编不会。 一、什么是回调? 回调(Callback) 是指通过将一个方法作为参数传递给另一个方法,在某些…

    2025 年 1 月 19 日
    56800
  • JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)

    目录 JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码) 一、为什么要使用Array.sort() Array.sort() 是 JavaScript 提供的一个内置数组排序方法。它不仅仅是一个简单的升序或降序排列工具,更是一种灵活的排序逻辑实现方式。通…

    未分类 2024 年 12 月 28 日
    53700
  • 深入解析 Java 多线程编程中的 Thread 类核心功能

    Java 平台的多线程编程能力主要依赖于 Thread 这个基础类。我们将全面剖析该类的重要特性与实用方法,并通过具体案例演示其应用场景。 一、线程的初始化与基础控制 在 Java 中,开发者可以通过以下两种主要途径创建新线程:1. #### 扩展 Thread 基类 class CustomThread extends Thread { public vo…

    2025 年 5 月 13 日
    41700
  • 深入浅出:Java 抽象类与接口

    前言 Java 是一种面向对象的编程语言,其中 抽象类 和 接口 是实现多态和设计模式中的重要工具。它们在编程中具有重要的地位,能够有效提高代码的灵活性和可维护性。尽管它们有一些相似之处,但在语法和应用场景上存在许多不同点。本博客将深入探讨 抽象类 和 接口。 一、什么是抽象类(Abstract Class)? 1. 抽象类的定义 抽象类是一个不能被实例化的…

    未分类 2025 年 1 月 12 日
    58000
  • 从混沌到秩序:Python的依赖管理工具分析

    “`markdownPython的依赖管理工具尚未形成统一标准,其原因主要包括: 历史发展的随意性:Python在早期发展过程中,对于依赖管理的重视不足,缺乏从一开始就进行统一规划和设计的意识。 社区的分散性:Python社区庞大且分散,众多开发者和团队各自为政,根据自己的需求和偏好开发工具,缺乏统一的协调和整合机制。 多样化的使用场景:Python应用场…

    未分类 2024 年 12 月 26 日
    55500

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信