SpringBoot整合Seata注册到Nacos服务

项目引入pom文件

<!--  SpringCloud Seata 组件-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-seata</artifactId><version>${alibaba.seata}</version><exclusions><exclusion><groupId>io.seata</groupId><artifactId>seata-all</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId><version>${seata}</version>
</dependency>

yml配置文件

  #====================================Seata Config===============================================
seata:enabled: truetx-service-group: my_test_tx_group # 1 事务群组(可以每个应用独立取名,也可以使用相同的名字)这个需要跟nacos的配置名字保持一致registry:type: nacosnacos:server-addr: ${nacos-addr} #nacos地址 localhost:8848application: service-seatanamespace: seata   #seata在nacos中配置的命名空间group: SEATA_GROUPcluster: defaultusername: nacospassword: nacosconfig:type: nacosnacos:server-addr: ${nacos-addr}  #nacos地址 localhost:8848namespace: seata   #seata在nacos中配置的命名空间group: SEATA_GROUPusername: nacospassword: nacos

Seata文件配置

修改file.conf

## transaction log store, only used in seata-server
store {## store mode: file、db、redismode = "db"  ##将file改为db## file store propertyfile {## store location dirdir = "sessionStore"# branch session size , if exceeded first try compress lockkey, still exceeded throws exceptionsmaxBranchSessionSize = 16384# globe session size , if exceeded throws exceptionsmaxGlobalSessionSize = 512# file buffer size , if exceeded allocate new bufferfileWriteBufferCacheSize = 16384# when recover batch read sizesessionReloadReadSize = 100# async, syncflushDiskMode = async}## database store propertydb {## the implement of javax.sql.DataSource, such as DruidDataSource(druid)/BasicDataSource(dbcp)/HikariDataSource(hikari) etc.datasource = "druid"## mysql/oracle/postgresql/h2/oceanbase etc.dbType = "mysql"driverClassName = "com.mysql.jdbc.Driver"url = "jdbc:mysql://127.0.0.1:3306/db_seata"     ##修改为自己的数据库连接user = "root"password = "123456"minConn = 5maxConn = 30globalTable = "global_table"branchTable = "branch_table"lockTable = "lock_table"queryLimit = 100maxWait = 5000}## redis store propertyredis {host = "127.0.0.1"port = "6379"password = ""database = "0"minConn = 1maxConn = 10queryLimit = 100}
}

修改regitry.conf

registry {# file 、nacos 、eureka、redis、zk、consul、etcd3、sofatype = "nacos"   ##我们使用的是nacos,因此将type修改为nacosnacos {application = "service-seata"  #application填写注册的服务名serverAddr = "127.0.0.1:8848"  #填写nacos注册中心地址group = "SEATA_GROUP" #group是服务注册的分组。可不填,注:是服务分组,不是配置分组namespace = "seata"  #填写服务注册时的命名空间,可不填,不填默认的时public命名空间cluster = "default" #cluster不用改username = "nacos" password = "nacos"}file {name = "file.conf"}
}
config {# file、nacos 、apollo、zk、consul、etcd3type = "nacos"nacos {serverAddr = "127.0.0.1:8848"namespace = "seata"group = "SEATA_GROUP"username = "nacos"password = "nacos"}file {name = "file.conf"}
}

将配置导入nacos

本来我们是需要把file.conf和registry.conf放入我们的项目中的,这里直接导入到nacos。需要什么配置直接从nacos中获取。不需要放在项目中了

修改conf.txt

在conf目录下

service.vgroupMapping.my_test_tx_group=default  #需要跟配置文件的保持一致
store.mode=db
store.db.datasource=druid
store.db.dbType=mysql
store.db.driverClassName=com.mysql.jdbc.Driver
store.db.url=jdbc:mysql://127.0.0.1:3306/db_seata?useUnicode=true  #自己的数据库连接地址
store.db.user=root
store.db.password=123456
store.db.minConn=5
store.db.maxConn=30
store.db.globalTable=global_table
store.db.branchTable=branch_table
store.db.queryLimit=100
store.db.lockTable=lock_table
store.db.maxWait=5000
创建命名空间

执行导入

打开git bash。

输入以下命令:

sh nacos-config.sh -h localhost -p 8848 -g SEATA_GROUP -t seata -u nacos -w nacos

注:命令解析:-h -p 指定nacos的端口地址;-g 指定配置的分组,注意,是配置的分组;-t 指定命名空间id; -u -w指定nacos的用户名和密码,同样,这里开启了nacos注册和配置认证的才需要指定。

导入成功之后如下图:

数据库配置

db_seata数据库中导入数据表

branch_table

global_table

lock_table

业务数据库中导入数据表

undo_log

启动Seata

配置成功

记得主接口增加注解 @GlobalTransactional

远程调用服务增加注解 @Transactional

大功告成!!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/749484.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

八股文打卡day34——数据库(11)

面试题&#xff1a;谈一下你对MySQL中锁的了解&#xff1f; 我的回答&#xff1a; 首先&#xff0c;从锁的粒度来分&#xff0c;可以分为&#xff1a; ①全局锁。全局锁主要用于数据库的备份&#xff0c;加上全局锁&#xff0c;意味着整个数据库都处于只读的状态。 ②行级锁。…

初学者必看的python中类型转换

Python中常见的类型转换 int(x [,base ]) 将x转换为一个整数 long(x [,base ]) 将x转换为一个长整数 float(x ) 将x转换到一个浮点数 complex(real [,imag ]) 创建一个复数 str(x ) 将对象 x 转换为字符串 repr(x ) 将对象 x 转换为表达式字符串 eval(str ) 用来计算在字符串中…

`sig_atomic_t` 是C语言中的一个数据类型,它通常用于在信号处理程序中声明变量

例子 static volatile sig_atomic_t signal_num; static void SigTerm(int signo) {running 0;signal_num signo; }int main(int argc, char *argv[]) {signal(SIGTERM, SigTerm);signal(SIGINT, SigTerm); }sig_atomic_t 是C语言中的一个数据类型&#xff0c;它通常用于在信…

(57)最富有客户的资产总量

文章目录 1. 每日一言2. 题目3. 解题思路3.1 法一3.2 法二 4. 代码4.1 法一4.2 法二 5. 结语 1. 每日一言 Care and diligence bring luck. 谨慎和勤奋&#xff0c;带来好运气。 2. 题目 题目链接&#xff1a;最富有客户的资产总量 给你一个 m x n 的整数网格 accounts &…

作业字符数组

凯撒密码 凯撒密码&#xff08;Caesar&#xff09;加密时会将明文中的 每个字母 都按照其在字母表中的顺序向后&#xff08;或向前&#xff09;移动固 定数目&#xff08; 循环移动 &#xff09;作为密文。例如&#xff0c;当偏移量是左移 3 的时候&#xff08;解密时的密钥…

python二级备考(3)-综合应用

1 《命运》是著名科幻作家倪匡的作品。这里给出《命运》的一个网络版本文件&#xff0c;文件名为“命运. txt”。 问题1 (5分) :在PY301-1. py文件中修改代码&#xff0c;对“命运. txt”文件进行字符频次统计&#xff0c;输出频次最高的中文字符(不包含标点符号)及其频次&…

SpringBoot Servlet容器启动解析

介绍 容器架构 容器处理请求 容器启动全局流程解析 启动前准备 WebServer创建入口 WebServer创建 Servlet启动 Web容器工厂类加载解析 Web容器个性化配置 属性注入 工厂类初始化 BeanPostProcessor方法实现 定制化流程 面试题 请描述下Servlet容器启动流程&#xff1f;介绍下…

Android什么情况下会出现内存泄漏以及怎么解决?

1.什么情况下会出现内存泄漏? (1)单例模式下为什么会造成内存泄漏? 因为单例的生命周期和应用的生命周期是一致的,如果往单例模式里面传了一个生命周期比较短的对象,比如Activity,就会导致Activity不能释放,导致内存泄漏。我们可以传context.getAppliactionContext,而…

周记-week3-人脸识别

感觉已经到极限了&#xff0c;&#xff0c;看看会不会上天~ 主要任务是人脸识别 Pytorch模型训练-----------数据集加载之ImageFolder之全过程 DataLoader的使用

4.10.CVAT——3D对象标注

文章目录 1. 创建任务2. 3D 任务工作区3.标准 3D 模式 Standard 3D mode4. 用长方体进行注释4.1. 用shapes进行注释4.2. 使用长方体进行跟踪Tracking 使用 3D 注释工具来标记 3D 对象和场景&#xff0c;例如车辆、建筑物、景观等。 1. 创建任务 要创建 3D 任务&#xff0c;您必…

hoverEnabled

hoverEnabled 是在 Qt Quick 中用于控制鼠标悬停事件是否可用的属性。当 hoverEnabled 设置为 true 时&#xff0c;表示该元素可以响应鼠标的悬停事件&#xff1b;设置为 false 时&#xff0c;则表示禁用鼠标悬停事件。 在 Qt Quick 中&#xff0c;鼠标悬停事件指的是当鼠标光…

kubernetes实战(2)

kubectl常用命令 1&#xff0c;创建deployment并启动pod(类似docker run): kubectl run --imagenginx nginx-app --port80 --env"DOMAINcluster" deployment "nginx-app" created 2&#xff0c;根据创建的deployment暴露新服务端口&#xff1a; kubect…

unity3d Animal Controller的Animal组件中General基础部分理解

控制器介绍 动物脚本负责控制动物的所有运动逻辑.它管理所有的动画师和刚体参数,以及所有的状态和模式,动物可以做。 动物控制器 是一个动画框架控制器,根动或到位,为任何生物或人形。它利用刚体与物理世界的互动和动画师的玩动画。 States States 是不互相重叠的动画。例如…

Redis语法总结

Redis语句总结 一、基本概念 Redis 全称&#xff1a; Remote Dictionary Server&#xff08;远程字典服务器&#xff09;的缩写&#xff0c;以字典结构存储数据&#xff0c;并允许其他应用通过TCP协议读写字典中的内容。 使用C语言编写&#xff0c;并以内存作为数据存储介质&a…

PyTorch学习笔记之基础函数篇(十四)

文章目录 7.14 torch.fmod() 函数7.15 torch.remainder() 函数7.16 torch.frac() 函数7.17 torch.round() 函数 7.14 torch.fmod() 函数 在PyTorch中&#xff0c;torch.fmod 函数用于计算张量&#xff08;tensor&#xff09;中每个元素除以另一个张量或标量后的浮点余数1。 函…

复习知识点

1. Java常用API 1.1 String类 在java中&#xff0c;String类代表字符串&#xff0c;字符串是常量的&#xff0c;不能被改变。如果想改变字符串。可以用字符串的缓冲区&#xff0c;StringBuffer、StringBuilder 1.1.1 String类的创建方式 第一种&#xff08;常用&#xff09…

一文搞懂PCL中自定义点云类型的构建与函数使用

上周猛男快乐开发时遇到个bug&#xff0c;要用pcl的函数对自定义的点云进行处理。一起解决问题时遇到了很多问题&#xff0c;解决后整理出来分享给各位参考&#xff0c;以免踩一样的坑&#x1f60a;。文章中自定义的点我用PointT来表示&#xff0c;自定义点云一般指的是pcl::Po…

什么是UUID?

UUID&#xff08;Universally Unique Identifier&#xff09;即通用唯一识别码&#xff0c;主要用于在分布式环境中生成全局唯一标识符的标准方法。 UUID是一个128位的数字&#xff0c;通常用32个十六进制数表示&#xff0c;并且按照特定格式显示&#xff0c; 例如&#xff1a…

Linux命令行学习之操作文件和目录

目录 通配符 mkdir – 创建目录 cp – 复制文件和目录 mv – 移动和重命名文件 rm – 删除文件和目录 ln – 创建链接 硬链接 符号链接 本文介绍Linux用于操作文件和目录的命令&#xff0c;介绍的命令有&#xff1a; cp – 复制文件和目录mv – 移动/重命名文件和目录…

文件上传漏洞------一句话木马原理解析

目录 一、实验环境 二、实验过程 构造一句话木马 一句话木马的使用: 木马原理解析: 一、实验环境 小皮面板搭建:upload-labs靶场 二、实验过程 构造一句话木马 这是一个最简单的一句话木马&#xff0c;我们用GET传参接受了两个参数&#xff0c;其最终目的是构造出:ass…