This article introduces the use of ZooKeeper data synchronization strategy in the Soul gateway framework, and a simple analysis of the source code.
background
The Soul gateway framework synchronizes data configured in the soul-admin gateway management background to the JVM memory of the soul-Bootstrap gateway application cluster.
In the process of using the gateway, the configuration needs to be changed dynamically frequently. Therefore, the data synchronization policy is crucial to the high performance of the gateway framework.
The Soul Gateway framework uses the Websocket synchronization policy by default and supports data synchronization using ZooKeeper.
The Soul uses ZooKeeper synchronization
soul-bootstrap
To introduce the zooKeeper data synchronization dependency and configure the ZK path.<dependency> <groupId>org.dromara</groupId> <artifactId>soul-spring-boot-starter-sync-data-zookeeper</artifactId> <version>${last.version}</version> </dependency> Copy the code
soul : sync: zookeeper: url: localhost:2181 sessionTimeout: 5000 connectionTimeout: 2000 Copy the code
soul-admin
You must also use the ZooKeeper synchronization policy and configure the ZooKeeper address.soul : sync: zookeeper: url: localhost:2181 sessionTimeout: 5000 connectionTimeout: 2000 Copy the code
- Start the ZooKeeper local instance.
zkServer start Copy the code
- In turn, start
soul-admin
、soul-bootstrap
; - in
soul-admin
Modify the configuration of the gateway management background, for exampledivide
Plug-in rules, the client initiates a request to check whether the rules take effect;
Soul zooKeeper synchronous source code analysis
Zookeeper synchronization principle
- Zk synchronization policy dependency
watch
Mechanism. soul-admin
Full data will be written to zK upon startup. When configuration changes, zK nodes will be added.soul-web
The module listens for configured nodes and updates the local cache of the SOUL cluster when configuration changes occur.
Zookeeper source code synchronization analysis
-
Configuration changes event notification and distribute are implemented through ApplicationEventPublisher and DataChangedEventDispatcher, concrete may refer to a Soul source study [7] – the websocket synchronization of data synchronization strategy.
-
When using zk synchronization strategies, event to ZookeeperDataChangedListener dispenser will handle;
-
Start the ZK client and view the current node configuration. Using divide plug-in rules as an example, you can see that there are six nodes corresponding to the current six rule configurations. The node content is the rule configuration.
-
When rule configuration changes, soul – admin will call ZookeeperDataChangedListener# onRuleChanged method, according to different event types do operation, if it is a rule to delete events, need to delete the corresponding zk nodes, Other updates or new rules correspond to adding ZK nodes;
-
Zk client is used to view the current node list. The number of nodes changes from 6 to 5.
-
After the soul-admin process is complete, the change event will be published through eventPublisher.
-
Soul – the bootstrap cluster is in the charge of CommonPluginDataSubscriber subscribe to handle change events, and update the local cache;
// CommonPluginDataSubscriber.java // .... else if (data instanceof RuleData) { RuleData ruleData = (RuleData) data; if (dataType == DataEventTypeEnum.UPDATE) { BaseDataCache.getInstance().cacheRuleData(ruleData); Optional.ofNullable(handlerMap.get(ruleData.getPluginName())).ifPresent(handler -> handler.handlerRule(ruleData)); } else if (dataType == DataEventTypeEnum.DELETE) { BaseDataCache.getInstance().removeRuleData(ruleData); Optional.ofNullable(handlerMap.get(ruleData.getPluginName())).ifPresent(handler -> handler.removeRule(ruleData)); }}Copy the code
-
ZookeeperSyncDataService Subscription mechanism
// ZookeeperSyncDataService.java private void watcherRule(final String pluginName) { String ruleParent = ZkPathConstants.buildRuleParentPath(pluginName); List<String> childrenList = zkClientGetChildren(ruleParent); if (CollectionUtils.isNotEmpty(childrenList)) { childrenList.forEach(children -> { String realPath = buildRealPath(ruleParent, children); cacheRuleData(zkClient.readData(realPath)); subscribeRuleDataChanges(realPath); }); } subscribeChildChanges(ConfigGroupEnum.RULE, ruleParent, childrenList); } Copy the code
conclusion
soul
The gateway framework uses ZK synchronization by means of the event Watch mechanism.- There are garbled characters in the zK node content viewed by the client, which may be related to the serialization protocol and needs to be further checked.
- The ZK synchronization mechanism needs further understanding;
series
- Soul source learning [1] – preliminary exploration
- Soul source learning [2] – divide load balancing plug-in
- Soul source learning [3] – Dubbo plug-in
- Soul source learning [4] – RateLimiter stream limiting plug-in
- Soul source learning [5] – SpringCloud plug-in
- Soul source learning [6] – Chain of responsibility mode
- Soul source learning [7] – Data synchronization strategy websocket synchronization