博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
zookeeper 服务端上下线,客户端感知
阅读量:5335 次
发布时间:2019-06-15

本文共 4330 字,大约阅读时间需要 14 分钟。

package pfs.y2017.m11.zookeeper.demo03;import java.util.ArrayList;import java.util.List;import org.apache.zookeeper.KeeperException;import org.apache.zookeeper.WatchedEvent;import org.apache.zookeeper.Watcher;import org.apache.zookeeper.ZooKeeper;public class DistributedClient {    private static final String connectString = "192.168.1.192:2181,192.168.1.55:2181,192.168.1.28:2181";    private static final int sessionTimeout = 2000;    private static final String parentNode = "/servers";    // 注意:加volatile的意义何在?    private volatile List
serverList; private ZooKeeper zk = null; /** * 创建到zk的客户端连接 * * @throws Exception */ public void getConnect() throws Exception { zk = new ZooKeeper(connectString, sessionTimeout, new Watcher() { @Override public void process(WatchedEvent event) { // 收到事件通知后的回调函数(应该是我们自己的事件处理逻辑) try { //重新更新服务器列表,并且注册了监听 getServerList(); } catch (Exception e) { } } }); } /** * 获取服务器信息列表 * * @throws Exception */ public void getServerList() throws Exception { // 获取服务器子节点信息,并且对父节点进行监听 List
children = zk.getChildren(parentNode, true); // 先创建一个局部的list来存服务器信息 List
servers = new ArrayList
(); for (String child : children) { // child只是子节点的节点名 byte[] data = zk.getData(parentNode + "/" + child, false, null); servers.add(new String(data)); } // 把servers赋值给成员变量serverList,已提供给各业务线程使用 serverList = servers; //打印服务器列表 System.out.println(serverList); } /** * 业务功能 * * @throws InterruptedException */ public void handleBussiness() throws InterruptedException { System.out.println("client start working....."); Thread.sleep(Long.MAX_VALUE); } public static void main(String[] args) throws Exception { // 获取zk连接 DistributedClient client = new DistributedClient(); client.getConnect(); // 获取servers的子节点信息(并监听),从中获取服务器信息列表 client.getServerList(); // 业务线程启动 client.handleBussiness(); }}

 

 

package pfs.y2017.m11.zookeeper.demo03;import java.util.List;import org.apache.zookeeper.CreateMode;import org.apache.zookeeper.WatchedEvent;import org.apache.zookeeper.Watcher;import org.apache.zookeeper.ZooDefs.Ids;import org.apache.zookeeper.ZooKeeper;public class DistributedServer {    private static final String connectString = "192.168.1.192:2181,192.168.1.55:2181,192.168.1.28:2181";    private static final int sessionTimeout = 2000;    private static final String parentNode = "/servers";    private ZooKeeper zk = null;    /**     * 创建到zk的客户端连接     *      * @throws Exception     */    public void getConnect() throws Exception {        zk = new ZooKeeper(connectString, sessionTimeout, new Watcher() {            @Override            public void process(WatchedEvent event) {                // 收到事件通知后的回调函数(应该是我们自己的事件处理逻辑)                System.out.println(event.getType() + "---" + event.getPath());                try {                    zk.getChildren("/", true);                } catch (Exception e) {                }            }        });    }    /**     * 向zk集群注册服务器信息     *      * @param hostname     * @throws Exception     */    public void registerServer(String hostname) throws Exception {        String create = zk.create(parentNode + "/server", hostname.getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);        System.out.println(hostname + "is online.." + create);    }    /**     * 业务功能     *      * @throws InterruptedException     */    public void handleBussiness(String hostname) throws InterruptedException {        System.out.println(hostname + "start working.....");        Thread.sleep(Long.MAX_VALUE);    }    public static void main(String[] args) throws Exception {        // 获取zk连接        DistributedServer server = new DistributedServer();        server.getConnect();        // 利用zk连接注册服务器信息        server.registerServer(args[0]);        // 启动业务功能        server.handleBussiness(args[0]);    }}

 

转载于:https://www.cnblogs.com/Damon-Luo/p/7825859.html

你可能感兴趣的文章
深度学习激活函数们
查看>>
极其平凡的一天——3.19
查看>>
12306购票
查看>>
[笔记] 走进 Pocket,看看只有 20 位员工的 Pocket 是如何搞定 2000 万用户的
查看>>
HMTL—表单
查看>>
QuickHit游戏
查看>>
字符串中数字,字母,空格等的数量统计
查看>>
C#OOP之四 深入理解方法
查看>>
Python生成器
查看>>
几个常用的小shell
查看>>
swiper3d横向滚动多张炫酷切换banner
查看>>
微信小程序 scroll-view 实现锚点跳转
查看>>
jenkins 构建到最后报权限的问题
查看>>
Node中怎么保持MySql一直连接不断开
查看>>
修正下载链接的树莓派Flash教程(前置:Chromium浏览器)
查看>>
iso网络模型
查看>>
Nagios监控磁盘
查看>>
802.1br
查看>>
JavaScript Function.prototype.bind()
查看>>
学习ruby/rails, rvm是必不可少的工具之一
查看>>