SpringCloud+Nacos集成Seata-1.7.0分布式事务

Seata是一个比较成熟的分布式事务工具,非常好用,主流的的一套,网上大多都是1.4版本,以及不完整了,鄙人也是找了好久才找到有个1.7版本的详细教程(放在最后面了,毕竟是别人的技术,这里就当记录一下自己的解决方案)


首先我没去github下载相对应的seata,网址放下面了


Releases · seata/seata (github.com)


选择相对应的版本进行下载


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第1张图片

 


下载好解压结构如下,(最新版1.7版本)


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第2张图片

 


config结构目录如下,(最新版只有两个配置文件)


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第3张图片

 


接下来我们去修改配置文件让它走nacos的路线(默认走file路线),打开application.yml文件


我配置好的如下


server:
  port: 7091

spring:
  application:
    name: seata-server

logging:
  config: classpath:logback-spring.xml
  file:
    path: D:\img_CSDN\seata-server-1.7.0\seata\logs.
  extend:
    logstash-appender:
      destination: 127.0.0.1:4560
    kafka-appender:
      bootstrap-servers: 127.0.0.1:9092
      topic: logback_to_logstash

console:
  user:
    username: seata
    password: seata
seata:
  config:
    type: nacos
    nacos:
      server-addr: 127.0.0.1:8848
      namespace:
      group: SEATA_GROUP
      username:
      password:
      context-path:
      data-id: seataServer.properties
      ##if use MSE Nacos with auth, mutex with username/password attribute
      #access-key:
      #secret-key:
  registry:
    # support: nacos, eureka, redis, zk, consul, etcd3, sofa
    type: nacos
    nacos:
      application: seata-server
      server-addr: 127.0.0.1:8848
      group: SEATA_GROUP
      namespace:
      cluster: default
      username:
      password:
      context-path:
  store:
    # support: file 、 db 、 redis
    mode: file
#  server:
#    service-port: 8091 #If not configured, the default is '${server.port} + 1000'
  security:
    secretKey: SeataSecretKey0c382ef121d778043159209298fd40bf3850a017
    tokenValidityInMilliseconds: 1800000
    ignore:
      urls: /,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.jpeg,/**/*.ico,/api/v1/auth/login

application.example.yml不需要修改


再将script下面的server下面的db文件夹里面的sql脚本运行添加数据库(有三个表)

 

SpringCloud+Nacos集成Seata-1.7.0分布式事务_第4张图片

 


运行完有如下几个表


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第5张图片

 


 接下来我们在nacos添加配置文件,mysql链接名和密码输入自己的,文件名与application.yml

的data-id一致,我这里取名seataServer.properties,group则是group设置的名字


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第6张图片

 


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第7张图片


 我的配置也放下面了,


#Transaction storage configuration, only for the server.
store.mode=db
store.lock.mode=db
store.session.mode=db

#These configurations are required if the `store mode` is `db`.
store.db.datasource=druid
store.db.dbType=mysql
store.db.driverClassName=com.mysql.cj.jdbc.Driver
store.db.url=jdbc:mysql://localhost:3306/seata?useSSL=false&useUnicode=true&rewriteBatchedStatements=true
store.db.user=root
store.db.password=root
store.db.minConn=5
store.db.maxConn=30
store.db.globalTable=global_table
store.db.branchTable=branch_table
store.db.distributedLockTable=distributed_lock
store.db.queryLimit=100
store.db.lockTable=lock_table
store.db.maxWait=5000

到这里就已经配置好了,直接启动seata,出现如下就表示成功,


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第8张图片


 我们打开nacos,发现它以及注册上去了,就表示成功了


SpringCloud+Nacos集成Seata-1.7.0分布式事务_第9张图片

 


希望能帮到各位小伙伴,这篇文件引至别人的,并非自己想到的原创


SpringCloud+Nacos集成Seata-1.7.0分布式事务 - 掘金 (juejin.cn)

你可能感兴趣的:(spring,cloud,分布式,spring)