精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

聊聊微服務中的 BFF 架構

開發 架構
在這個供應鏈系統中,很多界面都需要顯示多個服務數據,比如在一個 App 首頁中,針對門店運營人員,需要顯示工單數量、最近的工單、銷售訂單數據、最近待處理的訂單、低于庫存安全值的商品等信息。

在我們之前設計的一個供應鏈系統中,它包含了商品、銷售訂單、加盟商、門店運營、門店工單等服務,涉及了各種用戶角色,比如總部商品管理、總部門店管理、加盟商員工、門店人員等,而且每個部門的角色還會進行細分。而且這個系統中還包含了兩個客戶端 App:一個面向客戶,另一個面向公司員工和加盟商。

此時,整個供應鏈系統的架構如下圖所示:

圖片

上圖中的網關層主要負責路由、認證、監控、限流熔斷等工作。

  • 路由:所有的請求都需要通過網關層進行處理,網關層再根據 URI 將請求指向對應的后臺服務,如果同一個服務存在多個服務器節點,網關層還將承擔負載均衡的工作。
  • 認證:對所有的請求進行集中認證鑒權。
  • 監控:記錄所有的 API 請求數據,API 管理系統能對 API 調用實現管理和性能監控。
  • 限流熔斷:流量過大時,我們可以在網關層實現限流。如果后臺服務響應延時或故障,我們可以主動在調用端的上游服務做熔斷,以此保護后端服務資源,同時不影響用戶體驗。

此時,我們的架構看起來是不是挺完美?且市面上標準的 Spring Cloud 架構都是這樣做的。不過,這個架構會出現一些問題,下面我們先通過幾個例子來看看。

案例一

在這個供應鏈系統中,很多界面都需要顯示多個服務數據,比如在一個 App 首頁中,針對門店運營人員,需要顯示工單數量、最近的工單、銷售訂單數據、最近待處理的訂單、低于庫存安全值的商品等信息。

此時第一個問題來了,在接口設計過程中,我們經常糾結將兩個客戶端 App 調用的接口存放在哪個服務中?以至于決策效率低下,而且還會出現職責劃分不統一的情況。

最終我們決定將第一個接口存放在門店服務中,此時調用關系如下圖所示:

圖片

并將第二個接口存放在工單服務中,此時調用關系如下圖所示:

圖片

案例二

一個用戶的提交操作常常需要修改多個服務數據,比如一個提交工單的操作,我們需要修改庫存、銷售訂單狀態、工單等數據。

此時第二個問題出現了,因為這樣的需求非常多,所以服務經常被其他多個服務調來調去,導致服務之間的依賴非常混亂,最終服務調用關系如下圖所示:

圖片

通過上圖,我們發現服務間的依賴問題給技術迭代帶來了地獄般的體驗,關于這點我們已經在 15 講中進行了細致講解,這里就不過多贅述。

為了解決這 2 個問題,最終我們決定抽象一個 API 層。

API 層

一般來說,客戶端的接口需要滿足聚合、分布式調用、裝飾這三種需求。

聚合:一個接口需要聚合多個后臺服務返回的數據,并將數據返回給客戶端。

分布式調用:一個接口可能需要依次調用多個后臺服務,才能實現多個后臺服務的數據修改。

裝飾:一個接口需要重新裝飾后臺返回的數據,比如刪除一些字段或者對某些字段進行封裝,然后組成客戶端需要的數據。

因此,我們決定在客戶端與后臺服務之間增加一個新的 API 層,專門用來滿足上面的三點需求,此時整個架構如下圖所示。

圖片

從圖中我們發現,所有請求經過網關后,全部交由一個共用的 API 層進行處理,而該 API 層沒有自己的數據庫,它的主要職責是調用其他后臺服務。

通過這樣的設計方案后,以上兩個問題就得到了很多地解決。

  • 應該將某個接口放在哪個服務的糾結次數減少了:如果是聚合、裝飾、分布式的調用邏輯,我們直接把它們放在 API 層。如果是要落庫或者查詢數據庫的邏輯,目標數據在哪個服務中,我們就把數據和邏輯放在哪個服務中。
  • 后臺服務之間的依賴也大幅減少了:目前的依賴關系只有 API 層調用各個后臺服務。

此時,我們的設計方案完美了吧?別高興得太早,還會出現新的問題。

客戶端適配問題

在這個供應鏈系統中,一系列的接口主要供各種客戶端(比如 App、H5、PC 網頁、小程序等)進行調用,此時的調用關系如下圖所示:

圖片

不過,這種設計方案會存在 3 個問題:

不同客戶端的頁面細節的需求可能不一樣,比如 App 的功能比重大,就會要求頁面中多放一些信息,而小程序的功能比重小,同樣的頁面就會要求少放一些信息,以至于后臺服務中同一個 API 需要針對不同客戶端實現不同適配;

客戶端經常需要進行一些輕微的改動,比如增加一個字段/刪除一個字段,此時我們必須采取數據最小化原則來縮減客戶端接口的響應速度。而且,為了客戶端這種細微而頻繁的改動,后臺服務經常需要同步發版;

結合 #1 和 #2 我們發現,在后臺服務的發版過程中,常常需要綜合考慮不同客戶端的兼容問題,這無形中增加了 API 層為不同客戶端做兼容的復雜度。

這時該如何解決呢?我們就可以考慮使用 BFF 了。

BFF(Backend for Front)

BFF 不是一個架構,而是一個設計模式,它的主要職責是為前端設計出優雅的后臺服務,即一個 API。一般而言,每個客戶端都有自己的 API 服務,此時整個架構如下圖所示:

圖片

從上圖可以看到:不同的客戶端請求經過同一個網關后,它們都將分別重定向到為對應客戶端設計的 API 服務中。因為每個 API 服務只能針對一種客戶端,所以它們可以對特定的客戶端進行專門優化。而去除了兼容邏輯的 API 顯得更輕便,響應速度還比通用的 API 服務更快(因為它不需要判斷不同客戶端的邏輯)。

除此之外,每種客戶端還可以實現自己發布,不需要再跟著其他客戶端一起排期。

此時的方案挺完美了吧?還不完美,因為上面的方案屬于一個通用架構。在實際業務中,我們還需要結合實際業務來定,下面我們深入說明一下實際業務需求。

前面我們列出了 5 種服務,實際上,整個供應鏈系統將近有 100 種服務。因為它是一個非常龐大的系統,且整個業務鏈條的所有工作都包含在這個系統中,比如新零售、供應鏈、財務、加盟商、售后、客服等,,這就需要幾百號研發人員同時進行維護。

因為我們共同維護一個 App、PC 界面、新零售、售后、加盟商,還有各自的小程序和 H5,所以為了實現業務解耦和分開排期,每個部門需要各自維護自己的 API 服務,而且 App 與 PC 前端也需要根據部門實現組件化,此時的架構如下圖所示。

圖片

針對以上需求,我們如何在技術架構上進行實現呢?下面具體來看看。

技術架構上如何實現?

我們的整套架構還是基于 Spring Cloud 設計的,如下圖所示:

圖片

下面我們簡單介紹下圖中網關、API服務、后臺服務的作用。

網關:網關使用的是 Spring Cloud Zuul,Zuul 將拉取的注冊存放在 ZooKeeper 的 API 服務中,然后通過 Feign 調用 API 服務。

API 服務:API 服務其實就是一個 Spring Web 服務,它沒有自己的數據庫,主要職責是聚合、分布式調用及裝飾數據,并通過 Feign 調用后臺服務。

后臺服務:后臺服務其實也是一個 Spring Web 服務,它有自己的數據庫和緩存。

此時的方案看著很完美了,不過它會出現 API 之間代碼重復問題。此時我們該如何解決?且往下看

如何解決 API 之間代碼重復問題?

雖然 H5 與小程序的布局不同,但是頁面中很多功能一致,也就是說重復的代碼邏輯主要存在 PC API 和 App API 中。

然而,針對重復代碼的問題,不同部門在設計時會呈現 3 種不同的邏輯:

  • 某些部門將這些重復的代碼存放在一個 JAR 中,讓幾個 API 服務實現共用;
  • 某些部門將這些重復的代碼抽取出來,然后存放在一個叫 CommonAPI 的獨立 API 服務中,其他 API 服務直接調用這個 Common API 就行;
  • 某些部門因為重復邏輯少,通過評估后,他們發現維護這些重復代碼的成本小于維護 #1 中的 JAR 或者 #2 中的 CommonAPI 服務,所以會繼續讓這些重復代碼存在。

假如某些 API 服務提供接口的出入參與后臺服務的一致,此時該怎么辦? 此時 API 服務的接口無須做任何事情,因為它只是一個簡單的代理層。

于是,有同事提出:“每次一看到這些純代理的 API 接口就不爽,我們能不能想辦法把它們去掉。”辦法倒是有幾個,我們一起來看看。

  • 網關直接繞過 API 服務調用后臺服務,不過這樣就會破壞分層,所以很快被否掉了。
  • 在 API 服務層做一個攔截器,如果 URI 找不到對應 API 服務中的 controller mapping,就會直接通過 URI 找后臺服務并進行調用。不過這種方式將大大增加系統的復雜度,出問題時調查起來更麻煩且收益不大。而寫這些無腦代碼不僅成本低,整體的接口列表還更可控。

綜合考慮后,最終我們決定保留無腦的代碼。

后臺服務與 API 服務的開發團隊如何進行分工?

最后我們是這樣分工的:專門的 API 開發團隊負責 API 服務,而后臺服務需要根據領域再劃分小組的職責。

這種劃分方式的好處在于 API 團隊能對所有服務有個整體認識,且不會出現后臺服務劃分不清晰、工作重復的情況。而壞處在于 API 團隊整體業務邏輯偏簡單,長久留不住人。

責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2024-07-04 12:30:04

2023-07-03 09:49:35

API服務接口

2023-03-01 08:57:32

2024-07-31 09:09:20

2022-08-04 08:46:16

單體架構微服務事務管理

2025-02-27 11:05:03

API服務URI

2021-02-07 09:05:56

微服務結構云原生

2018-04-23 14:31:02

微服務GraphQLBFF

2023-01-29 09:06:24

微服務劃分關聯

2023-12-15 09:57:13

微服務鏈路服務

2025-03-11 10:58:00

2023-09-05 08:53:51

2021-07-20 08:03:43

微服務應用程序

2022-11-08 08:35:53

架構微服務移動

2018-12-06 14:56:46

微服務隔離熔斷

2018-05-09 08:18:26

微服務改造架構

2020-11-26 18:18:21

微服務業務規模技術

2024-04-19 08:49:50

微服務RPC事件驅動

2019-09-29 10:29:02

緩存模式微服務架構

2023-07-28 09:23:24

微服務架構
點贊
收藏

51CTO技術棧公眾號

国产高清免费av| 丰满大乳奶做爰ⅹxx视频| 国产黄色小视频在线| 国产福利视频一区二区三区| 97在线看福利| 成人小视频免费看| 丁香一区二区| 欧美三级电影精品| 男女私大尺度视频| 免费av在线网址| www亚洲一区| 91精品视频一区| 综合激情网五月| 欧美日本中文| 久久激情视频久久| 人妻熟女aⅴ一区二区三区汇编| 欧美黄色成人| 欧美午夜激情在线| 免费网站在线观看视频| 91porn在线观看| 91美女片黄在线观看91美女| 91久久国产精品| 免费看污视频的网站| 国一区二区在线观看| 日韩亚洲国产中文字幕| 我和岳m愉情xxxⅹ视频| 亚洲国产欧美在线观看| 欧美日韩精品一区视频| 青青青在线播放| 蜜臀久久精品| 亚洲一区二区三区四区五区中文| 天天爽天天狠久久久| 日韩av高清在线| 99在线热播精品免费| 成人网在线视频| 国产嫩bbwbbw高潮| 夜夜嗨一区二区| 性色av一区二区三区免费| 99视频只有精品| 国产精品精品国产一区二区| 一区二区在线视频| av网站免费在线看| 国产亚洲第一伦理第一区| 亚洲精品久久久一区二区三区| 又黄又爽又色的视频| 欧美亚洲综合视频| 欧美性大战久久久久久久| 热久久精品国产| 男人皇宫亚洲男人2020| 欧美日韩国产页| 激情伊人五月天| 国产激情在线播放| 欧美日韩国产在线| 岳毛多又紧做起爽| 欧美大胆性生话| 在线观看日韩电影| 99久久久无码国产精品性| 91福利在线免费| 亚洲高清免费观看| 国产无限制自拍| 蜜桃视频m3u8在线观看| 五月激情六月综合| 亚洲熟妇国产熟妇肥婆| 国产v日韩v欧美v| 狠狠久久亚洲欧美专区| 欧美日韩在线中文| 午夜精品成人av| 欧美在线不卡视频| 超碰成人在线播放| 日韩精品一区二区三区中文| 精品日韩欧美在线| 免费观看一级一片| 精品国产91| 色偷偷av亚洲男人的天堂| 永久免费看片视频教学| 国产精品99一区二区| 97免费在线视频| 波多野结衣mp4| 久久99热99| 岛国一区二区三区高清视频| 亚洲人在线观看视频| 国产欧美一区二区精品秋霞影院| 日韩欧美亚洲v片| 免费在线看黄网站| 亚洲高清免费在线| 欧美亚洲日本在线观看| av在线精品| 亚洲黄色成人网| 日韩视频在线观看免费视频| 久久久久久免费视频| 久久人91精品久久久久久不卡| 一级黄色大片视频| 国产一区三区三区| 久久手机视频| jizz性欧美| 色综合色综合色综合| 老司机久久精品| 国产丝袜一区| 日韩亚洲精品视频| 久久一区二区三区视频| 久久精品国产一区二区三 | 日韩资源av在线| 直接在线观看的三级网址| 一本一道波多野结衣一区二区| 国产美女视频免费看| 亚洲毛片免费看| 久久97精品久久久久久久不卡 | 欧美猛男男办公室激情| 欧美双性人妖o0| 亚洲成人99| 日韩美女在线播放| 免费观看的毛片| 综合久久国产九一剧情麻豆| 无码人妻精品一区二区三区在线| 韩国一区二区三区视频| 亚洲日本中文字幕| 国产污视频在线看| 国产麻豆91精品| 无遮挡亚洲一区| 日本不卡1234视频| 精品精品国产高清a毛片牛牛| а天堂中文在线资源| 久久久噜噜噜| 国产在线精品一区二区三区》| jizz性欧美| 91精品国产综合久久福利软件| 尤物视频最新网址| 久久精品导航| 美乳视频一区二区| 理论不卡电影大全神| 精品免费日韩av| 黄色一级片中国| 极品销魂美女一区二区三区| 视频二区一区| 中文字幕系列一区| 国产亚洲精品美女久久久久| 国产午夜性春猛交ⅹxxx| 成人黄色大片在线观看 | 日韩va亚洲va欧美va久久| 久久久久一区二区三区| 新版的欧美在线视频| 337p日本欧洲亚洲大胆精品| 久久网免费视频| 国产99久久久国产精品潘金| 999久久欧美人妻一区二区| 麻豆国产一区二区三区四区| 久久夜精品va视频免费观看| 国产精品乱码久久久| 亚洲欧洲另类国产综合| jizz欧美性11| 91精品啪在线观看国产81旧版| 国产一区红桃视频| av大片在线| 欧美v亚洲v综合ⅴ国产v| 久久久久亚洲天堂| 成人深夜视频在线观看| 国产精品裸体瑜伽视频| 亚州国产精品| 国产精品第七十二页| 在线观看精品一区二区三区| 8v天堂国产在线一区二区| www日韩在线| 高清在线观看日韩| 国产一级爱c视频| 自拍偷拍精品| 国产精品久久久久久久久| 一区二区三区视频在线观看视频| 欧美精品 国产精品| 美国黄色小视频| 成人av午夜影院| 玩弄japan白嫩少妇hd| 久久在线免费| 成人综合色站| 网友自拍亚洲| 欧美老女人性视频| 亚洲欧美日韩成人在线| 欧美性做爰猛烈叫床潮| 2021亚洲天堂| 久久在线观看免费| 久久久久xxxx| 国产视频欧美| 在线电影看在线一区二区三区| 一级毛片精品毛片| 日韩av电影手机在线| 国产精品剧情一区二区在线观看| 欧美精品一区二区蜜臀亚洲| 中文字幕av影视| 一区二区国产视频| 人妻aⅴ无码一区二区三区| 国产一区二区三区国产| www.99热这里只有精品| 精品一区二区三区在线| 粉嫩精品一区二区三区在线观看 | 少妇视频在线| 国产一区二区三区中文| 懂色av成人一区二区三区| 色美美综合视频| 久久高清无码视频| 中文字幕av一区二区三区| 国产草草浮力影院| 国模一区二区三区白浆| 国产l精品国产亚洲区久久| 自拍视频亚洲| 午夜精品一区二区三区在线观看| 大香伊人久久精品一区二区| 国产精品三级网站| 依依综合在线| 欧美激情一级欧美精品| 日本精品在线| 亚洲一区www| 午夜小视频免费| 精品人在线二区三区| 国产又粗又大又爽| 在线精品亚洲一区二区不卡| 九九九国产视频| 日韩理论片一区二区| 级毛片内射视频| 99久久久精品| 潘金莲一级淫片aaaaa| 久99久精品视频免费观看| 亚洲人成色77777| 在线欧美视频| 青青青在线观看视频| 亚洲91精品| 一区二区精品在线观看| 精品一区二区三区在线| 欧美一区国产一区| 欧美日韩一本| 国产综合 伊人色| 999国产精品一区| 亚洲综合最新在线| 超碰国产精品一区二页| 国产精品日韩在线观看| 国产精品蜜月aⅴ在线| 国产98色在线| 在线亚洲人成| 2019中文字幕全在线观看| xxxx视频在线| 久久久亚洲天堂| 第一av在线| 午夜精品在线观看| 高清在线视频不卡| 国产91精品久久久久久| 五月天av在线| 日本久久中文字幕| 88xx成人免费观看视频库 | jazzjazz国产精品麻豆| 成人综合色站| 台湾佬综合网| 日本高清视频一区二区三区| 国产欧美亚洲精品a| 欧美色图亚洲自拍| 精品freesex老太交| 日韩三级电影| 国产精品久久久久无码av| 天天做天天爱天天高潮| 欧美日本在线| 99精品人妻少妇一区二区| 久久久久久自在自线| www.日本一区| 国产精品自拍三区| 亚洲男女在线观看| 久久免费视频色| 又嫩又硬又黄又爽的视频| 一区精品在线播放| 免费在线观看av网址| 欧美日韩午夜视频在线观看| 69亚洲精品久久久蜜桃小说| 欧美日韩一区二区不卡| 国产福利第一视频| 亚洲精品国产精品国自产在线| 欧美性孕妇孕交| www.久久撸.com| 1234区中文字幕在线观看| 国产成人亚洲精品| 国产精品亚洲欧美日韩一区在线| 国产福利久久精品| 亚洲宅男一区| 黄色网络在线观看| 国产欧美欧美| 一级做a爱视频| 26uuu国产一区二区三区| 国产成人在线网址| 午夜成人在线视频| 中文字幕欧美人妻精品| 欧美成人精品福利| 高清福利在线观看| 久久久久久一区二区三区| 朝桐光一区二区| 成人av免费看| 欧美电影《轻佻寡妇》| 亚洲人精品午夜射精日韩| 久久草av在线| 少妇精品一区二区| 综合精品久久久| 中文字幕视频网| 日韩一区二区在线看| 国产色在线 com| 国产69精品久久久久9| 欧美男男gaygay1069| 国产美女99p| 天天综合网91| 国产一二三四在线视频| 成人免费三级在线| 日韩欧美123区| 91电影在线观看| 日韩一区免费视频| 超薄丝袜一区二区| 99只有精品| 欧美高清性xxxxhd| 国产精品分类| 想看黄色一级片| 国产蜜臀av在线一区二区三区| 国产一级在线观看视频| 欧美精品久久99久久在免费线| 免费人成黄页在线观看忧物| 久久免费成人精品视频| 麻豆精品在线| 三级网在线观看| 久久精品免费看| 色噜噜噜噜噜噜| 色综合av在线| 五月天婷婷激情网| 久久久久久成人精品| 国产精品视频一区视频二区| 亚洲午夜精品一区二区三区| 麻豆91精品| wwwwxxxx国产| 日韩欧美在线视频日韩欧美在线视频 | 视频一区视频二区视频三区视频四区国产 | 日韩一区二区三区在线看| 一本久久a久久精品vr综合| 日本vs亚洲vs韩国一区三区二区| 男生草女生视频| 色综合久久久久久久久| 日本中文字幕一区二区有码在线| 91豆花精品一区| 欧洲亚洲一区二区三区| 91成人在线观看喷潮教学| 成人免费的视频| 日韩免费在线视频观看| 亚洲第一精品夜夜躁人人爽| 欧美极品少妇videossex| 成人动漫视频在线观看完整版| 欧美理论在线| 香蕉视频免费网站| 午夜精品免费在线观看| 亚洲欧洲综合在线| 国产91在线高潮白浆在线观看| 精品国产91| 亚洲精品手机在线观看| 国产精品久久久久桃色tv| 97人妻人人澡人人爽人人精品| 久久九九免费视频| 一区二区三区四区视频免费观看| 成人免费观看在线| 99久久综合狠狠综合久久| 久久国产视频精品| 夜夜嗨av一区二区三区免费区| 国产日本久久| 九九久久九九久久| 成人网在线播放| 成人免费毛片视频| 日韩在线中文字| 亚洲一区网址| 精品一卡二卡三卡| 中文字幕一区视频| 韩国av在线免费观看| 日本一欧美一欧美一亚洲视频| 久久免费大视频| 国产a√精品区二区三区四区| 狠狠综合久久av一区二区小说| 黄色小视频在线免费观看| 国产日韩在线精品av| 韩国在线一区| 美女被到爽高潮视频| 51精品国自产在线| 女人高潮被爽到呻吟在线观看| 日韩视频精品| 国产激情一区二区三区| 国产毛片aaa| 久久综合国产精品台湾中文娱乐网| 日本免费精品| 黄色片视频在线播放| 亚洲免费在线观看| 九色在线免费| av成人在线电影| 久久一区中文字幕| 美女的奶胸大爽爽大片| 亚洲人成电影网| 天堂精品久久久久| 国产免费人做人爱午夜视频| 亚洲免费观看高清完整版在线观看熊 | 日韩 欧美 精品| 日韩亚洲精品视频| 尤物tv在线精品| 麻豆tv在线观看| 欧美日韩一级二级| 少妇视频一区| 国产精品videossex国产高清|