时间:2021-05-19
1.1 概述
分布式系统:分布式系统指由很多台计算机组成的一个整体!这个整体一致对外,并且处理同一请求!系统对内透明,对外不透明!内部的每台计算机,都可以相互通信,例如使用RPC/REST或者是WebService!客户端向一个分布式系统发送的一次请求到接受到响应,有可能会经历多台计算机!
Zookeeper是一个开源的分布式的,为分布式应用提供协调服务的Apache项目,多用作为集群提供服务的中间件!
Zookeeper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,它负责存储和管理大家都关心的数据,然后接受观察者的注册,一旦这些数据的状态发生变化,Zookeeper就将负责通知已经在Zookeeper上注册的那些观察者做出相应的反应,从而实现集群中类似Master/Slave管理模式
Zookeeper=文件系统+通知机制
1.2 特点
1)一致性:zookeeper中的数据按照顺序分批入库,且最终一致!
2)原子性:一次数据更新要么成功,要么失败。
3)单一视图:全局数据一致,每个server保存一份相同的数据副本,client无论连接到哪个server,数据都是一致的。
4)可靠性:每次对zk的操作状态都会保存到服务端,每个server保存一份相同的数据副本。
5)更新请求顺序进行,来自同一个client的更新请求按其发送顺序依次执行。
6)实时性,在一定时间范围内,client能读到最新数据。
7)集群中只要有半数以上节点存活,Zookeeper集群就能正常服务(集群选择奇数的原因)。
1.3 数据结构
ZooKeeper数据模型的结构与Unix文件系统很类似,整体上可以看作是一棵树,每个节点称做一个ZNode。每个Znode可以类似看作是一个目录,其下可以创建子目录。
很显然zookeeper集群自身维护了一套数据结构。这个存储结构是一个树形结构,其上的每一个节点,我们称之为"znode",每一个znode默认能够存储1MB的数据,每个ZNode都可以通过其路径唯一标识
1.4 应用场景
提供的服务包括:分布式消息同步和协调机制、服务器节点动态上下线、统一配置管理、负载均衡、集群管理等
统一命名服务
统一配置管理
统一集群管理
服务器动态上下线
软负载均衡
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
详解Corba开发之Java实现Service与Client1概述CORBA(CommonObjectRequestBrokerArchitecture,公共对
通过zookeeper实现分布式锁1、创建zookeeper的client首先通过CuratorFrameworkFactory创建一个连接zookeeper的
许多盆友针对淘宝宝贝长图文不了解,要了解,淘宝宝贝长图文是用于详解你的商品的的一张图片,每一个淘宝商家都是会给商品设定长图文,那麼淘宝宝贝长图文有什么作用?一、
一,下载Zookeeper,地址为http://archive.apache.org/dist/zookeeper/,找到你要下载的版本,我下载了这个版本apa
1、创建/usr/local/services/zookeeper文件夹:mkdir-p/usr/local/services/zookeeper2、进入到/u