BFF网关模式开发指南

这篇具有很好参考价值的文章主要介绍了BFF网关模式开发指南。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

BFF是近些年新衍生出来的一种开发模式,或者说是一种适配模式的系统,BFF全称为Backend OF Front意为后端的前端,为了适配微服务模式下前端后端系统接口调用混乱而出现的。在如今微服务盛行的趋势下,大型系统中划分出了数十个服务模块,例如商品,门店,运费,红包,订单,优惠券,CMS,用户,搜索,推荐,广告等等系统,前端也有小程序,APP,网页等端。由此产生了很多问题:

痛点

  1. 前端问题:每次需求开发前端要对接多个系统来确认接口信息,不同的数据要找不同的系统,各个接口散落一地,开发调试的效率极低。
  2. 后端问题:后端同样也需要各自包装数据信息来提供前端处理,重心变成如何为前端提供数据,因为需要根据不同的版本、客户端、用户、定位等特征来判别,很多时间浪费在展示层,而不能专注于业务逻辑处理,每个后端系统各自为战,都有自己的接口规则,各种历史版本问题都不能完全统一,所有系统都严重耦合了版本问题。
  3. 变更不灵活:当产品想要更新需求时,更是牵一发而动全身,某一块的小改动需要在各个系统之间找接口来回沟通,大部分系统都要重新上线一次。

如下面,前后端的沟通链路过多。

BFF网关模式开发指南,java,网关

BFF网关定位

鉴于此痛点,需要一个中间层来适配前后端服务,BBF由此而生,它负责将所有下游后端接口进行统一调用,下游接口只需要提供RPC接口供网关使用,BFF网关提供WEB接口来让前端调用,最后将数据进行组装拼接,根据前端的需求来返回数据。

所以BFF的核心定位就是:“统一下游接口,为前端提供服务”。

只有把握好服务这个概念,才能做好BFF网关系统,其他系统可以扯皮甩锅,但BFF网关不可以,它与生俱来的使命就是把这两边拉扯起来,所有不合理不合适,繁琐无用的逻辑都需要BFF网关去处理,后端只要做好业务逻辑,前端做好展示,其他的都可以交给BFF网关。

BFF网关模式开发指南,java,网关

BFF网关特点

琐碎

BFF网关主要为前端进行服务,前端不关心版本、客户端、定位、用户身份等情况,只接收渲染数据即可,而这些逻辑都需要耦合到BFF网关中,以版本、客户端、定位、用户等特征作为纬度,其中版本最为最复杂的分支,可能贯彻整个系统生涯几十个版本类型都需要做兼容,由此还需要兼顾不同客户端的展示要求和用户特征,所以BFF网关中必然需要做大量判断分支,根据上百种情况组合判断来生成-唯一版本-唯一端-唯一用户的数据结构。

数据琐碎

BFF不需要数据库,这点会在下面说明,所以有很多数据需要以静态变量的形式存放在代码里,或者是使用配置中心来动态配置,例如图片地址、各种色值、模块固定文字、处理标识等,这些琐碎的数据都会存放在BFF网关中进行维护,如果放在前端,修改时必须要进行发版,时间周期太长,而存放在后端的话,又会打散数据,不能从一个地方作为主要数据窗口进行管理。

逻辑琐碎

衍生第一点说到的,BFF网关作为下游接口的聚合,每次流程需要调用数十个后端接口,再根据版本、端、用户进行逻辑处理,历史逻辑与新需求杂糅在一起,实现新功能的同时要不断兼顾历史逻辑,只能是加入大量的分支判断,最后变成了if大爆炸,或者使用策略模式进行优化,但无论如何怎么包装都无法掩盖琐碎的逻辑。

性能

BFF网关的耗时主要有两部分

  1. 内部处理耗时
  2. 下游RPC接口耗时

BFF作为最直接和前端交互的接口,BFF的耗时将直接影响用户浏览体验,所以BFF性能一定要最优,不断压缩耗时来提高接口响应性能,内部逻辑优化时,首先观察下游接口耗时情况,各个模块之间难免重复调用接口,可以使用编排框架将下游接口调用进行优化。然后使用线程池进行并发处理,能够并发处理的一定要并发执行,这样可以极大降低下游接口耗时,提供接口处理能力。

缓存

切勿在BFF网关中使用缓存

此处指的缓存主要是Redis等中间件缓存,BFF网关主要数据来源都是通过调用下游接口获取,这里是最耗时的,如果想要减少下游接口耗时,应该使用并发或者编排能力,而不可以通过缓存下游接口数据来实现。

  1. 成本问题:下游接口数据会根据传入的定位、用户等信息查询,当系统用户量大、覆盖城市多时,需要缓存的数据量将剧增,而数据缓存后再次访问概率很低,造成严重的缓存空间浪费。
  2. 一致性问题:BFF网关的引入主要是为了统一后端接口,性能是网关的一大指标,但不能为了性能将所有下游接口数据进行缓存,从而牺牲数据一致性,后续展示时一旦出现问题,将增加排查难度。

降级

BFF网关模式开发指南,java,网关

任何时候都不要将错误直接返回给用户,不论是下游的错误还是系统内部的错误,这一点完全可以交给BFF网关来做,这里降级可以分为两类型处理。

  1. 下游接口降级:当下游接口出现超时或数据异常时,一定要做好降级措施,例如增加接口超时时间判断,及时中断调用,不要因为某个下游接口而影响整体性能,当下游接口报错时,也要做好异常捕获,整体页面可以直接丢弃这部分数据不做展示,而不能完全不展示。
  2. 异常整体降级:在BFF网关内部处理逻辑中难免会有错误发生,或者下游核心的定位、商品等接口异常,这里就需要做整体降级,例如模拟一个友情提示页面等,提示用户稍等重新刷新,或者在未开通城市里可以引导用户切换地址,整体页面的降级尽量交给BFF网关来做,而不要分散到不同的前端来做。

BFF网关划分

BFF网关模式开发指南,java,网关

接口粒度

如上图,BFF网关的下游接口较多,如何聚合下游接口进行划分是一个需要考虑的问题,这里提供的建议是按照页面来划分,例如在首页可以提供首页接口返回整体展示效果,购物车页面提供购物车接口,以页面为单位划分可以方便前后端的统一处理,当然如果页面内容太多时,BFF网关接口可能耗时较多,可以同页面拆分开来,让前端并行加载接口,这样既能降低整体页面加载时间,也能让BFF网关减少下游接口调用。

数据安全

BFF网关虽然也叫网关,但数据安全方面例如安全攻防等主要还是外层去做,BFF只负责数据的调用组装,不要再赋予其他太多功能,但BFF网关一定要有限流逻辑,可以采用Sentinel等框架实现,防止某个前端异常进行大量请求,打垮BFF网关导致所有前端异常。

上线注意

BFF网关较为单薄,没有依赖的数据库等大型中间件,可能只是用到比较轻量的配置中心和消息队列,所以上线时初始化参数较少,但因为BFF网关需要做版本、定位、客户端等特征的数据处理,所以一定要做好灰度上线,防止新功能影响到历史版本、不同定位下的用户浏览。

优势总结

BFF网关的引入:文章来源地址https://www.toymoban.com/news/detail-543028.html

  1. 降低后端开发联调成本:直接提供RPC接口将基础数据返回即可
  2. 降低前端开发联调成本:直接对接一两个接口就可以拿到全部数据,并且可以将很多前端写死的逻辑交给BFF网关做下发,提高前端展示的灵活性。
  3. 方便需求迭代升级:当大量前端逻辑移植到BFF网关,很多需求的上线不再依赖前后端发版,直接让BFF快速上线更新即可。
  4. 提高用户体验:BFF网关可以较低成本的做异常降级处理,为前后端包装错误提示,统一异常捕获类型。
  5. 提高系统性能:虽然引入BFF网关相当于多加了一层,但BFF网关可以通过并发调用下游接口,或者线程池的形式提高接口处理性能,而不需要像之前前端去逐个调用接口,规范了整体接口调用执行逻辑。

到了这里,关于BFF网关模式开发指南的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Java技术专题】「Guava开发指南」手把手教你如何进行使用Guava工具箱进行开发系统实战指南(基础编程篇)

    Preconditions(前置条件):让方法调用的前置条件判断更简单 。 Guava在Preconditions 类中提供了若干前置条件判断的实用方法,我们强烈建议在 Eclipse 中静态导入这些方法。每个方法都有三个变种: 当方法没有额外参数时,抛出的异常中不包含错误消息,这会使得调用方很难确

    2024年02月07日
    浏览(72)
  • 「Java开发指南」如何利用MyEclipse启用Spring DSL?(一)

    本教程将引导您通过启用Spring DSL和使用Service Spring DSL抽象来引导Spring和Spring代码生成项目,本教程中学习的技能也可以很容易地应用于其他抽象。在本教程中,您将学习如何: 为Spring DSL初始化一个项目 创建一个模型包 创建一个服务和操作 实现一个服务方法 启用JAX-WS和DW

    2024年04月13日
    浏览(42)
  • 🔥🔥Java开发者的Python快速进修指南:函数进阶

    在上一篇文章中,我们讲解了函数最基础常见的用法,今天我想在这里简单地谈一下函数的其他用法。尽管这些用法可能不是非常常见,但我认为它们仍然值得介绍。因此,我将单独为它们开设一个章节,并探讨匿名函数和装饰器函数这两种特殊的用法。 在Python中,匿名函数

    2024年02月05日
    浏览(55)
  • Java开发者的Python快速进修指南:异常捕获

    在之前的学习中,我们已经讲解了函数和控制流等基本概念。然而,在接触实际业务时,你会发现异常捕获也是必不可少的一部分,因为在Java编程中,异常处理是不可或缺的。Python的异常捕获与Java的异常捕获原理是相同的,只是在写法上有一些区别。它们的目的都是为了处

    2024年02月05日
    浏览(79)
  • 🔥🔥Java开发者的Python快速进修指南:函数基础

    话不多说,今天我们要介绍的是函数。本系列文章追求短而精,今天我们将重点讨论函数以及与Java方法的区别。与Java方法不同,函数不需要像Java方法一样讲究修饰符等其他特性,它只需要使用\\\"def\\\"进行声明。另外,函数的参数也与Java方法有所不同,Java方法中不存在默

    2024年02月05日
    浏览(62)
  • 🔥🔥Java开发者的Python快速进修指南:文件操作

    Python提供的文件操作相对于Java来说,确实简单方便许多。不仅操作简单,代码可读性也相对较高。然而,我们需要注意的不仅仅是文件操作的简单性,还有文件操作的各种模式。在Java中,我们并不经常使用像Python中那样的操作模式。 另外,我们还需要注意文件指针的移动。

    2024年02月05日
    浏览(81)
  • Java开发者必备:支付宝沙箱环境支付远程调试指南

    🔥 博客主页 : 小羊失眠啦. 🔖 系列专栏 : C语言 、 Linux 、 Cpolar ❤️ 感谢大家点赞👍收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 在沙箱环境调试支付SDK的时候,往往沙箱环境部署在本地

    2024年02月08日
    浏览(52)
  • 🔥🔥Java开发者的Python快速进修指南:面向对象进阶

    在上一期中,我们对Python中的对象声明进行了初步介绍。这一期,我们将深入探讨对象继承、组合以及多态这三个核心概念。不过,这里不打算赘述太多理论,因为我们都知道,Python与Java在这些方面的主要区别主要体现在语法上。例如,Python支持多重继承,这意味着一个类可

    2024年02月05日
    浏览(59)
  • 热门Java开发工具IDEA入门指南——插件安装方式

    IntelliJ IDEA,是java编程语言开发的集成环境。IntelliJ在业界被公认为最好的java开发工具,尤其在智能代码助手、代码自动提示、重构、JavaEE支持、各类版本工具(git、svn等)、JUnit、CVS整合、代码分析、 创新的GUI设计等方面的功能是非常强大的。 本文给大家讲解在使用IntelliJ I

    2024年02月09日
    浏览(59)
  • 🔥🔥Java开发者的Python快速进修指南:面向对象基础

    当我深入学习了面向对象编程之后,我首先感受到的是代码编写的自由度大幅提升。不同于Java中严格的结构和约束,Python在面向对象的实现中展现出更加灵活和自由的特性。它使用了一些独特的,如self和cls,这些不仅增强了代码的可读性,还提供了对类和实例的明确

    2024年02月05日
    浏览(66)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包