前言
上一篇文章:➣SpringCloud Alibaba之Seata入门以及踩坑(一)老顾介绍了seata相关的准备工作,以及版本的选择;今天老顾就来介绍一下seata的使用。以及在使用过程中遇到的问题。
案例背景
今天老顾介绍的案例场景也就是网上常用的场景,用户下单场景。整个流程就是用户下单时:
1)创建订单,订单状态为创建中
2)扣减商品库存
3)扣减用户金额
4)更改订单状态,订单状态为已完结
从以上业务流程,我们可以分为3个服务,如图
因为上面是3个分布式服务,事务问题就由此产生,我们来看看seata怎么来解决?
Client端准备
上文中已经介绍了seata-server的准备工作,需要首先启动seata服务。下面我们来看看client端项目需要做什么准备。
项目依赖
我们需要在项目中引入seata的jar包,有以下选择(任选其一):
- 依赖seata-all 手动配置较多
- 依赖seata-spring-boot-starter,支持yml配置
- 依赖spring-cloud-starter-alibaba-seata,内部集成了seata,并实现了xid传递
注意:client 版本与 server端版本一致
上面三种方式,需要做不同的事情,尤其xid的传递是比较麻烦的,还好spring-cloud-starter-alibaba-seata已经帮我们实现,具体看看下图:
这里我们就用spring-cloud-starter-alibaba-seata方式。