Seata集成SpringBoot
详细步骤
集成SpringBoot可以按照如下步骤实现(默认seataServer已经安装好了并且启动了):
- 引入依赖包
spring-cloud-starter-alibaba-seata
- 配置Seata
- 创建代理数据源
- @GlobalTransactional全局事务控制
项目结构图:
1)依赖引入
【用到seata的项目都要引入依赖】
我们首先在 hailtaxi-driver
和hailtaxi-order
中引入依赖:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-seata</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
2)配置Seata
【用到seata的项目都要添加如下配置】
依赖引入后,我们需要在项目中配置SeataClient端信息,关于SeataClient端配置信息,官方也给出了很多版本的模板,可以打开https://github.com/seata/seata/tree/1.4.0/script,如下图:
我们可以选择spring
,把 application.yml
文件直接拷贝到工程中,文件如下:
seata:
enabled: true
application-id: applicationName
#当前分布式事务所对应的组【一般自己修改,默认为:my_test_tx_group】
tx-service-group: seata_transcation
enable-auto-data-source-proxy: true
data-source-proxy-mode: AT
use-jdk-proxy: false
excludes-for-auto-proxying: firstClassNameForExclude,secondClassNameForExclude
client:
rm:
async-commit-buffer-limit: 1000
report-retry-count: 5
table-meta-check-enable: false
report-success-enable: false
saga-branch-register-enable: false
saga-json-parser: fastjson
lock:
retry-interval: 10
retry-times: 30
retry-policy-branch-rollback-on-conflict: true
tm:
commit-retry-count: 5
rollback-retry-count: 5
default-global-transaction-timeout: 60000
degrade-check: false
degrade-check-period: 2000
degrade-check-allow-times: 10
undo:
data-validation: true
log-serialization: jackson
log-table: undo_log
only-care-update-columns: true
log:
exceptionRate: 100
service:
# 默认为【vgroup-mapping:】需要修改为驼峰命名规则
vgroupMapping:
# 默认为【my_test_tx_group: default】,需要修改为【tx-service-group】的值
seata_transcation: default
grouplist:
# seataServer安装的地址
default: 192.168.80.16:8091
enable-degrade: false
disable-global-transaction: false
transport:
shutdown:
wait: 3
thread-factory:
boss-thread-prefix: NettyBoss
worker-thread-prefix: NettyServerNIOWorker
server-executor-thread-prefix: NettyServerBizHandler
share-boss-worker: false
client-selector-thread-prefix: NettyClientSelector
client-selector-thread-size: 1
client-worker-thread-prefix: NettyClientWorkerThread
worker-thread-size: default
boss-thread-size: 1
type: TCP
server: NIO
heartbeat: true
serialization: seata
compressor: none
enable-client-batch-send-request: true
# config:
# type: file
# consul:
# server-addr: 127.0.0.1:8500
# apollo:
# apollo-meta: http://192.168.1.204:8801
# app-id: seata-server
# namespace: application
# apollo-accesskey-secret: ""
# etcd3:
# server-addr: http://localhost:2379
# nacos:
# namespace:
# serverAddr: 127.0.0.1:8848
# group: SEATA_GROUP
# username: ""
# password: ""
# zk:
# server-addr: 127.0.0.1:2181
# session-timeout: 6000
# connect-timeout: 2000
# username: ""
# password: ""
# custom:
# name: ""
registry:
type: nacos
load-balance: RandomLoadBalance
load-balance-virtual-nodes: 10
file:
name: file.conf
nacos:
application: seata-server
server-addr: 114.215.191.164:8848
group : "DEFAULT_GROUP"
# consul:
# server-addr: 127.0.0.1:8500
# etcd3:
# serverAddr: http://localhost:2379
# eureka:
# weight: 1
# service-url: http://localhost:8761/eureka
# redis:
# server-addr: localhost:6379
# db: 0
# password:
# timeout: 0
# sofa:
# server-addr: 127.0.0.1:9603
# region: DEFAULT_ZONE
# datacenter: DefaultDataCenter
# group: SEATA_GROUP
# addressWaitTime: 3000
# application: default
# zk:
# server-addr: 127.0.0.1:2181
# session-timeout: 6000
# connect-timeout: 2000
# username: ""
# password: ""
# custom:
# name: ""
关于配置文件内容参数比较多,我们只需要掌握核心部分:
seata_transaction: default:事务分组,前面的seata_transaction可以自定义,通过事务分组很方便找到集群节点信息。
tx-service-group: seata_transaction:指定应用的事务分组,和上面定义的分组前部分保持一致。
default: 192.168.211.145:8091:服务地址,seata-server服务地址。
3)代理数据源
【用到seata的项目都要配置代理数据源】
通过代理数据源可以保障事务日志数据和业务数据能同步,关于代理数据源早期需要手动创建,但是随着Seata版本升级,不同版本实现方案不一样了,下面是官方的介绍:
我们当前的版本是1.3.0,所以我们创建代理数据源只需要在启动类上添加@EnableAutoDataSourceProxy
注解即可。在 Dirver和Order项目的主启动类上添加该注解:
4)全局事务控制
假设现在有下单->修改司机信息->创建订单3个操作同时在 hailtaxi-order
工程中执行,打车成功创建订单是由客户发起,在 hailtaxi- order
中执行,并且feign
调用hailtaxi-driver
,所以 hailtaxi-order
是全局事务入口,我们在OrderInfoServiceImpl.addOrder()
方法上添加 @GlobalTransactional
,那么此时该方法就是全局事务的入口,为了测试事务,我们在代码中添加一个异常,代码如下:
5)分布式事务测试
我们此时执行请求 http://localhost:18082/order/addOrder?id=123
,我们可以看到执行的最终结果是失败。
但是控制台可以看到driver其实是执行成功了的。因为driver是在发生异常前就执行了的。所以肯定能成功。
此时这种情况就需要全局事务控制,我们去数据库看看司机的状态是否改变了。
我们可发现,司机的状态并没有改变,这就是说全局事务控制起了效果。