分布式事務解決方案:Seata原理詳解與實戰教程

一、為什么需要Seata?

在微服務架構中,跨服務的事務管理成為核心痛點:

  • 傳統事務失效:服務拆分導致無法使用本地事務
  • 數據不一致風險:網絡抖動、服務宕機等情況導致數據錯亂
  • 復雜場景處理難:涉及多個數據庫、消息隊列等異構存儲

Seata(Simple Extensible Autonomous Transaction Architecture) 是阿里開源的分布式事務解決方案,提供 AT模式、TCC模式、Saga模式 三種事務模型,支持高并發場景下的數據一致性。


二、核心概念與架構原理

2.1 核心角色

角色說明
TC (Transaction Coordinator)事務協調器,維護全局事務狀態(需獨立部署)
TM (Transaction Manager)事務管理器,定義事務邊界(@GlobalTransactional注解)
RM (Resource Manager)資源管理器,管理分支事務(連接數據庫等資源)

2.2 AT模式核心原理

執行流程

TM TC RM1 RM2 1. 開啟全局事務(XID) 生成XID 2. 執行分支事務(注冊分支) 上報分支狀態 3. 執行分支事務(注冊分支) 上報分支狀態 4. 提交/回滾全局事務 通知提交/回滾 通知提交/回滾 TM TC RM1 RM2

數據回滾機制

  1. 階段一:執行業務SQL,保存前置鏡像(before image)和后置鏡像(after image)
  2. 階段二
    • 提交:異步刪除快照數據
    • 回滾:用前置鏡像還原數據

三、環境搭建與配置(Spring Cloud Alibaba版)

3.1 組件版本

組件版本
Spring Boot2.6.11
Spring Cloud2021.0.4
Spring Cloud Alibaba2021.0.4.0
Seata Server1.7.0

3.2 Seata Server部署

# 下載并解壓
wget https://github.com/seata/seata/releases/download/v1.7.0/seata-server-1.7.0.zip
unzip seata-server-1.7.0.zip# 修改配置文件 conf/registry.conf
registry {type = "nacos"nacos {serverAddr = "localhost:8848"namespace = ""cluster = "default"}
}# 啟動服務端
sh bin/seata-server.sh -p 8091 -h 127.0.0.1

四、SpringBoot整合AT模式實戰

4.1 訂單服務配置

pom.xml

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId>
</dependency>

application.yml

spring:cloud:alibaba:seata:tx-service-group: my_tx_group # 事務組名稱seata:registry:type: nacosnacos:server-addr: localhost:8848service:vgroup-mapping:my_tx_group: default # 對應TC集群

4.2 業務代碼示例

訂單服務(扣減庫存)

@Service
public class OrderServiceImpl implements OrderService {@Autowiredprivate StorageFeignClient storageFeignClient;@GlobalTransactional // 開啟全局事務@Overridepublic void createOrder(OrderDTO orderDTO) {// 1. 本地事務:創建訂單orderMapper.create(orderDTO);// 2. 遠程調用:扣減庫存storageFeignClient.deduct(orderDTO.getProductId(), orderDTO.getCount());// 測試回滾// int i = 1/0; }
}

庫存服務(Feign接口)

@FeignClient(name = "storage-service")
public interface StorageFeignClient {@PostMapping("/storage/deduct")void deduct(@RequestParam("productId") Long productId, @RequestParam("count") Integer count);
}

五、TCC模式實戰(適合高并發場景)

5.1 TCC核心概念

  • Try:預留資源(如凍結庫存)
  • Confirm:確認操作(真正扣減)
  • Cancel:回滾操作(釋放資源)

5.2 庫存服務實現

TCC接口定義

public interface StorageTccService {@TwoPhaseBusinessAction(name = "deduct", commitMethod = "confirm", rollbackMethod = "cancel")boolean tryDeduct(@BusinessActionContextParameter(paramName = "productId") Long productId,@BusinessActionContextParameter(paramName = "count") Integer count);boolean confirm(BusinessActionContext context);boolean cancel(BusinessActionContext context);
}

Try階段實現

@Override
public boolean tryDeduct(Long productId, Integer count) {// 凍結庫存(非實際扣減)storageMapper.freezeStock(productId, count);return true;
}

Cancel階段實現

@Override
public boolean cancel(BusinessActionContext context) {Long productId = Long.valueOf(context.getActionContext("productId").toString());Integer count = Integer.valueOf(context.getActionContext("count").toString());// 釋放凍結庫存storageMapper.unfreezeStock(productId, count);return true;
}

六、常見問題解決方案

6.1 TC服務無法注冊到Nacos

  • 檢查Nacos服務是否正常啟動
  • 確認registry.conf配置的namespace與Nacos一致
  • 查看seata-server啟動日志是否有連接錯誤

6.2 全局事務不生效

  • 確認@GlobalTransactional注解添加正確
  • 檢查spring-cloud-alibaba-seata依賴版本
  • 查看TM和RM是否使用相同的事務組配置

6.3 臟數據回滾失敗

  • 檢查undo_log表是否自動創建
  • 確認數據庫用戶有權限操作undo_log表
  • 驗證AT模式下的SQL是否符合要求(必須有主鍵)

七、生產環境最佳實踐

  1. TC服務高可用

    • 部署至少3個TC節點
    • 使用Nacos集群做服務發現
  2. 數據持久化配置

# conf/file.conf
store {mode = "db"db {datasource = "druid"dbType = "mysql"url = "jdbc:mysql://127.0.0.1:3306/seata"user = "root"password = "123456"}
}
  1. 監控告警
    • 集成Prometheus監控事務成功率
    • 配置事務超時時間(默認60秒)

八、源碼解析(理解核心機制)

關鍵類說明

類名作用
DefaultCoordinator事務協調核心邏輯
GlobalTransactionScanner掃描@GlobalTransactional注解
AsyncWorker異步處理分支提交/回滾
UndoLogManager管理數據快照

事務提交源碼片段

public void commit() {// 異步執行提交AsyncCallback<Boolean> callback = new AsyncCallback<Boolean>() {@Overridepublic void onSuccess(Boolean result) {// 刪除undo logundoLogManager.deleteUndoLog(xid, branchId);}};asyncWorker.branchCommit(branchType, xid, branchId, callback);
}

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

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

相關文章

docker需要sudo才能使用

一種方法是添加當前用戶到docker組里去&#xff0c;當時添加的時候貌似是沒問題的&#xff0c;但是現在又不可以了 產生的報錯 ? docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解決…

學習記錄 6 pointnet復現

一、復現代碼 然后去找相關的2d的聲吶圖像分類的算法 融合可以搞的&#xff0c;雖然有文獻但是不多&#xff0c;感覺也是可以的 """ Author: Benny Date: Nov 2019 """import os import sys import torch import numpy as npimport datetime …

Linux 文件操作-標準IO函數3- fread讀取、fwrite寫入、 fprintf向文件寫入格式化數據、fscanf逐行讀取格式化數據的驗證

目錄 1. fread 從文件中讀取數據 1.1 讀取次數 每次讀取字節數 < 原內容字節數 1.2 讀取次數 每次讀取字節數 > 原內容字節數 2.fwrite 向文件中寫入數據 2.1寫入字符串驗證 2.2寫入結構體驗證 3. fprintf 將數據寫入到指定文件 4. fscanf 從文件中逐行讀取內容…

Python 中下劃線 “_” 的多面性:從變量到約定

# Python中下劃線“_”的多面性&#xff1a;從變量到約定 在Python的語法體系里&#xff0c;下劃線“_”看似毫不起眼&#xff0c;實則扮演著極為重要且多樣化的角色。它不僅能作為普通變量參與編程&#xff0c;更在多個特殊場景下有著獨特的用途與約定。深入理解下劃線的各種…

深入 Linux 聲卡驅動開發:核心問題與實戰解析

1. 字符設備驅動如何為聲卡提供操作接口&#xff1f; 問題背景 在 Linux 系統中&#xff0c;聲卡被抽象為字符設備。如何通過代碼讓應用程序能夠訪問聲卡的錄音和播放功能&#xff1f; 核心答案 1.1 字符設備驅動的核心結構 Linux 字符設備驅動通過 file_operations 結構體定…

基于Spring Boot的圖書管理系統的設計與實現(LW+源碼+講解)

專注于大學生項目實戰開發,講解,畢業答疑輔導&#xff0c;歡迎高校老師/同行前輩交流合作?。 技術范圍&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬蟲、數據可視化、安卓app、大數據、物聯網、機器學習等設計與開發。 主要內容&#xff1a;…

記錄 macOS 上使用 Homebrew 安裝的軟件

Homebrew 是 macOS 上最受歡迎的軟件包管理器之一&#xff0c;能夠輕松安裝各種命令行工具和 GUI 應用。本文記錄了我通過 Homebrew 安裝的各種軟件&#xff0c;并對它們的用途和基本使用方法進行介紹。 &#x1f37a; Homebrew 介紹 Homebrew 是一個開源的包管理器&#xff…

個人AI助手的未來:Yi AI開源系統助力快速搭建

摘要 Yi AI推出了一站式個人AI助手平臺解決方案&#xff0c;助力用戶快速搭建專屬AI助手。該平臺采用全套開源系統&#xff0c;涵蓋前端應用、后臺管理及小程序功能&#xff0c;并基于MIT協議開放使用。同時&#xff0c;平臺集成了本地RAG方案&#xff0c;利用Milvus與Weaviate…

dpkg-architecture命令詳解

dpkg-architecture 是 Debian 系系統中用于處理軟件包架構相關操作的工具&#xff0c;尤其在軟件包構建和交叉編譯環境中至關重要。以下是其核心功能及用法的詳細說明&#xff1a; ?一、核心功能? ?架構查詢與驗證? 顯示或驗證當前系統&#xff08;DEB_HOST_ARCH&#xff…

STM32HAL庫,解決串口UART中斷接收到的第一個字節數據丟失

1.問題描述&#xff1a; 只有上電后第一次接收到的第一字節數據會丟失&#xff0c;往后再接收也不會存在問題了。 2.先貼出來重寫UART中斷回調函數 我在接收到第一字節數據后開啟定時器中斷的&#xff0c;做一個超時處理&#xff0c;每次接收到數據會對定時器計數值清零&…

解決 vxe-table 固定列對不齊,滾動后錯位、展開行遮擋的問題,解決渲染空白、邊框丟失問題

解決 vxe-table 固定列對不齊&#xff0c;滾動后錯位、展開行遮擋的問題&#xff0c;解決渲染空白、邊框丟失問題。 解決方法&#xff0c;更新到最新版本就完美解決了&#xff1b;v4 版本更新到 v4.12&#xff0c;v3版本更新到 v3.14 查看官網&#xff1a;https://vxetable.cn…

React相關面試題

以下是150道React面試題及其詳細回答&#xff0c;涵蓋了React的基礎知識、組件、狀態管理、路由、性能優化等多個方面&#xff0c;每道題目都盡量詳細且簡單易懂&#xff1a; React基礎概念類 1. 什么是React&#xff1f; React是一個用于構建用戶界面的JavaScript庫&#xff…

設備健康管理系統是什么,設備健康管理系統多少錢?

想象一下&#xff0c;你的汽車在儀表盤報警前 3 天&#xff0c;手機就收到 “發動機軸承剩余壽命 1500 公里” 的提醒 —— 這就是 ** 設備健康管理系統&#xff08;EHM&#xff09;** 的日常。在制造業&#xff0c;設備故障每年造成全球 3.4 萬億美元損失&#xff0c;而 80% 的…

Redis項目:秒殺業務

/*** 搶購秒殺券** param voucherId* return*/TransactionalOverridepublic Result seckillVoucher(Long voucherId) {// 1、查詢秒殺券SeckillVoucher voucher seckillVoucherService.getById(voucherId);// 2、判斷秒殺券是否合法if (voucher.getBeginTime().isAfter(LocalD…

區塊鏈(Blockchain)

區塊鏈&#xff08;Blockchain&#xff09;是一種去中心化、分布式的賬本技術&#xff0c;它通過密碼學保證數據的安全性和不可篡改性。它的核心特點包括去中心化、不可篡改性、可追溯性、智能合約等。 區塊鏈的關鍵概念 區塊&#xff08;Block&#xff09;&#xff1a;每個區…

和鯨科技受邀赴中國氣象局氣象干部培訓學院湖南分院開展 DeepSeek 趨勢下的人工智能技術應用專題培訓

為深入貫徹落實國家關于人工智能與氣象業務深度融合的戰略部署&#xff0c;提升在實際業務中應用人工智能技術解決問題的能力&#xff0c;推動氣象現代化高質量發展&#xff0c;中國氣象局氣象干部培訓學院湖南分院于 2025 年 3 月 14 日組織開展 “DeepSeek 等人工智能技術在氣…

Ubuntu 24 常用命令方法

文章目錄 環境說明1、賬號管理1.1、啟用 root 2、包管理工具 apt & dpkg2.1、apt 簡介 & 阿里源配置2.2、dpkg 簡介2.3、apt 和 dpkg 兩者之間的關系2.4、常用命令 3、啟用 ssh 服務4、防火墻5、開啟遠程登錄6、關閉交換分區7、build-essential&#xff08;編譯和開發軟…

OpenCV計算攝影學(22)將輸入的彩色圖像轉換為兩種風格的鉛筆素描效果函數pencilSketch()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 鉛筆風格非寫實線描圖。 該函數通過圖像處理技術將輸入的彩色圖像轉換為兩種風格的鉛筆素描效果&#xff1a; dst1&#xff1a;炭筆效果的灰度圖…

hackmyvm-Smol

信息收集 ┌──(root?kali)-[/home/kali] └─# arp-scan -I eth1 192.168.56.0/24 Interface: eth1, type: EN10MB, MAC: 00:0c:29:34:da:f5, IPv4: 192.168.56.103 WARNING: Cannot open MAC/Vendor file ieee-oui.txt: Permission denied WARNING: Cannot open MAC/Vendo…

使用DeepSeek和墨刀AI,寫PRD文檔、畫原型圖的思路、過程及方法

使用DeepSeek和墨刀AI&#xff0c;寫PRD文檔、畫原型圖的思路、過程及方法 現在PRD文檔要如何寫更高效、更清晰、更完整&#xff1f; 還是按以前的思路寫PRD&#xff0c;就還是以前的樣子。 現在AI這么強大&#xff0c;產品經理如何使用DeepSeek寫PRD文檔&#xff0c;產品經…