Data Synchronization Config
This document focuses on how to use different data synchronization strategies. Data synchronization refers to the strategy used to synchronize data to ShenYu gateway after shenyu-admin background operation data. ShenYu gateway currently supports ZooKeeper, WebSocket, HTTP Long Polling, Nacos, Etcd and Consul for data synchronization.
data:image/s3,"s3://crabby-images/1d4a8/1d4a805d9dd6d65e30090d95ee8509938b6efc59" alt=""
For details about the data synchronization principles, see Data Synchronization Design in the design document.
#
WebSocket Synchronization Config(default strategy, recommend)Apache ShenYu
gateway configAdd these dependencies in
pom.xml
:
<!-- apache shenyu data sync start use websocket--> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-websocket</artifactId> <version>${project.version}</version> </dependency>
data:image/s3,"s3://crabby-images/b81cb/b81cba729e5340ee7d56cb64c563797b494c3640" alt=""
Add these config values in yaml file:
shenyu: sync: websocket : # urls: address of shenyu-admin,multi-address will be separated with (,). urls: ws://localhost:9095/websocket allowOrigin: ws://localhost:9195
data:image/s3,"s3://crabby-images/ce915/ce915dd6db399777242b50849b030c697df0e666" alt=""
shenyu-admin
configAdd these config values in yaml file:
shenyu: sync: websocket: enabled: true
data:image/s3,"s3://crabby-images/5ae46/5ae463563b8e9e5fcffe3e90c3d46e3559b35c32" alt=""
After the connection is established, the data will be fully obtained once, and the subsequent data will be updated and added increments, with good performance. It also supports disconnection (default: 30
seconds). This mode is recommended for data synchronization and is the default data synchronization strategy of ShenYu.
#
Zookeeper Synchronization ConfigPlease pay attention! From ShenYu 2.5.0, ShenYu will no longer support Zookeeper 3.4.x or below version. If you're already using Zookeeper, You need to use Zookeeper with a higher version and initialize the data.
Apache ShenYu
gateway configAdd these dependencies in
pom.xml
:<!-- apache shenyu data sync start use zookeeper--> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-zookeeper</artifactId> <version>${project.version}</version> </dependency>
Add these config values in yaml file:
shenyu: sync: zookeeper: url: localhost:2181 #url: config with your zk address, used by the cluster environment, separated with (,). sessionTimeout: 5000 connectionTimeout: 2000
data:image/s3,"s3://crabby-images/4462b/4462b040276f84477492284e06530a4a5c9d3072" alt=""
shenyu-admin
config
Add these config values in yaml file:
shenyu: sync: zookeeper: url: localhost:2181 #url: config with your zk address, used by the cluster environment, separated with (,). sessionTimeout: 5000 connectionTimeout: 2000
data:image/s3,"s3://crabby-images/029a7/029a74406a1cfc667cc249c2afda99169f4f5e33" alt=""
It is a good idea to use ZooKeeper synchronization mechanism with high timeliness, but we also have to deal with the unstable environment of ZK, cluster brain splitting and other problems.
#
HTTP Long Polling Synchronization ConfigApache ShenYu
gateway config
Add these dependencies in pom.xml
:
<!-- apache shenyu data sync start use http--> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-http</artifactId> <version>${project.version}</version> </dependency>
data:image/s3,"s3://crabby-images/553e6/553e609d6463b977e9d83b1de55a4b5ba1682721" alt=""
Add these config values in yaml file:
shenyu: sync: http: url: http://localhost:9095 #url: config your shenyu-admin ip and port,cluster IP by split by (,)
data:image/s3,"s3://crabby-images/9f2eb/9f2eb79968cf458717ddad7a6bbc9f67c97d6476" alt=""
shenyu-admin
configAdd these config values in yaml file:
shenyu: sync: http: enabled: true
data:image/s3,"s3://crabby-images/3438b/3438b34abe91f0f711b1ae98df6509ca1163706f" alt=""
HTTP long-polling makes the gateway lightweight, but less time-sensitive. It pulls according to the group key, if the data is too large, it will have some influences, a small change under a group will pull the entire group.
#
Nacos Synchronization ConfigApache ShenYu
gateway config
Add these dependencies in pom.xml
:
<!-- apache shenyu data sync start use nacos--> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-nacos</artifactId> <version>${project.version}</version> </dependency>
data:image/s3,"s3://crabby-images/f6c4e/f6c4e0e5092e8b11df6c38f6a8cf728899ec1307" alt=""
Add these config values in yaml file:
shenyu: sync: nacos: url: localhost:8848 # url: config with your nacos address, please use (,) to split your cluster environment. namespace: 1c10d748-af86-43b9-8265-75f487d20c6c username: password: acm: enabled: false endpoint: acm.aliyun.com namespace: accessKey: secretKey: # other configure,please refer to the naocs website.
data:image/s3,"s3://crabby-images/75fb1/75fb13ba74a37ea93f2bb62276218b56bc4feb26" alt=""
shenyu-admin
configAdd these config values in yaml file:
shenyu: sync: nacos: url: localhost:8848 namespace: 1c10d748-af86-43b9-8265-75f487d20c6c username: password: acm: enabled: false endpoint: acm.aliyun.com namespace: accessKey: secretKey: # url: config with your nacos address, pls use (,) to split your cluster environment. # other configure,pls refer to the naocs website.
data:image/s3,"s3://crabby-images/25d3b/25d3b2a8254b8d035bce5164ff585e869297b2be" alt=""
#
Etcd Synchronization ConfigApache ShenYu
gateway configAdd these dependencies in
pom.xml
:
<!-- apache shenyu data sync start use etcd--> <dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-etcd</artifactId> <version>${project.version}</version> <exclusions> <exclusion> <groupId>io.grpc</groupId> <artifactId>grpc-grpclb</artifactId> </exclusion> <exclusion> <groupId>io.grpc</groupId> <artifactId>grpc-netty</artifactId> </exclusion> </exclusions> </dependency>
data:image/s3,"s3://crabby-images/8cca9/8cca9b1ad19cd239432390e52d636b87338e790b" alt=""
Add these config values in yaml file:
shenyu: sync: etcd: url: http://localhost:2379 #url: config with your etcd address, used by the cluster environment, separated with (,).
data:image/s3,"s3://crabby-images/ac9da/ac9daa872b054bd51874c7dfd348fec362a3721c" alt=""
shenyu-admin
configAdd these config values in yaml file:
shenyu: sync: etcd: url: http://localhost:2379 #url: config with your etcd address, used by the cluster environment, separated with (,).
data:image/s3,"s3://crabby-images/4080b/4080b5e6f14899e82fcf41c9cd192b2e1099f7b7" alt=""
#
Consul Synchronization ConfigApache ShenYu
gateway config
Add these dependencies in pom.xml
:
<!-- apache shenyu data sync start use consul--><dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-sync-data-consul</artifactId> <version>${project.version}</version></dependency>
data:image/s3,"s3://crabby-images/0dece/0dece94013161443487bedacc718092e7d147803" alt=""
Add these config values in yaml file:
shenyu: sync: consul: url: http://localhost:8500 waitTime: 1000 # query wait time watchDelay: 1000 # Data synchronization interval
data:image/s3,"s3://crabby-images/4d6a0/4d6a0a73ba59ba79b58dcc7f3b9aead0657f571c" alt=""
shenyu-admin
configAdd these config values in yaml file:
shenyu: sync: consul: url: http://localhost:8500
data:image/s3,"s3://crabby-images/c6cd8/c6cd8bb63023a8962dd55d374b3aad6107394c0a" alt=""
After the data synchronization strategy of Apache ShenYu gateway and shenyu-admin is reconfigured, the microservice needs to be restarted.
the Apache ShenYu gateway and shenyu-admin must use the same synchronization strategy.