国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

訂單不丟、庫(kù)存不亂!揭秘電商 Checkout 的分布式事務(wù)與 Saga 終極實(shí)戰(zhàn)

開(kāi)發(fā) 前端
? 為了實(shí)現(xiàn)高可用、可擴(kuò)展、可恢復(fù)的結(jié)算流程,系統(tǒng)必須運(yùn)用 分布式事務(wù)、Saga 模式、事件驅(qū)動(dòng)架構(gòu)以及防重冪等策略等關(guān)鍵技術(shù)。

在現(xiàn)代電商系統(tǒng)中,“結(jié)算(Checkout)”是訂單能否順利形成的關(guān)鍵環(huán)節(jié),它不僅要確保庫(kù)存與支付的一致性,還要避免在高并發(fā)環(huán)境下出現(xiàn)超賣、重復(fù)支付、狀態(tài)不一致等問(wèn)題。 為了實(shí)現(xiàn)高可用、可擴(kuò)展、可恢復(fù)的結(jié)算流程,系統(tǒng)必須運(yùn)用 分布式事務(wù)、Saga 模式、事件驅(qū)動(dòng)架構(gòu)以及防重冪等策略等關(guān)鍵技術(shù)。

本文通過(guò)一套 實(shí)戰(zhàn)級(jí) Checkout 系統(tǒng),深入解析其架構(gòu)設(shè)計(jì)、核心組件、關(guān)鍵流程與代碼示例。

架構(gòu)設(shè)計(jì)總覽

一個(gè)標(biāo)準(zhǔn)的 Checkout 系統(tǒng)由如下服務(wù)構(gòu)成:

  • Cart Service(購(gòu)物車服務(wù))
  • Order Service(訂單服務(wù))
  • Inventory Service(庫(kù)存服務(wù))
  • Payment Service(支付服務(wù))
  • Notification Service(通知服務(wù))
  • Saga Orchestrator(業(yè)務(wù)編排器)或事件驅(qū)動(dòng)協(xié)調(diào)器

整體架構(gòu)為典型的 微服務(wù) + 事件驅(qū)動(dòng)(Event-Driven)+ Saga 補(bǔ)償事務(wù)

用戶 → Checkout API → Saga Orchestrator
    → Order Service
    → Inventory Service
    → Payment Service
    → Notification Service

每一步都依賴事件協(xié)調(diào),Saga 可在失敗時(shí)回滾(補(bǔ)償)。

為什么分布式事務(wù)無(wú)法使用傳統(tǒng)的 2PC?

傳統(tǒng) 2PC(XA)存在的問(wèn)題:

  • 性能低
  • 全局鎖導(dǎo)致資源阻塞
  • 單點(diǎn)失敗風(fēng)險(xiǎn)大
  • 不適合高并發(fā)的互聯(lián)網(wǎng)系統(tǒng)

因此電商結(jié)算普遍采用:

  • Saga 模式(補(bǔ)償事務(wù))
  • 事件驅(qū)動(dòng)最終一致性(Eventual Consistency)
  • Outbox Pattern(可靠事件投遞)
  • 冪等機(jī)制(防止訂單重復(fù)操作)

Saga 模式的兩種實(shí)現(xiàn)方式

方式 A:編排式(Orchestration — 中央控制)

由一個(gè) Saga Orchestrator 來(lái)控制流程:

 清晰、可觀察  適用于流程復(fù)雜的系統(tǒng)  Orchestrator 本身需高可用

流程如下:

1. 創(chuàng)建訂單(Pending)
2. 扣減庫(kù)存
3. 預(yù)授權(quán)支付
4. 完成訂單(Completed)
5. 發(fā)送通知
失敗:依次回滾(補(bǔ)償操作)

方式 B:舞蹈式(Choreography — 服務(wù)間互相訂閱事件)

沒(méi)有中央控制器,每個(gè)服務(wù)監(jiān)聽(tīng)前一步事件并執(zhí)行下一步。

 更加松耦合  流程復(fù)雜時(shí)可讀性差

Checkout 核心 Saga 流程

以下為 Orchestrator 的偽代碼流程(原文代碼保留但采用中文注釋):

async function checkoutSaga(orderRequest) {
  const order = await orderService.createOrder(orderRequest); 
  try {
    // 扣庫(kù)存
    await inventoryService.reserve(order.id, order.items);


    // 支付預(yù)授權(quán)
    await paymentService.authorize(order.id, order.totalPrice);


    // 更新訂單狀態(tài)為成功
    await orderService.confirm(order.id);


    // 發(fā)通知
    await notificationService.sendOrderConfirmation(order.id);
  } catch (err) {
    // Saga 補(bǔ)償:支持部分步驟回滾
    await orderService.cancel(order.id);      
    await inventoryService.release(order.id); // 釋放庫(kù)存
    await paymentService.refund(order.id);    // 支付回滾
    throw err;
  }
  return order;
}

關(guān)鍵服務(wù)代碼示例

Order Service:創(chuàng)建訂單、更新?tīng)顟B(tài)

@RestController
@RequestMapping("/orders")
public class OrderController {


    @Autowired
    private OrderService orderService;


    // 創(chuàng)建訂單(Pending)
    @PostMapping
    public Order createOrder(@RequestBody OrderRequest request) {
        return orderService.createOrder(request);
    }


    // 訂單確認(rèn)
    @PostMapping("/{id}/confirm")
    public void confirm(@PathVariable String id) {
        orderService.updateStatus(id, "CONFIRMED");
    }


    // 訂單取消(Saga 補(bǔ)償)
    @PostMapping("/{id}/cancel")
    public void cancel(@PathVariable String id) {
        orderService.updateStatus(id, "CANCELLED");
    }
}

Inventory Service:扣減與回滾庫(kù)存

@Service
public class InventoryService {


    // 扣減庫(kù)存
    public void reserve(String orderId, List<Item> items) {
        // 庫(kù)存檢查 + 鎖定
    }


    // 回滾(釋放庫(kù)存)
    public void release(String orderId) {
        // 恢復(fù)庫(kù)存
    }
}

Payment Service:支付預(yù)授權(quán) + 回滾

@Service
public class PaymentService {


    // 預(yù)授權(quán)支付
    public void authorize(String orderId, BigDecimal amount) { }


    // 支付回滾
    public void refund(String orderId) { }
}

Outbox Pattern:確保事件不丟失

為避免:

  • 訂單狀態(tài)成功
  • 事件沒(méi)發(fā)出去 → 庫(kù)存和支付無(wú)法同步

使用 Outbox 表寫(xiě)入 + 異步投遞

orders
order_outbox

示例:

INSERT INTO order_outbox(event_type, payload, status)
VALUES ('ORDER_CONFIRMED', '{...}', 'PENDING');

后臺(tái)輪詢器安全投遞消息。

冪等性設(shè)計(jì)(關(guān)鍵!)

結(jié)算請(qǐng)求可能會(huì):

  • 用戶重復(fù)點(diǎn)擊
  • 網(wǎng)絡(luò)抖動(dòng)重試
  • MQ 重試
  • 支付回調(diào)重復(fù)通知

必須保證:

 不產(chǎn)生重復(fù)訂單  不重復(fù)扣庫(kù)存  不重復(fù)扣款

一般方案:

場(chǎng)景

冪等Key

訂單創(chuàng)建

userId + cartHash

庫(kù)存扣減

orderId

支付回調(diào)

paymentId

MQ 消費(fèi)

messageId

示例:避免重復(fù)付款

INSERT INTO payment_log(id, order_id) 
VALUES(:payId, :orderId)
ON CONFLICT (id) DO NOTHING;

高可用策略

  • 服務(wù)無(wú)狀態(tài) + 水平擴(kuò)容
  • 讀寫(xiě)分離數(shù)據(jù)庫(kù)
  • 多副本消息系統(tǒng)(Kafka/RabbitMQ)
  • 分布式鎖確保庫(kù)存準(zhǔn)確
  • 支付回調(diào)防重處理

整體 Checkout 流程

[User Checkout Request]
       |
       v
[Order Service: Create Pending Order]
       |
       v
[Saga Orchestrator]
       |
  ----------------------------
  | Reserve Inventory        |
  | Payment Authorization    |
  | Confirm Order            |
  | Send Notifications       |
  ----------------------------
       |
       v
 [Success or Compensation]

結(jié)語(yǔ):打造一個(gè)真正可靠的結(jié)算系統(tǒng)

一個(gè)成熟的電商結(jié)算系統(tǒng)必須:

  • 使用 Saga 模式保證最終一致性
  • 采用事件驅(qū)動(dòng)架構(gòu)實(shí)現(xiàn)高擴(kuò)展性
  • 使用 Outbox Pattern 保證消息可靠投遞
  • 所有關(guān)鍵鏈路實(shí)現(xiàn)冪等處理
  • 通過(guò)補(bǔ)償機(jī)制處理失敗場(chǎng)景
  • 提供完善的監(jiān)控、日志與追蹤能力

這樣才能確保在大促、秒殺、并發(fā)峰值下依然穩(wěn)定運(yùn)行。

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

2025-08-27 09:11:48

2025-07-09 01:22:00

Saga模式系統(tǒng)

2022-06-21 08:27:22

Seata分布式事務(wù)

2021-09-07 09:26:13

Python 開(kāi)發(fā)編程語(yǔ)言

2024-01-26 13:17:00

rollbackMQ訂單系統(tǒng)

2022-06-27 08:21:05

Seata分布式事務(wù)微服務(wù)

2017-07-26 15:08:05

大數(shù)據(jù)分布式事務(wù)

2024-01-05 07:28:50

分布式事務(wù)框架

2025-06-27 02:00:00

Spring高并發(fā)庫(kù)存

2021-11-05 07:18:15

分布式事務(wù)業(yè)務(wù)

2024-03-12 08:35:47

分布式事務(wù)中間件SeataSaga

2019-10-10 09:16:34

Zookeeper架構(gòu)分布式

2021-03-18 09:18:39

分布式事務(wù)Saga

2021-04-27 10:22:04

數(shù)倉(cāng)分布式事務(wù)

2021-04-23 08:15:51

Seata XA AT

2009-06-19 15:28:31

JDBC分布式事務(wù)

2009-09-18 15:10:13

分布式事務(wù)LINQ TO SQL

2021-09-29 09:07:37

分布式架構(gòu)系統(tǒng)
點(diǎn)贊
收藏

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

caoporm免费视频在线| 成人免费短视频| 国产精品亚洲综合一区在线观看| 亚洲天堂精品在线| 黄污网站在线观看| 成人动漫中文字幕| 精品欧美日韩| 久久国产精品成人免费观看的软件| 原创国产精品91| 欧美大黄免费观看| 国产成人欧美在线观看| 成人精品三级| 欧美日韩国产天堂| 新的色悠悠久久久| 亚洲国产精品精华液2区45| 神马影院一区二区三区| 68国产成人综合久久精品| 欧美高清在线观看| 激情亚洲影院在线观看| 884aa四虎影成人精品一区| 欧美激情图区| 亚洲色图一区二区| 免费在线观看毛片网站| 国产在线播放一区三区四| 国产在线精品一区| 91精品国产视频| 国产精品视频在线播放| 外国成人在线视频| 久久免费视频在线| 亚洲三区欧美一区国产二区| 亚洲国产成人精品久久久国产成人一区| 你懂的在线网址| 色婷婷视频在线观看| 国产精品 日产精品 欧美精品| 91精品视频在线看| 三级在线播放| 亚洲欧洲精品天堂一级| 天天影视综合色| 国产99久久久国产精品| 8x8x华人在线| 国产精品一区二区免费不卡| 亚洲欧美日韩不卡| 激情av综合网| 欧美性受黑人性爽| 国产盗摄精品一区二区三区在线| 亚洲激情一区二区| 免费精品99久久国产综合精品| 国产日韩一区二区三区| 黄色亚洲大片免费在线观看| 精品国产一区二区三区四区vr| 亚洲手机视频| 日本一区二区在线| 麻豆国产精品777777在线| 一本一道久久久a久久久精品91| 日韩精品五月天| 国产1区2区3区中文字幕| av资源网一区| 日本高清不卡中文字幕| 亚洲国产综合在线| 岛国在线大片| 亚洲国产精品嫩草影院久久| av成人免费看| 777精品视频| 午夜天堂精品久久久久| 天堂√在线观看一区二区| 国产主播一区二区| 天天爽天天爽夜夜爽| 亚洲成人免费在线观看| 日本韩国在线视频爽| 亚洲第一视频网站| 精品国产伦一区二区三区观看说明| 777午夜精品福利在线观看| 国内精品亚洲| 日韩视频在线观看视频| 国产精品视频第一区| 青草久久伊人| 亚洲视频999| 欧美日韩伦理在线免费| 日韩三级电影网站| 国产三级一区二区三区| 天堂网www中文在线| 日韩精品极品视频免费观看| 久久久久观看| 免费毛片一区二区三区久久久| 成人精品国产一区二区4080 | 亚洲精品国产嫩草在线观看| 久久久久久亚洲精品中文字幕| 天天射综合网视频| 在线播放 亚洲| 亚洲欧美日韩国产综合| 日韩在线免费电影| 久久最新资源网| 在线观看国产精品入口| www插插插无码免费视频网站| 亚洲精品日日夜夜| 91制片在线观看| 国产精品国内视频| 国产一区二区免费视频| 亚洲社区在线| 亚洲精品一区在线观看香蕉| 国内黄色精品| 青少年xxxxx性开放hg| 亚洲一区二区精品久久av| 国产精品论坛| 亚洲一区二区久久久久久久| 岛国精品在线观看| 国产在线免费观看| 久久久久久91香蕉国产| 日韩不卡手机在线v区| 国产污污在线观看| 日韩中文字幕精品| 亚洲综合电影一区二区三区| 国产免播放器视频| 夜夜嗨av一区二区三区免费区| 久久精品国内一区二区三区水蜜桃 | 久久高清国产| 成人国产视频在线| 亚洲人av在线影院| 亚洲电影成人| 女人裸体免费网站| 久久精品一区中文字幕| 天堂蜜桃91精品| 青青草超碰在线| 68精品久久久久久欧美| 成人国产亚洲欧美成人综合网| 日本韩国在线视频爽| 国产精品久在线观看| 久久久精品黄色| 九九九伊在线综合永久| 色播亚洲婷婷| 666欧美在线视频| 欧美精品aa| 中文日本高清免费| 91国语精品自产拍在线观看性色| 国产在线麻豆精品观看| 在线视频自拍| 国产精品久久久久久久久久尿| 久久久久久久综合| 国产精品原创视频| 在线免费观看一区二区三区| 欧美一区二区在线看| 国产精品s色| 亚洲欧洲成人| 国产精品视频永久免费播放| 中文字幕亚洲视频| jizz性欧美23| 天堂社区在线视频| 欧美猛少妇色xxxxx| 久久婷婷综合激情| 电影一区二区三区久久免费观看| 黄色特一级视频| 亚洲欧美另类人妖| 国产福利一区在线| 四虎影视4hu4虎成人| 成人在线国产视频| 神马国产精品影院av| av不卡一区二区三区| 欧美三级电影网址| 欧洲av无码放荡人妇网站| 久久夜精品香蕉| 久久九九久久九九| 欧美天堂影院| 黄网站app在线观看下载视频大全官网 | 人人狠狠综合久久亚洲婷| 国模大尺度私拍在线视频| 国产成人精品电影久久久| 亚洲一区二区偷拍精品| 色喇叭免费久久综合| 亚洲福利二区| 精品国产一区二区三区四区vr| 日韩三级精品电影久久久| 捆绑调教一区二区三区| 校园春色亚洲色图| 中文字幕乱码人妻综合二区三区| 欧美激情一二区| 性欧美疯狂xxxxbbbb| 国产精品porn| 欧美韩日亚洲| 欧美成人三级在线视频| 欧美激情视频一区| 玉米视频成人免费看| 99久久婷婷国产综合精品电影√| 国产一区二区影视| 欧美资源一区| www.亚洲成人| 亚洲影院久久精品| 国产精品日韩| jvid一区二区三区| 成人禁在线观看网站| 国产精品午夜国产小视频| 欧美日韩国产123区| 国产一区二区三区不卡在线观看| 国产精品亚洲综合在线观看| 色av一区二区三区| 久久爱av电影| 久久视频免费观看| 一本大道久久a久久综合婷婷| 美日韩一区二区| av成人资源| 麻豆网站在线观看|