《Zookeeper》源码分析(二十三)之 客户端的命令处理过程

客户端的命令处理过程

以创建节点命令为例,整个过程流程如下:
在这里插入图片描述

  1. CliCommand命令在抽象方法exec()方法中调用ZooKeeper实例的create()方法传送给Zookeeper处理
  2. Zookeeper对命令进行一定的包装后通过ClientCnxn.submitRequest()方法交由ClientCnxn处理
  3. ClientCnxn将命令请求存入outgoingQueue队列中等待异步处理
  4. SendThread的run()循环调用ClientCnxnSocket.doTransport()方法
  5. ClientCnxnSocket.doTransport()方法不断从ClientCnxn.outgoingQueue队列中读取请求并发送给服务器处理
  6. 服务器处理结束后返回结果,SendThread不断读取来自服务器的响应并将结果更新到请求中
  7. 请求Packet的finished标志更新,打印结果

对于不同的请求,除了第1步的入口不同,后续的过程都是类似的,接下来通过源码分析整个过程。

1. ZooKeeper.create()

在这里插入图片描述

2. ClientCnxn.submitRequest()

在这里插入图片描述

3. SendThread.run()

在这里插入图片描述

4. ClientCnxnSocket.doTransport()

在这里插入图片描述

将请求发送给服务端,服务端处理结束后向客户端发送相应结果,此时依旧由ClientCnxnSocket从最底层的Socket读取结果,将读取的响应流交给SendThread处理。

5. SendThread.readResponse()

在这里插入图片描述

至此,客户端的一个命令处理过程介绍到此结束。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值