`
qindongliang1922
  • 浏览: 2189441 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
7265517b-f87e-3137-b62c-5c6e30e26109
证道Lucene4
浏览量:117687
097be4a0-491e-39c0-89ff-3456fadf8262
证道Hadoop
浏览量:126090
41c37529-f6d8-32e4-8563-3b42b2712a50
证道shell编程
浏览量:60040
43832365-bc15-3f5d-b3cd-c9161722a70c
ELK修真
浏览量:71416
社区版块
存档分类
最新评论

如何使用Curator操作zookeeper

阅读更多
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("上传文件成功!");
		
		
	}
	
	
	
	
	
}









分享到:
评论
2 楼 qindongliang1922 2014-11-06  
不一样,curator是api级别操作
1 楼 福将1032 2014-11-06  
请求一下,用curator管理和hadoop那种直接配置zookeeper文件的方式有啥区别?

相关推荐

    curator_zookeeper需要的jar

    描述提到“curator封装zookeeper需要的jar”,这意味着我们将探讨Curator如何将复杂的Zookeeper操作包装成更易于使用的Java接口。 首先,`zookeeper-3.4.6.jar`是Zookeeper的核心库,包含了Zookeeper服务器和客户端...

    zookeeper客户端curator操作示例

    而Apache Curator是Facebook开源的一个ZooKeeper客户端库,它提供了更高级别的API,简化了ZooKeeper的使用,并增加了诸如连接管理、重试策略、事务操作等功能。 在Java开发中,Curator是使用ZooKeeper最常用且推荐...

    curator zookeeper 3.4.6 2.9.1

    5. javassist.jar:这是一个Java字节码操作库,Curator可能使用它来动态修改类的行为,例如在客户端实现更复杂的监控和管理功能。 6. swift-codec-0.16.0.jar和swift-service-0.16.0.jar:这些可能与特定项目或库...

    zookeeper 使用 Curator 示例监听、分布式锁

    综上所述,这个示例项目将展示如何使用 Curator 对 ZooKeeper 进行数据操作,以及如何实现基于 ZooKeeper 的分布式锁,这对于构建分布式系统中的并发控制和协调至关重要。通过学习这个示例,你可以深入理解 ...

    maven-zookeeper

    总的来说,`maven-zookeeper`项目为学习和实践如何使用Curator操作Zookeeper集群提供了一个很好的起点。通过这个项目,开发者不仅可以掌握Curator的使用,还能加深对Zookeeper的理解,并熟悉Maven在项目构建中的应用...

    curator zookeeper

    curator zookeeper 3.4.6 2.9.1

    Zookeeper 原生api zkClient Curator操作

    在Java开发中,我们通常使用三种方式来操作Zookeeper:原生API、zkClient和Curator。接下来,我们将详细探讨这三种方式。 **一、Zookeeper原生API** Zookeeper提供了Java API,可以直接与Zookeeper服务器进行交互...

    zookeeper开源客户端Curator

    Curator是Netflix公司开源的一套ZooKeeper客户端框架,Curator解决了很多ZooKeeper客户端非常底层的细节开发工作,包括连接重连、反复注册Watcher和NodeExistsException异常等,实现了Fluent风格的API接口,目前已经...

    zookeeper学习之三(Curator客户端)

    Curator客户端是Apache Curator框架的一部分,该框架为开发人员提供了一系列高级API和工具,用于处理常见的ZooKeeper用例,降低了使用ZooKeeper的复杂性。以下是对Curator客户端及其主要特性的详细阐述: 1. **连接...

    使用curator实现zookeeper锁服务的示例分享

    Curator是Netflix开源的一个用于简化Zookeeper使用的Java客户端库,它提供了很多高级功能,包括分布式锁、事件监听、配方等。在这个示例中,我们将使用Curator的`InterProcessMutex`类来实现分布式互斥锁(Mutex)。...

    项目加入zookeeper的依赖包(Curator框架)

    总的来说,Curator框架极大地简化了Zookeeper的使用,提供了丰富的功能和易于使用的API,使开发者能够更专注于业务逻辑而不是底层的协调细节。在项目中集成这些依赖包,能够有效地支持分布式环境下的协调需求。

    zookeeper Java api - curator 5.6.0

    CuratorFramework 是 Curator 的核心,它封装了 ZooKeeper 连接的创建、会话管理以及操作执行等。 3. **连接管理**:使用 `CuratorFrameworkFactory` 工厂类,你可以创建一个 ZooKeeper 客户端实例。例如: ```...

    curator-test单元测试zookeeper

    使用apache curator-test单元测试zookeeper

    zookeeper_demo maven项目:包含原生API、zkclient、Curator操作

    在本项目`zookeeper_demo`中,我们将深入探讨Zookeeper的三种主要客户端库——原生API、ZkClient和Curator的操作方式,以及它们在集群配置和分布式锁等实际场景中的应用。 1. **Zookeeper原生API** Zookeeper原生...

    Zookeeper客户端Curator Framework使用代码

    Zookeeper客户端Curator Framework是Apache Zookeeper项目的一个高级封装库,它为开发者提供了一系列便捷的API,使得操作Zookeeper变得更加简单。本篇文章将深入探讨Curator Framework的主要功能、使用方法以及示例...

    ZooKeeper-Curator:zookeeper的curator客户端

    - 操作:使用`CuratorFramework`提供的API进行增删改查等操作。 - 监听:注册Watchers来监听ZNode的变化。 - 关闭:在应用结束时,记得关闭`CuratorFramework`实例,释放资源。 通过ZooKeeper-Curator,开发者...

    5、zookeeper的java -Curator(服务注册与发现)

    Curator的`ServiceCache`提供了更加高效的服务查询方式,它会在内存中缓存服务实例,减少对Zookeeper的频繁查询,同时使用Watcher机制实时更新服务列表。 总的来说,Zookeeper结合Curator的`ServiceDiscovery`机制...

    zookeeper(java使用curator操作zooke.emmx

    使用mindmaster打开

    Zookeeper开源客户端框架Curator简介与示例

    Curator 是一个基于 ZooKeeper 的开源客户端框架,它为 ZooKeeper 提供了高级抽象和功能,使得开发人员能够更方便地使用 ZooKeeper。 **Curator 框架概述** Curator 包含多个模块,如 ZooKeeper 客户端连接管理、...

    zk使用curator实现分布式锁

    在分布式系统中,确保数据的一致性和正确性是至关重要的,而ZooKeeper与Curator的结合使用就是解决这一问题的有效方案。ZooKeeper是一个高度可靠的分布式协调服务,它提供了诸如分布式锁、队列和配置管理等核心功能...

Global site tag (gtag.js) - Google Analytics