ZeroMQ使用和结构详细分析

**

ZeroMQ使用和结构详细分析

**

1 ZeroMQ 概述
    ZeroMQ是一种基于消息队列的多线程网络库,其对套接字类型、连接处理、
帧、甚至路由的底层细节进行抽象,提供跨越多种传输协议的套接字。 ZeroMQ
是网络通信中新的一层,介于应用层和传输层之间(按照 TCP/IP划分),其是
一个可伸缩层,可并行运行,分散在分布式系统间。
2系统架构
2.1总体架构

    ZeroMC几乎所有的I/O操作都是异步的,主线程不会被阻塞。ZeroMQ会根 据用户调用zmqjnit函数时传入的接口参数,创建对应数量的 I/O Thread。每
个I/O Thread都有与之绑定的Poller,Poller釆用经典的Reactor模式实现, Poller根据不同操作系统平台使用不同的网络 I/O模型(select、poll、epoll、 devpoll、kequeue等)。主线程与I/O线程通过Mail Box传递消息来进行通信。 Server开始监听或者Client发起连接时,在主线程中创建 zmq_connecter或 zmq_listener,通过Mail Box发消息的形式将其绑定到I/O线程,I/O线程会 把zmq_connecter或zmq_listener添加到Poller中用以侦听读/写事件。Server 与Client在第一次通信时,会创建zmq_init来发送identity ,用以进行认证。 认证结束后,双方会为此次连接创建 Session,以后双方就通过Session进行通 信。每个Session都会关联到相应的读/写管道,主线程收发消息只是分别从管 道中读/写数据。Sess

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值