支付永遠(yuǎn)是一個(gè)公司的核心領(lǐng)域,因?yàn)檫@是一個(gè)有交易屬性公司的命脈。那么,支付系統(tǒng)到底長(zhǎng)什么樣,又是怎么運(yùn)行交互的呢?
拋開帶有支付牌照的金融公司的支付架構(gòu),下述鏈路和系統(tǒng)組成基本上符合絕大多數(shù)支付場(chǎng)景。
其實(shí)整體可以看成是交易核心+支付核心 兩個(gè)大系統(tǒng)。交易系統(tǒng)關(guān)聯(lián)了業(yè)務(wù)場(chǎng)景和底層支付,而支付系統(tǒng)完成了調(diào)用支付工具到對(duì)賬清算等一系列相關(guān)操作。下面我們就來一起看下 各個(gè)系統(tǒng)的核心組成和交互。
Part one 支付系統(tǒng)總覽
核心系統(tǒng)交互
業(yè)務(wù)圖譜
基于 Spring Boot + MyBatis Plus + Vue & Element 實(shí)現(xiàn)的后臺(tái)管理系統(tǒng) + 用戶小程序,支持 RBAC 動(dòng)態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能
項(xiàng)目地址:https://github.com/YunaiV/ruoyi-vue-pro
視頻教程:https://doc.iocoder.cn/video/
Part two 核心系統(tǒng)解析
交易核心
交易核心把公司的業(yè)務(wù)系統(tǒng)和底層支付關(guān)聯(lián)起來,讓業(yè)務(wù)系統(tǒng)專注于業(yè)務(wù),不比關(guān)心底層支付。
交易核心
基礎(chǔ)交易類型抽象
多表聚合 & 訂單關(guān)聯(lián)
支付核心
支付核心主要負(fù)責(zé)將多種支付類型進(jìn)行抽象,變成 充值、提現(xiàn)、退款、轉(zhuǎn)賬四種支付形態(tài)。同時(shí),還要負(fù)責(zé)集成多種支付工具,對(duì)支付指令進(jìn)行編排等等。
支付核心總覽
支付行為編排
其目的,是實(shí)現(xiàn) 插件式開發(fā)、支付規(guī)則可配置的 靈活開發(fā)方式。
異常處理
異常處理包括了 重復(fù)支付、部分支付、金額不一致、其他異常等異常場(chǎng)景。
渠道網(wǎng)關(guān)
資金核算
基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實(shí)現(xiàn)的后臺(tái)管理系統(tǒng) + 用戶小程序,支持 RBAC 動(dòng)態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能
項(xiàng)目地址:https://github.com/YunaiV/yudao-cloud
視頻教程:https://doc.iocoder.cn/video/
Part three 服務(wù)治理
平臺(tái)統(tǒng)一上下文
通過確定系統(tǒng)邊界、業(yè)務(wù)建模拆分之后,整個(gè)支付平臺(tái)被拆分幾十個(gè)服務(wù),而如何保障在服務(wù)間流轉(zhuǎn)業(yè)務(wù)信息不被丟失,是我們需要考慮的問題。平臺(tái)統(tǒng)一上下文的要素信息(唯一業(yè)務(wù)標(biāo)識(shí)碼),在整個(gè)支付平臺(tái)鏈路中全程傳遞,被用來解決這個(gè)問題。
數(shù)據(jù)一致性治理
大型的支付公司,內(nèi)部都有非常嚴(yán)格和完備的數(shù)據(jù)一致性方案,比如采用業(yè)務(wù)侵入性非常大的分布式事務(wù)等,以犧牲開發(fā)效率來提升數(shù)據(jù)的穩(wěn)定,是非常有必要的。而業(yè)務(wù)公司,如果不采用分布式事務(wù)又有哪些應(yīng)對(duì)策略呢?
CAS校驗(yàn)
冪等 & 異常補(bǔ)償
對(duì)賬
準(zhǔn)實(shí)時(shí)對(duì)賬
DB拆分
異步化
支付是整個(gè)交易鏈路的核心環(huán)節(jié),那么,怎么兼顧支付系統(tǒng)的穩(wěn)定性和執(zhí)行效率呢?是異步化。
消息異步化
外部支付調(diào)用異步化
在外部支付中,經(jīng)常需要服務(wù)方與第三方支付交互,獲取預(yù)支付憑證,如上圖所示。
這種同步調(diào)用的情況下,由于需要跨外部網(wǎng)絡(luò),響應(yīng)的 RT 會(huì)非常長(zhǎng),可能會(huì)出現(xiàn)跨秒的情況。由于是同步調(diào)用,會(huì)阻塞整個(gè)支付鏈路。一旦 RT 很長(zhǎng)且 QPS 比較大的情況下,服務(wù)會(huì)整體 hold 住,甚至?xí)霈F(xiàn)拒絕服務(wù)的情況。
因此,可以拆分獲取憑證的操作,通過獨(dú)立網(wǎng)關(guān)渠道前置服務(wù),將獲取的方式異步化,從前置網(wǎng)關(guān)獲取內(nèi)部憑證,然后由前置網(wǎng)關(guān)去異步調(diào)用第三方。
異步并行化
資金核算異步化
熱點(diǎn)賬戶賬務(wù)單獨(dú)處理
記賬事務(wù)切分
Part four 生產(chǎn)實(shí)踐
性能壓測(cè)
構(gòu)建壓測(cè)模型,模擬現(xiàn)實(shí)真實(shí)場(chǎng)景;壓測(cè)數(shù)據(jù)進(jìn)影子庫(kù),正常業(yè)務(wù)無侵入;單機(jī)性能和集權(quán)鏈路都不能忽視;識(shí)別系統(tǒng)穩(wěn)定性和容量配比。。。
穩(wěn)定性治理
核心鏈路分離
服務(wù)依賴降級(jí)
審核編輯 :李倩
-
網(wǎng)關(guān)
+關(guān)注
關(guān)注
9文章
4939瀏覽量
52122 -
架構(gòu)
+關(guān)注
關(guān)注
1文章
524瀏覽量
25761 -
支付系統(tǒng)
+關(guān)注
關(guān)注
0文章
79瀏覽量
10354
原文標(biāo)題:通用支付系統(tǒng)設(shè)計(jì)
文章出處:【微信號(hào):芋道源碼,微信公眾號(hào):芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
華為支付接入規(guī)范
華為支付-免密支付接入支付并簽約場(chǎng)景

NFC圓幣卡又稱錢幣卡,廣泛應(yīng)用于支付系統(tǒng)、門禁管理、交通票務(wù)和會(huì)員識(shí)別等領(lǐng)域
NFC支付
dtu公交一卡通支付的聯(lián)網(wǎng)接入
刷臉支付系統(tǒng)搭建跟刷臉支付代理加盟的功能優(yōu)勢(shì)
區(qū)塊鏈支付系統(tǒng)開發(fā),跑分系統(tǒng)APP定制
我們懂你需要 暢優(yōu)免簽支付系統(tǒng) 聚合支付系統(tǒng)
通用可組合的公平電子支付協(xié)議
移動(dòng)微支付系統(tǒng)研究
基于B/S的醫(yī)療保險(xiǎn)支付系統(tǒng)

評(píng)論