源码时代Java干货分享|带你认识Zookeeper 分布式服务框架
Posted IT-source
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了源码时代Java干货分享|带你认识Zookeeper 分布式服务框架相关的知识,希望对你有一定的参考价值。
本质
它是一个分布式服务框架,是Apache Hadoop 的一个子项目
提供一种集中式信息存储服务,用于解决分布式应用中的一些数据管理问题
简单来说 zookeeper = 文件系统 + 监听通知机制。
特点
数据存在内存中
类似文件系统的树形结构(文件和目录)
高吞吐量和低延迟
集群高可靠
作用
实现分布式统一配置中心
服务注册中心
分布式锁等功能
用于分布式应用程序的高性能协调
ZK实现配置中心操作
ZK 配置节点信息
我们通过 zkui 添加一个节点,并存放一些数据信息
Java 实现
1. pom 引入
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.5.RELEASE</version> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency>
<dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>4.0.0</version> </dependency> </dependencies> <properties> <java.version>1.8</java.version> </properties> |
2. 配置中心
本地配置文件 application.properties 中,需要配置关于Zookeeper配置中心的信息
config.zookeeper.url=127.0.0.1:2181 |
3. 监听配置修改
当配置中心的数据发生修改,我们需要实时的更新到各个站点去
Zookeeper的订阅发布
zk的发布订阅也就是watch机制,是一个轻量级的设计。
它采用了一种推拉模式。
一旦服务端感知数据发生了变化,那么会发送一个事件类型和节点信息给关注的客户端,而不会包括具体的变更内容,所以事件本身是轻量级的,这就是所谓的“推”部分。然后,收到变更通知的客户端需要自己去拉变更的数据,这就是“拉”部分。
4. Java客户端实现
@Configuration
|
以上是关于源码时代Java干货分享|带你认识Zookeeper 分布式服务框架的主要内容,如果未能解决你的问题,请参考以下文章