Nacos Configuration Center

Nacos is an important configuration center implementation in the Seata component.

Prerequisites

Before integrating nacos-client into your Seata project, make sure that the Nacos service is already started in the background. If you are not familiar with the basic usage of Nacos, you can refer to the Nacos Quick Start first. It is recommended to use Nacos version 1.2.0 or above.

Quick Start

The steps to integrate Seata with Nacos configuration center are very simple, and can be roughly divided into “adding Maven dependencies” and “configuring Nacos configuration center” and submitting the configuration to Nacos-Server.

Add Maven Dependencies

First, you need to add the Maven dependency of nacos-client to your project’s pom.xml file, it is recommended to use Seata 1.4.0+:

  1. <dependency>
  2. <groupId>io.seata</groupId>
  3. <artifactId>seata-spring-boot-starter</artifactId>
  4. <version>latest version</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.alibaba.nacos</groupId>
  8. <artifactId>nacos-client</artifactId>
  9. <version>1.2.0 or above</version>
  10. </dependency>

Client-side Configuration Center

Add the corresponding configuration center in application.yml, other configuration references are available.

  1. seata:
  2. config:
  3. type: nacos
  4. nacos:
  5. server-addr: 127.0.0.1:8848
  6. group: 'SEATA_GROUP'
  7. namespace: ''
  8. username: 'nacos'
  9. password: 'nacos'

Server-side Configuration Center

Add the corresponding configuration center in registry.conf, other configuration references are available.

  1. config {
  2. type = "nacos"
  3. nacos {
  4. serverAddr = "127.0.0.1:8848"
  5. group = "SEATA_GROUP"
  6. namespace = ""
  7. username = "nacos"
  8. password = "nacos"
  9. }
  10. }

Upload Configuration to Nacos Configuration Center

Configuration through dataId

  1. Starting from version 1.4.2, it is supported to obtain all configuration information from a Nacos dataId. You just need to add an additional dataId configuration item.

  2. First, you need to create a new configuration in Nacos. The dataId here is seataServer.properties, and the configuration content refers to https://github.com/apache/incubator-seata/tree/develop/script/config-center/config.txt and modify it as needed.

  3. In the client, modify the configuration as follows:

  1. seata:
  2. config:
  3. type: nacos
  4. nacos:
  5. server-addr: 127.0.0.1:8848
  6. group: 'SEATA_GROUP'
  7. namespace: ''
  8. dataId: 'seataServer.properties'
  9. username: 'nacos'
  10. password: 'nacos'

Upload Configuration to Nacos Using Script

Refer to https://github.com/apache/incubator-seata/tree/develop/script/config-center/config.txt and make modifications. Then run the provided Nacos script in the repository to submit the information to the Nacos console. If any changes are needed, they can be directly made through the console.

Example: sh ${SEATAPATH}/script/config-center/nacos/nacos-config.sh -h localhost -p 8848 -g SEATA_GROUP -t 5a3c7d6c-f497-4d68-a71a-2e5e3340b3ca -u username -w password

For detailed instructions, refer to the Readme document

Afterwards, start the Seata-Server and Client (business side) applications. If the Seata-Server and Client (business side) applications were already started before importing the configuration to Nacos, they need to be restarted.

This post is translated using ChatGPT, please feedback if any omissions.