当前位置: 首页 > news >正文

Zookeeper的简单了解

Zookeeper的简单了解

Zookeeper是一个为分布式应用程序提供协调服务的中间件。

主要作用有三点:分布式锁、注册中心、配置管理、。

特点有读写速度快(内存存储)、有监听机制(用于发布订阅)、保证了顺序一致性(所有写请求由leader节点串行写)等等。

基本概念

存储结构类似Linux的文件系统,都是树形结构,这个树形结构上的每个节点都叫znode,znode分为 持久节点 (客户端断开会话后依旧保存)和 临时节点(客户端断开会话后就会被删除) 。

监听器

客户端可以向服务端注册一个Watcher监听器,监听某一个节点的事件,如果监听的节点的事件发生了,Zookeeper就会向客户端发送事件通知。这个监听器是一次性的,如果要长久监听一个节点的事件还需要每次事件通知进行回调处理的时候再次为这个节点注册一个监听器。

实现分布式锁

在锁节点下,多个客户端去创建临时顺序节点(临时节点+自动根据创建顺序编号) ,然后编号小的获取到锁,后续的顺序节点会各自创建一个监听器,监听编号比自身小的上一个节点,上一个节点删除掉(释放锁)节点的时候,下一个节点就会获取到锁。很类似AQS锁。

实现注册中心

在手写实现RPC框架项目中,我使用了Zookeeper作为注册中心。Zookeeper数据模型很简单,而且还有事件监听功能,并且自带心跳检测功能,可以侦测哪些服务地址宕机及时删除。所以选择了它作为注册中心,但是呢,由于Zookeeper和服务之间建立着长连接,连接数量一多的话就会导致性能出问题,所以大规模的应用场景下还是使用nacos。我以微服务名作为永久节点,对应的服务地址作为临时节点挂载在对应的服务名下。临时节点会在它与Zookeeper服务端断开连接后自动删除,这时候就会有触发器通知需要服务的那方更新缓存(需要服务的那方实现了缓存机制)。

http://www.dtcms.com/a/298914.html

相关文章:

  • 学习嵌入式的第三十三天-数据结构-(2025.7.25)服务器/多客户端模型
  • Typecho插件开发:自定义注册用户组与免审发布功能实现
  • OTG原理讲解
  • 非定长滑动窗口(持续更新)
  • 【GoLang#3】:数据结构(切片 | map 映射)
  • 新手向:Git下载全攻略
  • 用Java实现rpc的逻辑和流程图和核心技术与难点分析
  • 图论:Dijkstra算法
  • 【WPF】NumericUpDown的用法
  • 01 01 01 第一部分 C++编程知识 C++入门 第一个C++程序
  • Linux如何执行系统调用及高效执行系统调用:深入浅出的解析
  • HashMap(JDK1.7、JDK1.8)原理与结构分析与synchronizedMap()
  • Spring Boot SSE实战:SseEmitter实现多客户端事件广播与心跳保活
  • Spring Boot 实战:用 Apache Commons CSV 优雅解析 CSV 文件
  • x86汇编语言入门基础(三)汇编指令篇5 串操作
  • OpenCV学习探秘之一 :了解opencv技术及架构解析、数据结构与内存管理​等基础
  • 技术赋能与营销创新:开源链动2+1模式AI智能名片S2B2C商城小程序的流量转化路径研究
  • 嵌入式硬件篇---zigbee无线串口通信问题解决方法
  • Claude 4.0 终极编程指南:模型对比、API配置与IDE集成实战
  • CMakeLists.txt 怎么写
  • 39.Python 中 list.sort() 与 sorted() 的本质区别与最佳实践
  • 数据库索引详解:原理、设计原则与应用场景
  • NLua和C#交互
  • 6G通感算
  • Spring Boot DFS、HDFS、AI、PyOD、ECOD、Junit、嵌入式实战指南
  • 学习游戏制作记录(剑投掷技能)7.26
  • Kotlin 数据容器 - List 扩展(转换操作、过滤操作、排序操作、分组操作、集合操作、归纳操作、窗口操作)
  • 一款基于react-native harmonyOS 封装的【文档】文件预览查看开源库(基于Harmony 原生文件预览服务进行封装)
  • 【深度之眼机器学习笔记】04-01-决策树简介、熵,04-02-条件熵及计算举例,04-03-信息增益、ID3算法
  • OpenCV图像梯度、边缘检测、轮廓绘制、凸包检测大合集