为什么要有分布式事务
因为分布式系统的存在,一个事务下若干个分支操作分别位于不同服务器上,传统的单机事务已经不再适应;分布式事务可以保证这些分支事务要么全部成功,要么全部失败,与传统的单机事务一样,都是为了保证对数据库数据操作的一致性
分布式事务的具体产品——seata
seata是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务
seata中几个角色
TC
Transaction Coordinate,事务协调者。维护全部和分支事务的状态,驱动全局事务提交和回滚
TM
Transaction Manager,事务管理器,定义全局事务的范围,开启全局事务、提交或者回滚全局事务
RM
Resource Manager,资源管理者,管理分支事务处理的资源,与TC通信以注册分支事务和报告分支事务的状态,并驱动分支事务的提交或者回滚
使用
下载seata-server,找到sql脚本,在数据库中执行
配置seata-server数据源相关配置
修改seata-server注册中心的配置信息
将seata-server的配置文件放到配置中心
启动seata-server服务
客户端处理业务相关的每个数据库中都要添加undo_log表,用于保存需要回滚的数据
spring.cloud.alibaba.seata.tx-service-group:事务名
在方法上使用@GlobalTransactional注解