当前位置:   article > 正文

Springboot整合Dubbo-Seate-Nacos,解决各种坑_seate和nacos问题

seate和nacos问题

1.简介

本文主要介绍SpringBoot2.2.2 + Dubbo 2.7.5 + Nacos 1.1.3 +Seata 1.4.2整合来实现Dubbo分布式事务管理,使用Nacos 作为 Dubbo和Seata的注册中心和配置中心,使用 MySQL 数据库和 MyBatis来操作数据。

如果你还对SpringBootDubboNacosSeataMybatis 不是很了解的话,可以从以下官网中了解基本的使用方法。

2.环境准备

2.1 下载nacos并安装启动

nacos下载:https://github.com/alibaba/nacos/releases/tag/1.1.3

Nacos 快速入门:Quick Start for Nacos

/=============== 注意:这个快速入门,有坑,官方文档缺失: =====================

下载Nacos后需要先:

1.创建nacos的数据库,并导入nacos-mysql.sql文件,创建nacos所需要的表;

2.配置数据库: 找到conf下的application.properties,把db的配置打开,正确找到你的数据库连接

  1. spring.datasource.platform=mysql
  2. db.num=1
  3. db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=10000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
  4. db.user.0=root
  5. db.password.0=root

报错问题:

直接双击startup.cmd可能会报错, 如果你已经配置了数据库,也建好了表,那么就考虑是集群和单机的问题。 从源码上下载的zip压缩包方式,默认是使用集群方式的,在conf下的application.properties下可以设置以集群还是单机启动,也可以使用命令

cmd startup.cmd -m standalone
或者修改startup.cmd指定mode=standalone,如下
  1. set MODE="standalone"
  2. set FUNCTION_MODE="all"
  3. set SERVER=nacos-server
  4. set MODE_INDEX=-1
  5. set FUNCTION_MODE_INDEX=-1
  6. set SERVER_INDEX=-1
  7. set EMBEDDED_STORAGE_INDEX=-1
  8. set EMBEDDED_STORAGE=""

============== 注意:这个快速入门,有坑,官方文档缺失END: ============

启动命令 :

sh startup.sh -m standalone
 startup.cmd -m standalone

在浏览器打开Nacos web 控制台:http://192.168.10.200:8848/nacos/index.html

输入nacos的账号和密码 分别为nacos:nacos

这是时候naocs 就正常启动了。

2.1 创建命名空间

名称:state-test, 描述等随便写。 发布后会得到一个唯一ID(seate注册到nacos的时候要用到)

2.2 下载seata server 并安装启动

注意:也要下载源码Source,这点官方列子中没有提到,很坑

2.2.1  修改 seata-server-1.4.2 的 conf/registry.conf 配置

目前seata支持如下的file、nacos 、apollo、zk、consul的注册中心和配置中心。这里我们以nacos 为例。将 type 改为 nacos

  1. registry {
  2. # file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
  3. type = "nacos"
  4. nacos {
  5. application = "seata-server"
  6. serverAddr = "127.0.0.1:8848"
  7. group = "SEATA_GROUP"
  8. namespace = "70e93027-ba24-4b45-9ecf-971e6b8e7f04"
  9. cluster = "default"
  10. username = "nacos"
  11. password = "nacos"
  12. }
  13. }
  14. config {
  15. # file、nacos 、apollo、zk、consul、etcd3
  16. type = "nacos"
  17. nacos {
  18. serverAddr = "127.0.0.1:8848"
  19. namespace = "70e93027-ba24-4b45-9ecf-971e6b8e7f04"
  20. group = "SEATA_GROUP"
  21. username = "nacos"
  22. password = "nacos"
  23. dataId = "seataServer.properties"
  24. }
  25. }
  • serverAddr = "127.0.0.1:8848" :nacos 的地址

  • namespace = "" :nacos的命名空间默认为``

  • cluster = "default" :集群设置未默认 default

** 经过本人亲测seata-service1.4.2版本,namespace要指定nacos的命名空间,账号密码也要

**注意:官方文档中有说明 seata0.9.0之后,配置namespace = "",可能有部分旧版本是如此。

2.2.2 修改 源码seata-1.4.2\script\config-center\config.txt配置

  1. transport.type=TCP
  2. transport.server=NIO
  3. transport.heartbeat=true
  4. transport.thread-factory.boss-thread-prefix=NettyBoss
  5. transport.thread-factory.worker-thread-prefix=NettyServerNIOWorker
  6. transport.thread-factory.server-executor-thread-prefix=NettyServerBizHandler
  7. transport.thread-factory.share-boss-worker=false
  8. transport.thread-factory.client-selector-thread-prefix=NettyClientSelector
  9. transport.thread-factory.client-selector-thread-size=1
  10. transport.thread-factory.client-worker-thread-prefix=NettyClientWorkerThread
  11. transport.thread-factory.boss-thread-size=1
  12. transport.thread-factory.worker-thread-size=8
  13. transport.shutdown.wait=3
  14. service.vgroup_mapping.order-service-seata-service-group=default
  15. service.vgroup_mapping.account-service-seata-service-group=default
  16. service.vgroup_mapping.storage-service-seata-service-group=default
  17. service.vgroup_mapping.business-service-seata-service-group=default
  18. service.enableDegrade=false
  19. service.disable=false
  20. service.max.commit.retry.timeout=-1
  21. service.max.rollback.retry.timeout=-1
  22. client.async.commit.buffer.limit=10000
  23. client.lock.retry.internal=10
  24. client.lock.retry.times=30
  25. store.mode=db
  26. store.file.dir=file_store/data
  27. store.file.max-branch-session-size=16384
  28. store.file.max-global-session-size=512
  29. store.file.file-write-buffer-cache-size=16384
  30. store.file.flush-disk-mode=async
  31. store.file.session.reload.read_size=100
  32. store.db.driver-class-name=com.mysql.jdbc.Driver
  33. store.db.datasource=dbcp
  34. store.db.db-type=mysql
  35. store.db.url=jdbc:mysql://192.168.10.200:3306/seata?useUnicode=true
  36. store.db.user=lidong
  37. store.db.password=cwj887766@@
  38. store.db.min-conn=1
  39. store.db.max-conn=3
  40. store.db.global.table=global_table
  41. store.db.branch.table=branch_table
  42. store.db.query-limit=100
  43. store.db.lock-table=lock_table
  44. recovery.committing-retry-period=1000
  45. recovery.asyn-committing-retry-period=1000
  46. recovery.rollbacking-retry-period=1000
  47. recovery.timeout-retry-period=1000
  48. transaction.undo.data.validation=true
  49. transaction.undo.log.serialization=jackson
  50. transaction.undo.log.save.days=7
  51. transaction.undo.log.delete.period=86400000
  52. transaction.undo.log.table=undo_log
  53. transport.serialization=seata
  54. transport.compressor=none
  55. metrics.enabled=false
  56. metrics.registry-type=compact
  57. metrics.exporter-list=prometheus
  58. metrics.exporter-prometheus-port=9898
  59. client.report.retry.count=5
  60. service.disableGlobalTransaction=false
  61. client.support.spring.datasource.autoproxy=true

配置的详细说明参考官网:Seata 参数配置

这里主要修改了如下几项:

  • store.mode :存储模式 默认file 这里我修改为db 模式 ,并且需要三个表global_tablebranch_tablelock_table

  • store.db.driver-class-name: 0.8.0版本默认没有,会报错。添加了 com.mysql.jdbc.Driver

  • store.db.datasource=dbcp :数据源 dbcp

  • store.db.db-type=mysql : 存储数据库的类型为mysql</

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/165678
推荐阅读
相关标签
  

闽ICP备14008679号