Spring Cloud同步场景分布式事务怎样做?试试Seata
2020-02-07 07:29
585 查看
一、概述
在微服务架构下,虽然我们会尽量避免分布式事务,但是只要业务复杂的情况下这是一个绕不开的问题,如何保证业务数据一致性呢?本文主要介绍同步场景下使用
Seata的
AT模式来解决一致性问题。
Seata是 阿里巴巴 开源的 一站式分布式事务解决方案 中间件,以 高效 并且对业务 0 侵入 的方式,解决 微服务 场景下面临的分布式事务问题
二、Seata介绍
整体事务逻辑是基于 两阶段提交 的模型,核心概念包括以下3个角色:
- TM:事务的发起者。用来告诉 TC,全局事务的开始,提交,回滚。
- RM:具体的事务资源,每一个 RM 都会作为一个分支事务注册在 TC。
- TC:事务的协调者seata-server,用于接收我们的事务的注册,提交和回滚。
目前的
Seata有两种模式可使用分别对应不同业务场景
2.1. AT模式
该模式适合的场景:
- 基于支持本地
ACID
事务的关系型数据库。 - Java 应用,通过
JDBC
访问数据库。
一个典型的分布式事务过程:
TM
向TC
申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的XID
。XID
在微服务调用链路的上下文中传播。RM
向TC
注册分支事务,将其纳入 XID 对应全局事务的管辖。TM
向TC
发起针对XID
的全局提交或回滚决议。TC
调度XID
下管辖的全部分支事务完成提交或回滚请求。
2.2. MT模式
该模式逻辑类似
TCC,需要 自定义实现
prepare、
commit和
rollback的逻辑,适合 非关系型数据库 的场景
三、Seata场景样例
模拟一个简单的用户下单场景,4个子工程分别是 Bussiness(事务发起者)、Order(创建订单)、Storage(扣减库存) 和 Account(扣减账户余额)
3.1. 部署Seata的Server端
Discover注册、
Config配置和
Store存储模块默认都是使用
file只能适用于单机,我们安装的时候分别改成使用
nacos和
Mysql以支持server端集群
3.1.1. 下载最新版本并解压
https://github.com/seata/seata/releases
3.1.2. 修改 conf/registry.conf 配置
注册中心和配置中心默认是
file这里改为
nacos;设置 registry 和 config 节点中的
type为
nacos,修改
serverAddr为你的
nacos节点地址。
registry { type = "nacos" nacos { serverAddr = "192.168.28.130" namespace = "public" cluster = "default" } } config { type = "nacos" nacos { serverAddr = "192.168.28.130" namespace = "public" cluster = "default" } }
3.1.3. 修改 conf/nacos-config.txt配置
修改 service.vgroup_mapping 为自己应用对应的名称;如果有多个服务,添加相应的配置
默认组名为
${spring.application.name}-fescar-service-group
,可通过spring.cloud.alibaba.seata.tx-service-group
配置修改修改 store.mode 为
db
,并修改数据库相关配置
3.1.4. 初始化seata的nacos配置
cd conf sh nacos-config.sh 192.168.28.130
成功后在
nacos的配置列表中能看到
seata的相关配置
3.1.5. 初始化数据库
执行
conf/db_store.sql中的脚本
3.1.6. 启动seata-server
sh bin/seata-server.sh -p 8091 -h 192.168.28.130
3.2. 应用配置
3.2.1. 初始化数据库
执行脚本 seata-demo.sql
需在业务相关的数据库中添加 undo_log 表,用于保存需要回滚的数据
3.2.2. 添加registry.conf配置
直接把 seata-server 中的
registry.conf复制到每个服务中去即可,不需要修改
3.2.3. 修改配置
demo中的每个服务各自修改配置文件
- bootstrap.yml 修改nacos地址
- application.yml 修改数据库配置
3.2.4. 配置数据源代理
Seata是通过代理数据源实现分布式事务,所以需要配置
io.seata.rm.datasource.DataSourceProxy的
Bean,且是
@Primary默认的数据源,否则事务不会回滚,无法实现分布式事务
public class DataSourceProxyConfig {
@Bean
@ConfigurationProperties(prefix = "spring.datasource")
public DruidDataSource druidDataSource() {
return new DruidDataSource();
}
@Primary
@Bean
public DataSourceProxy dataSourceProxy(DruidDataSource druidDataSource) {
return new DataSourceProxy(druidDataSource);
}
}
[/code]
因为使用了mybatis的starter所以需要排除
DataSourceAutoConfiguration,不然会产生循环依赖
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
[/code]
3.2.5. 事务发起者添加全局事务注解
事务发起者
business-service添加
@GlobalTransactional注解
@GlobalTransactional
public void placeOrder(String userId) {
......
}
[/code]
3.3. 测试
提供两个接口测试
- 事务成功:扣除库存成功 > 创建订单成功 > 扣减账户余额成功
http://localhost:9090/placeOrder - 事务失败:扣除库存成功 > 创建订单成功 > 扣减账户余额失败,事务回滚
http://localhost:9090/placeOrderFallBack
3.4. demo下载地址
https://gitee.com/zlt2000/microservices-platform/tree/master/zlt-demo/seata-demo
推荐阅读
- 日志排查问题困难?分布式日志链路跟踪来帮你
- zuul集成Sentinel最新的网关流控组件
- 阿里注册中心Nacos生产部署方案
- Spring Boot自定义配置项在IDE里面实现自动提示
- Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单
- Spring Cloud开发人员如何解决服务冲突和实例乱窜?
扫码关注有惊喜!
转载于:https://www.cnblogs.com/zlt2000/p/11525417.html
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- Spring Cloud同步场景分布式事务怎样做?试试Seata
- Spring Cloud异步场景分布式事务怎样做?试试RocketMQ
- springcloud-eureka-feign-mybatis-seata分布式事务实战
- Spring Cloud异步场景分布式事务怎样做?试试RocketMQ
- Spring Cloud 快速集成 Seata分布式事务
- SpringCloud系列——TX-LCN分布式事务管理
- 分布式架构springmvc+springboot+springcloud+redis
- Spring Cloud构建微服务架构(四)分布式配置中心(续)
- Spring Cloud微服务分布式云架构
- 分布式架构springmvc+springboot+springcloud+redis
- 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)
- [bigdata-108] spring-cloud-04 分布式服务的feign消费者
- 演示多数据源分布式事务的最小化Springboot Web应用
- SpringCloud系列:整合Apollo实现分布式配置中心(一)
- Java事务处理全解析(八)——分布式事务入门例子(Spring+JTA+Atomikos+Hibernate+JMS)
- 3分钟搞定SpringBoot+Mybatis+druid多数据源和分布式事务
- SpringCloud之分布式服务配置中心(Spring Cloud Config)
- spring cloud 系列第8篇 —— config+bus 分布式配置中心与配置热刷新 (F版本)
- spring cloud bus 配置不能同步刷新
- springcloud(十二):使用Spring Cloud Sleuth和Zipkin进行分布式链路跟踪