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中的用处。

1 0
原创粉丝点击