偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

高并發(fā)場(chǎng)景下,服務(wù)端如何避免訂單重復(fù)支付

開(kāi)發(fā) 架構(gòu)
支付訂單增加一個(gè)中間狀態(tài)“支付中”,當(dāng)同一個(gè)訂單去支付的時(shí)候,先檢查有沒(méi)有狀態(tài)為“支付中”的支付流水,當(dāng)然支付(prepay)的時(shí)候要加個(gè)鎖。支付完成以后更新支付流水狀態(tài)的時(shí)候再將其改成“支付成功”狀態(tài)。


概述

圖片圖片

如圖是一個(gè)簡(jiǎn)化的下單流程,首先是提交訂單,然后是支付。

支付的話(huà),一般是走支付網(wǎng)關(guān)(支付中心),然后支付中心與第三方支付渠道(微信、支付寶、銀聯(lián))交互。

支付成功以后,異步通知支付中心,支付中心更新自身支付訂單狀態(tài),再通知業(yè)務(wù)應(yīng)用,各業(yè)務(wù)再更新各自訂單狀態(tài)。

這個(gè)過(guò)程中經(jīng)??赡苡龅降膯?wèn)題是掉單,無(wú)論是超時(shí)未收到回調(diào)通知也好,還是程序自身報(bào)錯(cuò)也好。

總之由于各種各樣的原因,沒(méi)有如期收到通知并正確的處理后續(xù)邏輯等等,都會(huì)造成用戶(hù)支付成功了,但是服務(wù)端這邊訂單狀態(tài)沒(méi)更新。

這個(gè)時(shí)候有可能產(chǎn)生投訴,或者用戶(hù)重復(fù)支付。

由于③⑤造成的掉單稱(chēng)之為外部掉單,由④⑥造成的掉單我們稱(chēng)之為內(nèi)部掉單

為了防止掉單,這里可以這樣處理

  1. 支付訂單增加一個(gè)中間狀態(tài)“支付中”,當(dāng)同一個(gè)訂單去支付的時(shí)候,先檢查有沒(méi)有狀態(tài)為“支付中”的支付流水,當(dāng)然支付(prepay)的時(shí)候要加個(gè)鎖。支付完成以后更新支付流水狀態(tài)的時(shí)候再將其改成“支付成功”狀態(tài)。
  2. 支付中心這邊要自己定義一個(gè)超時(shí)時(shí)間(比如:30秒),在此時(shí)間范圍內(nèi)如果沒(méi)有收到支付成功回調(diào),則應(yīng)調(diào)用接口主動(dòng)查詢(xún)支付結(jié)果,比如10s、20s、30s查一次,如果在最大查詢(xún)次數(shù)內(nèi)沒(méi)有查到結(jié)果,應(yīng)做異常處理
  3. 支付中心收到支付結(jié)果以后,將結(jié)果同步給業(yè)務(wù)系統(tǒng),可以發(fā)MQ,也可以直接調(diào)用,直接調(diào)用的話(huà)要加重試(比如:SpringBoot Retry)
  4. 無(wú)論是支付中心,還是業(yè)務(wù)應(yīng)用,在接收支付結(jié)果通知時(shí)都要考慮接口冪等性,消息只處理一次,其余的忽略
  5. 業(yè)務(wù)應(yīng)用也應(yīng)做超時(shí)主動(dòng)查詢(xún)支付結(jié)果

對(duì)于上面說(shuō)的超時(shí)主動(dòng)查詢(xún)可以在發(fā)起支付的時(shí)候?qū)⑦@些支付訂單放到一張表中,用定時(shí)任務(wù)去掃

為了防止訂單重復(fù)提交,可以這樣處理

1、創(chuàng)建訂單的時(shí)候,用訂單信息計(jì)算一個(gè)哈希值,判斷redis中是否有key,有則不允許重復(fù)提交,沒(méi)有則生成一個(gè)新key,放到redis中設(shè)置個(gè)過(guò)期時(shí)間,然后創(chuàng)建訂單。

其實(shí)就是在一段時(shí)間內(nèi)不可重復(fù)相同的操作


附上微信支付最佳實(shí)踐

圖片圖片


責(zé)任編輯:武曉燕 來(lái)源: 一安未來(lái)
相關(guān)推薦

2021-01-13 05:27:02

服務(wù)器性能高并發(fā)

2025-02-28 00:03:22

高并發(fā)TPS系統(tǒng)

2025-02-26 03:00:00

2020-02-10 19:16:52

服務(wù)端高并發(fā)架構(gòu)

2019-09-25 09:01:53

高并發(fā)架構(gòu)分布式

2019-12-17 11:18:37

高并發(fā)分布式架構(gòu)

2025-06-05 01:22:00

SpringGateway高并發(fā)

2025-05-26 02:11:00

2019-06-14 09:33:58

淘寶架構(gòu)服務(wù)端

2020-09-03 06:33:35

高并發(fā)場(chǎng)景分布式鎖

2025-03-10 06:00:00

2025-02-14 03:00:00

2025-07-09 04:00:00

Kafka億級(jí)流量高并發(fā)

2021-07-28 13:28:43

高并發(fā)RPC服務(wù)端

2020-06-15 08:25:35

Linux 系統(tǒng) 數(shù)據(jù)

2020-06-15 08:13:42

Linux服務(wù)端并發(fā)數(shù)

2025-09-22 08:26:37

2025-09-18 08:53:20

2020-10-15 06:26:24

高并發(fā)場(chǎng)景冰河

2024-09-29 00:00:00

高并發(fā)交易所宕機(jī)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)