二十二 Zookeeper

1 Zookeeper概述

1.1 概述

分布式系统:分布式系统指由很多台计算机组成的一个整体!这个整体一致对外,并且处理同一请求!系统对内透明,对外不透明!内部的每台计算机,都可以相互通信,例如使用RPC/REST或者是WebService!客户端向一个分布式系统发送的一次请求到接受到响应,有可能会经历多台计算机!
Zookeeper是一个开源的分布式的,为分布式应用提供协调服务的Apache项目,多用作为集群提供服务的中间件!
Zookeeper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,它负责存储和管理大家都关心的数据,然后接受观察者的注册,一旦这些数据的状态发生变化,Zookeeper就将负责通知已经在Zookeeper上注册的那些观察者做出相应的反应从而实现集群中类似Master/Slave管理模式

Zookeeper=文件系统+通知机制

1.2 特点

1)一致性:zookeeper中的数据按照顺序分批入库,且最终一致!
(所有zookeeper节点上的数据一样,比如有三台机器安装了zookeeper组成集群,那么三台机器上的zookeeper的保存的数据一样)

2)原子性:一次数据更新要么成功,要么失败。

3)单一视图:client无论连接到哪个ZK节点,数据都是一致的。

4)可靠性:每次对zk的操作状态都会保存到服务端,每个server保存一份相同的数据副本。

5)更新请求顺序进行,来自同一个client的更新请求按其发送顺序依次执行。

6)实时性,在一定时间范围内,client能读到最新数据。

1.3 数据结构

ZooKeeper数据模型的结构与Unix文件系统很类似,整体上可以看作是一棵树,每个节点称做一个ZNode。每个Znode可以类似看作是一个目录,其下可以创建子目录。
很显然zookeeper集群自身维护了一套数据结构。这个存储结构是一个树形结构,其上的每一个节点,我们称之为"znode",每一个znode默认能够存储1MB的数据,每个ZNode都可以通过其路径唯一标识.
在这里插入图片描述

1.4 应用场景

提供的服务包括:分布式消息同步和协调机制、服务器节点动态上下线、统一配置管理、负载均衡、集群管理等。

1.5 下载地址

https://zookeeper.apache.org/

2 Zookeeper安装

安装之前首先需要安装JDK.
然后下载解压就可以了.

在这里插入图片描述

bin: 存放常用的可执行文件,例如启动服务端和客户端。
conf : 存放zookeeper的配置文件。
contrib: 其他的工具。
dis-maven: 使用maven编译后产生的目录。
lib:使用客户端开发,可能使用到的jar包。
recipes:官方提供的案例demo代码。
src: 源码目录。

3 Zookeeper单点模式的使用

3.1 服务端的启动

①启动之前,确保已经配置了JAVA_HOME
②可以将zookeeper安装目录的bin目录配置到环境变量中,使用方便
③将zookeeper-3.4.10/conf这个路径下的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值