zookeeper 面试

1zookeeper 是什么?

是一个开源的分布式协调服务,它提供了一个具有高可用性和一致性的分布式环境,用于协调和管理分布式系统中的各种数据和状态。

2 zookeeper 都有哪些功能?

分布式锁:可以通过 ZooKeeper 实现分布式锁,用于控制并发访问。

配置管理:可以将配置信息存储在 ZooKeeper 中,并实时同步给各个节点。

命名服务:可以为分布式系统提供统一的命名服务,方便节点的查找和发现。

分布式队列:可以基于 ZooKeeper 实现分布式队列,用于实现消息的生产者和消费者模式。

集群管理:可以用于管理分布式集群中的成员关系、状态变化等。

心跳检测:可以通过 ZooKeeper 监听机制实现节点的心跳检测,用于检测节点的健康状态。

3 zookeeper 有几种部署模式?

单机模式:用于开发和测试环境,只有一台 ZooKeeper 服务器。

集群模式:生产环境常用的部署方式,多台 ZooKeeper 服务器组成一个集群,通过选举机制选择一台服务器作为主节点。

嵌套模式:将多个 ZooKeeper 集群组成一个更大的集群,用于管理多个分布式系统。

4 zookeeper 怎么保证主从节点的状态同步?

在集群模式下,ZooKeeper 会选举出一台服务器作为主节点,其他服务器为从节点。主节点负责处理客户端请求,并将写操作广播给其他从节点进行状态同步。

当主节点宕机时,从节点中的一台会被选举为新的主节点,保证集群的可用性和数据的一致性。

5集群中为什么要有主节点?

主节点的存在可以提供统一的协调和管理,例如分布式锁的竞争、配置的更新等。主节点负责处理集群的写操作,并确保其他从节点与主节点的数据保持一致。

6集群中有 3 台服务器,其中一个节点宕机,这个时候 zookeeper 还可以使用吗?

当集群中有一台服务器宕机时,ZooKeeper 仍然可以使用。因为在集群模式下,ZooKeeper 会自动选举新的主节点来代替宕机的节点,保证集群的正常运行和数据的一致性。

7说一下 zookeeper 的通知机制?

ZooKeeper 的通知机制是指客户端可以注册对某个节点的监听,一旦该节点发生变化(例如数据变更、节点删除等),ZooKeeper 会向客户端发送通知。客户端可以通过监听机制实时获取节点的变化,从而及时做出相应的处理。这种机制可以用于实现分布式锁的等待通知、配置的动态更新等场景。

相关推荐
心平愈三千疾43 分钟前
学习秒杀系统-实现秒杀功能(商品列表,商品详情,基本秒杀功能实现,订单详情)
java·分布式·学习
岁忧2 小时前
(nice!!!)(LeetCode 面试经典 150 题 ) 30. 串联所有单词的子串 (哈希表+字符串+滑动窗口)
java·c++·leetcode·面试·go·散列表
绝无仅有4 小时前
OSS文件上传解析失败,错误:文件下载失败的排查与解决
后端·面试·架构
倔强青铜三6 小时前
苦练Python第22天:11个必学的列表方法
人工智能·python·面试
倔强青铜三6 小时前
苦练Python第21天:列表创建、访问与修改三板斧
人工智能·python·面试
军军君017 小时前
基于Springboot+UniApp+Ai实现模拟面试小工具三:后端项目基础框架搭建上
前端·vue.js·spring boot·面试·elementui·微信小程序·uni-app
程序员二黑7 小时前
零基础10分钟配好自动化环境!保姆级教程(Win/Mac双版)附避坑工具包
面试·程序员·测试
Java中文社群8 小时前
面试官:如何实现企业级MCP分布式部署?
java·后端·面试
搞数据的小杰9 小时前
spark广播表大小超过Spark默认的8GB限制
大数据·数据库·分布式·spark
isNotNullX9 小时前
数据怎么分层?从ODS、DW、ADS三大层一一拆解!
大数据·开发语言·数据仓库·分布式·spark