zmq_socket()

Name

zmq_socket : 创建0MQ socket

Synopsis

void *zmq_socket(void *context, int type)

描述

zmq_socket(): 在一个特定的context中创建一个0MQ socket,返回一个不透明的句柄到新创建的socket中。

type: 指定socket类型。

新创建的socket初试时时未绑定的,不和任何相关联。为了建立一个信息流,socket必须首先zmq_connect()其中一个终端,或是zmq_bind();


与传统socket的不同:

传统socket提供的同步接口,要么是面向连接的可靠的字节流(SOCK_STREAM),要么是无连接不可靠的数据包(SOCK_DGRAM).

0MQ socket 是异步的,物理连接的安装和卸载,重连和有效地转发等对用户来说都是透明的,时间由0MQ自己控制。 消息会排队,当一个peer不能有效接收时。


传统socket :严格的1-1(2个peer)、N-1(多个client,一个server)、1-N(多播)。

0MQ: ZMQ_PAIR是个特例。0MQ socket 可以连接到多个终端,使用zmq_connect();同时,可以结果多个终端的信息,使用zmq_bind().  N-N的模式


线程安全:

0MQ socket不是线程安全的。 Applications MUST NOT use a socket from multiple threads except after migrating a socket from one thread to another with a "full fence" memory barrier.

Socket类型

  1. Request-reply pattern:
    Summary of ZMQ_REQ characteristics
    Compatible peer socketsZMQ_REPZMQ_ROUTER
    DirectionBidirectional
    Send/receive patternSend, Receive, Send, Receive, …
    Outgoing routing strategyRound-robin
    Incoming routing strategyLast peer
    Action in mute stateBlock
    Summary of ZMQ_REP characteristics
    Compatible peer socketsZMQ_REQZMQ_DEALER
    DirectionBidirectional
    Send/receive patternReceive, Send, Receive, Send, …
    Incoming routing strategyFair-queued
    Outgoing routing strategyLast peer
    Action in mute stateDrop
    Summary of ZMQ_DEALER characteristics
    Compatible peer socketsZMQ_ROUTERZMQ_REPZMQ_DEALER
    DirectionBidirectional
    Send/receive patternUnrestricted
    Outgoing routing strategyRound-robin
    Incoming routing strategyFair-queued
    Action in mute stateBlock


    Summary of ZMQ_ROUTER characteristics
    Compatible peer socketsZMQ_DEALERZMQ_REQZMQ_ROUTER
    DirectionBidirectional
    Send/receive patternUnrestricted
    Outgoing routing strategySee text
    Incoming routing strategyFair-queued
    Action in mute stateDrop
    Summary of ZMQ_DEALER characteristics
    Compatible peer socketsZMQ_ROUTERZMQ_REPZMQ_DEALER
    DirectionBidirectional
    Send/receive patternUnrestricted
    Outgoing routing strategyRound-robin
    Incoming routing strategyFair-queued
    Action in mute stateBlock

  2. Publish-subscribe pattern : 1-N (1 publisher,multiple subscribers
  1. Summary of ZMQ_XSUB characteristics
    Compatible peer socketsZMQ_PUBZMQ_XPUB
    DirectionUnidirectional
    Send/receive patternReceive messages, send subscriptions
    Incoming routing strategyFair-queued
    Outgoing routing strategyN/A
    Action in mute stateDrop
    Summary of ZMQ_SUB characteristics
    Compatible peer socketsZMQ_PUBZMQ_XPUB
    DirectionUnidirectional
    Send/receive patternReceive only
    Incoming routing strategyFair-queued
    Outgoing routing strategyN/A
    Action in mute stateDrop
    Summary of ZMQ_PUB characteristics
    Compatible peer socketsZMQ_SUBZMQ_XSUB
    DirectionUnidirectional
    Send/receive patternSend only
    Incoming routing strategyN/A
    Outgoing routing strategyFan out
    Action in mute stateDrop
    Summary of ZMQ_XPUB characteristics
    Compatible peer socketsZMQ_SUBZMQ_XSUB
    DirectionUnidirectional
    Send/receive patternSend messages, receive subscriptions
    Incoming routing strategyN/A
    Outgoing routing strategyFan out
    Action in mute stateDrop
  2. pipeline pattern:ZMQ_PUSH、ZMQ_PULL
    Summary of ZMQ_PUSH characteristics
    Compatible peer socketsZMQ_PULL
    DirectionUnidirectional
    Send/receive patternSend only
    Incoming routing strategyN/A
    Outgoing routing strategyRound-robin
    Action in mute stateBlock

Summary of ZMQ_PULL characteristics
Compatible peer socketsZMQ_PUSH
DirectionUnidirectional
Send/receive patternReceive only
Incoming routing strategyFair-queued
Outgoing routing strategyN/A
Action in mute stateBlock

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值