zookeeper学习心得二:同步与异步
来源:互联网 发布:网络金融运营模式 编辑:程序博客网 时间:2024/05/20 05:55
上一节中,我们看到很多操作zk节点的方式有同步和异步两种方式,那么问题来了:
(1)两种方式有什么区别?
(2)哪种方式更好?应该用那种方式来写代码?
(3)最好的方式有哪些其他方面的知识?
本节我们从这三个角度来分析这个问题,毕竟基础得好才可以更好的学习更深的内容。
1、同步 OR 异步
ZooKeeper提供的Java API.每一个方法有一个异步调用版本。异步调用和同步调用的区别之处:
(1)同步调用中,需要处理异常。
(2)异步调用中已经把异常封装为返回码。 同时异步调用会得到更好的性能。这里要注意,一般来说异步调用会在命令发送到Zookeeper服务器之前,就返回继续执行之后的代码。
2、推荐使用异步方法
- 推荐使用异步方法访问Zookeeper,除了可以简化异常处理,提高性能外。还应为Watcher的处理是异常的。这样在构建复杂逻辑时,代码会更统一些。
- 因为回调函数里会有返回的服务器响应码,通过响应码我们可以了解操作有没有成功,没有成功可以通过调用方法来实现第二次尝试,比如生成一个节点,将生成节点的操作放进一个类中,通过服务器响应码来判断是否生成成功,如果没有成功,则继续调用该方法,直到成功为止。
3、异步回调函数类型
使用异步方式创建接口只需要实现AsyncCallback.StringCallback()接口即可,同时AsyncCallbackH还包含了StatCallback、DataCallback、ACLCallback、ChildrenCallback、Children2Callback、StringCallback和VoidCallback七种不同的回调接口,用户可以在不同的异步接口中实现不同的接口。
实现接口的类型中还必须要实现相应的public void processResult(int rc, String path, Object ctx, String name) 函数,可能不同的回调函数有不同的字段。
字段解读:
int rc:Result code,服务端响应码,客户端可以从这个响应码中识别API调用的结果,常见响应码如下:
(1)0(ok):接口调用成功。
(2)-4(ConnectionLoss):客户端和服务端连接已断开。
(3)-110(NodeExists):指定节点已存在。
(4)-112(SessionExpired):会话已过期。
通过Code.get(rc)方法可以将rc转换成相应的英文标识符,例如下面:
switch (Code.get(rc)) { case CONNECTIONLOSS: System.out.println("CONNECTIONLOSS"); break; case OK: System.out.println("OK"); System.out.println("--ctx--"+ctx+"--"+name+"--path--"+path); break; case NODEEXISTS: System.out.println("NODEEXISTS"); break; default: System.out.println("DEFAULT"); break; }
String path:接口调用时传入的API的数据节点的节点路径参数值
Object ctx:接口调用时传入的API的ctx参数值
String name:节点的名称
这里我一直有一个疑问:zookeeper中回调函数用来干嘛?难道就是用来将这些信息打印出来?因为processResult是没有返回类型的,除非我在回调函数里直接定义几个字属性,然后将processResult方法中的一些内容存进这些属性里,利用这些属性的get方法来返回结果,只有当结果正确了才继续执行主程序下一步的操作,但是这样是不是又是多余的操作。以上只是我的猜测,猜测回调函数在zookeeper中的用处。
- zookeeper学习心得二:同步与异步
- TinyOS 同步与异步处理学习心得
- 同步与异步(二)
- 实验二 同步与异步write的效率比较
- 浅谈WebService开发二(同步与异步调用)
- 学习mina同步与异步网络通讯(二)——服务器端
- C#学习之(二)同步调用与异步调用
- C#学习心得(二) 异步编程
- zookeeper学习心得
- 同步与异步通讯
- Socket 同步与异步
- 理解同步与异步
- 同步与异步
- 同步与异步
- AJAX 同步与异步
- extjs 同步与异步
- 同步与异步
- 同步与异步
- 位图模拟实现
- 设计模式——单例模式
- mysql增加用户并授权
- 树莓派上搭建NAS
- 递归
- zookeeper学习心得二:同步与异步
- Mysql修改数据库名
- fl2440——RTC(实时时钟)的学习、内核添加RTC支持
- 202. Happy Number
- 调整路由DHCP静态分配IP,便于接口开发
- 懒虫小鑫
- 同步yum源
- pandas的引用与复制
- MyEclipse6.5的内存管理(ini文件中的参数设置)