zookeeper+Springboot實(shí)現(xiàn)服務(wù)器動(dòng)態(tài)上下線監(jiān)聽教程詳解
zookeeper+Springboot實(shí)現(xiàn)服務(wù)器動(dòng)態(tài)上下線監(jiān)聽教程
一.什么是服務(wù)器動(dòng)態(tài)上下線監(jiān)聽
客戶端能夠?qū)崟r(shí)洞察到服務(wù)器上下線的變化,現(xiàn)在我們看看下面三個(gè)變化給集群、服務(wù)器、客戶端三者的變化
初始情況

服務(wù)器3啟動(dòng)

服務(wù)器2下線

從上面的圖我們可以知道,在集群中,每當(dāng)一臺服務(wù)器上線時(shí),都會(huì)在集群中注冊一個(gè)有序且臨時(shí)的節(jié)點(diǎn),并通知客戶端;在服務(wù)器下線的時(shí)候,服務(wù)器所注冊的節(jié)點(diǎn)也會(huì)被刪除,并通知客戶端。在這樣的結(jié)構(gòu)下,客戶端便能夠通過集群實(shí)時(shí)監(jiān)聽服務(wù)器的上下線。
二.為什么要實(shí)現(xiàn)對服務(wù)器上下線的監(jiān)聽
在開發(fā)中,這種結(jié)構(gòu)應(yīng)用的非常廣泛,核心用處如下:
- 用于監(jiān)聽節(jié)點(diǎn)數(shù)據(jù)產(chǎn)生的變化,在zk中可以配置集群的通用配置,當(dāng)配置數(shù)據(jù)發(fā)生了變化之后通知所有訂閱該節(jié)點(diǎn)的Watcher,該節(jié)點(diǎn)發(fā)生事件類型
- 用于監(jiān)聽節(jié)點(diǎn)狀態(tài)的變化,比如創(chuàng)建一個(gè)節(jié)點(diǎn)、刪除一個(gè)節(jié)點(diǎn)等對節(jié)點(diǎn)的操作
- 管理客戶端與服務(wù)端連接的生命周期
三.編碼實(shí)現(xiàn)
建議大家在實(shí)現(xiàn)之前可以先對zookeeper的一些API操作有一些了解,這些我在我的另外一篇文章做了詳細(xì)的介紹,有需要的小伙伴可以移步去看看喔。
基于Springboot整合zookeeper實(shí)現(xiàn)對節(jié)點(diǎn)的創(chuàng)建、監(jiān)聽與判斷
http://www.dhdzp.com/article/252816.htm
1.在集1.在zookeeper集群中創(chuàng)建一個(gè)servers節(jié)點(diǎn)
create /servers "servers"

2.創(chuàng)建一個(gè)簡單的springboot工程并引入zookeeper

<!--引入對應(yīng)的zookeeper -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.7.1</version>
</dependency>3.編寫DistributeServer(分布式服務(wù)端)
package com.canrioyuan.zookeepertest.zkcase1;
import org.apache.zookeeper.*;
import java.io.IOException;
//分布式服務(wù)器端
public class DistributeServer {
//對應(yīng)的zookeeper客戶端連接,連接之間不能存在空格
private String connectString = "192.168.154.133:2181,192.168.154.134:2181,192.168.154.135:2181";
//超時(shí)時(shí)間,我們設(shè)置成2s
private int sessionTimeout = 2000;
//聲明zookeeper服務(wù)器端
private ZooKeeper zkServer;
public static void main(String[] args) throws IOException, InterruptedException, KeeperException {
//1.獲取zookeeper連接
DistributeServer distributeServer = new DistributeServer();
distributeServer.getConnect();
//2.注冊服務(wù)器
distributeServer.register(args[0]);
//3.啟動(dòng)
distributeServer.business(args[0]);
}
private void business(String url) throws InterruptedException {
System.out.println("url為" + url + "的服務(wù)器正在工作中");
Thread.sleep(Long.MAX_VALUE);
}
private void register(String url) throws InterruptedException, KeeperException {
//創(chuàng)建一個(gè)節(jié)點(diǎn)
zkServer.create("/servers/" + url, url.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);
System.out.println("url為" + url + "的服務(wù)器已經(jīng)上線");
}
//創(chuàng)建到zookeeper的客戶端連接
private void getConnect() throws IOException {
zkServer = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
}
});
}
}4.分布式客戶端
package com.canrioyuan.zookeepertest.zkcase1;
import org.apache.zookeeper.*;
import java.io.IOException;
import java.util.List;
//分布式客戶端
public class DistributeClient {
//對應(yīng)的zookeeper客戶端連接,連接之間不能存在空格
private String connectString = "192.168.154.133:2181,192.168.154.134:2181,192.168.154.135:2181";
//超時(shí)時(shí)間,我們設(shè)置成2s
private int sessionTimeout = 2000;
//聲明zookeeper客戶端
private static ZooKeeper zkClient;
private final String PARENT_NODE = "/servers";
public static void main(String[] args) throws IOException, InterruptedException, KeeperException {
//1.獲取zookeeper連接
DistributeClient distributeClient = new DistributeClient();
distributeClient.getConnect();
//2.獲取servers中的子節(jié)點(diǎn)信息
distributeClient.getServerList();
//3.業(yè)務(wù)邏輯
distributeClient.business();
}
private void business() throws InterruptedException {
System.out.println("客戶端正在工作中......");
Thread.sleep(Long.MAX_VALUE);
}
private void getServerList() throws InterruptedException, KeeperException {
List<String> children = zkClient.getChildren(PARENT_NODE, true);
for (String child : children) {
System.out.println(child);
}
}
private void getConnect() throws IOException {
zkClient = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
try {
getServerList();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (KeeperException e) {
e.printStackTrace();
}
}
});
}
}四.測試
1.啟動(dòng)客戶端,開啟監(jiān)聽

2.按照下面的流程啟動(dòng)服務(wù)器端

輸入對應(yīng)的服務(wù)器名,如我輸入的就是:server1

啟動(dòng)成功后結(jié)果如下所示:

關(guān)注客戶端的監(jiān)聽狀況,發(fā)現(xiàn)已經(jīng)監(jiān)聽到集群中已經(jīng)出現(xiàn)了一個(gè)節(jié)點(diǎn)

為了使輸出更明顯,我們在zookeeper中的servers節(jié)點(diǎn)下創(chuàng)建一個(gè)server2的持久節(jié)點(diǎn)

此時(shí)客戶端也監(jiān)聽到了集群中節(jié)點(diǎn)的變化

4.此時(shí)我們關(guān)閉服務(wù)器端,再來觀察一下客戶端的監(jiān)聽情況
此時(shí)我們發(fā)現(xiàn)客戶端中只輸出了server2這個(gè)節(jié)點(diǎn)

至此,我們便成功實(shí)現(xiàn)了簡單的zookeeper集群對服務(wù)器端上下線的監(jiān)聽。
至此,我們zookeeper+Springboot實(shí)現(xiàn)服務(wù)器動(dòng)態(tài)上下線監(jiān)聽教程就結(jié)束啦~
到此這篇關(guān)于zookeeper+Springboot實(shí)現(xiàn)服務(wù)器動(dòng)態(tài)上下線監(jiān)聽的文章就介紹到這了,更多相關(guān)zookeeper動(dòng)態(tài)上下線監(jiān)聽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入解析Spring?AI框架如何在Java應(yīng)用中實(shí)現(xiàn)智能化交互的關(guān)鍵
本文詳細(xì)介紹了SpringAI框架在Java應(yīng)用中的應(yīng)用,包括實(shí)體類映射、函數(shù)回調(diào)等核心功能的實(shí)現(xiàn),通過源碼分析,幫助開發(fā)者更好地理解和使用這些高級特性,提升業(yè)務(wù)效率,感興趣的朋友跟隨小編一起看看吧2024-11-11
java通過AES生成公鑰加密數(shù)據(jù)ECC加密公鑰
這篇文章主要為大家介紹了java通過AES生成公鑰加密數(shù)據(jù)ECC加密公鑰實(shí)現(xiàn)案例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
java實(shí)現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù)
今天小編就為大家分享一篇java實(shí)現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
Spring Boot實(shí)戰(zhàn)之netty-socketio實(shí)現(xiàn)簡單聊天室(給指定用戶推送消息)
本篇文章主要介紹了Spring Boot實(shí)戰(zhàn)之netty-socketio實(shí)現(xiàn)簡單聊天室(給指定用戶推送消息),具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03
Mybatis持久層框架入門之CRUD實(shí)例代碼詳解
這篇文章主要介紹了Mybatis持久層框架入門之CRUD實(shí)例,需要的朋友可以參考下2022-05-05
SpringBoot整合kafka遇到的版本不對應(yīng)問題及解決
這篇文章主要介紹了SpringBoot整合kafka遇到的版本不對應(yīng)問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
java面試題之try中含return語句時(shí)代碼的執(zhí)行順序詳解
這篇文章主要介紹了關(guān)于java中的一道面試題,這套題就是在try中含return語句時(shí)代碼的執(zhí)行順序,這個(gè)問題看似簡單,卻暗藏殺機(jī)??!文中通過一個(gè)個(gè)例子詳細(xì)介紹了其中玄機(jī),需要的朋友可以參考學(xué)習(xí),下面來一起看看吧。2017-04-04
SpringBoot中的@ConfigurationProperties注解解析
這篇文章主要介紹了SpringBoot中的@ConfigurationProperties注解解析,Spring源碼中大量使用了ConfigurationProperties注解,通過與其他注解配合使用,能夠?qū)崿F(xiàn)Bean的按需配置,該注解可以放在類上,也可以放在方法上,需要的朋友可以參考下2023-11-11

