-
Part one 支付系統總覽
- 核心系統交互
- 業務圖譜
-
Part two 核心系統解析
- 交易核心
- 支付核心
- 渠道網關
- 資金核算
-
Part three 服務治理
- 平臺統一上下文
- 數據一致性治理
- DB拆分
- 異步化
-
Part four 生產實踐
- 性能壓測
- 穩定性治理
- 核心鏈路分離
- 服務依賴降級
支付永遠是一個公司的核心領域,因為這是一個有交易屬性公司的命脈。那么,支付系統到底長什么樣,又是怎么運行交互的呢?
拋開帶有支付牌照的金融公司的支付架構,下述鏈路和系統組成基本上符合絕大多數支付場景。
其實整體可以看成是交易核心+支付核心 兩個大系統。交易系統關聯了業務場景和底層支付,而支付系統完成了調用支付工具到對賬清算等一系列相關操作。下面我們就來一起看下 各個系統的核心組成和交互。
Part one 支付系統總覽
核心系統交互
![3b682330-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3KAXCqRAAD-AKRwyJ4463.png)
業務圖譜
![3b6fb384-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3KABQ9uAAHZLj2140Y805.png)
基于 Spring Boot + MyBatis Plus + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能
- 項目地址:https://github.com/YunaiV/ruoyi-vue-pro
- 視頻教程:https://doc.iocoder.cn/video/
Part two 核心系統解析
交易核心
交易核心把公司的業務系統和底層支付關聯起來,讓業務系統專注于業務,不比關心底層支付。
交易核心
![3b758214-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3OAao0vAAE2pt8BpOI782.png)
基礎交易類型抽象
![3b7cc7b8-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3OAK5-TAAIz8aAD0Bg564.png)
多表聚合 & 訂單關聯
![3b89cda0-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3OAJvbEAAFViD9mmTQ024.png)
支付核心
支付核心主要負責將多種支付類型進行抽象,變成 充值
、提現
、退款
、轉賬
四種支付形態。同時,還要負責集成多種支付工具,對支付指令進行編排等等。
支付核心總覽
![3b91bec0-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3OATT85AAF_v6g_yeo558.png)
支付行為編排
其目的,是實現 插件式開發
、支付規則可配置
的 靈活開發方式。
![3ba1c018-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3SASBzkAAGdiS9vZvU373.png)
異常處理
異常處理包括了 重復支付、部分支付、金額不一致、其他異常等異常場景。
![3baa50c0-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3SAZ8GxAACpUFRphGw055.png)
渠道網關
![3bb0a4ac-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3SAZW61AAH1QxAGjvw751.png)
資金核算
![3bbcc138-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3SARfTSAAIGo_DQ1uo055.png)
基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能
Part three 服務治理
平臺統一上下文
通過確定系統邊界、業務建模拆分之后,整個支付平臺被拆分幾十個服務,而如何保障在服務間流轉業務信息不被丟失,是我們需要考慮的問題。平臺統一上下文的要素信息(唯一業務標識碼),在整個支付平臺鏈路中全程傳遞,被用來解決這個問題。
![3bc2496e-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3WAY0k7AAFb9hicEdQ680.png)
數據一致性治理
大型的支付公司,內部都有非常嚴格和完備的數據一致性方案,比如采用業務侵入性非常大的分布式事務等,以犧牲開發效率來提升數據的穩定,是非常有必要的。而業務公司,如果不采用分布式事務又有哪些應對策略呢?
CAS校驗
![3bca70c6-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3WAN61BAAEMnEuUcB0706.png)
冪等 & 異常補償
![3bd0b1b6-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3WAHHDJAAG5alo5cW8700.png)
對賬
![3bd9326e-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3WAKkOJAADLMlzOPEw815.png)
準實時對賬
![3bdf5bb2-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAAjkAAAF8XWzT9B8236.png)
DB拆分
![3be780f8-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAB9NnAAEthcWgQL4347.png)
異步化
支付是整個交易鏈路的核心環節,那么,怎么兼顧支付系統的穩定性和執行效率呢?是異步化。
消息異步化
![3bef9d2e-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAWCkGAAHfhE8urm8356.png)
外部支付調用異步化
![3bf7c620-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAEeePAAFDPN0A9HE546.png)
在外部支付中,經常需要服務方與第三方支付交互,獲取預支付憑證,如上圖所示。
這種同步調用的情況下,由于需要跨外部網絡,響應的 RT 會非常長,可能會出現跨秒的情況。由于是同步調用,會阻塞整個支付鏈路。一旦 RT 很長且 QPS 比較大的情況下,服務會整體 hold 住,甚至會出現拒絕服務的情況。
![3bfcaabe-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAFWGcAAD_31n4cjQ562.png)
因此,可以拆分獲取憑證的操作,通過獨立網關渠道前置服務,將獲取的方式異步化,從前置網關獲取內部憑證,然后由前置網關去異步調用第三方。
異步并行化
![3c036606-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3aAZPqpAAGrja90WqQ189.png)
資金核算異步化
![3c0c94ce-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eAOafWAAI9a3YQVps791.png)
熱點賬戶賬務單獨處理
![3c1300ac-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eALeKcAAD4AuXQKhg066.png)
記賬事務切分
![3c1a7ca6-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eAYSxbAAGmjc0nNeE326.png)
Part four 生產實踐
性能壓測
構建壓測模型,模擬現實真實場景;壓測數據進影子庫,正常業務無侵入;單機性能和集權鏈路都不能忽視;識別系統穩定性和容量配比。。。
![3c27893c-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eAAzM4AAMJsCtD9t0030.png)
穩定性治理
![3c3172c6-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eAcXJLAACM_UDBvwc864.png)
核心鏈路分離
![3c3e7cf0-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3eABSMYAAHAFNYELlc529.png)
服務依賴降級
![3c43c322-fafb-11ed-90ce-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9A/C0/wKgZomTnq3iAJsOXAADCzg4J3G8770.png)
審核編輯 :李倩
-
數據
+關注
關注
8文章
7170瀏覽量
89705 -
網關
+關注
關注
9文章
4611瀏覽量
51557 -
支付系統
+關注
關注
0文章
79瀏覽量
10231
原文標題:支付系統就該這么設計,穩的一批!!
文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論