Curator 异步获取结果
原声的ZooKeeper 的CRUD API有同步和异步之分,对于异步API,需要传递AsyncCallback回调。对于getData,getChildren,exists这三个API,还可以设置Watcher。这些功能在Curator中是如何实现的?
在Curator中,可以通过如下三种方式来异步获取结果:
1.inBackground()+CuratorListener
2.inBackground(new BackgroundCallback(){ public void processResult(CuratorFramework client,CuratorEvent event){}})
3.inBackground(newBackgroundCallback(){},Executor)
以inBackground()+CuratorListener这种方式来使用异步API,如下:
             client.getCuratorListenable().addListener(new CuratorListener(){
                @Override
                public void eventReceived(CuratorFramework client, CuratorEvent event) throws Exception {
                     // TODO Auto-generated method stub
                    if(event.getType()==CuratorEventType.CREATE){
                        System.out.println("create path="+event.getPath()+",code="+event.getResultCode());
                    }else if(event.getType()==CuratorEventType.GET_DATA){
                        System.out.println("get path="+event.getPath()+",data="+new String(event.getData()));
                    }else if(event.getType()==CuratorEventType.SET_DATA){
                        System.out.println("set path="+event.getPath()+",data="+new String(client.getData().forPath(event.getPath()))/*+",data="+new String(event.getData())*/);
                    }else if(event.getType()==CuratorEventType.DELETE){
                        System.out.println("delete path="+event.getPath());
                    }
                }});
接下来client的所有以inBackground()方式使用的API,其异步处理结果都是通过这个CuratorListener来处理。
在第二中方式inBackground(BackgroundCallback)中,如下:
client.create()
.creatingParentsIfNeeded()
.withProtection()
.withMode(CreateMode.EPHEMERAL)
.inBackground(new BackgroundCallback(){ @Override
public void processResult(CuratorFramework client, CuratorEvent event) throws Exception {
// TODO Auto-generated method stub
if(event.getType()==CuratorEventType.CREATE){
System.out.println("code:"+event.getResultCode()+"path:"+event.getPath()); //client.getData().inBackground().forPath(event.getPath());
}
}
} )
.forPath("/francis/tmp/a","wbs".getBytes());
Curator 异步获取结果的更多相关文章
- jquery的异步获取返回值为中文时乱码解决方法
		
用jqgrid异步获取列表值,遇到个问题,服务器端从数据库取到的数据没有出现中文乱码问题(日志打出来是没有乱码的),但是异步传到客户的时候却出现了乱码. 服务器端已经编码过了(UTF-8编码).开始一 ...
 - 分享一个安卓中异步获取网络图片并自适应大小的第三方程序(来自github)
		
安卓中获取网络图片,生成缓存 用安卓手机,因为手机流量的限制,所以我们在做应用时,要尽量为用户考虑,尽量少耗点用户的流量,而在应用中网络图片的显示无疑是消耗流量最大的,所以我们可以采取压缩图片或者将图 ...
 - 如何解决设置Session保存在StateServer后引起WebService/WebMethod无法异步获取Session
		
项目中有一个文件上传功能,需要显示文件上传进度.于是使用PageMethods 调用WebService/WebMethod . 在demo中测试一切正常.但是转移到项目中之后无法异步刷新文件上传进度 ...
 - Swift - 异步获取网络数据封装类
		
使用NSURLConnection.sendAsynchronousRequest()可以采用异步获取的方式取得数据.下面通过对数据获取类进行封装,演示如何进行数据请求与接收. 1,HttpContr ...
 - nettyclient异步获取数据
		
源代码见,以下主要是做个重要代码记录 http://download.csdn.net/detail/json20080301/8180351 NETTYclient获取数据採用的方式是异步获取数据, ...
 - Vue父组件传递异步获取的数据给子组件
		
问题场景: 当父组件传给子组件的数据是在父组件中异步获取的时候,如何让子组件获取期望的值? 在父组件中: 首先在data()中定义data_detail为空: data(){ data_detail: ...
 - 用redux-thunk异步获取数据
		
概述 最近学习redux,打算用redux-thunk给todo添加异步获取数据组件.记录下来,供以后开发时参考,相信对其他人也有用. 注意: 在todo下方,我异步获取我的react博客的标题,点击 ...
 - Python: PySide(Qt)异步获取网页源码
		
学习PyQt UI编程笔记.相对PyQt来说,PySide资料为少. 此篇记录异步获取代码后,同步显示于界面窗体中,涉及线程网步,此为知识点. 直录代码: # encoding: utf-8 from ...
 - easyui panel异步获取后台数据在前台显示
		
我在使用easyui的时候,想做一个向下图所示的效果,这个panel的样式已经做好了,想从后台异步获取json数据,然后填入到文本框中,不知道哪位大神能给点指导?万分感谢! 放入表单中,使用form对 ...
 
随机推荐
- 关于JS事件的几点总结
			
1.理解事件(2点) 事件行为本身:没有给事件绑定方法事件也是一直存在的,当触发行为的时候,也对触发对应的行为,只不过由于没有绑定事件,导致没有任何事件发生: 事件绑定:给元素绑定一个方法:触发行为, ...
 - [原创]CSS3打造动态3D气球
			
周末在江边晨跑的时候发现很多 当时心血来潮就想,应该可以在网页中实现一下 这几天得闲就做了一下,效果如下 (尽量在最新版本的chrome或者firefox中查看) demo下载在文章最后 预览 --& ...
 - bzoj 4695: 最假女选手
			
……一道丧病线段树膜板题…… 被常数卡的死去活来……QAQ 学到了些奇技淫巧:把取min标记 和 区间最小值 合并 可以快很多…… #include <bits/stdc++.h> #de ...
 - git 实用技巧
			
一.git 常用操作 1.1 // 该方法会显示某次提交的所有更改 git log --pretty=oneline 文件名 git show 356f6def9d3fb7f3b9032ff5aa4b ...
 - Hadoop学习记录
			
http://blog.csdn.net/m_star_jy_sy/article/details/26476907配置windows里eclipse连接hadoop集群 hadoop常见命令 启动H ...
 - shell 脚本中的运算
			
#!/bin/bash read -p "please Insert two integer values: " a b if [ ! -n "$a" -o ! ...
 - js 数组,字符串,json互相转换
			
数组转字符串 var arr = [1,2,3,4,'巴德','merge']; var str = arr.join(','); console.log(str); // 1,2,3,4,巴德,me ...
 - Angular2 NgModule
			
1. 说明 典型的模块是一个内聚的代码块,用来实现某种单一的功能.Angular2应用程序本质上是有一系列模块组成的,而且Angular 本身就是一组模块库.模块主要是导出一些东西——类,函数,值,供 ...
 - Newtonsoft.Json 版本冲突解决
			
在做asp.net MVC 开发时,因为引用的dll 中使用了更高版本的 Newtonsoft.Json ,导致运行时发生错误, 查资料说是因为webApi使用了Newtonsoft.Json 导致了 ...
 - linux内核(kernel)版本号的意义
			
转自:http://www.cnblogs.com/jsjliuxing/archive/2011/12/01/2271182.html 在linux下有一个目录,即/usr/src/kernels/ ...