ZooKeeper Registry Center

ZooKeeper serves as a critical registry center implementation within the Seata component.

This document is based on Seata 1.7.0, demonstrating how to register Seata with ZooKeeper using a file as the configuration center.

It is recommended to use ZooKeeper version 3.4.13 or above. The following example uses ZooKeeper version 3.4.14.

Prerequisites

Before registering Seata with ZooKeeper, ensure that the ZooKeeper service is running. If you are unfamiliar with basic ZooKeeper usage, you can refer to the ZooKeeper official documentation.

Quick Start

Integrating Seata with ZooKeeper involves simple steps, roughly categorized as “Adding Maven Dependencies” and “Configuring the Registry Center.”

Server-side Registry Center Configuration

Download Seata 1.7.0 release and extract the files.

Modify the corresponding configuration in /conf/application.yaml. For other configuration options, refer to the Seata configuration reference.

  1. seata:
  2. registry:
  3. type: zk
  4. zk:
  5. cluster: default
  6. server-addr: 127.0.0.1:2181
  7. session-timeout: 6000
  8. connect-timeout: 2000
  9. username: ""
  10. password: ""

Execute /bin/seata-server.bat (Windows) or /bin/seata-server.sh (Unix) to start Seata. The service will run on the local port 8091. Open the ZooKeeper command-line client and enter ls /registry/zk/default, check if the node address is listed, indicating successful registration (as shown below).

  1. [zk: localhost:2181(CONNECTED) 1] ls /registry/zk/default
  2. [127.0.0.1:8091]

Client-side Configuration

If you are using the io.seata:seata-spring-boot-starter dependency, you need to add the following ZooKeeper configuration in the application.yml file. For additional configurations, please refer to the configuration reference :

  1. seata:
  2. registry:
  3. type: zk
  4. zk:
  5. server-addr: 127.0.0.1:2181
  6. session-timeout: 6000
  7. connect-timeout: 2000
  8. username:
  9. password:
  10. tx-service-group: default_tx_group
  11. service:
  12. vgroup-mapping:
  13. default_tx_group: default

Alternatively, if you are using the io.seata:seata-all dependency, add the ZooKeeper configuration in the registry.conf file. For additional configurations, please refer to the configuration reference:

  1. zk {
  2. serverAddr = "127.0.0.1:2181"
  3. sessionTimeout = 6000
  4. connectTimeout = 2000
  5. username = ""
  6. password = ""
  7. }

After configuring the client, start the application and wait for a moment, the Seata service will be operational soon.