java微服务配置中心常见问题_Zookeeper实现微服务统一配置中心

本文介绍了Zookeeper作为分布式服务框架的功能,强调其作为配置中心的作用。通过Zookeeper实现配置节点信息,包括pom引入、配置中心设置、监听配置修改以及Java客户端的具体实现。Zookeeper的订阅发布机制允许在数据变化时通知客户端进行更新。
摘要由CSDN通过智能技术生成
153579ada4ba1ced89aa230931c4331d.png

Zookeeper 介绍

本质

它是一个分布式服务框架,是Apache Hadoop 的一个子项目

提供一种集中式信息存储服务,用于解决分布式应用中的一些数据管理问题

简单来说 zookeeper = 文件系统 + 监听通知机制。

特点

数据存在内存中

类似文件系统的树形结构(文件和目录)

高吞吐量和低延迟

集群高可靠

作用

实现分布式统一配置中心

服务注册中心

分布式锁等功能

用于分布式应用程序的高性能协调

ZK实现配置中心操作

ZK 配置节点信息

我们通过 zkui 添加一个节点,并存放一些数据信息

4b307206c3787e1d7b97cce9155c63bf.png

Java 实现

1. pom 引入

 org.springframework.boot
 spring-boot-starter-parent
 2.0.5.RELEASE
 
 org.springframework.boot
 spring-boot-starter-web
 
 
 org.springframework.boot
 spring-boot-configuration-processor
 true
 
 
 org.springframework.boot
 spring-boot-starter-test
 
 
 junit
 junit
 4.12
 
 
 
 org.apache.curator
 curator-recipes
 4.0.0
 
 1.8

2. 配置中心

本地配置文件 application.properties 中,需要配置关于Zookeeper配置中心的信息

config.zookeeper.url=127.0.0.1:2181
config.zookeeper.nodename=pay-server-config

3. 监听配置修改

当配置中心的数据发生修改,我们需要实时的更新到各个站点去

Zookeeper的订阅发布

zk的发布订阅也就是watch机制,是一个轻量级的设计。

它采用了一种推拉模式

一旦服务端感知数据发生了变化,那么会发送一个事件类型和节点信息给关注的客户端,而不会包括具体的变更内容,所以事件本身是轻量级的,这就是所谓的“推”部分。然后,收到变更通知的客户端需要自己去拉变更的数据,这就是“拉”部分。

b66dbf2417ece8d8acc1edd732141640.png

4. Java客户端实现

@Configuration
public class ZkConfig {
@Value("${config.zookeeper.url}")
String zkUrl; // 配置文件读取zk的地址
@Value("${config.zookeeper.nodename}")
String nodename; // 配置所在的节点名
private Properties properties = new Properties();
public String getProperty(String key) {
String value = properties.getProperty(key);
if (StringUtils.isEmpty(value)) {
throw new RuntimeException("配置信息不存在");
}
return value;
}
@PostConstruct
public void init() {
CuratorFramework zkclient = CuratorFrameworkFactory.newClient(zkUrl,
new RetryOneTime(1000));
zkclient.start();// 启动Zookeeper的连接
try {
// 1. 读取zookeeper数据
HashMap configMap = new HashMap<>();
List configKeys = zkclient.getChildren().forPath("/" + nodename);
for (String configKey : configKeys) {
byte[] data = zkclient.getData().forPath("/" + nodename + "/" + configKey);
configMap.put(configKey, new String(data));
}
// 2. 把数据存储到 properties中
properties.putAll(configMap);
// 3. 配置发生修改 --> watch监听机制
TreeCache treeCache = new TreeCache(zkclient, "/" + nodename);
treeCache.start(); // 监听整个节点内的数据变化
treeCache.getListenable().addListener(new TreeCacheListener() {
@Override
public void childEvent(CuratorFramework curatorFramework,

TreeCacheEvent treeCacheEvent) throws Exception {
// 如果zk中有数据变化,执行相应的代码
switch (treeCacheEvent.getType()) {
case NODE_UPDATED:
System.out.println("数据发生了变化: "+treeCacheEvent.getData());
String key = treeCacheEvent.getData().getPath().replace("/"+nodename+"/","");
String value = new String(treeCacheEvent.getData().getData());
properties.setProperty(key, value);
break;
default:
break;// 其他情况不做处理


}
});
} catch (Exception e) {
e.printStackTrace();
}
}
}

a078f110defca350662d3a4531ec8487.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值