博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
5. 监视和ZooKeeper操作
阅读量:4558 次
发布时间:2019-06-08

本文共 1168 字,大约阅读时间需要 3 分钟。

ZooKeeper中的写入(write)操作是原子性和持久性的。 写入到大多数ZooKeeper服务器上的持久性存储中,可以保证写操作成功。 无论如何,ZooKeeper的最终一致性模型允许读取(read)ZooKeeper服务的最新状态,并且同步(sync)操作允许客户端更新ZooKeeper服务的最新状态。

znode中的读取(read)操作(如existsgetChildrengetData)允许在其上设置监视。 另一方面,由znode的写入(write)操作触发的监视(如createdeletesetData ACL操作)并不会有监控的参与。

以下是在znode状态更改期间可能发生的监视事件的类型:

  • NodeChildrenChanged: 一个znode的子节点被创建或删除时
  • NodeCreated:在ZooKeeper路径中创建一个znode时
  • NodeDataChanged:与znode相关的数据被更新时
  • NodeDeleted: znode在ZooKeeper路径中被删除时

监视事件的类型取决于监视和触发监视的操作。 关于三个主要操作如何产生事件的一些关键信息如下表所示:

操作 事件生成操作
exists znode被创建或删除,或其数据被更新
getChildren znode的子节点被创建或删除,或者znode本身被删除
getData znode被删除或其数据被更新

监视事件包括生成事件的znode的路径。 因此,客户端可以通过检查znode的路径来找到NodeCreatedNodeDeleted事件的znode创建和删除。 要发现NodeChildrenChanged事件后哪些子节点发生了变化,必须调用getChildren操作来检索新的子节点列表。 同样,为了发现NodeDataChanged事件的新数据,必须调用getData方法。

ZooKeeper从其数据模型的角度提供了一系列的保证,并在其基础上构建了监视底层建设,从而实现了其他分布式协调原语的简单,快速和可扩展的构建:

  • Sequential consistency:这确保了客户端的更新总是以FIFO的顺序处理。
  • Atomicity:这确保更新要么成功,要么失败,不会有部分提交的情况。
  • Single system image:客户端可以看到ZooKeeper服务的相同视图,它不依赖于它所连接的系统中的哪个ZooKeeper服务器。
  • Reliability:这确保了这些更新一旦被应用就会一直存在。直到被客户端重写。
  • Timeliness:客户端的系统视图保证在一定的时间内是最新的。这被称为最终一致性。

转载于:https://www.cnblogs.com/IcanFixIt/p/7830922.html

你可能感兴趣的文章
python 3 廖雪峰博客笔记(一) python特性
查看>>
JAVA学习心得
查看>>
[转]推荐highcharts学习网址
查看>>
centos7下自定义服务启动和自动执行脚本
查看>>
docker上部署nginx容器80端口自动转443端口
查看>>
ps命令查看子进程
查看>>
2019春第七周编程总结
查看>>
angularjs1-7,http,location
查看>>
sass01
查看>>
Java 8 Lambda 表达式
查看>>
codeblocks 教程
查看>>
微信小微商户申请入驻
查看>>
Java的并发和多处理器的并行的理解
查看>>
1178.复数集合
查看>>
1174.查找第k小数
查看>>
优先队列(堆)
查看>>
C语言中函数参数传递的本质是值传递
查看>>
noip2018游记
查看>>
redis分布式锁
查看>>
判断手机andriod还是iphone
查看>>