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


    一,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 了。

     

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

     

  • 相关阅读:
    从零开始学习 Java:简单易懂的入门指南之Stream流(二十七)
    【数据库编程-SQLite3(四)】基本常用操作
    Nextcloud删除动态/活动日志(activity log)
    python flet 设置全局字体
    万字逐行解析与实现Transformer,并进行德译英实战(一)
    LaTex常用技巧6:矩阵编写总结
    安卓常见设计模式13------过滤器模式(Kotlin版)
    Docker(V3)与Docker Compose的安装
    java计算机毕业设计健康饮食推荐系统MyBatis+系统+LW文档+源码+调试部署
    练习1-5:窗口函数,关联查询,子查询,分组聚合查询
  • 原文地址:https://www.cnblogs.com/blbl-blog/p/16057062.html