七叶笔记 » java编程 » zookeeper+Springboot实现服务器动态上下线监听教程详解

zookeeper+Springboot实现服务器动态上下线监听教程详解

zookeeper+Springboot实现服务器动态上下线监听教程

一.什么是服务器动态上下线监听

客户端能够实时洞察到服务器上下线的变化,现在我们看看下面三个变化给集群、服务器、客户端三者的变化

初始情况

服务器3启动

服务器2下线

从上面的图我们可以知道,在集群中,每当一台服务器上线时,都会在集群中注册一个有序且临时的节点,并通知客户端;在服务器下线的时候,服务器所注册的节点也会被删除,并通知客户端。在这样的结构下,客户端便能够通过集群实时监听服务器的上下线。

二.为什么要实现对服务器上下线的监听

在开发中,这种结构应用的非常广泛,核心用处如下:

用于监听节点数据产生的变化,在zk中可以配置集群的通用配置,当配置数据发生了变化之后通知所有订阅该节点的Watcher,该节点发生事件类型用于监听节点状态的变化,比如创建一个节点、删除一个节点等对节点的操作管理客户端与服务端连接的生命周期

三.编码实现

建议大家在实现之前可以先对zookeeper的一些API操作有一些了解,这些我在我的另外一篇文章做了详细的介绍,有需要的小伙伴可以移步去看看喔。

基于Springboot整合zookeeper实现对节点的创建、监听与判断

https://www.jb51.net/article/252816.htm

1.在集1.在zookeeper集群中创建一个servers节点

2.创建一个简单的springboot工程并引入zookeeper

3.编写DistributeServer(分布式服务端)

4.分布式客户端

四.测试

1.启动客户端,开启监听

2.按照下面的流程启动服务器端

输入对应的服务器名,如我输入的就是:server1

启动成功后结果如下所示:

关注客户端的监听状况,发现已经监听到集群中已经出现了一个节点

为了使输出更明显,我们在zookeeper中的servers节点下创建一个server2的持久节点

此时客户端也监听到了集群中节点的变化

4.此时我们关闭服务器端,再来观察一下客户端的监听情况

此时我们发现客户端中只输出了server2这个节点

至此,我们便成功实现了简单的zookeeper集群对服务器端上下线的监听。

至此,我们zookeeper+Springboot实现服务器动态上下线监听教程就结束啦~

到此这篇关于zookeeper+Springboot实现服务器动态上下线监听的文章就介绍到这了,更多相关zookeeper动态上下线监听内容请搜索七叶笔记以前的文章或继续浏览下面的相关文章希望大家以后多多支持七叶笔记!

相关文章