支付渠道路由系統進化史

来源:https://www.cnblogs.com/goodAndyxublog/archive/2019/05/11/10848843.html
-Advertisement-
Play Games

支付系統一般需要對接多個支付渠道,一是為了保證系統的可靠性,不能因為單一渠道的問題影響整個支付系統。二是為了提高支付能力,不同渠道提供支付能力不同。三是為了降低支付成本。 對接多個支付渠道以後,為了可以正確選擇支付渠道支付,因此設計渠道路由系統。 從上圖可以看到路由系統功能其實很簡單,分發支付請求到 ...


支付系統一般需要對接多個支付渠道,一是為了保證系統的可靠性,不能因為單一渠道的問題影響整個支付系統。二是為了提高支付能力,不同渠道提供支付能力不同。三是為了降低支付成本。

對接多個支付渠道以後,為了可以正確選擇支付渠道支付,因此設計渠道路由系統。

從上圖可以看到路由系統功能其實很簡單,分發支付請求到正確的渠道。但就是這個簡單系統,也經過幾次系統改造升級,最終才成為現在的樣子。下麵就來說說這個系統是如何演進。

下麵假設對接支付渠道為支付寶與微信。

初期

支付系統初期,這個階段業務需求較簡單,僅僅需要滿足一個支付場景(例如使用支付寶支付)。為了快速上線,設計方案就簡單粗暴,對外直接暴露支付服務介面,由業務系統發起直接調用。

系統設計圖如下:

這個階段由於只有一個支付渠道,所以也不需要有路由系統,直接由業務系統調用支付服務介面發起支付。

這個設計方案存在很多問題:

  1. 業務系統與支付系統位於同一個系統,系統任何一次變更都會影響整個系統。
  2. 擴展性問題。接入新支付渠道,如微信,需要新暴露一個微信支付服務介面。業務系統需要改動代碼。從另一方面講,業務系統承擔路由系統的功能。
  3. 復用性。新支付渠道,其實除了與支付渠道交互相關代碼之外,其他代碼可以復用。

針對以上問題,將系統進行了相應改造。

首先是將支付系統與業務系統單獨拆分出來,成為兩套單獨的系統。支付系統對外暴露一組通用介面。業務系統僅對接這組介面。業務系統若想指定支付渠道支付,介面參數傳入渠道標識即可。這樣就將耦合在業務系統中路由功下沉到支付系統。

其次梳理渠道介面文檔,抽象出共性介面。接入新支付渠道,只要繼承介面,實現相關方法即可,簡化渠道開發難度。

改版後的系統實現圖如下:

此時,路由系統知識支付系統的一個模塊,具體實現如下。

首先定義通用渠道介面,其中 channelName 方法,返回渠道渠道唯一標識,如支付寶渠道返回 aliPay

然後根據 Spring ApplicationContext getBeansOfType 方法,獲取實現同一個介面的所有 Bean.最後將其放入 Map 緩存中,其中鍵值為 channelName 方法返回渠道標識。

這個階段方案的問題在於支付系統所有模塊位於同一工程。有些模塊需要頻繁發佈,而有些模塊,如渠道模塊,路由模塊改動就很少。這樣就導致系統任一改動發佈,影響整個支付系統可用性。

中期

針對初期後面的問題,進行了相應改造。

首先還是進行拆分,將支付系統按照模塊拆分。路由系統,渠道系統,成為獨立系統,獨立部署維護。

系統之間調用採用 RPC 通訊,使用 Dubbo 框架。

相關實現如下:

相關介面邏輯不變,只是將同一進程內調用變成跨系統的調用。

渠道系統提供服務:

這裡改動,將渠道標識放入 Dubbo 服務 group 欄位,藉助 Dubbo 分組功能標識中唯一的渠道系統。

路由系統引用渠道系統的服務:

這裡同樣需要設置 group 且需要和服務提供者一致。然後在路由系統中將服務註冊到緩存中,使用渠道標識為 key,渠道服務名為 value。

最後路由系統藉助 Spring ApplicationContext getBean 獲取具體的服務。

這個設計的問題在於:

路由系統中需要手動引用渠道系統服務,然後再註冊。這樣在增加渠道系統就比較繁瑣。那是不是可以做到增加渠道系統時,無需修改路由系統,路由系統自動發現服務?

藉助 Dubbo API

後期

查看 Dubbo 文檔,可以直接使用 ReferenceConfig 直接查找服務提供者。

官方文檔建議:

ReferenceConfig 實例很重,封裝了與註冊中心的連接以及與提供者的連接,需要緩存。否則重覆生成 ReferenceConfig 可能造成性能問題並且會有記憶體和連接泄漏。在 API 方式編程時,容易忽略此問題。

這裡使用ReferenceConfigCache,用於緩存 ReferenceConfig 實例。

去除之前所有引用服務配置文件以及緩存註冊代碼,引入 ReferenceConfigCache,改造如下。

總結

回顧上文路由系統,可以看到初期沒有路由系統,整個系統可以運行下去。但是隨著系統複雜度提高,初期系統架構已經不能滿足系統的高效運行,所以才一步步改進系統。改進的過程中,不斷發現方案不足處,然後一步步迭代演進。這個過程中,要善於利用現有框架的功能,加速功能的開發。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 之前有收集了一些主流的隱藏鏈接代碼,最近又發現一種相當牛X的代碼,如下: 源代碼: <div style="position:absolute;left:expression(1-900);top:expression(3-999);">隱藏內容</a></div> 這個代碼中,expression ...
  • 一個網頁裡面的內容理解為一個XML或者說網頁本身也就是一個XML文檔,XML文檔都有很特殊的象徵:"標簽"也叫"節點"。 一個基本的網頁格式 這些是最基本的形態,但是其實它省略了最外面的一個標簽<document> 這其實才是它的本來面目(預設把document標簽給省略了)。document.bo ...
  • 學習專業知識,不是都靠自己頑強的意志,更多的是需要跟別人交流,重要的就是跟比你強的人交流,加一些氛圍比較好的交流學習群,或者別人的一句話就能讓你茅塞頓開,學技術切記不能閉門造車,學習的大忌。 5.遇到問題搞不清楚,只能百度,然後自己一團糟 遇到問題的時候,不假思索「百度」,但是很多時候我們是浪費了大 ...
  • 首先這邊我先貼一個地址:https://www.adobe.com/cn/products/photoshop.html 安裝軟體,這裡就不贅述了,真的不會,可以百度^_^我當初就是百度的,哈哈 說到PS,作為前端開發的同學,一點都不陌生 前端需要掌握的PS知識,也不是很多 針對頁面佈局,我們前端需 ...
  • 一、字體類屬性: 1.字體類型: font-family:字體1,字體2,字體3; 常用寫法: font-family:"微軟雅黑",Arial; 註:a) 多個字體之間用逗號分隔; b)中文字體要放在雙引號中,英文字體由多個單片語成時也要加雙引號; c) 瀏覽器優先識別字體1,如果找不到字體1,識 ...
  • 1. 通過axios實現數據請求 vue.js預設沒有提供ajax功能的。 所以使用vue的時候,一般都會使用axios的插件來實現ajax與後端伺服器的數據交互。 註意,axios本質上就是javascript的ajax封裝,所以會被同源策略限制。 下載地址: axios提供發送請求的常用方法有兩 ...
  • 開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892 開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 ...
  • 裝飾模式概述 定義:動態地給一個對象增加一些附屬的職責。 裝飾裝飾,自然的理解就是在原有物品的基礎上,增加一些別的東西,讓它變得更令人滿意。且裝飾模式是在不改變對象本身的基礎上就行額外的增加,更加靈活。 比如買房,首先買的是個空房,隨後我們會放進去傢具,和各種生活中要用的東西,讓這個家變得更有家的味 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...