主頁 >  其他 > BFF層聚合查詢服務異步改造及治理實踐 | 京東云技術團隊

BFF層聚合查詢服務異步改造及治理實踐 | 京東云技術團隊

2023-06-03 08:03:23 其他

首先感謝王曉老師的[介面優化的常見方案實戰總結]一文總結,恰巧最近在對穩健理財BFF層聚合查詢服務優化治理,針對文章內的串行改并行章節進行展開,分享下實踐經驗,主要涉及原同步改異步的程序、全異步化后衍生的問題以及治理方面的思考與改進,

希望通過分享這些經驗,能夠對大家的作業有所啟發和幫助,如果有任何問題或建議,請隨時提出,

一、問題背景

將不同理財產品(如基金、券商、保險、銀行理財等)針對不同投放渠道人群進行個性化商品推薦,每個渠道或人群看到的商品或特性資料又各不相同,為方便渠道快速對接,由BFF層統一對所有資料進行聚合下發,因此BFF層聚集依賴了大量底層原子服務,所以主要問題是在依賴大量上游介面的場景下保障TP99、以及可用率,

案例:

以其中比較典型的商品推薦介面為例,需要依賴本地商品池快取、演算法推薦服務、商品基礎資訊服務、持倉查詢服務、人群標簽服務、券配置服務,可領用券服務、其他資料服務ServN……等等,其中大部分上游原子介面對單次批量查詢支持有限,所以極端情況,單個推品介面單次推薦1-n個推品,每個商品如果要系結10個動態屬性,至少需要發起(1~n)*10次io呼叫,

改造前的流程和問題:

流程:

問題:

  • 一是邏輯流程強耦合,很多上下游服務強同步依賴;

  • 二是鏈路較長,其中某個上游服務不穩定時很容易造成整體鏈路失敗,

改造后的流程和實作的目標:

流程:

目標:

  • 改造目標也很明確,就是對現有邏輯改造,盡可能增加弱依賴比例,一是方便異步提前加載,二是弱依賴代表可摘除,為降級操作奠定基礎,減少因某個鏈路抖動影響整體鏈路失敗;

初步改造后的新問題【【重點解決】】:

?邏輯上解耦比較簡單,無非就是前置引數或冗余加載,本次不展開探討;

?技術上改造前期異步邏輯主要是采用@Async("tpXXX")標注,這也是最快捷實作的方式,但也存在以下幾個問題,主要是涉及治理方面:

  1. 隨著專案和人員不斷迭代,造成@Async注解滿天飛;

  2. 不同人員在不熟悉其他模塊的情況下,無法界定不同執行緒池的是否可公用,大多都會采用宣告新的執行緒池,造成執行緒池資源泛濫;

  3. 部分呼叫場景不合理造成@Async嵌套過多或注解失效問題;

  4. 降級機制重復代碼太多,需要頻繁手動宣告各種降級開關;

  5. 缺少統一的請求級別的快取機制,雖然jsf已經提供了一定程度的支持;

  6. 執行緒池背景關系傳遞問題;

  7. 缺少執行緒池狀態的統一監控報警,無法觀測實際運行程序中的每個執行緒池狀態,可能每次都是拍腦袋覺設定執行緒池引數,

二、整體改造路徑

切入點:

鑒于大部分專案都會封裝單獨的io呼叫層,比如 com.xx.package.xxx.client,所以以此為切入點進行重點改造治理,

最終目標:

實作、應用簡單,對老代碼改造友好,盡可能降低改造成本;

  1. 抽象io呼叫模板,統一io呼叫層封裝規范,標準化io呼叫需要的增強屬性宣告并提供默認配置,如所屬執行緒池分配、超時、快取、熔斷、降級等;

  2. 優化@Async呼叫,所有io異步操作統一收縮至io呼叫層,在模板層實作回呼機制,老代碼僅繼承模板即可實作異步回呼;

  3. 請求級別的快取實作,默認支持r2m;

  4. 請求級別的熔斷降級支持,在上游故障時使服務實作一定程度的自治理;

  5. 執行緒池集中管理,對背景關系自動傳遞MDC引數提供支持;

  6. 執行緒池狀態自動可視化監控、報警實作;

  7. 支持配置中心動態設定,

具體實作:

1. io呼叫抽象模板

模板主要作用是進行規范和增強,目前提供兩種模板,默認模板、快取模板,核心思想就是對io操作涉及的大部分行為進行宣告,比如當前服務所屬執行緒池分組、請求分組等,由委托組件按照宣告的屬性進行增強實作,示例如下:

主要是提供代碼級別的默認宣告,從日常實踐看大部分采用開發時的代碼級別的配置即可,

2. 委托代理

此委托屬于整個執行程序的橋接實作,io封裝實作繼承抽象模板后,由模板創建委托代理實體,主要用于對io封裝進行增強實作,比如呼叫前、呼叫后、以及呼叫失敗自動呼叫宣告的降級方法等處理,

可以理解為:模板專注請求行為,委托關注物件行為進行組合增強,

3. 執行器選型

基于前面的實作目標,減少自研成本,調研目前已有框架,如 hystrix、sentinel、resilience4j,由于主要目的是期望支持執行緒池級別的壁艙模式實作,且hystrix集成度要優于resilience4j,最終選型默認集成hystrix,備選resilience4j, 以此實作執行緒池的動態創建管理、熔斷降級、半連接重試等機制,HystrixCommander實作如下:

4. hystrix 適配 concrete 動態配置

1、繼承concrete.PropertiesNotifier, 注冊HystrixPropertiesNotifier監聽器,快取配置中心所有以hystrix起始的key配置;

2、實作HystrixDynamicProperties,注冊ConcreteHystrixDynamicProperties替換默認實作,最終支持所有的hystrix配置項,具體用法參考hystrix檔案,

5. hystrix 執行緒池背景關系傳遞改造

hystrix已經提供了改造點,主要是對HystrixConcurrencyStrategy#wrapCallable方法重寫實作即可,在submit任務前暫存主執行緒背景關系進行傳遞,

6. hystrix、jsf、spring注冊執行緒池狀態多維可視化監控、報警

主要依賴以下三個自定義組件,注冊一個狀態監控處理器,單獨啟動一個執行緒,定期(每秒)收集所有實作資料上報模板的實體,通過指定的通道實作狀態資料推送,目前默認使用PFinder上報:

  • ThreadPoolMonitorHandler 定義一個執行緒狀態監控處理器,定期執行上報程序;

  • ThreadPoolEndpointMetrics 定義要上報的資料模板,包括應用實體、執行緒型別(spring、jsf、hystrix……)、型別執行緒分組、以及執行緒池的幾個核心引數;

  • AbstractThreadPoolMetricsPublisher 定義監控處理器執行上報時依賴的通道(Micrometer、PFinder、UMP……),

例如以下是hystrix的狀態收集實作,最終可實作基于機房、分組、實體、執行緒池型別、名稱等不同維度的狀態監控:

PFinder實際效果:支持不同維度組合查看及報警

7. 提供統一await future工具類

由于大部分呼叫是基于串列形式的異步結果List<Future>、Map<String,Future>,并且hystrix目前暫不支持回傳CompletableFuture,方便統一await,提供工具類:

8. 其他小功能

1、除了sgm traceId支持,同時內置自定義的traceId實作,主要是處理sgm在子執行緒內列印traceId需要在控制臺手動添加監控方法的問題以及提供對部分無sgm環境的鏈路Id支持,方便日志跟蹤;

2、比如針對jsf呼叫,基于jsf過濾器實作跨應用級別的前后請求id傳遞支持;

3、默認增加jsf過濾器實作日志列印,同時支持provider、consume的動態日志列印開關,方便線上隨時開關jsf日志,不再需要在client層重復logger.isDebugerEnabled();

4、代理層自動上報io呼叫方法、fallback等資訊至ump,方便監控報警,

日常使用示例:

1. 一個最簡單的io呼叫封裝

僅增加繼承即可支持異步回呼,不重寫執行緒池分組時使用默認分組,

2. 一個支持請求級別熔斷的io呼叫封裝

默認支持的熔斷級別是服務級別,老服務僅需要繼承原請求引數,實作FallbackRequest介面即可,可防止因為某一個特殊引數引起的整體介面熔斷,

3. 一個支持請求級別快取、介面級別熔斷降級、獨立執行緒池的io呼叫封裝

4. 上層呼叫,實際效果

1、直接將一個商品串列轉換成一個異步屬性系結任務;

2、利用工具類await List<Future>;

3、在上層無感知的狀態下,實作執行緒池的管理、熔斷、降級、或快取邏輯的增強,且可根據pfinder監控的可視化執行緒池狀態,通過concrete實時調整執行緒池及超時或熔斷引數;

4、舉例:比如某介面頻繁500ms超時,可通過配置直接打開短路回傳降級結果,或者調低超時為100ms,快速觸發熔斷,默認10s內請求總數達到20個,50%失敗時打開斷路器,每隔5s半鏈接重試,

三、最后

本篇主要是思考如何依賴現有框架、環境的能力,從代碼層面系統化的實作相關治理規范,

最后仍參考王曉老師文章結尾來結束

介面性能問題形成的原因思考我相信很多介面的效率問題不是一朝一夕形成的,在需求迭代的程序中,為了需求快速上線,采取直接累加代碼的方式去實作功能,這樣會造成以上這些介面性能問題, 變換思路,更高一級思考問題,站在介面設計者的角度去開發需求,會避免很多這樣的問題,也是降本增效的一種行之有效的方式, 以上,共勉!

作者:京東科技 劉大朋

來源:京東云開發者社區

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/554161.html

標籤:其他

上一篇:Gitlab Registries

下一篇:返回列表

標籤雲
其他(160235) Python(38199) JavaScript(25473) Java(18184) C(15236) 區塊鏈(8269) C#(7972) AI(7469) 爪哇(7425) MySQL(7223) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5346) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4581) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1980) 功能(1967) Web開發(1951) HtmlCss(1951) C++(1928) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • BFF層聚合查詢服務異步改造及治理實踐 | 京東云技術團隊

    最近在對穩健理財BFF層聚合查詢服務優化治理,針對文章內的串行改并行章節進行展開,分享下實踐經驗,主要涉及原同步改異步的程序、全異步化后衍生的問題以及治理方面的思考與改進。 ......

    uj5u.com 2023-06-03 08:03:23 more
  • Gitlab Registries

    在專案開發和部署程序中,我們常常需要一套私有倉庫,比如 `Code Repository`、`Package Repository`,`Docker Registry` 等。 + Code Repository:在 github 或 gitlab 或 gitee 等平臺上創建私有專案;或搭建本地代碼 ......

    uj5u.com 2023-06-03 08:02:22 more
  • 軟體測驗工程師如何從功能測驗轉成自動化測驗?經驗分享篇

    隨著測驗行業的發展,"會代碼"越來越成為測驗工程師的一個標簽。打開各大招聘網站,測驗工程師月薪一萬以上基本都有一個必備技能,那就是自動化測驗。那么自動化測驗到底難不難呢?下面我將會將我的經歷講給大家聽,希望聽完后,大家會有自己的一個判斷。 ......

    uj5u.com 2023-06-03 08:01:57 more
  • 學習筆記——VMWare的使用和Windows的安裝

    2023-06-02 一、VMware介紹 1.1 VMware即虛擬機軟體,用于模擬計算機(虛擬機/客戶機) 物體機(是實實在在的計算機) (1)特點 ①多啟動系統 一個時刻只能運行一個系統,切換時必須重啟。 ②虛擬PC軟體 一臺機器上同時運行多個系統 二、在虛擬機中安裝作業系統 2.1 安裝前的 ......

    uj5u.com 2023-06-03 08:01:37 more
  • 軟體測驗作業3年,我是如何從剛入門進階到自動化測驗的?

    從事測驗作業已3年有余了,今天想聊一下自己剛入門時和現在的今昔對比,雖然現在也沒什么成就,只能說笑談一下自己的測驗生涯,各位看官就當是茶余飯后的吐槽吧,另外也想寫一寫自己的職場感想,希望對剛開始作業的小伙伴能夠有些幫助或啟發。 ......

    uj5u.com 2023-06-03 08:01:29 more
  • 學習筆記——軟體、軟體分類、軟體測驗、資料的形式與數制(進制之

    2023-06-02 一、軟體 1、軟體包含的內容:程式、資料和檔案 ①程式:一遍是由編程語言撰寫的,例如:C、C++、java、Python等。 ②資料:一般使用檔案或者資料庫來存盤資料 ③檔案:包括安裝說明書、幫助檔案、許可協議等。 2、軟體分類 2.1 安裝功能用途分類 (1)系統軟體 例如: ......

    uj5u.com 2023-06-03 08:01:18 more
  • python mitmproxy抓包庫

    一.簡介 mitmproxy是一款用Python撰寫的支持HTTP(S)的中間人代理工具。它可以攔截、查看、修改、重放和保存HTTP/HTTPS流量 ,支持命令列界面和圖形界面,可用于安全測驗、網路除錯、API開發和反向工程等場景。mitmproxy具有很高的靈活性和擴展性,可以通過插件機制進行定制 ......

    uj5u.com 2023-06-03 08:00:57 more
  • Python單元測驗:一步步了解測驗框架、測驗用例和覆寫率分析

    在軟體開發中,單元測驗是一個非常重要的環節。它可以確保你的代碼能夠正常運行,并且在將來的修改中不會出現問題。在Python中,單元測驗是非常容易實作的。本文將介紹Python單元測驗的所有知識點,包括測驗框架,測驗用例,測驗裝置,測驗套件和覆寫率分析。 ......

    uj5u.com 2023-06-03 08:00:42 more
  • 利用遠控工具橫向移動

    # 利用遠控工具橫向移動 [TOC] ## 一、利用遠控工具向日葵橫向移動 ### 1、向日葵介紹 向日葵遠程控制軟體是一款免費的集遠程控制電腦/手機/平板、遠程桌面連接、遠程開機、遠程管理、支持內網穿透的一體化遠程控制管理工具軟體,且還能進行遠程檔案傳輸、遠程攝像頭監控等。 ### 2、利用思路 ......

    uj5u.com 2023-06-03 08:00:29 more
  • QR防偽溯源系統追溯原理是什么?

    QR防偽溯源系統是一種基于QR技術的防偽技術,通過為每件產品生成唯一的QR標簽,并將其與產品資訊、生產資訊、物流資訊等進行關聯,實作產品的全程追溯。本文將從追溯原理、系統構成、應用場景等方面對QR防偽溯源系統進行詳細介紹 ......

    uj5u.com 2023-06-03 08:00:25 more