zookeeper学习心得二:同步与异步

  上一节中,我们看到很多操作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中的用处。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值