Spring Boot 分布式事務常見問題:Seata、XA 與本地消息表對比

一、前言

在單體應用中,事務一般由關系型數據庫本身來保證,通過 ACID 特性實現數據一致性。但隨著微服務架構的普及,應用被拆分為多個獨立服務,數據可能分散在不同數據庫、不同存儲引擎中,傳統的單機事務無法再覆蓋。

這就引出了 分布式事務 的問題:如何在多服務、多數據庫場景下,仍然保證數據一致性?

本文將結合 Spring Boot 實際開發,對常見的幾種分布式事務方案進行解析:

  • XA 方案(兩階段提交,強一致性)

  • Seata(柔性事務,常用于阿里系微服務)

  • 本地消息表 + 最終一致性(高可用場景的常見落地方案)

同時會總結它們的 優缺點、常見坑點與適用場景

二、分布式事務常見場景

在 Spring Boot 開發中,以下場景經常涉及分布式事務:

  1. 訂單系統:創建訂單 → 扣減庫存 → 扣減余額

  2. 支付系統:支付成功 → 修改訂單狀態 → 發送消息通知 → 更新積分

  3. 營銷系統:用戶下單 → 觸發優惠券核銷 → 更新活動數據

這些流程往往跨越多個服務和數據庫,如果其中一步失敗,就可能導致數據不一致,例如:

  • 庫存已扣減,但訂單未生成

  • 訂單已支付,但未發貨

  • 優惠券已核銷,但活動未更新

因此需要合理的分布式事務方案來保證一致性。

三、XA 方案(兩階段提交)

1. 原理

XA 是 分布式事務標準協議,基于兩階段提交(2PC,Two Phase Commit):

  • 階段一:事務協調者向所有數據庫發送 prepare,各數據庫執行但不提交,返回可提交狀態

  • 階段二:如果所有數據庫都返回成功,則發送 commit,否則發送 rollback

2. 在 Spring Boot 中的實現

常見實現方式是 Atomikos、Narayana 等第三方事務管理器,也可以結合 JTA 來管理。

示例配置(Atomikos):

spring:jta:enabled:?trueatomikos:properties:service:?com.atomikos.icatch.standalone.UserTransactionServiceFactory

3. 優缺點

? 優點

  • 強一致性保證

  • 對開發透明,業務代碼幾乎不用改

? 缺點

  • 性能差:兩階段提交會增加鎖時間,導致吞吐量下降

  • 擴展性差:跨多數據源時容易成為瓶頸

  • 單點風險:協調者掛掉可能導致事務懸掛

4. 適用場景

適合金融級場景(如銀行轉賬)——必須保證強一致性,但對性能要求相對次要。

四、Seata(柔性事務)

1. 原理

Seata 是阿里開源的分布式事務解決方案,支持 AT 模式、TCC 模式、Saga 模式

  • AT 模式:自動代理數據源,類似本地事務 + Undo Log 回滾,開發成本低

  • TCC 模式:需要業務實現 Try/Confirm/Cancel 三個接口,粒度更細,性能更高

  • Saga 模式:長事務補償,適合跨服務調用鏈較長的業務

2. 在 Spring Boot 中集成

依賴:

<dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId><version>1.7.1</version>
</dependency>

配置:

seata:enabled:?trueapplication-id:?order-servicetx-service-group:?my_tx_groupservice:vgroup-mapping:my_tx_group:?default

使用:

@GlobalTransactional
public?void?createOrder(Order?order)?{orderDao.save(order);inventoryService.deduct(order.getId());
}

3. 優缺點

? 優點

  • 透明代理數據庫,AT 模式對開發友好

  • 多種事務模式可選,適配不同業務場景

  • 社區活躍,生態完善

? 缺點

  • 需要額外部署 Seata Server

  • Undo Log 占用空間,長事務性能下降

  • 某些復雜 SQL(批量更新/存儲過程)支持有限

4. 適用場景

電商下單、庫存扣減等典型 高并發場景,對性能要求較高,能接受短時間的不一致。

五、本地消息表(最終一致性)

1. 原理

核心思想是 業務數據 + 消息發送放在同一個本地事務中,通過消息隊列來保證最終一致性:

  1. 業務服務在本地事務中寫入業務表 + 消息表

  2. 定時任務掃描消息表,發送消息到 MQ

  3. 消費者消費 MQ 消息,執行后續邏輯

  4. 成功后更新消息表狀態

2. 在 Spring Boot 中實現

數據庫表:

CREATE?TABLE?t_outbox_message?(id?BIGINT?PRIMARY?KEY?AUTO_INCREMENT,content?TEXT?NOT?NULL,status?TINYINT?DEFAULT?0,create_time?TIMESTAMP?DEFAULT?CURRENT_TIMESTAMP
);

業務代碼:

@Transactional
public?void?createOrder(Order?order)?{orderDao.insert(order);outboxDao.insert(new?OutboxMessage(order));
}

定時任務發送消息:

@Scheduled(fixedRate?=?5000)
public?void?sendPendingMessages()?{List<OutboxMessage>?messages?=?outboxDao.findPending();for?(OutboxMessage?msg?:?messages)?{mqProducer.send(msg);outboxDao.markSent(msg.getId());}
}

3. 優缺點

? 優點

  • 無需額外中間件,簡單可靠

  • 高可用,適合最終一致性場景

? 缺點

  • 開發成本較高,需要寫消息表邏輯

  • 延遲一致性(可能有幾秒的延遲)

  • 消息補償、冪等處理邏輯復雜

4. 適用場景

訂單系統、積分系統、日志收集等對 最終一致性容忍度高 的業務。

六、三種方案對比

方案一致性性能開發成本典型場景
XA強一致銀行轉賬、核心金融業務
Seata最終一致(AT/TCC)中高電商下單、庫存、支付
本地消息表最終一致營銷、積分、日志系統

七、常見坑點總結

  1. XA 事務懸掛:協調者掛掉可能導致數據庫鎖未釋放

  2. Seata Undo Log 膨脹:要定期清理,否則影響性能

  3. 本地消息表補償失敗:要考慮消息冪等、死信隊列機制

八、結語

分布式事務沒有“銀彈”,不同方案適合的場景完全不同:

  • 金融強一致 → 優先考慮 XA

  • 電商高并發 → 選擇 Seata AT/TCC

  • 最終一致性即可 → 本地消息表是首選

在 Spring Boot 實踐中,建議結合 業務場景 + 性能要求 + 容錯能力 來選擇合適的方案,而不是盲目套用。


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/98844.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/98844.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/98844.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Transporter App 使用全流程詳解:iOS 應用 ipa 上傳工具、 uni-app 應用發布指南

在 iOS 應用開發與發布過程中&#xff0c;Transporter App 是蘋果官方提供的一款上傳工具&#xff0c;專門用于將 ipa 文件 或 應用資源 上傳到 App Store Connect。 與 Xcode 上傳 相比&#xff0c;Transporter 更加穩定&#xff0c;尤其適合大文件上傳&#xff0c;因此在 iOS…

計算機畢業設計 基于Hadoop的B站數據分析可視化系統的設計與實現 Python 大數據畢業設計 Hadoop畢業設計選題【附源碼+文檔報告+安裝調試】

博主介紹&#xff1a;?從事軟件開發10年之余&#xff0c;專注于Java技術領域、Python、大數據、人工智能及數據挖掘、小程序項目開發和Android項目開發等。CSDN、掘金、華為云、InfoQ、阿里云等平臺優質作者? &#x1f345;文末獲取源碼聯系&#x1f345; &#x1f447;&…

使用自定義LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成

使用自定義LLM和Embedding模型部署Vanna&#xff1a;基于RAG的Text-to-SQL生成 說明&#xff1a; 首次發表日期&#xff1a;2024-07-12Vanna Github地址&#xff1a; https://github.com/vanna-ai/vannaVanna官方文檔&#xff1a; https://vanna.ai/ 部署Vanna時我們可以選擇使…

Linux多線程概念

背景知識內存管理OS進行內存管理不是以字節為單位的&#xff0c;而是以內存塊為單位的&#xff0c;默認大小為4kb&#xff1b;系統和磁盤文件進行IO交互的單位是4kb&#xff08;8個扇區&#xff09;&#xff1b;OS對內存管理實質上是對頁框進行管理。頁框&#xff08;Page Fram…

【Problem】動態規劃之跳躍游戲系列

一、跳躍游戲 55. 跳躍游戲 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/jump-game/description/?envTypeproblem-list-v2&envIddynamic-programming class Solution { public:bool canJump(vector<int>& nums) {// 狀態定義&#x…

射頻EVM

EVM&#xff08;Error Vector Magnitude&#xff0c;誤差矢量幅度&#xff09;是衡量無線通信系統中調制質量的重要指標&#xff0c;尤其用于評估信號的調制誤差和系統性能。它通常用來表示傳輸信號與理想信號之間的偏差&#xff0c;特別是在數字通信中。EVM的基本概念&#xf…

Java 更改 Word 文檔中文本顏色

在日常的自動化文檔處理中&#xff0c;我們經常會遇到需要對 Word 文檔內容進行編程修改的需求&#xff0c;其中一項常見且重要的操作就是更改文本的顏色。無論是為了突出重點、統一品牌風格&#xff0c;還是實現動態內容展示&#xff0c;精準地修改文本顏色都是一個核心痛點。…

STM32—SPI協議

文章目錄一、SPI 協議簡介二、硬件電路2.1.SPI的連接2.2.數據的移位2.3.時序基本單元2.3.1.起始條件和終止條件2.3.2.模式 02.3.3.模式 12.3.4.模式 22.3.5.模式 32.4.時序三、軟件實現四、W25Q644.1.簡介4.2.硬件電路4.3.框圖4.4.操作注意事項五、實驗一、SPI 協議簡介 SPI&a…

Qt中的QWebEngineView

第1章 本地目錄結構1.1 自己寫的兩個網頁(html)mermaid.html &#xff08;自己寫的網頁界面&#xff09;WebTest.html (自己寫的網頁界面)qwebchannel.js (Qt下載安裝之后&#xff0c;會在安裝目錄下有這個文件&#xff0c;需要將安裝目錄下的改文件拷貝…

Flutter 應用國際化 (i18n) 與本地化 (l10n) 完整指南

Flutter 國際化 (i18n) 完全指南&#xff1a;從入門到精通 在現代移動應用開發中&#xff0c;支持多語言是觸達全球用戶的基本要求。Flutter 提供了強大且靈活的國際化 (i18n) 和本地化 (l10n) 支持。本文將帶你從零開始&#xff0c;一步步深入掌握在 Flutter 中實現國際化的幾…

計算機視覺與深度學習 | 計算機視覺中線特征提取與匹配算法綜述

文章目錄 一、線特征提取算法原理 1.1 Hough變換及其優化 1.2 LSD算法 1.3 EDLines算法 二、核心數學公式 2.1 直線表示與誤差計算 2.2 LSD算法關鍵公式 三、線特征匹配算法 3.1 LBD描述符 3.2 匹配策略 四、代碼實現 4.1 LSD線段檢測(Python) 4.2 LBD特征匹配(C++) 五、算…

Transformer 模型:Attention is All You Need 的真正含義

2017 年&#xff0c;Google Brain 發布了一篇具有里程碑意義的論文——《Attention Is All You Need》&#xff0c;這篇論文不僅首次提出了 Transformer 模型&#xff0c;更重要的是&#xff0c;它宣稱“注意機制&#xff08;Attention Mechanism&#xff09;就足以構建強大的模…

數據庫約束表的設計

數據庫約束概念&#xff1a;數據庫約束是關系型數據庫的一個重要功能&#xff0c;主要是保證數據的完整性&#xff0c;也可理解為數據的正確性&#xff08;數據本身是否正確&#xff0c;關聯關系是否正確&#xff09;&#xff08;一般是用在指定列上&#xff09;常見的約束類型…

【案例分享】TeeChart 助力 Softdrill 提升油氣鉆井數據可視化能力

在鉆井與地質工程領域&#xff0c;數據可視化是核心環節。圖表不僅需要精確與高效&#xff0c;還需符合行業習慣并支持交互與定制。Softdrill 自 2012 年起在核心產品中集成了TeeChart 圖表庫&#xff0c;將復雜的井下數據轉化為直觀的工程圖表&#xff0c;極大提升了鉆井工程師…

【Flink】Flink Runtime 架構設計

Flink Runtime 架構設計 整體架構 ┌─────────────────────────────────────────────────────────────────┐ │ Flink Runtime │ ├─────────…

Git 命令教程

Git介紹 分布式版本控制系統。 Git命令 初始化/全局配置git init初始化一個Git倉庫&#xff08;會創建一個.git的目錄&#xff09;git config --global user.name “name”設置提交時的用戶名git config user.name查看設置的用戶名git config --global user.email “youemail.c…

git config --global user.name指令報錯時的解決方案

問題分析 %HOMEDRIVE%%HOMEPATH%/.gitconfig 是Windows環境變量的表示方式&#xff1a; %HOMEDRIVE% 通常是 C:%HOMEPATH% 通常是 \Users\你的用戶名完整路徑應該是&#xff1a;C:\Users\你的用戶名\.gitconfig 但這里環境變量沒有被正確解析&#xff0c;顯示的是字面意思。 …

websocket和socket io的區別

好的&#xff0c;這是一個更具體也更常見的問題。WebSocket 是一種協議&#xff0c;而 Socket.IO 是一個庫&#xff0c;它使用了 WebSocket 但提供了多得多的功能。 簡單比喻&#xff1a; WebSocket 就像是給你提供了一條高效的“快遞專線”&#xff08;雙向通信通道&#xff…

Nginx反向代理與負載均衡部署

Nginx反向代理與負載均衡部署實戰指南前言一、規劃部署負載均衡和反向代理二、部署Nginx負載均衡器2.1. 準備基礎環境2.2. 創建Nginx運行用戶2.3. 編譯安裝Nginx2.4. 配置Nginx系統服務2.5. 驗證Nginx安裝三、部署后端2臺Tomcat應用服務器3.1. 安裝JDK3.2. 部署Tomcat實例13.3.…

從源碼和設計模式深挖AQS(AbstractQueuedSynchronizer)

AQS 概念 AbstractQueuedSynchronizer&#xff08;AQS&#xff09; 是 Java 并發包 (java.util.concurrent.locks) 的核心基礎框架&#xff0c;它的實現關鍵是先進先出 (FIFO) 等待隊列和一個用volatile修飾的鎖狀態status。具體實現有 : ReentrantLock、Semaphore、CountDownL…