zookeeper的简单使用
来源:互联网 发布:matlab微电网优化调度 编辑:程序博客网 时间:2024/06/05 11:45
前言
最近项目中要使用基于zookeeper的集中配置管理系统,而对于zookeeper仅在当初使用阿里开源分布式服务调用框架dubbo时简单的了解一下。本
文的主要目的,调用zkclient (maven 地址见下面)实现监听当某个节点的数据发生变化时,将变化的信息打印到控制台。
zkclient的maven地址
<dependency> <groupId>com.101tec</groupId> <artifactId>zkclient</artifactId> <version>0.4</version></dependency>
master app 应用程序
编写 master app应用程序,该程序主要功能是创建一个"root1"的节点,并每20s改变该节点的数据。程序代码如下:
1 import java.util.UUID; 2 3 import org.I0Itec.zkclient.ZkClient; 4 import org.apache.zookeeper.CreateMode; 5 6 7 public class App { 8 9 private ZkClient zkClient;10 11 public ZkClient getZkClient() {12 return zkClient;13 }14 15 public void setZkClient(ZkClient zkClient) {16 this.zkClient = zkClient;17 }18 19 20 /**21 * 函数入口22 * @param args23 */24 public static void main( String[] args ) {25 26 App bootStrap=new App();27 bootStrap.initialize();28 29 try {30 Thread.sleep(100000000);31 } catch (InterruptedException e) {32 e.printStackTrace();33 }34 35 }36 37 38 /**39 * 初始化zookeeper40 */41 public void initialize() {42 43 String connectionString="192.168.19.128:2181";44 int connectionTimeout=50000;45 46 zkClient=new ZkClient(connectionString, connectionTimeout);47 48 if(!zkClient.exists("/root1")) {49 zkClient.create("/root1", new Long(System.currentTimeMillis()), CreateMode.EPHEMERAL);50 }51 52 new Thread(new RootNodeChangeThread()).start();53 }54 55 /**56 * 每20s改变一次 'root1'节点的数据57 * @author yang58 *59 */60 private class RootNodeChangeThread implements Runnable{61 62 public void run() {63 64 while(true) {65 66 try {67 Thread.sleep(20000);68 } catch (InterruptedException e) {69 //ignore70 }71 72 String uuidStr=UUID.randomUUID().toString(); 73 74 System.out.println(">>>>>>>>>> 产生随机的 uuid string,'uuidStr'===>"+uuidStr);75 76 zkClient.writeData("/root1", uuidStr);77 78 }79 80 }81 82 }83 }
slave app应用程序
编写 slave app应用程序,该程序主要功能是监听"root1"的节点,当其数据发生变化时,在控制台中打印中相关信息。程序代码如下:
1 import org.I0Itec.zkclient.IZkDataListener; 2 import org.I0Itec.zkclient.ZkClient; 3 4 public class App { 5 6 private ZkClient zkClient; 7 8 public ZkClient getZkClient() { 9 return zkClient;10 }11 12 public void setZkClient(ZkClient zkClient) {13 this.zkClient = zkClient;14 }15 16 /**17 * 初始化zookeeper18 */19 public void initialize() {20 21 String connectionString="192.168.19.128:2181";22 int connectionTimeout=500000;23 24 zkClient=new ZkClient(connectionString, connectionTimeout);25 26 new Thread(new Runnable() {27 28 public void run() {29 30 zkClient.subscribeDataChanges("/root1", new IZkDataListener() {31 32 public void handleDataDeleted(String dataPath) throws Exception {33 System.out.println("the node 'dataPath'===>"); 34 }35 36 public void handleDataChange(String dataPath, Object data) throws Exception {37 System.out.println("the node 'dataPath'===>"+dataPath+", data has changed.it's data is "+String.valueOf(data));38 39 }40 });41 42 }43 44 }).start();45 }46 47 /**48 * 函数入口49 * @param args50 */51 public static void main( String[] args ) {52 53 App bootStrap=new App();54 bootStrap.initialize();55 56 try {57 Thread.sleep(100000000);58 } catch (InterruptedException e) {59 e.printStackTrace();60 }61 62 }63 }
环境准备
启动zookeeper,并关闭linux防火墙。
运行程序
运行 master app和slave app 两个应用程序,截图如下:
阅读全文
0 0
- zookeeper的简单使用
- zookeeper的简单使用
- zookeeper的简单使用
- zookeeper的简单使用
- ZooKeeper的部署以及简单使用
- zookeeper的下载使用及简单demo
- ZooKeeper的部署以及简单使用
- ZooKeeper的部署以及简单使用
- Dubbo-02:使用zookeeper的简单demo
- 分布式zookeeper+dubbo的简单配置使用
- zookeeper简单配置使用
- zookeeper简单使用
- Zookeeper的简单应用
- ZooKeeper的简单操作
- ZooKeeper的简单操作
- zookeeper的简单介绍
- zookeeper的简单介绍
- ZooKeeper的简单操作
- 分析 ddp aal 模块
- ES6
- Fire Game(两点bfs)
- 求字符串的最长回文子串(manacher算法O(n)时间)
- node_modules目录嵌套无法删除
- zookeeper的简单使用
- 计算机网络复习笔记
- CF 333 A.Secrets【枚举】
- Linux虚拟机安装后没有IP地址怎么办
- AlphaGo Zero 总结
- python学习(二十一)
- php——后台表格分页
- C语言入门——时间换算
- Oracle转换成SqlServer数据库的步骤