- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
主要内容ZooKeeper的数据模型ZooKeeper的数据读写机制ZooKeeper的使用方法第1页/共16页第一页,共17页。
为什么需要ZooKeeper?大部分分布式应用需要一个主控、协调器或控制器来管理物理分布的子进程(如资源、任务分配等)目前,大部分应用需要开发私有的协调程序,缺乏一个通用的机制协调程序的反复编写浪费,且难以形成通用、伸缩性好的协调器ZooKeeper:提供通用的分布式锁服务,用以协调分布式应用(如,为HBase提供服务)第2页/共16页第二页,共17页。
ZooKeeper的数据模型层次化目录结构命名符合常规文件系统规范, 不能包含/节点Znode可以包含数据与子 节点客户端应用可在节点上设置 监视器节点数据不支持部分读写, 而是一次性完整读写Ephemeral节点第3页/共16页第三页,共17页。
节点创建属性Ephemeral创建的节点不是持久节点一旦与客户端的会话结束,节点自动删除Sequence创建节点时,编号自动加1例如x-1,x-2,s-3,x-4等第4页/共16页第四页,共17页。
ZooKeeper的读写机制ZooKeeper是一个由多个Server组成的集群一个Leader,多个Follower每个Server都保存了一份数据副本全局数据一致分布式读写更新请求转发,由Leader实施第5页/共16页第五页,共17页。
使用ZooKeeper的约定更新请求顺序执行来自同一个Client的更新请求按其发送顺序依次执行数据更新原子性一次数据更新要么成功,要么失败。不存在部分数据写入成功或失败的情况全局唯一数据视图Client无论连接哪个Server,数据视图都是一致的实时性在一定时间范围内,Client能读到最新数据第6页/共16页第六页,共17页。
ZooKeeper的APIString create(path, data, acl, flags)void delete(path, expectedVersion)Stat setData(path, data, expectedVersion)(data, Stat) getData(path, watch)Stat exists(path, watch)String[] getChildren(path, watch)void sync(path)Stat setACL(path, acl, expectedVersion)(acl, Stat) getACL(path)包含监视器调用参数均包含节点路径第7页/共16页第七页,共17页。
对比:Chubby的APIhandle Open(path,…)?Close(handle,…)?GetContentsAndStat(handle,…), GetStat(handle), ReadDir(handle,…)?SetContents(handle), SetACL(handle,…)?Delete(path)?Acquire(), TryAcquire(), Release()?GetSequencer(), SetSequencer(), CheckSequencer()?仅Open包含节点路径,生成handle供其他API使用第8页/共16页第八页,共17页。
如何使用ZooKeeper?关于ZooKeeper的锁服务这里的“锁”并非对ZooKeeper的资源加锁,用于对第三方资源加锁用例多个第三方分布式Server需要使用某第三方资源,谁获取了ZooKeeper中的独占锁,谁就可以使用第三方资源,否则等待第9页/共16页第九页,共17页。
如何使用ZooKeeper?Leader选举用于在多个节点中选取主控,如GFS中对外服务Master节点的选取1)getData(“/servers/leader”, true)2)如果读取成功则从数据中获取leader信息,退出3)读取失败,执行create(“.../servers/leader”, hostname, EPHEMERAL)(注意节点类型)如果创建成功则自己成为leader,写入信息,退出5)如果写入失败,则返回步骤1getData设置了监视器,如果数据发生变化,会重启上述流程第10页/共16页第十页,共17页。
如何使用ZooKeeper?独占锁如果分布式应用需要对某资源独占使用,可以申请独占锁1)id = create(“.../locks/x-”, SEQUENCE|EPHEMERAL)2)getChildren(“.../locks/”, false)3)如果id是第一个节点,则获取独占锁,退出4)exists(name of last child before id, true)(注意,设置了监视器)
您可能关注的文档
最近下载
- 第十一章气敏传感器及其应用.ppt VIP
- 第2课 专业学习资源库 课件 赣科学技术版信息科技三年级上册.pptx VIP
- 第2课中国特色社会主义在中国的开创与发展课件(共22张PPT)中职思想政治高教版中国特色社会主义(含音频+视频).pptx VIP
- 14 普罗米修斯 课件(共37张PPT).pptx VIP
- 2025贵州贵安城市置业开发投资有限公司招聘32人笔试备考试题及答案解析.docx VIP
- 建设银行校招笔试题目及答案.doc VIP
- 人教版(2019)选择性必修第一册 Unit 4 Body Language Reading and Thinking 课件(共31张PPT)(含音频+视频).pptx VIP
- 一种提高奶牛产奶量及牛奶中Omega-3含量的方法.pdf VIP
- 保安公司经营管理概论.docx VIP
- 人教版高一语文必修一知识点总结编订.docx VIP
文档评论(0)