<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          支付系統(tǒng)就該這么設(shè)計(萬能通用),穩(wěn)的一批!

          共 1704字,需瀏覽 4分鐘

           ·

          2022-11-22 10:48

          點(diǎn)擊關(guān)注公眾號,Java干貨及時送達(dá)??

          來源:www.cnblogs.com/wintersun/

          • Part one 支付系統(tǒng)總覽
            • 核心系統(tǒng)交互
            • 業(yè)務(wù)圖譜
          • Part two 核心系統(tǒng)解析
            • 交易核心
            • 支付核心
            • 渠道網(wǎng)關(guān)
            • 資金核算
          • Part three 服務(wù)治理
            • 平臺統(tǒng)一上下文
            • 數(shù)據(jù)一致性治理
            • DB拆分
            • 異步化
          • Part four 生產(chǎn)實踐
            • 性能壓測
            • 穩(wěn)定性治理
            • 核心鏈路分離
            • 服務(wù)依賴降級

          支付永遠(yuǎn)是一個公司的核心領(lǐng)域,因為這是一個有交易屬性公司的命脈。那么,支付系統(tǒng)到底長什么樣,又是怎么運(yùn)行交互的呢?

          拋開帶有支付牌照的金融公司的支付架構(gòu),下述鏈路和系統(tǒng)組成基本上符合絕大多數(shù)支付場景。

          其實整體可以看成是交易核心+支付核心 兩個大系統(tǒng)。交易系統(tǒng)關(guān)聯(lián)了業(yè)務(wù)場景和底層支付,而支付系統(tǒng)完成了調(diào)用支付工具到對賬清算等一系列相關(guān)操作。下面我們就來一起看下 各個系統(tǒng)的核心組成和交互。

          Part one 支付系統(tǒng)總覽

          核心系統(tǒng)交互

          圖片

          業(yè)務(wù)圖譜

          圖片

          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)。同時,還要負(fù)責(zé)集成多種支付工具,對支付指令進(jìn)行編排等等。

          支付核心總覽

          圖片

          支付行為編排

          其目的,是實現(xiàn) 插件式開發(fā)支付規(guī)則可配置的 靈活開發(fā)方式。

          圖片

          異常處理

          異常處理包括了 重復(fù)支付、部分支付、金額不一致、其他異常等異常場景。

          圖片

          渠道網(wǎng)關(guān)

          圖片

          資金核算

          圖片

          Part three 服務(wù)治理

          平臺統(tǒng)一上下文

          通過確定系統(tǒng)邊界、業(yè)務(wù)建模拆分之后,整個支付平臺被拆分幾十個服務(wù),而如何保障在服務(wù)間流轉(zhuǎn)業(yè)務(wù)信息不被丟失,是我們需要考慮的問題。平臺統(tǒng)一上下文的要素信息(唯一業(yè)務(wù)標(biāo)識碼),在整個支付平臺鏈路中全程傳遞,被用來解決這個問題。

          圖片

          數(shù)據(jù)一致性治理

          大型的支付公司,內(nèi)部都有非常嚴(yán)格和完備的數(shù)據(jù)一致性方案,比如采用業(yè)務(wù)侵入性非常大的分布式事務(wù)等,以犧牲開發(fā)效率來提升數(shù)據(jù)的穩(wěn)定,是非常有必要的。而業(yè)務(wù)公司,如果不采用分布式事務(wù)又有哪些應(yīng)對策略呢?

          CAS校驗

          圖片

          冪等 & 異常補(bǔ)償

          圖片

          對賬

          圖片

          準(zhǔn)實時對賬

          圖片

          DB拆分

          圖片

          異步化

          支付是整個交易鏈路的核心環(huán)節(jié),那么,怎么兼顧支付系統(tǒng)的穩(wěn)定性和執(zhí)行效率呢?是異步化。

          消息異步化

          圖片

          外部支付調(diào)用異步化

          圖片

          在外部支付中,經(jīng)常需要服務(wù)方與第三方支付交互,獲取預(yù)支付憑證,如上圖所示。

          這種同步調(diào)用的情況下,由于需要跨外部網(wǎng)絡(luò),響應(yīng)的 RT 會非常長,可能會出現(xiàn)跨秒的情況。由于是同步調(diào)用,會阻塞整個支付鏈路。一旦 RT 很長且 QPS 比較大的情況下,服務(wù)會整體 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)實踐

          性能壓測

          構(gòu)建壓測模型,模擬現(xiàn)實真實場景;壓測數(shù)據(jù)進(jìn)影子庫,正常業(yè)務(wù)無侵入;單機(jī)性能和集權(quán)鏈路都不能忽視;識別系統(tǒng)穩(wěn)定性和容量配比。。。

          圖片

          穩(wěn)定性治理

          圖片

          核心鏈路分離

          圖片

          服務(wù)依賴降級

          圖片

          1. 工作中如何體現(xiàn)一個人的技術(shù)深度?

          2. SpringBoot + Flyway,自動化實現(xiàn)數(shù)據(jù)庫版本控制

          3. Kubernetes 缺少的多租戶功能,你可以通過這些方式實現(xiàn)

          4. 老板讓我牽頭搞ELK,我該如何確定ES的集群規(guī)模?

          最近面試BAT,整理一份面試資料Java面試BATJ通關(guān)手冊,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫、數(shù)據(jù)結(jié)構(gòu)等等。

          獲取方式:點(diǎn)“在看”,關(guān)注公眾號并回復(fù) Java 領(lǐng)取,更多內(nèi)容陸續(xù)奉上。

          PS:因公眾號平臺更改了推送規(guī)則,如果不想錯過內(nèi)容,記得讀完點(diǎn)一下在看,加個星標(biāo),這樣每次新文章推送才會第一時間出現(xiàn)在你的訂閱列表里。

          點(diǎn)“在看”支持小哈呀,謝謝啦

          瀏覽 42
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  吴梦梦精品一区二区三区观看 | 79AV成人无码 | 国产精彩视频在线 | 免费一级婬片A片女人不叫 | 免费观看一区二区三区四区 |