向Zookeeper中注册内容以及从zookeeper中发现内容
admin
2024-03-22 00:58:21

一、向Zookeeper中注册内容

新建项目ZookeeperClient

1 创建/demo

使用zookeeper的客户端命令工具创建/demo

./zkCli.sh
create /demos

2 添加依赖

org.apache.zookeeperzookeeper3.5.5

3 编写代码

创建类com.msb.MyApp。

ZooDefs.Ids.OPEN_ACL_UNSAFE 表示权限。

CreateMode.PERSISTENT_SEQUENTIAL 永久存储,文件内容编号递增。

public static void main(String [] args){try {ZooKeeper zookeeper = new ZooKeeper("192.168.32.128:2181", 10000, new Watcher() {@Overridepublic void process(WatchedEvent watchedEvent) {System.out.println("获取连接");}});String content = zookeeper.create("/demo/nn", "content".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT_SEQUENTIAL);System.out.println("content"+content);} catch (IOException e) {e.printStackTrace();} catch (KeeperException e) {e.printStackTrace();} catch (InterruptedException e) {e.printStackTrace();}
}

4 查看上传数据

ls -R / :查看列表

get /demo/nn0000000002 :查看内容

二、 从zookeeper中发现内容

在原有项目中新建一个类,类中编写主方法。

public static void main(String[] args) {try {ZooKeeper zookeeper = new ZooKeeper("192.168.32.128:2181", 10000, new Watcher() {@Overridepublic void process(WatchedEvent watchedEvent) {System.out.println("获取连接");}});//获取列表List list = zookeeper.getChildren("/demo", false);for (String child : list) {byte[] result = zookeeper.getData("/demo/" + child, false, null);System.out.println(new String(result));}} catch (IOException e) {e.printStackTrace();} catch (KeeperException e) {e.printStackTrace();} catch (InterruptedException e) {e.printStackTrace();}
}

相关内容

热门资讯

香煎鳕鱼的鲜嫩秘诀!外焦里嫩比... 你知道吗?78%的人煎鳕鱼总感觉又柴又老,其实是因为没掌握对的方法。今天就教你如何在家做出外焦里嫩、...
怎么做才能让春饼更正宗?家常春... 春天来临,万物复苏,是时候享受美味的春饼了!你是否也曾在春日的阳光下,期待一份热气腾腾的春饼?那么,...
金沙食记 金沙羊肉粉(吴艳禹 摄) 一 清晨的雾还未散尽,巷口那口大锅已吐着白茫茫的蒸汽。羊骨在汤底里慢悠悠地...