Zookeeper--07---案例----服务器动态上下线

Posted 高高for 循环

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Zookeeper--07---案例----服务器动态上下线相关的知识,希望对你有一定的参考价值。

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


服务器动态上下线

需求:

  • 客户端能实时洞察到服务器上下线的变化

步骤

  1. 服务端启动时去注册信息(创建都是临时节点)
  2. 获取到当前在线服务器列表,并且注册监听
  3. 服务器节点下线
  4. 服务器节点上下线事件通知

临时节点是如何维持⼼跳呢?

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 注册代码

  1. 获取zk连接
  2. 注册服务器到zk集群
  3. 启动业务逻辑
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引导

Exchange服务无法启动案例分享

Tomcat服务器 Tomcat应用案例 Varnish代理服务器

RHCE 第九天 DNS及案例

SpringCloud服务拆分初探与案例解析

案例10:设置商业服务网点的高层住宅防火案例分析