微服务中 Zookeeper 应用及原理

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
MSE Nacos/ZooKeeper 企业版试用,1600元额度,限量50份
简介: 了解微服务的小伙伴都应该知道Zookeeper,Zookeeper是一个分布式的,开源的分布式应用程序协调服务。现在比较流行的微服务框架Dubbo、Spring Cloud都可以使用Zookeeper作为服务发现与组册中心。但是,为什么Zookeeper就能实现服务发现与组册呢?

作者:Marvin Mai https://blog.csdn.net/Mkhaixian2014/article/details/89980476


了解微服务的小伙伴都应该知道Zookeeper,Zookeeper是一个分布式的,开源的分布式应用程序协调服务。


现在比较流行的微服务框架Dubbo、Spring Cloud都可以使用Zookeeper作为服务发现与组册中心。但是,为什么Zookeeper就能实现服务发现与组册呢?


Zookeeper的特性


我们先来了解一下Zookeeper的特性吧,因为它的特性决定了它的使用场景。


1.树状目录结构


image.png


如上图,Zookeeper是一个树状的文件目录结构,有点想应用系统中的文件系统的概念。每个子目录(如App)被称为znode,我们可以对每个znode进行增删改查。


2.持久节点(Persistent)

image.png

客户端与Zookeeper服务端断开连接后,该节点仍然存在。


3.持久有序节点(Persistent_sequential)


在持久节点基础上,由zookeeper给该节点名称进行有序编号,如0000001,0000002。


4.临时节点(Ephemeral)

image.png

客户端与Zookeeper服务端断开连接后,该节点被删除。临时节点下,不存在子节点。


5.临时有序节点(Ephemeral_sequential)


在临时节点基础上,由Zookeeper给该节点名称进行有序编号,如0000001,0000002。


6.节点监听(Wacher)

image.png

客户端2注册监听它关心的临时节点SubApp1的变化,当临时节点SubApp1发生变化时(如图中被删除的时候),zookeeper会通知客户端2。


该机制是zookeeper实现分布式协调的重要特性。我们可以通过get,exists,getchildren三种方式对某个节点进行监听。但是该事件只会通知一次。


===


微服务中应用场景


1.分布式锁

分布式锁主要解决不同进程中的资源同步问题。大家可以联想一下单进程中的多线程共享资源的情况,线程需要访问共享资源,首先要获得锁,操作完共享资源后便释放锁。Zookeeper怎么实现分布式锁?这篇推荐大家阅读。


分布式中,上述的锁就变成了分布式锁了。那这个分布式锁又是如何实现呢?


image.png


步骤1: 如图,根据Zookeeper有序临时节点的特性,每个进程对应连接一个有序临时节点(进程1对应节点/znode/00000001,进程2对应节点/znode/00000002…如此类推)。


每个进程监听对应的上一个节点的变化。编号最小的节点对应的进程获得锁,可以操作资源。

image.png



步骤2: 当进程1完成业务后,删除对应的子节点/znode/00000001,释放锁。此时,编号最小的锁便获得锁(即/znode/00000002对应进程)。


重复以上步骤,保证了多个进程获取的是同一个锁,且只有一个进程能获得锁,就是Zookeeper分布式锁的实现原理。


2.服务注册与发现

2.1 背景

image.png


在微服务中,服务提供方把服务注册到Zookeeper中心去如图中的Member服务,但是每个应用可能拆分成多个服务对应不同的Ip地址,Zookeeper注册中心可以动态感知到服务节点的变化。


服务消费方(Order 服务)需要调用提供方(Member 服务)提供的服务时,从Zookeeper中获取提供方的调用地址列表,然后进行调用。这个过程称为服务的订阅。


2.2服务注册原理

image.png


rpc框架会在Zookeeper的注册目录下,为每个应用创建一个持久节点,如order应用创建order持久节点,member应用创建member持久节点。


然后在对应的持久节点下,为每个微服务创建一个临时节点,记录每个服务的URL等信息。


2.3服务动态发现原理

image.png


由于服务消费方向Zookeeper订阅了(监听)服务提供方,一旦服务提供方有变动的时候(增加服务或者减少服务),Zookeeper就会把最新的服务提供方列表(member list)推送给服务消费方,这就是服务动态发现的原理。


相关文章
|
监控 Java 持续交付
深入理解微服务架构及其在现代应用开发中的应用
深入理解微服务架构及其在现代应用开发中的应用
313 1
|
运维 持续交付 云计算
深入解析云计算中的微服务架构:原理、优势与实践
深入解析云计算中的微服务架构:原理、优势与实践
704 86
|
7月前
|
Cloud Native Serverless 流计算
云原生时代的应用架构演进:从微服务到 Serverless 的阿里云实践
云原生技术正重塑企业数字化转型路径。阿里云作为亚太领先云服务商,提供完整云原生产品矩阵:容器服务ACK优化启动速度与镜像分发效率;MSE微服务引擎保障高可用性;ASM服务网格降低资源消耗;函数计算FC突破冷启动瓶颈;SAE重新定义PaaS边界;PolarDB数据库实现存储计算分离;DataWorks简化数据湖构建;Flink实时计算助力风控系统。这些技术已在多行业落地,推动效率提升与商业模式创新,助力企业在数字化浪潮中占据先机。
444 12
|
监控 持续交付 API
深入理解微服务架构:从设计原则到实践应用
深入理解微服务架构:从设计原则到实践应用
|
监控 持续交付 API
深入理解云计算中的微服务架构:原理、优势与实践
深入理解云计算中的微服务架构:原理、优势与实践
549 83
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用
555 60
|
8月前
|
存储 NoSQL 关系型数据库
微服务——MongoDB的应用场景
随着Web2.0时代的到来,传统关系型数据库(如MySQL)在高并发读写、海量数据存储及高可扩展性需求方面逐渐力不从心。而MongoDB凭借其灵活的文档结构和高效性能,在社交、游戏、物流、物联网和视频直播等场景中表现出色。这些场景通常具有数据量大、写入频繁且对事务要求不高的特点。选择MongoDB适合以下情况:应用无需复杂事务与join支持、需求不确定需快速迭代、需处理高QPS读写或超大规模数据存储、追求高可用性和快速水平扩展能力。相比MySQL,MongoDB能以更低的学习、开发和运维成本满足现代应用需求。
293 0
|
Cloud Native 安全 持续交付
深入理解微服务架构及其在现代软件开发中的应用
深入理解微服务架构及其在现代软件开发中的应用
351 33
|
10月前
|
人工智能 安全 Java
微服务引擎 MSE:打造通用的企业级微服务架构
微服务引擎MSE致力于打造通用的企业级微服务架构,涵盖四大核心内容:微服务技术趋势与挑战、MSE应对方案、拥抱开源及最佳实践。MSE通过流量入口、内部流量管理、服务治理等模块,提供高可用、跨语言支持和性能优化。此外,MSE坚持开放,推动云原生与AI融合,助力企业实现无缝迁移和高效运维。
432 1
|
存储 JSON 监控
微服务链路追踪原理,一文搞懂!
本文重点讲解微服务链路追踪(Microservices Distributed Tracing),介绍其原理、架构及工作流程。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
微服务链路追踪原理,一文搞懂!

热门文章

最新文章

相关产品

  • 微服务引擎