SpringCloud-Alibaba之Seata入门以及踩坑(二)

前言

上一篇文章:➣SpringCloud Alibaba之Seata入门以及踩坑(一)老顾介绍了seata相关的准备工作,以及版本的选择;今天老顾就来介绍一下seata的使用。以及在使用过程中遇到的问题。

案例背景

今天老顾介绍的案例场景也就是网上常用的场景,用户下单场景。整个流程就是用户下单时:

1)创建订单,订单状态为创建中

2)扣减商品库存

3)扣减用户金额

4)更改订单状态,订单状态为已完结

从以上业务流程,我们可以分为3个服务,如图

SpringCloud-Alibaba之Seata入门以及踩坑(二)_第1张图片

因为上面是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方式。

你可能感兴趣的:(程序员,面试,java,经验分享)