Zookeeper应用之一:数据发布与订阅初体验
Zookeeper到底是什么?可以从Zookeeper提供的功能来理解。本篇小作文就是使用其提供的功能之一:数据发布与订阅。
需求:服务端开启多个实例提供服务,客户端使用服务。如果服务端某个服务下线或者新服务上线,客户端可感知并与客户端断开或者接连服务端。
分析:利用Zookeeper作为注册中心,服务端进行注册,客户端读取注册信息。
实现:
一、服务器端启动时自动将ip/port注册到Zookeeper
1、注册时点:服务端绑定端口后注册
2、注册具体实现:
3、验证:
启动两个服务端实例,查看Zookeeper节点信息(Zookeeper服务端启动,参考CentOS8系统上Zookeeper安装启动 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com))
1)未启动服务端实例前,Zookeeper节点信息
具体节点信息
2)启动一个服务127.0.0.1:8899,查看节点信息
3)启动一个服务127.0.0.1:8989,查看节点信息
二、客户端启动使用浏览器访问服务端时,自动捕获服务实例上下线地同时链接服务器端
1、仅初始两个服务:8899和8989
2、上线一个服务:127.0.0.1:8889
3、下线一个服务
以上是客户端结果验证,那么是如何实现的呢?
分析:客户端访问服务器端,重点是获得服务端的ip:port。如果没有Zookeeper注册中心提供数据的发布(此案例中服务端ip:port作为数据发布到Zookeeper相关节点),那么客户端可能就需要硬编码,如下:
一旦有新的服务实例上线或者某个服务下线,那么就得重新编写代码。如果是生产环境,服务由于某种未知原因下线,那么会直接影响生产运行。
客户端如何利用Zookeeper实现客户端订阅注册信息数据信息的呢?此案例订阅的事lf_provider节点下所有子节点的数据信息,具体实现如下:
1、链接Zookeeper服务
2、获取注册中心数据信息(ip:port 列表)
3、新建客户端实例链接所有地址信息建立客户端链接列表
4、实际业务逻辑中随机使用一个客户端链接
以上就是Zookeeper应用之一~数据发布与订阅,在实际业务中解决共享数据的集中管理及动态更新并动态获取数据。
在以上体验中,用到了Zookeeper提供的API及命令行,后续将分别介绍。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?