分布式服务管理zookeeper的java api
zookeeper是一个分布式服务管理工具,本身具备高可用性,很多知名分布式系统入hadoop、Hbase等都采用zk管理。
常见的两个应用场景:1、服务的注册与发现 2、集群统一配置
下面看一下使用java 对zk进行交互的常用api
首先maven引入:
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.5.3-beta</version>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
import org.I0Itec.zkclient.ZkClient;
import org.I0Itec.zkclient.serialize.SerializableSerializer;
import org.apache.zookeeper.CreateMode; /**
* @author panteng
* @description
* @date 17-5-24.
*/
public class Zk {
public static void main(String[] arges) {
String ZKServers = "10.38.164.80:2181,10.38.164.80:2182,10.38.164.80:2183";
/**
* 创建会话
* new SerializableSerializer() 创建序列化器接口,用来序列化和反序列化
*/
ZkClient zkClient = new ZkClient(ZKServers, 10000, 10000, new SerializableSerializer());
System.out.println("conneted ok!"); //订阅节点的子节点变化
zkClient.subscribeChildChanges("/javaApp", new ZKChildListener());
String appPath = zkClient.create("/javaApp/api", "javaApp", CreateMode.EPHEMERAL_SEQUENTIAL);
//输出创建节点的路径
System.out.println("created path:" + appPath);
//订阅数据的变化
zkClient.subscribeDataChanges(appPath, new ZkDataListener()); //读数据
String str = zkClient.readData(appPath);
System.out.println(str);
//写数据
zkClient.writeData(appPath, "newJavaApp");
System.out.println(zkClient.readData(appPath));
//判断节点是否存在
System.out.println(zkClient.exists("/javaApp/api0000000010")); try {
Thread.sleep(20000);
} catch (Exception e) { }
}
}
Zk.java
import org.I0Itec.zkclient.IZkDataListener; /**
* @author panteng
* @description
* @date 17-5-24.
*/
public class ZkDataListener implements IZkDataListener {
/**
* 节点数据发生变化时 触发此函数
*
* @param s 发生变化的节点路径
* @param o 节点变化后的数据
* @throws Exception
*/
@Override
public void handleDataChange(String s, Object o) throws Exception {
System.out.println("Change = " + s + " obj=" + o);
} @Override
public void handleDataDeleted(String s) throws Exception {
System.out.println("Delete = " + s);
}
}
ZkDataListener
import org.I0Itec.zkclient.IZkDataListener; /**
* @author panteng
* @description
* @date 17-5-24.
*/
public class ZkDataListener implements IZkDataListener {
/**
* 节点数据发生变化时 触发此函数
*
* @param s 发生变化的节点路径
* @param o 节点变化后的数据
* @throws Exception
*/
@Override
public void handleDataChange(String s, Object o) throws Exception {
System.out.println("Change = " + s + " obj=" + o);
} @Override
public void handleDataDeleted(String s) throws Exception {
System.out.println("Delete = " + s);
}
}
ZkDataListener
遍历所有节点
public static void getAllNodes(ZkClient zkClient, String currentPath) {
try {
List<String> stringList = zkClient.getChildren(currentPath);
for (String str : stringList) {
if ("/".equals(currentPath)) {
str = currentPath + str;
} else {
str = currentPath + "/" + str;
}
System.out.println(str);
getAllNodes(zkClient, str);
}
} catch (Exception e) {
if (e.getMessage().indexOf("KeeperErrorCode = NoNode for") > -1) {
return;
}
}
}
分布式服务管理zookeeper的java api的更多相关文章
- 分布式服务框架 Zookeeper — 管理分布式环境中的数据
本节本来是要介绍ZooKeeper的实现原理,但是ZooKeeper的原理比较复杂,它涉及到了paxos算法.Zab协议.通信协议等相关知识,理解起来比较抽象所以还需要借助一些应用场景,来帮我们理解. ...
- 分布式服务框架 Zookeeper(转)
分布式服务框架 Zookeeper -- 管理分布式环境中的数据 Zookeeper 分布式服务框架是 Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题 ...
- 大数据 --> 分布式服务框架Zookeeper
分布式服务框架 Zookeeper Zookeeper系列 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
- Linux -- 基于zookeeper的java api(二)
Linux -- 基于zookeeper的java api(二) 写一个关于基于集群的zookeeper的自定义实现HA 基于客户端和监控器:使用监控的方法查看每个注册过的节点的状态来做出操作. Wa ...
- zookeeper的java api操作
zookeeper的java api操作 创建会话: Zookeeper(String connectString,int sessionTimeout,Watcher watcher) Zookee ...
- Linux -- 基于zookeeper的java api(一)
Linux -- 基于zookeeper的java api 首先启动你所有的 zkService.sh 查看状态:检查是否启动正确 [root@hu-hadoop2 ~]# zkServer.sh s ...
- 【分布式】Zookeeper使用--Java API
一.前言 上一篇博客我们通过命令行来操作Zookeper的客户端和服务端并进行相应的操作,这篇主要介绍如何通过API(JAVA)来操作Zookeeper. 二.开发环境配置 首先打开Zookeeper ...
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据
转自:http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/index.html Zookeeper 分布式服务框架是 Apa ...
- 分布式服务框架 Zookeeper -- 管理分布式环境中的数据(转载)
本文转载自:http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/ Zookeeper 分布式服务框架是 Apache Had ...
随机推荐
- WordPress常用标签和调用总结
调用头部模板<?php get_header();?> 调用尾部模板<?php get_footer();?> 调用侧边栏<?php get_sidebar();?> ...
- php读取xml的神器
<?xml version="1.0 encoding="UTF-8"?> <humans> <zhangying> <name ...
- 控制器post参数接收
一.post对象 1.后台c# public class TestController : ApiController { [HttpPost] public string SaveData1(Tb_ ...
- Scala之模式匹配(Patterns Matching)
前言 首先.我们要在一開始强调一件非常重要的事:Scala的模式匹配发生在但绝不仅限于发生在match case语句块中.这是Scala模式匹配之所以重要且实用的一个关键因素!我们会在文章的后半部分具 ...
- MySQL索引使用:字段为varchar类型时,条件要使用''包起来
结论: 当MySQL中字段为int类型时,搜索条件where num='111' 与where num=111都可以使用该字段的索引.当MySQL中字段为varchar类型时,搜索条件where nu ...
- gcc 编译 连接 生成可执行文件
gcc c语言编译器 g++ c++编译器 gcc a.c 生成默认的a.out 可执行文件 ./a.out 来执行 gcc -c a.c 编译生成 a.o 目标文件 可以检查语法错误 gcc ...
- Python操作yaml文件
基本的yaml语法 http://ansible-tran.readthedocs.io/en/latest/docs/YAMLSyntax.html YAML 还有一个小的怪癖. 所有的 YAML ...
- java中通过配置文件的方式(Jedis驱动)使用Redis
在java中使用Redis,实际上是将Redis的一些命令封装到Jedis的实体类中,然后进行调用.
- css,查询相应标签,div等
1.类名 .类别 例子: 查询类名为“useradd” .useradd{ margin-top:50px; margin-left:200px;} 2.属性找 例子:查询类为useradd下的inp ...
- 解决Initializing Java Tooling 和 Initializing Java Tooling卡死问题
遇到了如题的问题,使用如下方法解决了 工作中eclipse崩溃,再次启动后,状态栏一直显示 Initializing Javascript Tooling . 解决方案: 删除\workspace\ ...