SpringcloudAlibaba+Nacos+Seata1.4.0分布式事务配置

seata-develop链接:https://pan.baidu.com/s/1WAMPzIwof3Z_RwfE-w6JqQ

提取码:df5n

seata-server-1.4.0链接:https://pan.baidu.com/s/1JfsvN2ir6piou3aUbZO_Ow

提取码:6lt3

官网源码地址:https://github.com/seata/seata

网上许多搭建版本趋向于老版本,故自己参考官网 http://seata.io/en-us/ 和其他搭建方法总结出一套完整说明,故记录一哈

 

环境搭建 Seata+Nacos+Springcloud Alibaba

Server配置:

..\seata\conf 目录下

配置:file.conf

 

配置:registry.conf

 

服务端及配置完成,接下来是创建对应数据库

..\seata-develop\script\server\db 目录下根据对应的数据库执行对应的sql文件

先创建数据库或者导入已经使用的数据库,但是需要跟file.conf配置的数据库名字对应即可

 

需要在所有服务数据库下创建回滚日志表

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for undo_log
-- ----------------------------
DROP TABLE IF EXISTS `undo_log`;
CREATE TABLE `undo_log`  (
  `id` bigint(0) NOT NULL AUTO_INCREMENT,
  `branch_id` bigint(0) NOT NULL,
  `xid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `context` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `rollback_info` longblob NOT NULL,
  `log_status` int(0) NOT NULL,
  `log_created` datetime(0) NOT NULL,
  `log_modified` datetime(0) NOT NULL,
  `ext` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE INDEX `ux_undo_log`(`xid`, `branch_id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '回滚日志表' ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of undo_log
-- ----------------------------

SET FOREIGN_KEY_CHECKS = 1;

启动顺序,启动naocs(nacos配置自行百度)

..\seata\bin目录下 执行

遇到问题一:执行日志路径错误

在bin同级创建log文件

seata-server.bat 

启动成功后访问localhost:8848/nacos (nacos默认端口)

 

出现上图表示配置成功

 

接下来配置客户端:

..\seata-develop\script\config-center 该目录下将nacos和config.txt复制到

..\seata\conf目录下

 

然后配置复制后的config.txt

transport.type=TCP
transport.server=NIO
transport.heartbeat=true
transport.enableClientBatchSendRequest=false
transport.threadFactory.bossThreadPrefix=NettyBoss
transport.threadFactory.workerThreadPrefix=NettyServerNIOWorker
transport.threadFactory.serverExecutorThreadPrefix=NettyServerBizHandler
transport.threadFactory.shareBossWorker=false
transport.threadFactory.clientSelectorThreadPrefix=NettyClientSelector
transport.threadFactory.clientSelectorThreadSize=1
transport.threadFactory.clientWorkerThreadPrefix=NettyClientWorkerThread
transport.threadFactory.bossThreadSize=1
transport.threadFactory.workerThreadSize=default
transport.shutdown.wait=3
#修改my_test_tx_group为自定义服务seata-group
service.vgroupMapping.seata-group=default

service.default.grouplist=127.0.0.1:8091
service.enableDegrade=false
service.disableGlobalTransaction=false
client.rm.asyncCommitBufferLimit=10000
client.rm.lock.retryInterval=10
client.rm.lock.retryTimes=30
client.rm.lock.retryPolicyBranchRollbackOnConflict=true
client.rm.reportRetryCount=5
client.rm.tableMetaCheckEnable=false
client.rm.tableMetaCheckerInterval=60000
client.rm.sqlParserType=druid
client.rm.reportSuccessEnable=false
client.rm.sagaBranchRegisterEnable=false
client.tm.commitRetryCount=5
client.tm.rollbackRetryCount=5
client.tm.defaultGlobalTransactionTimeout=60000
client.tm.degradeCheck=false
client.tm.degradeCheckAllowTimes=10
client.tm.degradeCheckPeriod=2000
#此处配置file.conf一致
store.mode=db

store.publicKey=
store.file.dir=file_store/data
store.file.maxBranchSessionSize=16384
store.file.maxGlobalSessionSize=512
store.file.fileWriteBufferCacheSize=16384
store.file.flushDiskMode=async
store.file.sessionReloadReadSize=100
store.db.datasource=druid
store.db.dbType=mysql
#配置数据库相关信息
store.db.driverClassName=com.mysql.cj.jdbc.Driver
store.db.url=jdbc:mysql://127.0.0.1:3306/seata?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT%2B8&allowPublicKeyRetrieval=true
store.db.user=root
store.db.password=123123

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
store.redis.mode=single
store.redis.single.host=127.0.0.1
store.redis.single.port=6379
store.redis.maxConn=10
store.redis.minConn=1
store.redis.maxTotal=100
store.redis.database=0
store.redis.password=
store.redis.queryLimit=100
server.recovery.committingRetryPeriod=1000
server.recovery.asynCommittingRetryPeriod=1000
server.recovery.rollbackingRetryPeriod=1000
server.recovery.timeoutRetryPeriod=1000
server.maxCommitRetryTimeout=-1
server.maxRollbackRetryTimeout=-1
server.rollbackRetryTimeoutUnlockEnable=false
client.undo.dataValidation=true
client.undo.logSerialization=jackson
client.undo.onlyCareUpdateColumns=true
server.undo.logSaveDays=7
server.undo.logDeletePeriod=86400000
client.undo.logTable=undo_log
client.undo.compress.enable=true
client.undo.compress.type=zip
client.undo.compress.threshold=64k
log.exceptionRate=100
transport.serialization=seata
transport.compressor=none
metrics.enabled=false
metrics.registryType=compact
metrics.exporterList=prometheus
metrics.exporterPrometheusPort=9898

然后执行复制过来的nacos文件夹下面的nacos-config.sh脚本

如果启动成功则访问nacos查看配置文件,如果出现下图列表文件,即表示配置成功


然后重新启动seata-server及执行bin目录启动脚本

到此相关配置已经配置完成

接下来配置项目

<!--Spring Cloud Seata 分布式事务-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-seata</artifactId>
            <version>${spring.cloud.alibaba.system.version}</version>
        </dependency>
        <dependency>
            <groupId>io.seata</groupId>
            <artifactId>seata-spring-boot-starter</artifactId>
            <version>${seata.version}</version>
        </dependency>

 

网上很多需要引入文件配置才行,但是现在新增特性配置好 过后不需要引入文件

 

出现这个表示所有配置成功

使用方式:@GlobalTransactional

您好!要搭建Spring Cloud Alibaba Nacos项目,您可以按照以下步骤进行操作: 1. 创建Spring Boot项目:首先,在您的IDE中创建一个新的Spring Boot项目。 2. 添加依赖:在项目的pom.xml文件中添加相应的依赖。您需要添加以下四个核心依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> ``` 3. 配置Nacos Server地址:在application.properties(或application.yml)文件中配置Nacos Server的地址。例如: ```yaml spring.cloud.nacos.discovery.server-addr=${NACOS_SERVER_ADDR:localhost:8848} ``` 4. 创建服务提供者和消费者:根据您的需求,创建相应的服务提供者和消费者。您可以使用`@RestController`注解创建简单的RESTful接口。 5. 注册服务:在服务提供者的主类上添加`@EnableDiscoveryClient`注解,以将服务注册到Nacos Server上。 6. 调用服务:在服务消费者中使用`@RestTemplate`或Feign等方式调用服务。您可以通过在方法上添加`@LoadBalanced`注解来实现负载均衡。 7. 启动应用程序:最后,启动应用程序并验证各个微服务之间的通信是否正常。 这些是搭建Spring Cloud Alibaba Nacos项目的基本步骤。根据您的具体需求,您可能还需要配置其他功能,如动态配置等。希望对您有帮助!如有更多问题,请随时提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

平常心丷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值