Zookeeper--07---案例----服务器动态上下线
Posted 高高for 循环
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Zookeeper--07---案例----服务器动态上下线相关的知识,希望对你有一定的参考价值。
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
服务器动态上下线
需求:
- 客户端能实时洞察到服务器上下线的变化
步骤
- 服务端启动时去注册信息(创建都是临时节点)
- 获取到当前在线服务器列表,并且注册监听
- 服务器节点下线
- 服务器节点上下线事件通知
临时节点是如何维持⼼跳呢?
zk的watch机制
Watch机制介绍
- 我们可以把 Watch 理解成是注册在特定 Znode 上的触发器。
- 当这个 Znode 发⽣改变,也就是调⽤了 create , delete , setData ⽅法的时候,将会触发 Znode上注册的对应事件,请求 Watch 的客户端会接收到异步通知。
具体交互过程如下:
- 客户端调⽤ getData ⽅法, watch 参数是 true 。服务端接到请求,返回节点数据,并且在对应的哈希表⾥插⼊被 Watch 的 Znode 路径,以及 Watcher 列表。
- 当被 Watch 的 Znode 已删除,服务端会查找哈希表,找到该 Znode
对应的所有Watcher,异步通知客户端,并且删除哈希表中对应的 Key-Value。
客户端使⽤了NIO通信模式监听服务端的调⽤。
具体实现
1.先在集群上创建/servers 节点
[zk: localhost:2181(CONNECTED) 10] create /servers "servers"
2. 服务器端向Zookeeper 注册代码
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.5.7</version>
</dependency>
3.服务器端向Zookeeper 注册代码
- 获取zk连接
- 注册服务器到zk集群
- 启动业务逻辑
package com.example.demo.atguigu.case1;
import org.apache.zookeeper.*;
import java.io.IOException;
public class DistributeServer
private String connectString = "hadoop102:2181,hadoop103:2181,hadoop104:2181";
private int sessionTimeout = 2000;
private ZooKeeper zk;
public static void main(String[] args) throws IOException, KeeperException, InterruptedException
DistributeServer server = new DistributeServer();
// 1 获取zk连接
server.getConnect();
// 2 注册服务器到zk集群
server.regist(args[0]);
// 3 启动业务逻辑(睡觉)
server.business();
private void business() throws InterruptedException
Thread.sleep(Long.MAX_VALUE);
private void regist(String hostname) throws KeeperException, InterruptedException
String create = zk.create("/servers/"+hostname, hostname.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);
System.out.println(hostname +" is online") ;
private void getConnect() throws IOException
zk = new ZooKeeper(connectString, sessionTimeout, new Watcher()
@Override
public void process(WatchedEvent watchedEvent)
);
4.客户端代码 )客户端代码
package com.example.demo.atguigu.case1;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
public class DistributeClient
private String connectString = "hadoop102:2181,hadoop103:2181,hadoop104:2181";
private int sessionTimeout = 2000;
private ZooKeeper zk;
public static void main(String[] args) throws IOException, KeeperException, InterruptedException
DistributeClient client = new DistributeClient();
// 1 获取zk连接
client.getConnect();
// 2 监听/servers下面子节点的增加和删除
client.getServerList();
// 3 业务逻辑(睡觉)
client.business();
private void business() throws InterruptedException
Thread.sleep(Long.MAX_VALUE);
private void getServerList() throws KeeperException, InterruptedException
List<String> children = zk.getChildren("/servers", true);
ArrayList<String> servers = new ArrayList<>();
for (String child : children)
byte[] data = zk.getData("/servers/" + child, false, null);
servers.add(new String(data));
// 打印
System.out.println(servers);
private void getConnect() throws IOException
zk = new ZooKeeper(connectString, sessionTimeout, new Watcher()
@Override
public void process(WatchedEvent watchedEvent)
try
getServerList();
catch (KeeperException e)
e.printStackTrace();
catch (InterruptedException e)
e.printStackTrace();
);
5.测试
1)在 Linux命令行上操作增加减少服务器
2)在 Idea上操作增加减少服务器
以上是关于Zookeeper--07---案例----服务器动态上下线的主要内容,如果未能解决你的问题,请参考以下文章
PXE基础装机环境 案例2:配置并验证DHCP服务 案例3:配置PXE引导