分布式事务介绍 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部署完成!

相关推荐
zandy10115 小时前
Agentic BI 架构实战:当AI Agent接管数据建模、指标计算与可视化全链路
人工智能·架构
薪火铺子7 小时前
微服务认证方案对比与选型
微服务·云原生·架构
运维全栈笔记9 小时前
K8S部署Redis高可用全攻略:1主2从3哨兵架构实战
redis·docker·云原生·容器·架构·kubernetes·bootstrap
weixin_4462608510 小时前
城市智能化的底层基石:基于腾讯地图服务生态的移动定位与导航架构指引
大数据·人工智能·架构
KmSH8umpK12 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第三篇
redis·分布式·wpf
@#¥&~是乱码鱼啦12 小时前
Spring分层架构:Controller、Service、Mapper数据链路,IOC的真实工作意义
java·spring·架构
vortex512 小时前
SafeLine 雷池WAF 真实体验,谈谈架构与原理
架构
该昵称用户已存在13 小时前
MyEMS 开源能源管理系统:模块化架构赋能精细化能源管控
架构·开源·能源
Ulyanov13 小时前
《现代 Python 桌面应用架构实战:PySide6 + QML 从入门到工程化》 开发环境搭建与工具链极简主义 —— 拒绝臃肿,构建工业级基座
开发语言·python·qt·ui·架构·系统仿真
郭龙_Jack14 小时前
Kubernetes 架构一张图讲透
架构