Commit 7c9b09bc authored by Martin Lucina's avatar Martin Lucina

Documentation: Flow control, zmq_socket(3)

Mostly Flow control and additions to zmq_socket(3)
Removed/changed lots of text regarding message queues
More fixes for 2.0.7 changes
parent 9d00d300
...@@ -86,17 +86,9 @@ Message manipulation:: ...@@ -86,17 +86,9 @@ Message manipulation::
Sockets Sockets
~~~~~~~ ~~~~~~~
Standard sockets present a _synchronous_ interface to either connection-mode 0MQ sockets present an abstraction of a asynchronous _message queue_, with the
reliable byte streams (SOCK_STREAM), or connection-less unreliable datagrams exact queueing semantics depending on the socket type in use. See
(SOCK_DGRAM). In comparison, 0MQ sockets present an abstraction of a linkzmq:zmq_socket[3] for the socket types provided.
asynchronous _message queue_, with the exact queueing semantics depending on
the socket type in use. See linkzmq:zmq_socket[3] for the socket types
provided.
0MQ sockets being _asynchronous_ means that the timings of the physical
connection setup and teardown, reconnect and effective delivery are organized
by 0MQ itself, and that messages may be _queued_ in the event that a peer is
unavailable to receive them.
The following functions are provided to work with sockets: The following functions are provided to work with sockets:
...@@ -118,9 +110,7 @@ Sending and receiving messages:: ...@@ -118,9 +110,7 @@ Sending and receiving messages::
linkzmq:zmq_send[3] linkzmq:zmq_send[3]
linkzmq:zmq_recv[3] linkzmq:zmq_recv[3]
.Input/output multiplexing
Input/output multiplexing
^^^^^^^^^^^^^^^^^^^^^^^^^
0MQ provides a mechanism for applications to multiplex input/output events over 0MQ provides a mechanism for applications to multiplex input/output events over
a set containing both 0MQ sockets and standard sockets. This mechanism mirrors a set containing both 0MQ sockets and standard sockets. This mechanism mirrors
the standard _poll()_ system call, and is described in detail in the standard _poll()_ system call, and is described in detail in
......
...@@ -45,12 +45,16 @@ Applicable socket types:: all ...@@ -45,12 +45,16 @@ Applicable socket types:: all
ZMQ_HWM: Retrieve high water mark ZMQ_HWM: Retrieve high water mark
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The 'ZMQ_HWM' option shall retrieve the high water mark for the _message queue_ The 'ZMQ_HWM' option shall retrieve the high water mark for the specified
associated with the specified 'socket'. The high water mark is a hard limit on 'socket'. The high water mark is a hard limit on the maximum number of
the number of outstanding messages in the queue; if this limit has been reached outstanding messages 0MQ shall queue in memory for any single peer that the
the socket shall enter an "emergency" state and depending on the socket type, specified 'socket' is communicating with.
0MQ shall take appropriate action such as blocking or dropping new messages
entering the queue. If this limit has been reached the socket shall enter an exceptional state and
depending on the socket type, 0MQ shall take appropriate action such as
blocking or dropping sent messages. Refer to the individual socket descriptions
in linkzmq:zmq_socket[3] for details on the exact action taken for each socket
type.
The default 'ZMQ_HWM' value of zero means "no limit". The default 'ZMQ_HWM' value of zero means "no limit".
...@@ -63,10 +67,9 @@ Applicable socket types:: all ...@@ -63,10 +67,9 @@ Applicable socket types:: all
ZMQ_SWAP: Retrieve disk offload size ZMQ_SWAP: Retrieve disk offload size
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The 'ZMQ_SWAP' option shall retrieve the disk offload (swap) size for the The 'ZMQ_SWAP' option shall retrieve the disk offload (swap) size for the
_message queue_ associated with the specified 'socket'. A socket which has specified 'socket'. A socket which has 'ZMQ_SWAP' set to a non-zero value may
'ZMQ_SWAP' set to a non-zero value may exceed it's high water mark; in this exceed it's high water mark; in this case outstanding messages shall be
case outstanding messages shall be offloaded to storage on disk rather than offloaded to storage on disk rather than held in memory.
held in memory.
The value of 'ZMQ_SWAP' defines the maximum size of the swap space in bytes. The value of 'ZMQ_SWAP' defines the maximum size of the swap space in bytes.
......
...@@ -54,18 +54,16 @@ The 'events' and 'revents' members of *zmq_pollitem_t* are bitmasks constructed ...@@ -54,18 +54,16 @@ The 'events' and 'revents' members of *zmq_pollitem_t* are bitmasks constructed
by OR'ing a combination of the following event flags: by OR'ing a combination of the following event flags:
*ZMQ_POLLIN*:: *ZMQ_POLLIN*::
For 0MQ sockets, at least one message may be dequeued from the underlying For 0MQ sockets, at least one message may be received from the 'socket' without
_message queue_ associated with 'socket' without blocking. For standard sockets blocking. For standard sockets this is equivalent to the 'POLLIN' flag of the
this is equivalent to the 'POLLIN' flag of the _poll()_ system call and _poll()_ system call and generally means that at least one byte of data may be
generally means that at least one byte of data may be read from 'fd' without read from 'fd' without blocking.
blocking.
*ZMQ_POLLOUT*:: *ZMQ_POLLOUT*::
For 0MQ sockets, at least one message may be queued on the underlying For 0MQ sockets, at least one message may be sent to the 'socket' without
_message queue_ associated with 'socket' without blocking. For standard sockets blocking. For standard sockets this is equivalent to the 'POLLOUT' flag of the
this is equivalent to the 'POLLOUT' flag of the _poll()_ system call and _poll()_ system call and generally means that at least one byte of data may be
generally means that at least one byte of data may be written to 'fd' written to 'fd' without blocking.
without blocking.
*ZMQ_POLLERR*:: *ZMQ_POLLERR*::
For standard sockets, this flag is passed through _zmq_poll()_ to the For standard sockets, this flag is passed through _zmq_poll()_ to the
...@@ -82,10 +80,12 @@ of those interfaces in ways not defined in this documentation. ...@@ -82,10 +80,12 @@ of those interfaces in ways not defined in this documentation.
RETURN VALUE RETURN VALUE
------------ ------------
Upon successful completion, the _zmq_poll()_ function shall return the number Upon successful completion, the _zmq_poll()_ function shall return the number
of *zmq_pollitem_t* structures with events signaled in 'revents' or `0` if the of *zmq_pollitem_t* structures with events signaled in 'revents' or `0` if no
'timeout' period has expired and no events have been signaled. Upon failure, events have been signaled. Upon failure, _zmq_poll()_ shall return `-1` and set
_zmq_poll()_ shall return `-1` and set 'errno' to one of the values defined 'errno' to one of the values defined below.
below.
IMPORTANT: The _zmq_poll()_ function may return *before* the 'timeout' period
has expired even if no events have been signaled.
ERRORS ERRORS
......
...@@ -14,19 +14,17 @@ SYNOPSIS ...@@ -14,19 +14,17 @@ SYNOPSIS
DESCRIPTION DESCRIPTION
----------- -----------
The _zmq_recv()_ function shall dequeue a message from the underlying _message The _zmq_recv()_ function shall receive a message from the socket referenced by
queue_ associated with the socket referenced by the 'socket' argument and store the 'socket' argument and store it in the message referenced by the 'msg'
it in the message referenced by the 'msg' argument. Any content previously argument. Any content previously stored in 'msg' shall be properly deallocated.
stored in 'msg' shall be properly deallocated. If there are no messages If there are no messages available on the specified 'socket' the _zmq_recv()_
available to be dequeued from the underlying _message queue_ associated with function shall block until the request can be satisfied. The 'flags' argument
'socket' the _zmq_recv()_ function shall block until the request can be is a combination of the flags defined below:
satisfied. The 'flags' argument is a combination of the flags defined below:
*ZMQ_NOBLOCK*:: *ZMQ_NOBLOCK*::
Specifies that the operation should be performed in non-blocking mode. If there Specifies that the operation should be performed in non-blocking mode. If there
are no messages available to be dequeued from the underlying _message queue_ are no messages available on the specified 'socket', the _zmq_recv()_ function
associated with 'socket', the _zmq_recv()_ function shall fail with 'errno' set shall fail with 'errno' set to EAGAIN.
to EAGAIN.
Multi-part messages Multi-part messages
...@@ -75,7 +73,7 @@ EXAMPLE ...@@ -75,7 +73,7 @@ EXAMPLE
zmq_msg_t msg; zmq_msg_t msg;
int rc = zmq_msg_init (&msg); int rc = zmq_msg_init (&msg);
assert (rc == 0); assert (rc == 0);
/* Block until a message is available to be dequeued from socket */ /* Block until a message is available to be received from socket */
rc = zmq_recv (socket, &msg, 0); rc = zmq_recv (socket, &msg, 0);
assert (rc == 0); assert (rc == 0);
---- ----
...@@ -89,7 +87,7 @@ do { ...@@ -89,7 +87,7 @@ do {
zmq_msg_t part; zmq_msg_t part;
int rc = zmq_msg_init (&part); int rc = zmq_msg_init (&part);
assert (rc == 0); assert (rc == 0);
/* Block until a message is available to be dequeued from socket */ /* Block until a message is available to be received from socket */
rc = zmq_recv (socket, &part, 0); rc = zmq_recv (socket, &part, 0);
assert (rc == 0); assert (rc == 0);
/* Determine if more message parts are to follow */ /* Determine if more message parts are to follow */
......
...@@ -20,8 +20,8 @@ argument to be sent to the socket referenced by the 'socket' argument. The ...@@ -20,8 +20,8 @@ argument to be sent to the socket referenced by the 'socket' argument. The
*ZMQ_NOBLOCK*:: *ZMQ_NOBLOCK*::
Specifies that the operation should be performed in non-blocking mode. If the Specifies that the operation should be performed in non-blocking mode. If the
message cannot be queued on the underlying _message queue_ associated with message cannot be queued on the 'socket', the _zmq_send()_ function shall fail
'socket', the _zmq_send()_ function shall fail with 'errno' set to EAGAIN. with 'errno' set to EAGAIN.
*ZMQ_SNDMORE*:: *ZMQ_SNDMORE*::
Specifies that the message being sent is a multi-part message, and that further Specifies that the message being sent is a multi-part message, and that further
...@@ -30,8 +30,7 @@ below for a detailed description. ...@@ -30,8 +30,7 @@ below for a detailed description.
NOTE: A successful invocation of _zmq_send()_ does not indicate that the NOTE: A successful invocation of _zmq_send()_ does not indicate that the
message has been transmitted to the network, only that it has been queued on message has been transmitted to the network, only that it has been queued on
the _message queue_ associated with the socket and 0MQ has assumed the 'socket' and 0MQ has assumed responsibility for the message.
responsibility for the message.
Multi-part messages Multi-part messages
...@@ -60,7 +59,7 @@ return `-1` and set 'errno' to one of the values defined below. ...@@ -60,7 +59,7 @@ return `-1` and set 'errno' to one of the values defined below.
ERRORS ERRORS
------ ------
*EAGAIN*:: *EAGAIN*::
Non-blocking mode was requested and the message cannot be queued at the moment. Non-blocking mode was requested and the message cannot be sent at the moment.
*ENOTSUP*:: *ENOTSUP*::
The _zmq_send()_ operation is not supported by this socket type. The _zmq_send()_ operation is not supported by this socket type.
*EFSM*:: *EFSM*::
......
...@@ -25,12 +25,16 @@ The following socket options can be set with the _zmq_setsockopt()_ function: ...@@ -25,12 +25,16 @@ The following socket options can be set with the _zmq_setsockopt()_ function:
ZMQ_HWM: Set high water mark ZMQ_HWM: Set high water mark
~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The 'ZMQ_HWM' option shall set the high water mark for the _message queue_ The 'ZMQ_HWM' option shall set the high water mark for the specified 'socket'.
associated with the specified 'socket'. The high water mark is a hard limit on The high water mark is a hard limit on the maximum number of outstanding
the number of outstanding messages in the queue; if this limit has been reached messages 0MQ shall queue in memory for any single peer that the specified
the socket shall enter an "emergency" state and depending on the socket type, 'socket' is communicating with.
0MQ shall take appropriate action such as blocking or dropping new messages
entering the queue. If this limit has been reached the socket shall enter an exceptional state and
depending on the socket type, 0MQ shall take appropriate action such as
blocking or dropping sent messages. Refer to the individual socket descriptions
in linkzmq:zmq_socket[3] for details on the exact action taken for each socket
type.
The default 'ZMQ_HWM' value of zero means "no limit". The default 'ZMQ_HWM' value of zero means "no limit".
...@@ -42,11 +46,10 @@ Applicable socket types:: all ...@@ -42,11 +46,10 @@ Applicable socket types:: all
ZMQ_SWAP: Set disk offload size ZMQ_SWAP: Set disk offload size
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The 'ZMQ_SWAP' option shall set the disk offload (swap) size for the _message The 'ZMQ_SWAP' option shall set the disk offload (swap) size for the specified
queue_ associated with the specified 'socket'. A socket which has 'ZMQ_SWAP' 'socket'. A socket which has 'ZMQ_SWAP' set to a non-zero value may exceed it's
set to a non-zero value may exceed it's high water mark; in this case high water mark; in this case outstanding messages shall be offloaded to
outstanding messages shall be offloaded to storage on disk rather than held in storage on disk rather than held in memory.
memory.
The value of 'ZMQ_SWAP' defines the maximum size of the swap space in bytes. The value of 'ZMQ_SWAP' defines the maximum size of the swap space in bytes.
......
...@@ -19,30 +19,89 @@ The 'zmq_socket()' function shall create a 0MQ socket within the specified ...@@ -19,30 +19,89 @@ The 'zmq_socket()' function shall create a 0MQ socket within the specified
argument specifies the socket type, which determines the semantics of argument specifies the socket type, which determines the semantics of
communication over the socket. communication over the socket.
The newly created socket is initially unbound, and not associated with any
endpoints. In order to establish a message flow a socket must first be
connected to at least one endpoint with linkzmq:zmq_connect[3], or at least one
endpoint must be created for accepting incoming connections with
linkzmq:zmq_bind[3].
.Key differences to conventional sockets
Generally speaking, conventional sockets present a _synchronous_ interface to
either connection-oriented reliable byte streams (SOCK_STREAM), or
connection-less unreliable datagrams (SOCK_DGRAM). In comparison, 0MQ sockets
present an abstraction of an asynchronous _message queue_, with the exact
queueing semantics depending on the socket type in use. Where conventional
sockets transfer streams of bytes or discrete datagrams, 0MQ sockets transfer
discrete _messages_.
0MQ sockets being _asynchronous_ means that the timings of the physical
connection setup and teardown, reconnect and effective delivery are transparent
to the user and organized by 0MQ itself. Further, messages may be _queued_ in
the event that a peer is unavailable to receive them.
Conventional sockets allow only strict one-to-one (two peers), many-to-one
(many clients, one server), or in some cases one-to-many (multicast)
relationships. With the exception of 'ZMQ_PAIR', 0MQ sockets may be connected
*to multiple endpoints* using _zmq_connect()_, while simultaneously accepting
incoming connections *from multiple endpoints* bound to the socket using
_zmq_bind()_, thus allowing many-to-many relationships.
.Socket types
The following sections present the socket types defined by 0MQ, grouped by the The following sections present the socket types defined by 0MQ, grouped by the
general _messaging pattern_ built from related socket types. general _messaging pattern_ which is built from related socket types.
Request-reply pattern Request-reply pattern
~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~
The request-reply pattern is used for sending requests from a _client_ to a The request-reply pattern is used for sending requests from a _client_ to one
_service_, and receiving subsequent replies to each request sent. or more instances of a _service_, and receiving subsequent replies to each
request sent.
Socket type:: 'ZMQ_REQ'
Compatible peer sockets:: 'ZMQ_REP'
ZMQ_REQ
^^^^^^^
A socket of type 'ZMQ_REQ' is used by a _client_ to send requests to and A socket of type 'ZMQ_REQ' is used by a _client_ to send requests to and
receive replies from a _service_. This socket type allows only an alternating receive replies from a _service_. This socket type allows only an alternating
sequence of _zmq_send(request)_ and subsequent _zmq_recv(reply)_ calls. Each sequence of _zmq_send(request)_ and subsequent _zmq_recv(reply)_ calls. Each
request sent is load-balanced among all connected _services_. request sent is load-balanced among all _services_, and each reply received is
matched with the last issued request.
Socket type:: 'ZMQ_REP' When a 'ZMQ_REQ' socket enters an exceptional state due to having reached the
Compatible peer sockets:: 'ZMQ_REQ' high water mark for all _services_, or if there are no _services_ at all, then
any linkzmq:zmq_send[3] operations on the socket shall block until the
exceptional state ends or at least one _service_ becomes available for sending;
messages are not discarded.
[horizontal]
.Summary of ZMQ_REQ characteristics
Compatible peer sockets:: 'ZMQ_REP'
Direction:: Bidirectional
Send/receive pattern:: Send, Receive, Send, Receive, ...
Outgoing routing strategy:: Load-balanced
Incoming routing strategy:: Last peer
ZMQ_HWM option action:: Block
ZMQ_REP
^^^^^^^
A socket of type 'ZMQ_REP' is used by a _service_ to receive requests from and A socket of type 'ZMQ_REP' is used by a _service_ to receive requests from and
send replies to a _client_. This socket type allows only an alternating send replies to a _client_. This socket type allows only an alternating
sequence of _zmq_recv(request)_ and subsequent _zmq_send(reply)_ calls. Each sequence of _zmq_recv(request)_ and subsequent _zmq_send(reply)_ calls. Each
reply is routed to the _client_ that issued the last received request. request received is fair-queued from among all _clients_, and each reply sent
is routed to the _client_ that issued the last request.
When a 'ZMQ_REP' socket enters an exceptional state due to having reached the
high water mark for a _client_, then any replies sent to the _client_ in
question shall be dropped until the exceptional state ends.
[horizontal]
.Summary of ZMQ_REP characteristics
Compatible peer sockets:: 'ZMQ_REQ'
Direction:: Bidirectional
Send/receive pattern:: Receive, Send, Receive, Send, ...
Incoming routing strategy:: Fair-queued
Outgoing routing stratagy:: Last peer
ZMQ_HWM option action:: Drop
Publish-subscribe pattern Publish-subscribe pattern
...@@ -50,21 +109,44 @@ Publish-subscribe pattern ...@@ -50,21 +109,44 @@ Publish-subscribe pattern
The publish-subscribe pattern is used for one-to-many distribution of data from The publish-subscribe pattern is used for one-to-many distribution of data from
a single _publisher_ to multiple _subscribers_ in a fanout fashion. a single _publisher_ to multiple _subscribers_ in a fanout fashion.
Socket type:: 'ZMQ_PUB'
Compatible peer sockets:: 'ZMQ_SUB'
ZMQ_PUB
^^^^^^^
A socket of type 'ZMQ_PUB' is used by a _publisher_ to distribute data. A socket of type 'ZMQ_PUB' is used by a _publisher_ to distribute data.
Messages sent are distributed in a fanout fashion to all connected peers. Messages sent are distributed in a fanout fashion to all connected peers.
The _zmq_recv()_ function is not implemented for this socket type. The linkzmq:zmq_recv[3] function is not implemented for this socket type.
Socket type:: 'ZMQ_SUB' When a 'ZMQ_PUB' socket enters an exceptional state due to having reached the
Compatible peer sockets:: 'ZMQ_PUB' high water mark for a _subscriber_, then any messages that would be sent to the
_subscriber_ in question shall instead be dropped until the exceptional state
ends.
[horizontal]
.Summary of ZMQ_PUB characteristics
Compatible peer sockets:: 'ZMQ_SUB'
Direction:: Unidirectional
Send/receive pattern:: Send only
Incoming routing strategy:: N/A
Outgoing routing strategy:: Fanout
ZMQ_HWM option action:: Drop
ZMQ_SUB
^^^^^^^
A socket of type 'ZMQ_SUB' is used by a _subscriber_ to subscribe to data A socket of type 'ZMQ_SUB' is used by a _subscriber_ to subscribe to data
distributed by a _publisher_. Initially a 'ZMQ_SUB' socket is not subscribed to distributed by a _publisher_. Initially a 'ZMQ_SUB' socket is not subscribed to
any messages, use the 'ZMQ_SUBSCRIBE' option of _zmq_setsockopt()_ to specify any messages, use the 'ZMQ_SUBSCRIBE' option of linkzmq:zmq_setsockopt[3] to
which messages to subscribe to. The _zmq_send()_ function is not implemented specify which messages to subscribe to. The _zmq_send()_ function is not
for this socket type. implemented for this socket type.
[horizontal]
.Summary of ZMQ_SUB characteristics
Compatible peer sockets:: 'ZMQ_PUB'
Direction:: Unidirectional
Send/receive pattern:: Receive only
Incoming routing strategy:: Fair-queued
Outgoing routing strategy:: N/A
ZMQ_HWM option action:: N/A
Pipeline pattern Pipeline pattern
...@@ -74,38 +156,76 @@ a pipeline. Data always flows down the pipeline, and each stage of the pipeline ...@@ -74,38 +156,76 @@ a pipeline. Data always flows down the pipeline, and each stage of the pipeline
is connected to at least one _node_. When a pipeline stage is connected to is connected to at least one _node_. When a pipeline stage is connected to
multiple _nodes_ data is load-balanced among all connected _nodes_. multiple _nodes_ data is load-balanced among all connected _nodes_.
Socket type:: 'ZMQ_DOWNSTREAM'
Compatible peer sockets:: 'ZMQ_UPSTREAM'
ZMQ_DOWNSTREAM
^^^^^^^^^^^^^^
A socket of type 'ZMQ_DOWNSTREAM' is used by a pipeline _node_ to send messages A socket of type 'ZMQ_DOWNSTREAM' is used by a pipeline _node_ to send messages
to downstream pipeline _nodes_. Messages are load-balanced to all connected to downstream pipeline _nodes_. Messages are load-balanced to all connected
downstream _nodes_. The _zmq_recv()_ function is not implemented for this downstream _nodes_. The _zmq_recv()_ function is not implemented for this
socket type. socket type.
Socket type:: 'ZMQ_UPSTREAM' When a 'ZMQ_DOWNSTREAM' socket enters an exceptional state due to having
Compatible peer sockets:: 'ZMQ_DOWNSTREAM' reached the high water mark for all downstream _nodes_, or if there are no
downstream _nodes_ at all, then any linkzmq:zmq_send[3] operations on the
socket shall block until the exceptional state ends or at least one downstream
_node_ becomes available for sending; messages are not discarded.
[horizontal]
.Summary of ZMQ_DOWNSTREAM characteristics
Compatible peer sockets:: 'ZMQ_UPSTREAM'
Direction:: Unidirectional
Send/receive pattern:: Send only
Incoming routing strategy:: N/A
Outgoing routing strategy:: Load-balanced
ZMQ_HWM option action:: Block
ZMQ_UPSTREAM
^^^^^^^^^^^^
A socket of type 'ZMQ_UPSTREAM' is used by a pipeline _node_ to receive A socket of type 'ZMQ_UPSTREAM' is used by a pipeline _node_ to receive
messages from upstream pipeline _nodes_. Messages are fair-queued from among messages from upstream pipeline _nodes_. Messages are fair-queued from among
all connected upstream _nodes_. The _zmq_send()_ function is not implemented all connected upstream _nodes_. The _zmq_send()_ function is not implemented
for this socket type. for this socket type.
[horizontal]
.Summary of ZMQ_UPSTREAM characteristics
Compatible peer sockets:: 'ZMQ_DOWNSTREAM'
Direction:: Unidirectional
Send/receive pattern:: Receive only
Incoming routing strategy:: Fair-queued
Outgoing routing strategy:: N/A
ZMQ_HWM option action:: N/A
Exclusive pair pattern Exclusive pair pattern
~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~
The exclusive pair is an advanced pattern used for communicating exclusively The exclusive pair is an advanced pattern used for communicating exclusively
between two peers. between two peers.
Socket type:: 'ZMQ_PAIR'
Compatible peer sockets:: 'ZMQ_PAIR'
ZMQ_PAIR
^^^^^^^^
A socket of type 'ZMQ_PAIR' can only be connected to a single peer at any one A socket of type 'ZMQ_PAIR' can only be connected to a single peer at any one
time. No message routing or filtering is performed on messages sent over a time. No message routing or filtering is performed on messages sent over a
'ZMQ_PAIR' socket. 'ZMQ_PAIR' socket.
When a 'ZMQ_PAIR' socket enters an exceptional state due to having reached the
high water mark for the connected peer, or if no peer is connected, then
any linkzmq:zmq_send[3] operations on the socket shall block until the peer
becomes available for sending; messages are not discarded.
NOTE: 'ZMQ_PAIR' sockets are experimental, and are currently missing several NOTE: 'ZMQ_PAIR' sockets are experimental, and are currently missing several
features such as auto-reconnection. features such as auto-reconnection.
[horizontal]
.Summary of ZMQ_PAIR characteristics
Compatible peer sockets:: 'ZMQ_PAIR'
Direction:: Bidirectional
Send/receive pattern:: Unrestricted
Incoming routing strategy:: N/A
Outgoing routing strategy:: N/A
ZMQ_HWM option action:: Block
RETURN VALUE RETURN VALUE
------------ ------------
...@@ -120,8 +240,7 @@ ERRORS ...@@ -120,8 +240,7 @@ ERRORS
The requested socket 'type' is invalid. The requested socket 'type' is invalid.
*EMTHREAD*:: *EMTHREAD*::
The number of application threads using sockets within this 'context' has been The maximum number of sockets within this 'context' has been exceeded.
exceeded. See the 'app_threads' parameter of the _zmq_init()_ function.
SEE ALSO SEE ALSO
...@@ -132,6 +251,7 @@ linkzmq:zmq_bind[3] ...@@ -132,6 +251,7 @@ linkzmq:zmq_bind[3]
linkzmq:zmq_connect[3] linkzmq:zmq_connect[3]
linkzmq:zmq_send[3] linkzmq:zmq_send[3]
linkzmq:zmq_recv[3] linkzmq:zmq_recv[3]
linkzmq:zmq[7]
AUTHORS AUTHORS
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment