当前位置 : 主页 > 编程语言 > 其它开发 >

搭建分布式事务组件 seata 的Server 端和Client 端详解(小白都能看懂)

来源:互联网 收集:自由互联 发布时间:2022-05-20
一,server 端的存储模式为: Server 端 存 储 模 式 (store-mode) 支 持 三 种 : file: ( 默 认 ) 单 机 模 式 , 全 局 事 务 会 话 信 息 内 存 中 读 写 并 持 久 化 本 地 文 件 root.data , 性

一,server 端的存储模式为:
Server 端 存 储 模 式 (store-mode) 支 持 三 种 :
file: ( 默 认 ) 单 机 模 式 , 全 局 事 务 会 话 信 息 内 存 中 读 写 并 持 久 化 本 地 文 件 root.data , 性 能 较 高 ( 默 认 )。
db: 高 可 用 模 式 , 全 局 事 务 会 话 信 息 通 过 d b 共 享 , 相 应 性 能 差 些。
redis: Seata-server 1 3 及 以 上 版 本 支 持 , 性 能 较 高 , 存 在 事 务 信 息 丢 失 风 险 , 请 提 前 配 置 适 合 当 前 场 景 的 red is 持 久 化 配 置。
资 源 目 录 : https://github.com/seata/seata/tree/l . 3.0/scri Qt
· client
存 放 client 端 sq | 脚 本 , 参 数 配 置
· config-center
各 个 配 置 中 心 参 数 导 入 脚 本 , config.txt( 包 aserver和Client , 原 名 nacos-config.txt ) 为 通 用 参 数 文 件
server
server 端 数 据 库 脚 本 及 各 个 容 器 配 置。

 

注:如果对seata 不了解可以参考文章:Spring Cloud Alibaba分布式事务组件 seata 详解(小白都能看懂) - 古渡蓝按 - 自由互联 (cnblogs.com)

二,修改存储模式

我们使用DB模式。

修改配置文件:file.conf (路径:seata/conf/file.conf)

1,修改默认配置:

 

 2,配置DB信息

 

 3,创建数据库

 

 4,新建表结构,运行第三步里面SQL文件

 

5,配置nacos 注册中心

为什么? 因为微服务或者客户端要和事务协调者进行通信,我们得注册到注册中心,不然无法进行通信。

 

6,修改配置中心的文件 registry.conf  (路径:seata/conf/registry.conf)

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 7,可以配置负载均衡的策略(也可以不用)

 

 8,为什么要用配置中心?对各个seata的配置进行一个统一保存。

修改配置中心:registry.conf  (路径:Seata/conf/registry.conf) 注:行号,这个是第7行,config里面进行修改。

 

 如果使用的是 file 模式的话,它存储的就是在config.txt 里面。

 

 

 9,修改config.txt,里面还有个默认的是file 改成 DB。这些配置最后都会注册成 data ID。

 

 10,读取配置文件

 

 如果要在远端(linux服务器),我们可以使用命令。

Shell

sh ${SEATAPATH}/script/config-center/nacos/nacos-config.sh -h localhost -p 8848 -g SEATA_GROUP -T XXXX(这里自己配置)

 

 

 

注册成功:它会把每一个的配置都注册成一个 data ID。

 

 

 11,启动 Seata Server 

 

 

 

 12,搭建client 端

1.在项目中导入依赖:

 2,对各个微服务对应的数据库添加undo_log 表(记录数据的操作)

 

 3,如果进行了分组,就在nacos.seata 配置分组信息

 

 4,告诉客户端的注册信息

 

 5,编写配置中心

 

 

 6,使用分布式注解: @GlobalTransactional

 

到这里就可以使用分布式组件 Seata 了。

 

编写不易:点个关注,或者打赏一下吧!!!

 

上一篇:K8S原来如此简单(七)存储
下一篇:没有了
网友评论