设为首页 收藏本站
查看: 790|回复: 0

[经验分享] 如何使用Curator操作zookeeper

[复制链接]

尚未签到

发表于 2017-4-19 08:49:51 | 显示全部楼层 |阅读模式
Curator是Netflix开源的一套ZooKeeper客户端框架,用它来操作zookeeper更加简单方便,按Curator官方所比喻的,guava to JAVA, Curator to Zookeeper,Curator采用了fluent风格的代码,非常简洁。
有关curator的介绍:请参照官方文档:http://curator.apache.org/index.html

本篇主要看下,使用curator操作zookeeper的一些基础例子:
主要的功能:
1,在zk上添加,或更新数据
2,删除zk节点上数据
3,读取某个节点上的数据
4,上传一些本地文件到zk节点上
5,检查zookeeper上是否存在某个节点路径
核心代码如下:
package com.qin.curator.zk;
import java.io.File;
import java.util.List;
import org.apache.commons.io.FileUtils;
import org.apache.curator.CuratorZookeeperClient;
import org.apache.curator.RetryPolicy;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.CuratorFrameworkFactory.Builder;
import org.apache.curator.framework.api.CreateBuilder;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZKUtil;
import framework.CrudExamples;
/**
* @author qindongliang
* curator操作zookeeper的
* 基本例子
* **/
public class CuratorTools {
static CuratorFramework zkclient=null;
static String nameSpace="php";
static {
String zkhost="192.168.46.22:2181";//zk的host
RetryPolicy rp=new ExponentialBackoffRetry(1000, 3);//重试机制
Builder builder = CuratorFrameworkFactory.builder().connectString(zkhost)
.connectionTimeoutMs(5000)
.sessionTimeoutMs(5000)
.retryPolicy(rp);
builder.namespace(nameSpace);
CuratorFramework zclient = builder.build();
zkclient=zclient;
zkclient.start();// 放在这前面执行
zkclient.newNamespaceAwareEnsurePath(nameSpace);
}
public static void main(String[] args)throws Exception {
CuratorTools ct=new  CuratorTools();
//ct.getListChildren("/zk/bb");
//ct.upload("/jianli/123.txt", "D:\\123.txt");
//ct.createrOrUpdate("/zk/cc334/zzz","c");
//ct.delete("/qinb/bb");
//ct.checkExist("/zk");
ct.read("/jianli/123.txt");
zkclient.close();

}
/**
* 创建或更新一个节点
*
* @param path 路径
* @param content 内容
* **/
public void createrOrUpdate(String path,String content)throws Exception{
zkclient.newNamespaceAwareEnsurePath(path).ensure(zkclient.getZookeeperClient());
zkclient.setData().forPath(path,content.getBytes());
System.out.println("添加成功!!!");
}
/**
* 删除zk节点
* @param path 删除节点的路径
*
* **/
public void delete(String path)throws Exception{
zkclient.delete().guaranteed().deletingChildrenIfNeeded().forPath(path);
System.out.println("删除成功!");
}

/**
* 判断路径是否存在
* @param path
* **/
public void checkExist(String path)throws Exception{
if(zkclient.checkExists().forPath(path)==null){
System.out.println("路径不存在!");
}else{
System.out.println("路径已经存在!");
}
}
/**
* 读取的路径
* @param path
* **/
public void read(String path)throws Exception{

String data=new String(zkclient.getData().forPath(path),"gbk");
System.out.println("读取的数据:"+data);
}

/**
* @param path 路径
* 获取某个节点下的所有子文件
* */
public void getListChildren(String path)throws Exception{
List<String> paths=zkclient.getChildren().forPath(path);
for(String p:paths){
System.out.println(p);
}
}
/**
* @param zkPath zk上的路径
* @param localpath 本地上的文件路径
*
* **/
public void upload(String zkPath,String localpath)throws Exception{
createrOrUpdate(zkPath, "");//创建路径
byte[] bs=FileUtils.readFileToByteArray(new File(localpath));
zkclient.setData().forPath(zkPath, bs);
System.out.println("上传文件成功!");

}


}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-366138-1-1.html 上篇帖子: zookeeper使用原理探究 下篇帖子: Zookeeper 安装和配置 集群
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表