Alibaba Spring Cloud 四 Seata 的核心组件:TC

news2025/1/24 6:15:37

Seata 的 Transaction Coordinator (TC) 是分布式事务架构中的核心组件之一,它负责管理全局事务的生命周期,包括事务的创建、状态维护以及协调各分支事务的提交和回滚。以下是有关 TC 的详细解析及其配置和使用方法:


1. TC 的核心功能

  1. 全局事务管理:

    • TC 记录全局事务(Global Transaction)的状态,包括开始、提交和回滚。
    • 为每个全局事务分配一个唯一的事务 ID(XID)。
  2. 分支事务协调:

    • TC 维护每个全局事务下的分支事务列表。
    • 协调分支事务的注册、提交和回滚。
  3. 事务状态维护:

    • TC 持久化事务状态到数据库,确保分布式事务的可靠性。
  4. 事务超时与清理:

    • 如果全局事务长时间未完成,TC 会主动清理超时事务。

2. TC 的工作流程

  1. 全局事务的创建:

    • Transaction Manager ™ 请求 TC 开启全局事务。
    • TC 生成一个唯一的全局事务 ID (XID)。
  2. 分支事务的注册:

    • Resource Manager (RM) 在执行分支事务前向 TC 注册。
    • TC 将分支事务与全局事务绑定。
  3. 分支事务的状态更新:

    • 分支事务完成后,RM 向 TC 报告状态(成功或失败)。
    • TC 更新分支事务状态。
  4. 全局事务的提交或回滚:

    • TM 通知 TC 提交或回滚全局事务。
    • TC 根据分支事务的状态协调 RM 进行提交或回滚操作。

3. TC 的部署与配置

3.1 环境准备

下载 Seata Server

从 Seata 官方 GitHub 下载最新版本。

配置文件修改
  1. registry.conf
    配置 Seata 的注册中心和配置中心。

    示例(Nacos):

    registry {
      type = "nacos"
      nacos {
        serverAddr = "127.0.0.1:8848"
        namespace = ""
        group = "SEATA_GROUP"
      }
    }
    config {
      type = "nacos"
      nacos {
        serverAddr = "127.0.0.1:8848"
        namespace = ""
        group = "SEATA_GROUP"
        dataId = "seata.properties"
      }
    }
    
  2. file.conf
    配置事务日志存储。

    示例(数据库):

    store {
      mode = "db"  # 使用数据库存储事务日志
      db {
        datasource = "druid"
        dbType = "mysql"
        driverClassName = "com.mysql.cj.jdbc.Driver"
        url = "jdbc:mysql://127.0.0.1:3306/seata"
        user = "root"
        password = "root"
      }
    }
    

3.2 数据库表配置

如果 TC 使用数据库模式,需要创建以下表:

  1. global_table
    存储全局事务信息。

    CREATE TABLE global_table (
        xid VARCHAR(128) NOT NULL,
        transaction_id BIGINT,
        status TINYINT,
        gmt_create TIMESTAMP,
        gmt_modified TIMESTAMP,
        PRIMARY KEY (xid)
    );
    
  2. branch_table
    存储分支事务信息。

    CREATE TABLE branch_table (
        branch_id BIGINT,
        xid VARCHAR(128) NOT NULL,
        resource_group_id VARCHAR(32),
        resource_id VARCHAR(256),
        branch_type VARCHAR(8),
        status TINYINT,
        client_id VARCHAR(64),
        application_data TEXT,
        gmt_create TIMESTAMP,
        gmt_modified TIMESTAMP,
        PRIMARY KEY (branch_id)
    );
    
  3. lock_table
    存储分布式事务锁。

    CREATE TABLE lock_table (
        row_key VARCHAR(128) NOT NULL,
        xid VARCHAR(128),
        transaction_id BIGINT,
        branch_id BIGINT,
        resource_id VARCHAR(256),
        gmt_create TIMESTAMP,
        gmt_modified TIMESTAMP,
        PRIMARY KEY (row_key)
    );
    

3.3 启动 Seata Server

在 Seata 解压目录中执行以下命令启动 TC 服务:

sh bin/seata-server.sh -p 8091

参数说明:

  • -p:指定服务端口。
  • -m:指定存储模式(默认 file,可设置为 db)。

4. TC 的高可用部署

4.1 多节点集群部署

Seata 支持多节点集群部署,通过注册中心(如 Nacos、Eureka)实现。

配置集群节点

conf/cluster.conf 文件中配置多个节点:

192.168.1.101:8091
192.168.1.102:8091
192.168.1.103:8091
配置注册中心

确保所有节点的 registry.conf 指向同一个注册中心(如 Nacos)。


4.2 数据库高可用

  • 配置数据库主从复制或使用分布式数据库(如 TiDB)。
  • file.conf 中配置数据源连接池(如 HikariCP 或 Druid)。

5. TC 的运行与调试

查看 TC 日志

  • Seata Server 的日志文件默认保存在 logs/seata.log 中。
  • 关注以下关键日志:
    1. 全局事务的创建与状态变更。
    2. 分支事务的注册与状态报告。
    3. 超时事务的清理。

配置日志级别

conf/logback.xml 中配置日志级别为 DEBUG 或 INFO:

<root level="DEBUG">
    <appender-ref ref="Console"/>
    <appender-ref ref="File"/>
</root>

6. TC 的实践建议

  1. 高可用:

    • 使用集群模式部署 TC,避免单点故障。
    • 确保数据库的高可用性,防止数据丢失。
  2. 事务超时配置:

    • 设置合理的事务超时时间,避免长时间占用资源。
    • 配置项(在 application.yml 中):
      seata:
        service:
          vgroup-mapping:
            my_tx_group: default
        client:
          transaction:
            timeout: 60000 # 单位:毫秒
      
  3. 监控与调试:

    • 使用 Seata 控制台(seata-console)监控事务状态。
    • 定期清理过期事务和日志文件。
  4. 优化性能:

    • 配置数据库连接池(如 Druid)提升数据库操作性能。
    • 在高并发场景下,优化锁表(lock_table)的索引设计。

7. TC 与 TM、RM 的交互流程

  1. 全局事务创建

    • TM 调用 TC 的 begin 接口,创建全局事务。
    • TC 返回 XID,作为事务标识。
  2. 分支事务注册

    • RM 在执行本地事务前向 TC 注册分支事务。
    • TC 返回注册成功的状态。
  3. 事务状态更新

    • RM 向 TC 报告分支事务的执行结果(成功或失败)。
    • TC 更新分支事务的状态。
  4. 全局事务提交或回滚

    • TM 通知 TC 提交或回滚全局事务。
    • TC 通知所有相关 RM 执行分支事务的提交或回滚。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2281260.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

低代码可视化-转盘小游戏可视化-代码生成器

转盘小程序是一种互动工具&#xff0c;它通过模拟真实的转盘抽奖或决策体验&#xff0c;为用户提供了一种有趣且公平的选择方式。以下是对转盘小程序的详细介绍&#xff1a; 转盘小程序的应用场景 日常决策&#xff1a;转盘小程序可以帮助用户解决日常生活中的选择困难问题&a…

【Uniapp-Vue3】uni-icons的安装和使用

一、uni-icon的安装 进入到如下页面中&#xff0c;点击“点击下载&安装”。 uni-icons 图标 | uni-app官网 点击“下载插件并导入HBuilder”&#xff0c;如果没有登录就登陆一下 网页中会打开Hbuilder&#xff0c;进入Hbuilder以后&#xff0c;选择需要使用该插件的项目进…

【橘子ES】Kibana的分析能力Analytics简易分析

一、kibana是啥&#xff0c;能干嘛 我们经常会用es来实现一些关于检索&#xff0c;关于分析的业务。但是es本身并没有UI,我们只能通过调用api来完成一些能力。而kibana就是他的一个外置UI&#xff0c;你完全可以这么理解。 当我们进入kibana的主页的时候你可以看到这样的布局。…

一、引论,《组合数学(第4版)》卢开澄 卢华明

零、前言 发现自己数数题做的很烂&#xff0c;重新学一遍组合数学吧。 参考卢开澄 卢华明 编著的《组合数学(第4版)》&#xff0c;只打算学前四章。 通过几个经典问题来了解组合数学所研究的内容。 一、幻方问题 据说大禹治水之前&#xff0c;河里冒出来一只乌龟&#xff0c…

LabVIEW太阳能照明监控系统

在公共照明领域&#xff0c;传统的电力照明系统存在高能耗和维护不便等问题。利用LabVIEW开发太阳能照明监控系统&#xff0c;通过智能控制和实时监测&#xff0c;提高能源利用效率&#xff0c;降低维护成本&#xff0c;实现照明系统的可持续发展。 ​ 项目背景 随着能源危机…

5. 马科维茨资产组合模型+政策意图AI金融智能体(Qwen-Max)增强方案(理论+Python实战)

目录 0. 承前1. AI金融智能体1.1 What is AI金融智能体1.2 Why is AI金融智能体1.3 How to AI金融智能体 2. 数据要素&计算流程2.1 参数集设置2.2 数据获取&预处理2.3 收益率计算2.4 因子构建与预期收益率计算2.5 协方差矩阵计算2.6 投资组合优化2.7 持仓筛选2.8 AI金融…

【华为路由的arp配置】

华为路由的arp配置 ARP&#xff1a;IP地址与MAC地址的映射。 R1: g0/0/0:10.1.1.254/24 g0/0/1:10.1.2.254/24 PC1: 10.1.1.1/16 PC2: 10.1.1.2/16 PC3: 10.1.2.3/16 动态ARP 查看PC1的arp表&#xff0c;可以看到&#xff0c;列表为空。 查看R1的arp表 在PC3上ping命令测…

U3D的.Net学习

Mono&#xff1a;这是 Unity 最初采用的方式&#xff0c;它将 C# 代码编译为中间语言 (IL)&#xff0c;然后在目标平台上使用虚拟机 (VM) 将其转换为本地机器码执行。 IL2CPP&#xff1a;这是一种较新的方法&#xff0c;它会将 C# 代码先编译为 C 代码&#xff0c;再由 C 编译器…

机器学习-线性回归(简单回归、多元回归)

这一篇文章&#xff0c;我们主要来理解一下&#xff0c;什么是线性回归中的简单回归和多元回归&#xff0c;顺便掌握一下特征向量的概念。 一、简单回归 简单回归是线性回归的一种最基本形式&#xff0c;它用于研究**一个自变量&#xff08;输入&#xff09;与一个因变量&…

智能体的核心技能之插件,插件详解和实例 ,扣子免费系列教程(11)

欢迎来到滔滔讲AI&#xff0c;今天我们来学习智能体的核心功能点之一的插件。 插件是通过API连接集成各种平台和服务&#xff0c;它扩展了智能体的能力。平台内置了丰富的插件&#xff0c;我们可以直接调用。 一、什么是插件 首先&#xff0c;插件其实就像一个工具箱。 每个插…

Spring Security(maven项目) 3.0.2.6版本—总

通过实践而发现真理&#xff0c;又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识&#xff0c;又从理性认识而能动地指导革命实践&#xff0c;改造主观世界和客观世界。实践、认识、再实践、再认识&#xff0c;这种形式&#xff0c;循环往复以至无穷&#xf…

超强推理大模型 QVQ-32B-preview 一键部署

QwQ-32B-Preview 是 Qwen 团队于 2024 年开发的实验研究模型&#xff0c;专注于提高 AI 推理能力。这个模型在多个基准测试中展现了卓越的性能&#xff0c;特别是在 GPQA、AIME、MATH-500 和 LiveCodeBench 等测试中&#xff0c;准确率分别达到了 65.2%、50.0%、90.6% 和 50.0%…

数据结构(Java)——二叉树

1.概念 二叉树是一种树形数据结构&#xff0c;其中每个节点最多有两个子节点&#xff0c;通常被称为左子节点和右子节点。二叉树可以是空的&#xff08;即没有节点&#xff09;&#xff0c;或者由一个根节点以及零个或多个左子树和右子树组成&#xff0c;其中左子树和右子树也分…

谷粒商城——商品服务-三级分类

1.商品服务-三级分类 1.1三级分类介绍 1.2查询三级分类查询-递归树型结构数据获取 1.2.1导入数据pms_catelog.sql到数据表pms_category 1.2.2一次性查出所有分类及子分类 1.2.2.1修改CategoryController.java /*** 查出所有分类以及子分类&#xff0c;以树形结构组装起来*/R…

AviatorScript用法

AviatorScript的介绍&#xff0c;网上有很多&#xff0c;这里就不啰嗦了。这里介绍下传参的用法 应用场景&#xff1a;如果不想频繁的打包升级&#xff0c;而是想只更新某些规则脚本重启服务就可以升级的话&#xff0c;AviatorScript无疑是最佳选择。比如说&#xff0c;今天制…

云计算和服务器

一、云计算概述 ICT是世界电信协会在2001年的全球性会议上提出的综合性概念&#xff0c;ICT分为IT和CT&#xff0c;IT(information technology)信息技术&#xff0c;负责对数据生命周期的管理&#xff1b;CT(communication technology)&#xff0c;负责数据的传输管理。 CT技术…

论文:深度可分离神经网络存内计算处理芯片

引言&#xff1a;SRAM - CIM芯片在处理深度可分离神经网络时面临的挑战 深度可分离卷积&#xff08;Depthwise separable convolution, DSC&#xff09;由逐深度卷积&#xff08;DW&#xff09;和逐点卷积&#xff08;PW)组成&#xff0c;逐深度卷积用于提取空间特征&#xff…

代码随想录刷题day14(1)|(链表篇)142.环形链表 II

目录 一、链表理论基础 二、环形链表思路 1.如何判断有环&#xff1f; 2.如何找出环的入口&#xff1f; 3.其他疑问 三、相关算法题目 四、总结 一、链表理论基础 代码随想录 (programmercarl.com) 二、环形链表思路 1.如何判断有环&#xff1f; 使用快慢指针法&…

运算放大器应用电路设计笔记(六)

6.1输出失调电压发生的原因与计算 6.1.1用噪声增益进行评价 若运算放大器两个输入端接地&#xff0c;则理想运放输出为零&#xff0c;但实际的运放输出不为零&#xff0c;有一定的直流输出电压。这种直流电压称为输出失调电压。发生的原因是&#xff0c;运算放大器内部元件尤…

openresty(nginx)+lua+kafka实现日志搜集系统

今天我们来实现一下快捷的nginx日志搜集系统&#xff0c;主讲的是nginx服务里面的openresty的日志搜集。采用的手段是采用lua做中间桥梁。 一、安装openresty 具体安装步骤在这里《centos7 二进制安装openresty》 二、安装kafka 1、安装Java及配置Java 具体安装步骤在这里《采…