精品欧美一区二区三区在线观看 _久久久久国色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 網頁、小程序等)進行調用,此時的調用關系如下圖所示:

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

  • 不同客戶端的頁面細節的需求可能不一樣,比如 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 團隊整體業務邏輯偏簡單,長久留不住人。

責任編輯:趙寧寧 來源: 技術老男孩
相關推薦

2012-07-06 09:00:56

微軟CRM

2013-10-11 09:31:39

開源數據處理云計算

2024-12-09 09:18:21

Android原生控件

2015-10-22 11:36:44

教育云

2022-07-28 15:06:17

人工智能AI

2022-01-24 19:45:35

智能機器人新冠疫情

2010-03-25 15:16:30

艾默生

2023-12-21 08:26:54

MPP數據庫查詢

2018-04-24 14:43:01

微軟工業博覽會

2021-07-28 21:50:02

大數據云計算人工智能

2021-01-21 14:03:18

人工智能醫療健康深度學習

2017-08-03 11:26:56

筆記本商用筆記本

2020-11-19 15:18:40

Nutanix

2016-03-28 09:08:09

OpenDayligh

2017-04-08 17:36:04

2023-02-24 15:30:04

ChatGPT代碼

2015-09-10 14:33:52

敏捷網絡寧波華為

2021-03-04 20:31:55

采集服務器異步

2025-08-11 01:55:00

2023-09-24 20:22:58

點贊
收藏

51CTO技術棧公眾號

色老汉一区二区三区| 久久亚洲欧美国产精品乐播 | 国产91在线播放| 91青草视频久久| 99re视频在线播放| 国产男女猛烈无遮挡在线喷水| 亚洲伊人精品酒店| 婷婷综合另类小说色区| 神马影院午夜我不卡影院| 国产日韩欧美视频在线观看| 一区二区三区四区五区在线| 中文字幕精品网| 久久精品aⅴ无码中文字字幕重口| 亚洲最大网站| 一区二区三区不卡视频在线观看 | 免费看国产黄色片| 黄色大片在线| 日本一区二区三区在线不卡| 成人黄色片视频网站| 懂色av中文字幕| 欧美视频久久| 视频在线一区二区| 一级特黄a大片免费| 亚洲欧洲专区| 日本高清不卡视频| 免费在线观看视频a| 欧美a在线看| 国产亚洲成aⅴ人片在线观看| 产国精品偷在线| 在线观看国产一区二区三区| 亚洲一区二区网站| 国模叶桐国产精品一区| 91老司机在线| 伊人成色综合网| 2024最新电影免费在线观看| 久久久久久久久99精品| 国产精品12| 国产情侣在线播放| 久久精品免费观看| 国产精品久久久久久久电影 | 午夜精品网站| 久久久精品国产| 亚洲色图 激情小说| 日韩电影不卡一区| 亚洲国产三级网| 少妇献身老头系列| 日韩免费高清视频网站| 欧美一区二区三区在| 国产一伦一伦一伦| 久久er热在这里只有精品66| 色欧美乱欧美15图片| 97视频在线免费播放| 亚洲风情在线资源| 精品国产1区2区| 黄色一级视频片| 久草在线资源福利站| 欧美日韩免费在线观看| 亚洲 高清 成人 动漫| 高清精品在线| 欧美午夜丰满在线18影院| 尤物av无码色av无码| 国产拍在线视频| 精品成人av一区| 草草久久久无码国产专区| 美女高潮视频在线看| 欧美日韩一二三四五区| 国产精品免费观看久久| 美女一区网站| 欧美午夜精品久久久久久孕妇| 精品久久久久av| julia一区二区三区中文字幕| 欧美三级视频在线观看| 999在线观看| 国产一区二区三区国产精品| 欧美成va人片在线观看| 国产精品久久久久久在线观看| 精品国内亚洲2022精品成人| 日韩精品视频在线播放| 欧美18—19性高清hd4k| 国产精品久久久久久久免费观看 | 亚洲精品www久久久| 日韩天堂在线视频| 超碰成人在线播放| 国产在线一区不卡| 亚洲第一色在线| a级在线观看视频| 欧美日韩色图| 超碰97人人做人人爱少妇| 久草资源在线视频| 久久精品人人| 51成人做爰www免费看网站| 免费观看黄一级视频| 国产亚洲一区二区三区| 一区二区冒白浆视频| 亚洲精品白浆| 日本道色综合久久| 少妇伦子伦精品无吗| 日韩美女毛片| 久久精品视频在线| 国产精品xxxx喷水欧美| 麻豆视频观看网址久久| 国产精品国产精品| av在线女优影院| 亚洲夂夂婷婷色拍ww47 | 三级全黄做爰视频| 亚洲免费高清| 国产综合香蕉五月婷在线| 秋霞网一区二区| ...xxx性欧美| 91免费视频网站在线观看| 99精品视频在线免费播放| 日韩精品久久久久久福利| 破处女黄色一级片| 日本在线观看不卡视频| 国产在线一区二区三区四区| h网站在线免费观看| 五月综合激情网| 亚洲天堂网站在线| 欧美午夜精品一区二区三区电影| 欧美激情精品久久久久久免费印度| 免费黄色小视频在线观看| 成人在线一区二区三区| 中文字幕日韩精品久久| 精品欧美一区二区三区免费观看| 欧美精品资源| 精品av久久707| 午夜激情福利网| 免费成人性网站| 欧美色图亚洲自拍| 樱花草涩涩www在线播放| 精品美女在线播放| 永久免费看黄网站| 国产资源在线一区| 亚洲v欧美v另类v综合v日韩v| 成入视频在线观看| 欧美tickling挠脚心丨vk| 久久福利免费视频| 蜜臀av一区二区在线免费观看| 91沈先生播放一区二区| 黄色免费在线观看网站| 欧美性生活影院| 性欧美13一14内谢| 久久久久久色| 欧美日韩国产高清视频| 天堂在线中文网官网| 亚洲精品成人av| 日韩欧美中文字幕一区二区| 国产 欧美在线| 欧美性潮喷xxxxx免费视频看| 日韩三级不卡| 欧美精品激情视频| 蜜臀av在线观看| 性做久久久久久| 9.1成人看片| 国产日韩欧美三级| 免费成人在线观看av| 欧美私密网站| 亚洲人精品午夜在线观看| 香蕉影院在线观看| 欧美激情在线看| 欧美成人福利在线观看| 91麻豆精品国产91久久久平台 | 亚洲图片在区色| 在线观看你懂的网站| 国产精品伦理在线| 一级网站在线观看| 激情成人综合| 久久久精品国产一区二区三区| videos性欧美另类高清| 亚洲一区二区国产| 国产剧情久久久| 亚洲大片精品永久免费| 精品国产人妻一区二区三区| 男人的天堂亚洲在线| 天天综合色天天综合色hd| 国产午夜久久av| 国产做受高潮69| 国产乱子伦三级在线播放| 欧美日韩卡一卡二| 久草中文在线视频| 久久久久久久久久看片| 亚洲综合欧美在线| 好吊日精品视频| 欧美一区二区三区精美影视| 欧美黄色成人| 亚洲91av视频| 91官网在线| 精品日韩成人av| 天堂网视频在线| 亚洲色图在线视频| jizz日本免费| 激情成人综合网| 欧美日韩在线视频一区二区三区| 欧美1级片网站| 精品蜜桃一区二区三区| 国模私拍国内精品国内av| 久久久免费精品| 波多野结衣在线网站| 日韩欧美一区二区视频| 狠狠人妻久久久久久综合| 亚洲老司机在线| xxxx日本黄色| 不卡视频在线观看| 久久婷婷中文字幕| 老司机午夜精品视频在线观看| 男插女免费视频| 奇米狠狠一区二区三区| 7777精品伊久久久大香线蕉语言| 国产免费不卡| 国外色69视频在线观看| 国产激情小视频在线| 亚洲免费视频网站| 国产综合视频在线| 9191久久久久久久久久久| 国产欧美一区二区三区在线看蜜臂| 日韩一区在线免费观看| 免费黄色片网站| 99久久综合99久久综合网站| 久久久久亚洲av无码麻豆| 日本午夜一本久久久综合| 少妇av一区二区三区无码| 欧美在线高清| 亚洲午夜精品久久| 欧美亚洲国产激情| 欧美日韩精品免费观看视一区二区| 亚洲小说春色综合另类电影| 成人av色在线观看| 成人亚洲综合| 国产不卡视频在线| 成人影院av| 4k岛国日韩精品**专区| 男女免费观看在线爽爽爽视频| 北条麻妃一区二区三区中文字幕| 国产免费a∨片在线观看不卡| 亚洲国产精品久久91精品| 亚洲精品911| 欧美videos中文字幕| 国产女人18毛片水真多| 在线电影一区二区三区| 中文字幕 亚洲视频| 欧美少妇性性性| 中文字幕一区二区人妻痴汉电车| 日本精品一级二级| 丰满少妇xoxoxo视频| 欧美性20hd另类| 成年人视频在线免费看| 欧美日韩国产中文精品字幕自在自线| 精品一区在线视频| 亚洲国产视频直播| 日韩免费一二三区| 欧美三级免费观看| 天天干天天干天天| 在线影视一区二区三区| 一级片在线免费播放| 欧美日韩精品一区二区三区四区| 中文字幕一二三四| 91麻豆精品国产无毒不卡在线观看| 91国内精品视频| 日韩视频免费观看高清在线视频| 亚洲va久久久噜噜噜无码久久| 精品久久久久久久人人人人传媒 | 中文字幕69页| 欧美亚洲一区二区三区四区| 欧美一级黄视频| 欧美浪妇xxxx高跟鞋交| www.好吊色| 亚洲精品国产福利| 国产日韩精品在线看| 在线视频日本亚洲性| 蜜桃视频网站在线| 九九热99久久久国产盗摄| 丰满诱人av在线播放| 日韩av手机在线观看| 日韩伦理一区二区| 成人欧美一区二区三区视频| 日本成人7777| 天天久久人人| 欧美xxx在线观看| 欧美日韩黄色一级片| 日韩成人免费电影| 四川一级毛毛片| 久久尤物电影视频在线观看| 国产又粗又黄又猛| 亚洲综合在线视频| 欧美一级淫片免费视频黄| 91精品综合久久久久久| 日韩在线视频观看免费| 中文在线资源观看视频网站免费不卡| 1024在线播放| 日本免费久久高清视频| 亚洲男男av| 欧美精品中文字幕一区二区| 午夜精品毛片| 99色精品视频| 国产一区二区按摩在线观看| 久久久久久久久久久国产精品| 国产精品久线观看视频| 国产午夜久久久| 精品视频色一区| 亚洲av成人无码久久精品老人| 色播久久人人爽人人爽人人片视av| 182在线播放| 成人做爰www免费看视频网站| 色橹橹欧美在线观看视频高清 | 黄色在线一区| 亚洲激情在线观看视频| 成人免费视频视频在线观看免费 | 亚洲一区在线电影| 中文字幕一区二区免费| 精品视频在线播放免| av免费看在线| 国产精品永久免费| 精品一区免费| 性一交一乱一伧国产女士spa| 美女在线视频一区| 久久精品视频18| 午夜不卡av在线| 午夜久久久久久噜噜噜噜| 国产一区二区久久精品| 美女视频在线免费| 成人自拍视频网站| 亚洲国产老妈| 天天干天天玩天天操| 99久久婷婷国产| 久久艹精品视频| 日韩一区二区免费高清| 一级毛片视频在线| 国产精品电影网站| 中文有码一区| 丝袜老师办公室里做好紧好爽| 国产成人在线色| 日韩一级片大全| 在线播放/欧美激情| 亚洲精品传媒| 国产精品自产拍高潮在线观看| 国产成人黄色| 亚洲男人天堂色| 国产视频亚洲色图| 91久久偷偷做嫩草影院| 四虎久久免费| 国产精品美女无圣光视频| 国产精品欧美三级在线观看| www国产黄色| 久久理论电影网| 性色av免费观看| 亚洲欧美在线一区二区| 另类专区亚洲| 欧美日韩日本网| 欧美aⅴ一区二区三区视频| 2019男人天堂| 欧美美女bb生活片| 国产三区视频在线观看| 1卡2卡3卡精品视频| 国产精品va| 欧美熟妇精品一区二区蜜桃视频| 亚洲无线码一区二区三区| 免费观看a视频| 2023亚洲男人天堂| 成人动漫免费在线观看| 性欧美videossex精品| 国产精品久久久久久久浪潮网站 | 亚洲欧美综合7777色婷婷| 欧美高清视频在线高清观看mv色露露十八| 老司机精品影院| wwwxx欧美| 亚洲欧美日韩精品一区二区| 亚洲熟妇一区二区三区| 在线视频欧美区| 老司机99精品99| 国产在线精品一区二区中文 | 中文字幕在线综合| 一卡二卡欧美日韩| 男同在线观看| 成人黄色av网站| 亚洲精品系列| 极品人妻videosss人妻| 日韩午夜在线观看| 日韩欧美一中文字暮专区| 日韩欧美亚洲v片| 国产高清在线观看免费不卡| 久久夜靖品2区| 中文字幕亚洲综合| 亚洲综合色婷婷在线观看| 成人小视频在线看| 亚洲免费观看在线视频| 午夜小视频在线播放| 国产精品久久久久不卡| 欧美日本在线| 久久亚洲AV无码专区成人国产| 欧美一区中文字幕| 中文字幕在线官网| 性做爰过程免费播放| 2019国产精品| a在线观看免费| 国产精品91久久久久久| 欧美三级小说| 婷婷综合在线视频| 亚洲韩国欧洲国产日产av| 伊人久久大香伊蕉在人线观看热v| 成年人看的毛片|