设为首页 收藏本站
查看: 950|回复: 0

[经验分享] 总结zookeeper使用场景

[复制链接]

尚未签到

发表于 2015-9-6 09:03:17 | 显示全部楼层 |阅读模式
  zookeeper是一个基于观察者的模式的分布式服务管理框架,负责存储和管理大家都关心的数据,并且接受观察者的注册,一旦发生变化,zookeeper就将通知到这些观察者做相应的变化。
核心场景:解决分布式系统中的一致性问题
核心特性: zookeeper会维护一个目录结点树,每个节点znode可以被监控,包括监控某个目录中存储的数据变化,子目录节点的变化,一旦变化可以通知设置监控的客户端。
术语:客户端有二种,一种是client连接zookeeper的客户端,另一种是follower做为客户端与leader连接。任何一台leader或者follower都可以做为客户端连接zookeeper服务器,主要操作如下:
1.创建与zookeeper的连接,通过该对象来在zookeeper上维护目录树,ZooKeeper zk = new ZooKeeper...
2.在zookeeper上创建一个给定路径的znode....
3.基于znode做相应的数据存储,子节点增减等操作
基于核心特性的主要用途:
1.单server单进程内的锁好实现,但是更复杂的跨越多个server多进程的分布式锁zookeeper可以轻松实现。
2.统一配置,集群中的每个server配置都需要改动,而通过zookeeper核心特性,只需要其中的一个配置,就会通过watch通知到其它的server自动更新。
3.类似于jndi,给使用者返回一个标志资源的名称,只不过zookeeper利用了目录的层次结构唯一标志资源(资源应该是znode或者对应的server)
4.zookeeper用来管理集群(感觉应该是zookeeper将管理的重任代理给了leader,zookeeper会通过指定的端口与leader交换信息,zookeeper还会指定另一个端口用来election与服务器通信)
leader-follower有点类似master-save的模式. zookeeper可以用来管理由leader与follower组成的集群。leader election 动态选择master,避免了传统意义上的单master容易出现的单点故障,选择的策略就是找当前序列号最小的follower做为leader。
这样确保集群的情况下,总是存在一个leader。
leader的目的就是管理服务器的状态,是否可用。
一旦follower挂了,follower与leader之间的长连接就会在指定的时间之后断开,zookeeper就会将对应的znode删除,并通知其它的follower.
一旦leader挂了,那么zookeeper就会从剩下的followers对应的znode中选择序列号最小的充当leader。
leader election主要利用了SEQUENTIAL类型的znode。该node会有序列号,election总是选最小序列号的znode对应的server做为leader。
5.同步队列:有点类似于barrier,当队列中的所有成员都加入才触发。
6.先进先出队列,比如PERSISTENT_SEQUENTIAL,仍然利用了通过SEQUENTIAL生成的序列号。

整理内容来自:http://wenku.baidu.com/view/9f9dc1d749649b6648d7471a.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-109946-1-1.html 上篇帖子: Zookeeper 日志输出到指定文件夹 下篇帖子: Hadoop2的HA安装(high availability):nfs+zookeeper
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表