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

微服務設計中,BFF層是個什么東西?

開發 前端
在 API 服務層做一個攔截器,如果 URI 找不到對應 API 服務中的 controller mapping,就會直接通過 URI 找后臺服務并進行調用。

在我們之前設計的一個供應鏈系統中,它包含了商品、銷售訂單、加盟商、門店運營、門店工單等服務,涉及了各種用戶角色,比如總部商品管理、總部門店管理、加盟商員工、門店人員等,而且每個部門的角色還會進行細分。而且這個系統中還包含了兩個客戶端 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 團隊整體業務邏輯偏簡單,長久留不住人。

責任編輯:武曉燕 來源: JAVA日知錄
相關推薦

2022-11-02 08:31:53

BFF架構App

2021-01-08 09:48:18

Pythonname變量

2018-10-29 16:15:09

MySQL數據庫緩存

2018-10-30 15:40:15

MySQL緩存Tomcat

2024-10-29 11:08:23

2011-12-28 09:53:18

HTML 5

2024-07-04 12:30:04

2023-07-03 09:49:35

API服務接口

2024-11-06 16:27:12

2021-12-29 08:30:48

微服務架構開發

2018-04-23 14:31:02

微服務GraphQLBFF

2021-07-20 08:03:43

微服務應用程序

2019-04-17 09:09:42

2021-07-13 09:08:19

磁盤陣列系統

2021-08-13 10:16:49

等保合規網絡安全網絡攻擊

2016-08-30 21:09:33

2023-09-18 14:54:02

2024-03-15 08:45:31

Vue 3setup語法

2018-05-14 08:36:53

微服務接入層動靜資源

2023-10-11 11:37:36

微服務架構
點贊
收藏

51CTO技術棧公眾號

中文字幕日韩高清| 欧美日韩免费网站| 91高跟黑色丝袜呻吟在线观看| 五月天丁香激情| 91九色鹿精品国产综合久久香蕉| 亚洲成a人v欧美综合天堂下载| 久久一区免费| 91亚洲国产成人久久精品麻豆| 欧美韩国一区| 亚洲精品自拍视频| 日韩精品你懂的| 牛牛在线精品视频| 久久婷婷久久一区二区三区| 国产精品视频久| 欧美丰满艳妇bbwbbw| 亚洲三级网页| 日韩精品中文字幕在线一区| 国产精品无码专区av在线播放 | 天堂成人免费av电影一区| www.亚洲男人天堂| 欧美熟妇一区二区| 亚洲一区二区三区日本久久九| 色狠狠色噜噜噜综合网| 日本五级黄色片| www.在线播放| 99精品久久久久久| 97国产超碰| 亚洲综合网av| 日韩高清不卡一区二区三区| 国产综合在线视频| 久久中文免费视频| 日本一区二区在线看| 日韩av最新在线观看| 日本少妇xxx| 欧美美女福利视频| 色94色欧美sute亚洲13| 国产91xxx| 青春草视频在线| 亚洲视频一区在线观看| 亚洲国产一区二区精品视频| 你懂的在线看| 2022国产精品视频| 国产精品国产一区二区| av男人天堂av| 激情综合网天天干| 国产欧美亚洲视频| 自拍偷拍福利视频| 日日夜夜免费精品视频| 日本不卡视频在线播放| 日本系列第一页| 黄色av日韩| 久久久女女女女999久久| 青娱乐国产在线| 欧美日本一区| 欧美第一页在线| 欧美精品一区二区蜜桃| 欧美日韩精品免费观看视频完整| 欧美成人一二三| 国产一区二区三区在线视频观看| 中文在线播放一区二区| 久久国产精品久久久| 91麻豆免费视频网站| 91精品观看| 欧美大码xxxx| 久久精品第一页| 亚洲一级影院| 91干在线观看| 高潮毛片又色又爽免费| 日本不卡一二三区黄网| 国产日韩欧美中文| 国内精品国产成人国产三级| 成人丝袜视频网| 国产主播一区二区三区四区| 日本v片在线免费观看| 久久精品亚洲精品国产欧美kt∨| 日韩欧美在线电影| 国产区在线看| 亚洲成人1区2区| 欧美激情成人网| 日日夜夜亚洲| 亚洲精品一区二区三区四区高清| 免费a在线观看播放| 欧美精品色图| 久久久99久久精品女同性| 久久久久久久久久综合| 国产一区白浆| 国产日韩欧美在线| 天堂在线视频网站| 国产香蕉久久精品综合网| 中文字幕超清在线免费观看| 激情网站在线| 欧美性欧美巨大黑白大战| 色一情一区二区三区| 麻豆一区在线| 亚洲天堂av女优| 丝袜 亚洲 另类 欧美 重口| 亚洲影视在线| 成人黄色免费网站在线观看| 免费看黄网站在线观看| 国产嫩草影院久久久久| 欧美日韩中文字幕在线播放| 在线看的毛片| 日韩一区二区三区免费观看| 国产传媒第一页| 香蕉综合视频| 国产97在线|亚洲| 亚洲第一天堂影院| 国产精品视频九色porn| 成年人午夜免费视频| 国产成人精品一区二区三区视频 | 偷拍亚洲欧洲综合| 色婷婷.com| 亚洲精品一级二级三级| 欧美大肥婆大肥bbbbb| 久草热在线观看| 波多野结衣一区二区三区| 中国一区二区三区| 自拍偷拍欧美视频| 精品99999| 久久免费看少妇高潮v片特黄| 玖玖精品视频| 精品国产综合区久久久久久| 99热国产在线| 欧美日韩三级视频| 最近中文字幕在线mv视频在线| 黄色欧美日韩| 亚洲综合成人婷婷小说| 97视频在线观看网站| 欧美日韩午夜视频在线观看| 亚洲精品一区二区18漫画 | 国产成人生活片| 国产a亚洲精品| 国产一区二区三区视频免费| 日韩精品在线观看免费| 成人av免费网站| 8x8ⅹ国产精品一区二区二区| 欧美黑粗硬大| 中文字幕不卡av| 免费看一级视频| 99精品视频一区二区| 国产成人一区二区三区别| 国产一区二区三区亚洲综合| xxxxx91麻豆| 怡红院成永久免费人全部视频| 国产偷国产偷亚洲高清人白洁| 日韩av中文字幕第一页| 亚洲一区 二区| 久久久精品美女| 国产精品视频久久久久久| 中文字幕在线观看不卡视频| 黄色一级片免费的| 99热在线成人| 成人黄色片在线| 国产精品一区二区三区视频网站| 欧美精选午夜久久久乱码6080| 刘亦菲国产毛片bd| 精品一区二区三区影院在线午夜| 亚洲一区综合| 精品午夜视频| 国产69精品久久久久9999| 天天射天天色天天干| 欧美日韩中文在线观看| 国产精品九九九九九| 视频一区二区国产| 亚洲精品一区二区三区樱花 | 精品欧美一区二区精品久久| 午夜激情电影在线播放| 亚洲欧美在线一区| 在线免费观看视频网站| 亚洲品质自拍视频网站| 无码人妻一区二区三区免费n鬼沢 久久久无码人妻精品无码 | 亚洲国产成人av在线| 中日韩黄色大片| 国产丝袜美腿一区二区三区| 蜜臀一区二区三区精品免费视频| 亚洲香蕉av| 国产麻豆乱码精品一区二区三区| 人在线成免费视频| 最近2019年手机中文字幕| 99久久国产免费| 香蕉久久一区二区不卡无毒影院| 成人影视免费观看| 黄色日韩网站视频| 野外做受又硬又粗又大视频√| 噜噜噜狠狠夜夜躁精品仙踪林| 欧美做受高潮1| 麻豆传媒视频在线| 日韩av在线网页| 中文字幕码精品视频网站| 亚洲女人****多毛耸耸8| 亚洲精品激情视频| 秋霞电影一区二区| 欧日韩免费视频| 99精品全国免费观看视频软件| 成人资源av| 国产成人福利夜色影视| 97在线视频精品| 老司机精品视频在线观看6| 亚洲精品大尺度| 一区二区www| 欧美日韩午夜激情| 国产波霸爆乳一区二区| 国产清纯在线一区二区www| 成人在线短视频| 日韩精品三区四区| 亚洲一区二区三区av无码| blacked蜜桃精品一区| 国产高清精品一区二区| 人人玩人人添人人澡欧美| 国产91精品久久久久久| 综合图区亚洲| 中文字幕亚洲综合久久| 日本免费一区二区三区最新| 日韩精品一区二| 在线观看色网站| 色老汉av一区二区三区| 91香蕉在线视频| 亚洲免费在线观看| 超碰人人人人人人人| xfplay精品久久| 成年人小视频在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | 91精品国产美女浴室洗澡无遮挡| 日日夜夜操视频| 偷拍一区二区三区四区| 国产精品18p| 亚洲综合免费观看高清完整版在线 | 亚洲人成人一区二区在线观看| 亚洲女优在线观看| 久久综合av免费| 亚洲观看黄色网| 成人爽a毛片一区二区免费| 人妻巨大乳一二三区| 久久精品国产久精国产爱| 欧美激情国产精品日韩| 亚洲综合丁香| 亚洲自偷自拍熟女另类| 亚洲毛片av| 欧美日韩在线一| 亚洲免费精品| 玩弄中年熟妇正在播放| 亚洲黄色高清| 青青视频在线播放| 麻豆成人精品| 一本久道中文无码字幕av| 丝袜诱惑亚洲看片| 毛片毛片毛片毛片毛片毛片毛片毛片毛片 | 在线观看免费观看在线| 欧美日韩国产另类不卡| 亚洲天堂avav| 欧美精品黑人性xxxx| 国产精品视频无码| 欧美变态口味重另类| 好吊视频一二三区| 亚洲国产欧美一区| 婷婷综合激情网| 亚洲女人天堂成人av在线| 美丽的姑娘在线观看免费动漫| 亚洲欧美精品一区| 成人动漫在线免费观看| 日韩一区二区精品视频| bt在线麻豆视频| 久久久久久久97| 亚洲啊v在线| 国产精品人成电影在线观看| 亚洲国产91视频| 99国精产品一二二线| 精品国产一区二区三区成人影院| 久久精品国产一区二区三区不卡| 蜜臀91精品国产高清在线观看| 日韩av一级大片| 偷拍欧美精品| av无码久久久久久不卡网站| 欧美专区一区二区三区| 国产又黄又猛又粗又爽的视频| 国产一区二区三区香蕉 | 国产精品国产馆在线真实露脸| 亚洲天堂黄色片| 欧美日韩国产专区| 亚洲特级黄色片| 亚洲成人精品视频| 成人免费在线视频网| 欧美日韩999| 亚洲人体影院| 亚洲va男人天堂| 午夜a一级毛片亚洲欧洲| 在线视频不卡一区二区三区| 国自产拍偷拍福利精品免费一| 干日本少妇首页| av片在线观看网站| 99精品视频一区二区三区| 中文字幕18页| 久久色在线视频| 天天操天天操天天操天天操天天操| 亚洲丰满少妇videoshd| 在线视频精品免费| 精品少妇一区二区三区视频免付费| 天堂在线观看视频| 日韩中文字幕国产精品| 欧美少妇精品| 91免费看国产| 国产成人调教视频在线观看 | 亚洲国产欧美视频| 亚洲欧美激情在线| 亚洲av综合一区| 亚洲成人精品久久| a级网站在线播放| 国产成人一区二| 国产欧美三级电影| 青春草在线视频免费观看| 久久久久国产精品午夜一区| 丰满少妇中文字幕| 国产精品久久久久一区| 成人精品在线看| 亚洲第一中文字幕| www.久久ai| 国产欧美日韩专区发布| 国产探花一区二区| 精品欧美一区免费观看α√| 国产一区二区三区免费观看| 天天舔天天操天天干| 精品成人av一区| 成人毛片在线精品国产| xvideos亚洲人网站| 色猫猫成人app| 欧美一区二区三区在线播放| 99在线|亚洲一区二区| 韩国一区二区三区四区| 亚洲乱码一区二区三区在线观看| 亚洲精品一区二区二区| 亚洲精品网站在线播放gif| 91吃瓜在线观看| 国产精品12| 激情综合久久| 五月天丁香社区| 亚洲一区二区视频在线| 亚洲精品一级片| 欧美日本亚洲视频| 91精品尤物| 给我免费播放片在线观看| 成人黄页毛片网站| 久一视频在线观看| 亚洲精品在线免费播放| 爱福利在线视频| 国产伦精品一区二区三区在线| 亚洲性感美女99在线| 四虎精品一区二区| 亚洲午夜精品网| 天天色天天操天天射| 欧美亚洲成人精品| 狠狠色丁香婷婷综合影院| 欧美xxxxx在线视频| 国产网红主播福利一区二区| 午夜精品一区二| 色yeye香蕉凹凸一区二区av| 亚洲免费资源| 国产成人亚洲综合无码| 成人性生交大片免费看视频在线| 日韩精品成人在线| 亚洲免费视频观看| 国产精品99| 青青草免费在线视频观看| 国产成a人无v码亚洲福利| 日本最新中文字幕| 亚洲色图偷窥自拍| 日韩精品第二页| 久久久久久久久久久综合| 99久久夜色精品国产网站| 日本中文字幕久久| 日日狠狠久久偷偷四色综合免费| 秋霞影院一区| 欧美视频在线观看网站| 国产日产精品一区| 国产又粗又黄又爽视频| 国内精品久久久久久久久| 国产99亚洲| 亚洲精品mv在线观看| 亚洲成人av一区二区三区| 黄色免费在线播放| 91亚洲精品在线观看| 亚洲精品免费观看| 欧美精品一区二区精品网| 三级外国片在线观看视频| 99re视频| 久久一综合视频| 久草综合在线视频| 国产丝袜精品视频| 日韩护士脚交太爽了| 久久这里只有精品23| 国产视频一区不卡| www.国产黄色| 国产精品久久久久av| 国产精品多人| 蜜桃av乱码一区二区三区| 91精品国产免费久久综合| 都市激情综合| 日本男女交配视频| 中文无字幕一区二区三区| 肥臀熟女一区二区三区| 国产精品久久久久久网站 |