zookeeper分布式集群中基于Curator实现单点设备上线下线心跳感知系统(二)(1)

.forPath(DEVICE_PATH);

System.out.println(“已创建:” + s);

} else {

System.out.println(“已存在:” + DEVICE_PATH);

}

TreeCache treeCache = new TreeCache(client, DEVICE_PATH);

TreeCacheListener treeCacheListener = new TreeCacheListener() {

@Override

public void childEvent(CuratorFramework client, TreeCacheEvent event) throws Exception {

System.out.println(“-----”);

System.out.println(“路径:” + event.getData().getPath());

System.out.println(“数据:” + new String(event.getData().getData(), “UTF-8”));

System.out.println(“ZooKeeper:” + client.getZookeeperClient().getZooKeeper().toString());

}

};

treeCache.getListenable().addListener(treeCacheListener);

treeCache.start();

synchronized (this) {

wait();

}

}

}

下面这个设备B模拟一个普通设备接入分布式集群中:

import org.apache.curator.RetryPolicy;

import org.apache.curator.framework.CuratorFramework;

import org.apache.curator.framework.CuratorFrameworkFactory;

import org.apache.curator.retry.ExponentialBackoffRetry;

import org.apache.zookeeper.CreateMode;

public class Main {

private String DEVICE_PATH = “/devices”;

public static void main(String[] args) {

//初始化log4j,zookeeper否则报错。

//org.apache.log4j.BasicConfigurator.configure();

try {

Main app = new Main();

} catch (Exception e) {

e.printStackTrace();

}

}

public Main() throws Exception {

RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 5);

CuratorFramework client = CuratorFrameworkFactory.builder()

.connectString(getAddress())

.sessionTimeoutMs(20 * 1000)

.connectionTimeoutMs(20 * 1000)

.retryPolicy(retryPolicy)

.build();

client.start();

String s = client.create()

.creatingParentsIfNeeded()

.withMode(CreateMode.EPHEMERAL_SEQUENTIAL)

.forPath(DEVICE_PATH + “/client”);

System.out.println(“已创建:” + s);

synchronized (this) {

wait();

}

}

private String getAddress() {

String ip = “127.0.0.1”;
return ip + “:2181,” + ip + “:2182,” + ip + “:2183”;
}
}
设备A和设备B均针对/devices作为node path监听。

最后

希望大家能有一个好心态,想进什么样的公司要想清楚,并不一定是大公司,我选的也不是特大厂。当然如果你不知道选或是没有规划,那就选大公司!希望我们能先选好想去的公司再投或内推,而不是有一个公司要我我就去!还有就是不要害怕,也不要有压力,平常心对待就行,但准备要充足。最后希望大家都能拿到一份满意的 offer !如果目前有一份工作也请好好珍惜好好努力,找工作其实挺累挺辛苦的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

升。**

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值