分布式事务介绍 Seata架构与原理+部署TC服务 示例:黑马商城

1. 什么是分布式事务?

分布式系统 中,如果一个业务需要多个服务合作完成 ,而且每一个服务都有事务多个事务 必须同时成功或失败 ,这样的事务就是分布式事务 。其中的每个服务的事务就是一个分支事务。整个业务称为全局事务

打个比方:就像一个跨国连锁超市的库存管理系统。它在中国、美国、欧洲等地都有仓库和数据库来记录库存。当全球统一补货的事务发生时,涉及这些不同地区的库存更新操作,这就是分布式事务。所有地区的库存更新都成功,这个补货事务才算成功;只要有一个地区更新库存出现问题,整个补货事务就要回滚,保证各地库存数据不会因为部分成功而出现混乱。

分布式事务所产生的问题:

  1. 数据一致性难题: 数据分散在不同节点,很难保证所有节点数据在事务前后都一致。比如电商系统里,下单减库存,可能出现库存减了但订单没生成的情况。
  2. 事务协调复杂: 要让多个节点的事务要么都成功要么都失败很复杂。因为节点可能出现故障、网络延迟等情况,很难统一控制。
  3. 性能损耗: 保证分布式事务的正确执行,需要更多的通信、协调和额外的操作,这会降低系统的整体性能。

这个时候就用到了在众多的开源分布式事务框架 中,功能最完善、使用最多 的就是阿里巴巴在2019年开源的Seata


2. 认识Seata

分布式事务产生的一个重要原因,就是参与事务的多个分支事务互相无感知,不知道彼此的执行状态。因此解决分布式事务的思想非常简单:

就是找一个统一的事务协调者,与多个分支事务通信,检测每个分支事务的执行状态,保证全局事务下的每一个分支事务同时成功或失败即可。大多数的分布式事务框架都是基于这个理论来实现的。

在Seata的事务管理中有三个重要的角色:

  • TC ( Transaction Coordinator ) - **事务协调者:**维护全局和分支事务的状态,协调全局事务提交或回滚。

  • TM (Transaction Manager) - **事务管理器:**定义全局事务的范围、开始全局事务、提交或回滚全局事务。

  • RM (Resource Manager) - **资源管理器:**管理分支事务,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。

Seata的工作架构图


3. 部署TC服务

这里我们使用黑马商城做为示例,所以对应的相关资料已准备好

3.1 插入数据库表


3.2 准备配置文件并上传到虚拟机对应的目录中

准备了一个seata目录,其中包含了seata运行时所需要的配置文件

整个seata文件夹seata镜像jar包 上传到虚拟机的/root目录

解压加载seata镜像jar包,命令:

XML 复制代码
docker load -i seata-1.5.2.tar

然后输入命令进行查看镜像是否存在:


3.3 Docker部署

操作前先确保mysqlnacos容器都在同一个网络里(本次网络名为hm-net)

查看网络详情命令:

XML 复制代码
docker network inspect 网络名

将某容器加入指定网络命令:

XML 复制代码
docker network connect [网络名] [容器名]

将两个容器都加入hm-net网络之后,便可以下面的命令:

XML 复制代码
docker run --name seata \
-p 8099:8099 \
-p 7099:7099 \
-e SEATA_IP=192.168.218.15 \  #自己虚拟机ip
-v ./seata:/seata-server/resources \
--privileged=true \
--network hm-net \
-d \
seataio/seata-server:1.5.2

安装完毕,通过docker ps指令进行查看容器是否创建成功

可以看到,已经容器创建成功!

通过日志命令查看seata

XML 复制代码
docker logs -f seata

3.4 测试

打开Nacos控制台查看,发现服务管理->服务列表多了一个seata-server ,说明注册上来了

输入 http://192.168.218.15:7099/ 进入Seata控制台,账号和密码同一个:admin

因为我们application.yml配置文件中写的是admin

登录页面

进入登录页面

到此,Seata部署完成!

相关推荐
唐人街都是苦瓜脸6 分钟前
Kafka和RocketMQ相比有什么区别?那个更好用?
分布式·中间件·kafka·rocketmq
信徒_10 分钟前
Kafka 中的高低水位
分布式·kafka
信徒_11 分钟前
kafka 的存储文件结构
分布式·kafka
猿java39 分钟前
为什么有了服务降级,还需要服务熔断?
java·分布式·后端
IT成长日记2 小时前
【Kafka基础】单机安装与配置指南,从零搭建环境
分布式·kafka·单机部署
小天努力学java2 小时前
【软考-架构】13.2、软件层次风格
架构
凯子坚持 c3 小时前
从个人博客到电商中台:EdgeOne Pages的MCP Server弹性架构×DeepSeek多场景模板实测报告
架构·腾讯云
信徒_8 小时前
Kafka 中的生产者分区策略
分布式·kafka
李詹10 小时前
WAF防护规则配置技巧与企业级安全实践指南
网络·tcp/ip·安全·架构·ddos
郭涤生11 小时前
Chapter 4: Encoding and Evolution_《Designing Data-Intensive Application》
笔记·分布式