Consul 配置中心

以 Consul 作为注册中心 的基础上,将 Seata 配置放到 Consul 中

本文基于 Seata 1.4.2,Consul 版本建议 1.8+,下文以 Consul 1.11.2 为例

准备工作

当您决定使用 Consul 作为 Seata 配置中心前,请确保已经启动 Consul 服务。

快速上手

将 Consul 作为 Seata 配置中心的操作步骤非常简单,可分为以下几步:

  1. seata-server 配置 Consul 为配置中心
  2. 提交 Key-Value 配置至 Consul
  3. Client 端 配置 Consul 为配置中心

配置 Consul 为配置中心

首先,请确保您的 Consul 服务已启动

在 Seata 目录下 /conf/registry.conf 中加入对应配置中心,其余配置参考

  1. config {
  2. type = "consul"
  3. consul {
  4. serverAddr = "127.0.0.1:8500"
  5. aclToken = ""
  6. }
  7. }

此时启动 Seata 服务,会提示如下字样信息,可先关闭服务

  1. config operation timeout,cost:5015 ms,op:GET,dataId:store.mode
  2. config operation timeout,cost:5006 ms,op:GET,dataId:metrics.enabled
  3. config operation timeout,cost:5001 ms,op:GET,dataId:transport.threadFactory.bossThreadPrefix
  4. config operation timeout,cost:5009 ms,op:GET,dataId:transport.threadFactory.workerThreadPrefix
  5. # 此处省略类似的其他信息~

提交 Key-Value 配置至 Consul

出现以上报错信息是因为 Consul 中缺少对应配置,请从以下方式中选择其中一种方式提交配置到 Consul Key/Value 中

  1. 通过 Consul 控制台 ui,Key/Value -> create
  2. 通过 http 请求
  3. 通过 Consul 命令行工具
  4. 推荐:使用官方提供的上传配置脚本

tips: 1.4.2 需要逐个创建 key-value,1.5.0 后支持 key 对应文件

以 store.mode=file 为例,提交报错信息对应的配置,在这里可以找到默认配置

  1. store.mode=file
  2. store.publicKey=
  3. store.file.dir=file_store/data
  4. store.file.maxBranchSessionSize=16384
  5. # 剩下的配置项省略~

推荐使用官方脚本: 以上方式 1~3 需要逐个添加配置,操作较为繁琐,为此官方提供了 脚本默认配置 以快速添加配置

将 config.txt 放在 consul-config.sh 的上层目录, 根据自己的需要微调 config.txt 的配置(主要是 seata.mode 及 seata.file | seata.db | seata.redis 这几个前缀的配置)

执行如下命令

  1. sh {PATH}/consul-config.sh -h localhost -p 8500

具体操作可参考README.md

此时重启 Seata 服务,发现不再报错,即成功使用 Consul 作为配置中心了,后面如需调整配置,可前往控制台单独修改对应的配置,修改后需重启服务

Client 端 配置 Consul 为配置中心

以 SpringBoot 项目为例,在项目 pom.xml 中加入

  1. <dependency>
  2. <groupId>io.seata</groupId>
  3. <artifactId>seata-spring-boot-starter</artifactId>
  4. <version>最新版(Seata版本)</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.cloud</groupId>
  8. <artifactId>spring-cloud-starter-consul-config</artifactId>
  9. </dependency>

Client端配置

在 application.yml 中加入对应的配置中心,其余配置参考

  1. seata:
  2. config:
  3. type: consul
  4. consul:
  5. server-addr: 127.0.0.1:8500

重启 Client 即可