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

Zookeeper的简单了解

Zookeeper的简单了解

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

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

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

基本概念

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

监听器

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

实现分布式锁

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

实现注册中心

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

http://www.lryc.cn/news/600641.html

相关文章:

  • 安卓学习记录1——持续更新ing
  • Java基础day17-LinkedHashMap类,TreeMap类和集合工具类
  • linux下变更mysql的数据文件目录
  • 基于粒子群算法优化高斯过程回归(PSO-GPR)的多输出回归
  • 基于MySQL实现基础图数据库
  • React入门指南——指北指南(第二节)
  • SpringMVC相关基础知识
  • RustFS for .NET 演示项目深度解析:构建 S3 兼容的分布式存储应用
  • 计划任务(at和cron命令介绍及操作)
  • 《用于几何广义断层触觉传感的图结构超分辨率:在仿人面部的应用》论文解读
  • 一款基于react-native harmonyOS 封装的【文档】文件预览查看开源库(基于Harmony 原生文件预览服务进行封装)
  • 深入剖析 MetaGPT 中的提示词工程:WriteCode 动作的提示词设计
  • Blender入门笔记(一)
  • 简单实现支付密码的页面及输入效果
  • Sql server查询汇总补缺月份
  • 【iOS】网易云仿写
  • 基于深度学习的胸部 X 光图像肺炎分类系统(七)
  • springboot 前后端,基于票据+SHA派生密钥+SM4加解密
  • 经典IDE之Turbo C
  • 基于MC9S12XEP100的整车控制器(VCU)设计
  • 【Zephyr】Window下的Zephyr编译和使用
  • Redis的数据淘汰策略是什么?有哪些?
  • 资产负债表及其数据获取
  • 【LeetCode 热题 100】79. 单词搜索——回溯
  • 进阶数据结构:用红黑树实现封装map和set
  • element-plus安装以及使用
  • 机器人仿真(2)Ubuntu24.04下RTX5090配置IsaacSim与IsaacLab
  • Java实现大根堆与小根堆详解
  • 【数据结构】栈和队列的实现
  • 基于DataX的数据同步实战