• Zookeeper面试点深入剖析


    Zookeeper

    谈谈你对Zookeeper的理解?

    Zookeeper是一个开源的分布式协调服务,由雅虎公司创建,由于最初雅虎公司的内部研究小组的项目大多以动物的名字命名,所以后来就以Zookeeper(动物管理员)来命名了,而就是由Zookeeper来负责这些分布式组件环境的协调工作。

    他的目标是可以提供高性能、高可用和顺序访问控制的能力,同时也是为了解决分布式环境下数据一致性的问题。

    集群

    首先,Zookeeper集群中有几个关键的概念,Leader、Follower和Observer,Zookeeper中通常只有Leader节点可以写入,Follower和Observer都只是负责读,但是Follower会参与节点的选举和过半写成功,Observer则不会,他只是单纯的提供读取数据的功能。

    通常这样设置的话,是为了避免太多的从节点参与过半写的过程,导致影响性能,这样Zookeeper只要使用一个几台机器的小集群就可以实现高性能了,如果要横向扩展的话,只需要增加Observer节点即可。

    Zookeeper建议集群节点个数为奇数,只要超过一半的机器能够正常提供服务,那么整个集群都是可用的状态。

    f3d0d752caea4f67aaceff4bb1f67b9b.png
    数据节点Znode 

    Zookeeper中数据存储于内存之中,这个数据节点就叫做Znode,他是一个树形结构,比如/a/b/c类似。

    而Znode又分为持久节点、临时节点、顺序节点三大类。

    持久节点是指只要被创建,除非主动移除,否则都应该一直保存在Zookeeper中。

    临时节点不同的是,他的生命周期和客户端Session会话一样,会话失效,那么临时节点就会被移除。

    还有就是临时顺序节点和持久顺序节点,除了基本的特性之外,子节点的名称还具有有序性。

    会话Session

    会话自然就是指Zookeeper客户端和服务端之间的通信,他们使用TCP长连接的方式保持通信,通常,肯定会有心跳检测的机制,同时他可以接受来自服务器的Watch事件通知。

    事件监听器Wather

    用户可以在指定的节点上注册Wather,这样在事件触发的时候,客户端就会收到来自服务端的通知。

    权限控制ACL

    Zookeeper使用ACL来进行权限的控制,包含以下5种:

    CREATE,创建子节点权限
    DELETE,删除子节点权限
    READ,获取节点数据和子节点列表权限
    WRITE,更新节点权限
    ADMIN,设置节点ACL权限
    所以,Zookeeper通过集群的方式来做到高可用,通过内存数据节点Znode来达到高性能,但是存储的数据量不能太大,通常适用于读多写少的场景。

    <
  • 相关阅读:
    C++算法:寻找两个正序数组的中位数
    爬虫项目(四):抓取网页所有图片
    解决idea下tomcat乱码
    STM32利用标准库编写程序proteus仿真流水灯
    PLC和工控机的网络特性
    Linux内核源码分析 (B.2)虚拟地址空间布局架构
    07数据结构与算法刷题之【树】篇
    ASP.NET Core教程
    C++ - 搜索二叉树
    消息队列_kafka简介
  • 原文地址:https://blog.csdn.net/m0_72088858/article/details/126616333