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 会向客户端发送通知。客户端可以通过监听机制实时获取节点的变化,从而及时做出相应的处理。这种机制可以用于实现分布式锁的等待通知、配置的动态更新等场景。

相关推荐
哈里谢顿12 分钟前
1000台裸金属并发创建中的重难点问题分析
面试
哈里谢顿13 分钟前
20260303面试总结(全栈)
面试
over6975 小时前
从 LLM 到全栈 Agent:MCP 协议 × RAG 技术如何重构 AI 的“做事能力”
面试·llm·mcp
初次攀爬者6 小时前
Kafka + ZooKeeper架构基础介绍
后端·zookeeper·kafka
SuperEugene6 小时前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
Sailing8 小时前
🚀 别再乱写 16px 了!CSS 单位体系已经进入“计算时代”,真正的响应式布局
前端·css·面试
SuperEugene11 小时前
Vue状态管理扫盲篇:Vuex 到 Pinia | 为什么大家都在迁移?核心用法对比
前端·vue.js·面试
Hilaku11 小时前
我会如何考核一个在简历里大谈 AI 提效的高级前端?
前端·javascript·面试
前端Hardy12 小时前
别再用 $emit 满天飞了!Vue 3 组件通信的 4 种正确姿势,第 3 种 90% 的人不知道
前端·vue.js·面试
我叫黑大帅12 小时前
前端如何利用 GitHub Actions 自动构建并发布到 GitHub Pages?
前端·面试·github