云计算系列教程10【教育类别】

上传人:cn****1 文档编号:567581409 上传时间:2024-07-21 格式:PPT 页数:16 大小:719KB
返回 下载 相关 举报
云计算系列教程10【教育类别】_第1页
第1页 / 共16页
云计算系列教程10【教育类别】_第2页
第2页 / 共16页
云计算系列教程10【教育类别】_第3页
第3页 / 共16页
云计算系列教程10【教育类别】_第4页
第4页 / 共16页
云计算系列教程10【教育类别】_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《云计算系列教程10【教育类别】》由会员分享,可在线阅读,更多相关《云计算系列教程10【教育类别】(16页珍藏版)》请在金锄头文库上搜索。

1、ZooKeeper分布式应用的协调器1培训类主要内容ZooKeeper的数据模型ZooKeeper的数据读写机制ZooKeeper的使用方法2培训类为什么需要ZooKeeper?大部分分布式应用需要一个主控、协调器或控制器来管理物理分布的子进程(如资源、任务分配等)目前,大部分应用需要开发私有的协调程序,缺乏一个通用的机制协调程序的反复编写浪费,且难以形成通用、伸缩性好的协调器ZooKeeper:提供通用的分布式锁服务,用以协调分布式应用(如,为HBase提供服务)3培训类ZooKeeper的数据模型层次化目录结构命名符合常规文件系统规范, 不能包含/节点Znode可以包含数据与子 节点客户端

2、应用可在节点上设置 监视器节点数据不支持部分读写, 而是一次性完整读写Ephemeral节点4培训类节点创建属性Ephemeral创建的节点不是持久节点一旦与客户端的会话结束,节点自动删除Sequence创建节点时,编号自动加1例如x-1,x-2,s-3,x-4等5培训类ZooKeeper的读写机制ZooKeeper是一个由多个Server组成的集群一个Leader,多个Follower每个Server都保存了一份数据副本全局数据一致分布式读写更新请求转发,由Leader实施6培训类使用ZooKeeper的约定更新请求顺序执行来自同一个Client的更新请求按其发送顺序依次执行数据更新原子性一

3、次数据更新要么成功,要么失败。不存在部分数据写入成功或失败的情况全局唯一数据视图Client无论连接哪个Server,数据视图都是一致的实时性在一定时间范围内,Client能读到最新数据7培训类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(pa

4、th, watch)void sync(path)Stat setACL(path, acl, expectedVersion)(acl, Stat) getACL(path)包含监视器调用参数均包含节点路径8培训类对比:Chubby的APIhandle Open(path,)Close(handle,)GetContentsAndStat(handle,), GetStat(handle), ReadDir(handle,)SetContents(handle), SetACL(handle,)Delete(path)Acquire(), TryAcquire(), Release()Get

5、Sequencer(), SetSequencer(), CheckSequencer()仅Open包含节点路径,生成handle供其他API使用9培训类如何使用ZooKeeper?关于ZooKeeper的锁服务这里的“锁”并非对ZooKeeper的资源加锁,用于对第三方资源加锁用例多个第三方分布式Server需要使用某第三方资源,谁获取了ZooKeeper中的独占锁,谁就可以使用第三方资源,否则等待10培训类如何使用ZooKeeper?Leader选举用于在多个节点中选取主控,如GFS中对外服务Master节点的选取1)getData(“/servers/leader”, true)2)如果

6、读取成功则从数据中获取leader信息,退出3)读取失败,执行create(“./servers/leader”, hostname, EPHEMERAL)(注意节点类型)如果创建成功则自己成为leader,写入信息,退出5)如果写入失败,则返回步骤1getData设置了监视器,如果数据发生变化,会重启上述流程11培训类如何使用ZooKeeper?独占锁如果分布式应用需要对某资源独占使用,可以申请独占锁1)id = create(“./locks/x-”, SEQUENCE|EPHEMERAL)2)getChildren(“./locks/”, false)3)如果id是第一个节点,则获取独占

7、锁,退出4)exists(name of last child before id, true)(注意,设置了监视器)5)如果id之前不存在节点,返回步骤26)等待通知7)返回步骤2有且仅有一个Client可以获取到独占锁12培训类如何使用ZooKeeper?共享锁1)id = create(“./locks/s-”, SEQUENCE|EPHEMERAL)2)getChildren(“./locks/”, false)3)如果id之前没有x-类型的节点,获取共享锁,退出4)exists(name of the last x- before id, true)5)如果id之前不存在x-类型节点

8、,返回步骤26)等待事件通知7)返回步骤2如果之前没有独占锁,就可以获取共享锁13培训类如何使用ZooKeeper?其他应用(小数据存储)例如,GFS中master如何获知ChunkServer信息?基于ZooKeeper的实现方法ChunkServer执行如下操作:1)id = create(“./chunkservers/cs-”, SEQUENCE|EPHEMERAL)2)向节点id中写入ChunkServer元信息Master执行如下操作:1) getChildren(“./chunkservers/”, true)2)读取子节点数据,获知ChunkServer元信息14培训类其他ZooKeeper的会话Client通过发送PING请求与Server保持会话通过PING,可以同时获知Client与Server是否活跃ZooKeeper的监视器监视器是一次性的,一次事件通知后就作废15培训类性能ZooKeeper适用于主要负载为读的应用场合16培训类

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号