【zookeeper CuratorFramework实现服务发现】 1.TreeCache+TreeCacheListener

pom.xml

复制代码
        <!--zk-->
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>4.0.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>4.0.0</version>
        </dependency>

1.Gateway.java

复制代码
package org.example.testZk;

import java.nio.charset.StandardCharsets;
import java.util.List;
import lombok.extern.slf4j.Slf4j;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.cache.ChildData;
import org.apache.curator.framework.recipes.cache.TreeCache;
import org.apache.curator.framework.recipes.cache.TreeCacheListener;
import org.apache.curator.retry.ExponentialBackoffRetry;

@Slf4j
public class Gateway {

    public static void main(String[] args) throws Exception {
        // 启动zk
        CuratorFramework cf = CuratorFrameworkFactory.builder().connectString("127.0.0.1:2181").sessionTimeoutMs(4000)
                .retryPolicy(new ExponentialBackoffRetry(1000, 3)).build();

        cf.start();

        // 打印下状态
        log.info("zk启动状态:{}", cf.getState());

        // 创建持久节点:游戏服列表根节点
        if (cf.checkExists().forPath("/game-nodes") == null) {
            log.info("持久节点不存在,创建下");
            cf.create().forPath("/game-nodes", "".getBytes(StandardCharsets.UTF_8));
        } else {
            log.info("根节点已经存在");
        }

        // 监听节点的变化
        TreeCache treeCache = new TreeCache(cf, "/game-nodes");
        TreeCacheListener listener = (curatorFramework, event) -> {
            ChildData data = event.getData();
            boolean change = true;

            if (data != null) {
                log.info("改变的路径path={} 事件type={} data={}", event.getData().getPath(), event.getType(), new String(event.getData().getData()));

                switch (event.getType()) {
                    case NODE_ADDED:
                        break;
                    case NODE_UPDATED:
                        break;
                    case NODE_REMOVED:
                        break;
                    default:
                        change = false;
                        break;
                }
            } else {
                change = false;
                log.info("事件type={}", event.getType());
            }


            if (change) {
                System.out.println();
                // 获取所有的游戏服节点列表
                List<String> serverList = cf.getChildren().forPath("/game-nodes");
                if (!serverList.isEmpty()) {
                    for (String gameNodeName : serverList) {
                        String hostPort = new String(cf.getData().forPath("/game-nodes/" + gameNodeName));
                        log.info("游戏服{} 地址信息:{}", gameNodeName, hostPort);
                    }
                } else {
                    log.info("服务器列表为空");
                }

                System.out.println();
            }
        };
        treeCache.getListenable().addListener(listener);
        treeCache.start();

        System.in.read();
    }
}

/*
参考:https://blog.csdn.net/ytangdigl/article/details/108593958
 */

2.GameNode.java

复制代码
package org.example.testZk;

import java.nio.charset.StandardCharsets;
import java.util.List;
import lombok.extern.slf4j.Slf4j;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.apache.zookeeper.CreateMode;

@Slf4j
public class GameNode {

    public static void main(String[] args) throws Exception {
        // 启动zk
        CuratorFramework cf = CuratorFrameworkFactory.builder().connectString("127.0.0.1:2181").sessionTimeoutMs(4000)
                .retryPolicy(new ExponentialBackoffRetry(1000, 3)).build();

        cf.start();

        // 打印下状态
        log.info("zk启动状态:{}", cf.getState());

        // 创建持久节点:游戏服列表根节点
        if (cf.checkExists().forPath("/game-nodes") == null) {
            log.info("持久节点不存在,创建下");
            cf.create().forPath("/game-nodes", "".getBytes(StandardCharsets.UTF_8));
        } else {
            log.info("根节点已经存在");
        }

        // 创建临时节点(存在则删除)
        String addNodePath = "/game-nodes/game-node-1";
        if (cf.checkExists().forPath(addNodePath) != null) {
            cf.delete().forPath(addNodePath);
        }
        cf.create().withMode(CreateMode.EPHEMERAL).forPath(addNodePath, "127.0.0.1:6000".getBytes(StandardCharsets.UTF_8));

        System.in.read();
    }
}

/*
11:26:09.747 [main] INFO org.example.testZk.GameNode -- 根节点已经存在
 */

思考:

zk中我们往往是:2层节点树就够了,这样子可以获取服务器列表之类的。

相关推荐
007php0072 天前
百度面试题解析:Zookeeper、ArrayList、生产者消费者模型及多线程(二)
java·分布式·zookeeper·云原生·职场和发展·eureka·java-zookeeper
坐吃山猪4 天前
zk02-知识演进
运维·zookeeper·debian
yumgpkpm4 天前
华为鲲鹏 Aarch64 环境下多 Oracle 数据库汇聚操作指南 CMP(类 Cloudera CDP 7.3)
大数据·hive·hadoop·elasticsearch·zookeeper·big data·cloudera
小醉你真好5 天前
16、Docker Compose 安装Kafka(含Zookeeper)
docker·zookeeper·kafka
yumgpkpm6 天前
CMP (类ClouderaCDP7.3(404次编译) )华为鲲鹏Aarch64(ARM)信创环境多个mysql数据库汇聚的操作指南
大数据·hive·hadoop·zookeeper·big data·cloudera
yumgpkpm8 天前
大数据综合管理平台(CMP)(类Cloudera CDP7.3)有哪些核心功能?
hive·hadoop·elasticsearch·zookeeper·big data
回家路上绕了弯11 天前
深入 Zookeeper 数据模型:树形 ZNode 结构的设计与实践
后端·zookeeper
90919322112 天前
SQL关键词标签在数据分析中的应用与实践
zookeeper
小马爱打代码12 天前
zookeeper:一致性原理和算法
分布式·zookeeper·云原生
小马爱打代码12 天前
zookeeper:架构原理和使用场景
分布式·zookeeper·架构