Zookeeper实例ZkClient API-获取节点数据内容


import org.I0Itec.zkclient.IZkDataListener;
import org.I0Itec.zkclient.ZkClient;

/**
 * 
* @ClassName: Get_Data_Sample 
* @Description: TODO(ZkClient获取节点数据) 
* @author 
* @date 2017年6月14日 下午1:03:46 
*
 */
public class Get_Data_Sample {
    public static void main(String[] args) throws Exception {
        
        String path = "/zk-book";
        ZkClient zkClient = new ZkClient("localhost:2181", 5000);
        zkClient.createEphemeral(path, "123");
        
        zkClient.subscribeDataChanges(path, new IZkDataListener() {
            public void handleDataDeleted(String dataPath) throws Exception {
                System.out.println("Node " + dataPath + " deleted.");
            }
            public void handleDataChange(String dataPath, Object data) throws Exception {
                System.out.println("Node " + dataPath + " changed, new data: " + data);
            }
        });
        
       // System.out.println(zkClient.readData(path));
        zkClient.writeData(path,"456");
        Thread.sleep(1000);
        zkClient.delete(path);
        Thread.sleep( Integer.MAX_VALUE );
    }
}

输出:
Node /zk-book changed, new data: 456
Node /zk-book deleted.


注意:

getData方法有一个 boolean returnNullIfPathNotExists参数,这样如果当指定的节点不存在就不会抛异常而是返回null.通过调用getData()接口,就可以获得指定节点的内容,这里方法的返回值,在ZkClient内部已经被反序列化成了指定对象。


扩展





参考

1.《从Paxos到Zookeeper:分布式一致性原理与实践》

2. http://javadox.com/com.101tec/zkclient/0.4/org/I0Itec/zkclient/ZkClient.html





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值