2010-02-10 16:18:46 +01:00
|
|
|
zmq(7)
|
|
|
|
======
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
|
|
|
zmq - 0MQ lightweight messaging kernel
|
|
|
|
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2009-12-04 10:06:46 +01:00
|
|
|
0MQ is an extension of POSIX sockets. It is a library that augments standard
|
|
|
|
networking sockets by special capabilities that you can otherwise get only
|
|
|
|
by using specialised "messaging middleware" products, such as automated
|
|
|
|
handling of connections and disconnections, delivery of a message to multiple
|
|
|
|
destinations, load balancing messages, sophisticated message filtering etc.
|
|
|
|
|
|
|
|
0MQ is designed to be extremely fast. Expected end-to-end latencies for
|
|
|
|
messages passed over a LAN are in tens of microseconds. Expected
|
|
|
|
throughputs are to be measured in millions of messages per second.
|
|
|
|
|
|
|
|
0MQ is designed to be very thin. It requires no more than couple of
|
|
|
|
pages in resident memory and is thus well suited for any environment ranging
|
|
|
|
from small embedded devices, routers and cell phones to enterprise-scale
|
2010-01-18 13:16:14 +01:00
|
|
|
data centers.
|
2009-12-04 10:06:46 +01:00
|
|
|
|
|
|
|
0MQ runs on a wide range of operating systems and supports variety of processor
|
|
|
|
microarchitectures.
|
|
|
|
|
|
|
|
0MQ is accessible from a large set of programming languages.
|
|
|
|
|
|
|
|
0MQ is fully open sourced LGPL-licensed software.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
|
|
|
|
CONTEXT
|
|
|
|
-------
|
2009-12-04 10:06:46 +01:00
|
|
|
Each 0MQ socket lives within a specific context. Creating and destroying
|
|
|
|
context is a counterpart of library initialisation/deinitialisation as used
|
|
|
|
elsewhere. Ability to create multiple contexts saves the day when an application
|
|
|
|
happens to link (indirectly and involuntarily) with several instances of 0MQ.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Initialise 0MQ context::
|
|
|
|
linkzmq:zmq_init[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Uninitialise 0MQ context::
|
|
|
|
linkzmq:zmq_term[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
|
|
|
|
MESSAGES
|
|
|
|
--------
|
2009-12-04 10:06:46 +01:00
|
|
|
Message is a discrete unit of data passed between applications or components
|
|
|
|
of the same application. 0MQ message has no internal structure, it is an opaque
|
|
|
|
BLOB. When writing data to or reading data from the message, you are free to
|
|
|
|
use any of the many serialisation libraries available. Alternatively, you can
|
|
|
|
use your own serialisation code. The latter option is especially useful when
|
|
|
|
migrating legacy applications to 0MQ - there's no need to break existing
|
|
|
|
message formats.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Initialise a message::
|
|
|
|
linkzmq:zmq_msg_init[3]
|
|
|
|
linkzmq:zmq_msg_size[3]
|
|
|
|
linkzmq:zmq_msg_data[3]
|
|
|
|
|
|
|
|
Uninitialise a message::
|
|
|
|
linkzmq:zmq_msg_close[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Access message content::
|
|
|
|
linkzmq:zmq_msg_data[3]
|
|
|
|
linkzmq:zmq_msg_size[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Message manipulation::
|
|
|
|
linkzmq:zmq_msg_copy[3]
|
|
|
|
linkzmq:zmq_msg_move[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
SOCKETS
|
|
|
|
-------
|
2009-12-04 10:06:46 +01:00
|
|
|
0MQ sockets are very similar to POSIX sockets. See following manual pages to
|
|
|
|
understand them in depth.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Creating a socket::
|
|
|
|
linkzmq:zmq_socket[3]
|
|
|
|
|
|
|
|
Closing a socket::
|
|
|
|
linkzmq:zmq_close[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Setting socket options::
|
|
|
|
linkzmq:zmq_setsockopt[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Establishing a message flow::
|
|
|
|
linkzmq:zmq_bind[3]
|
|
|
|
linkzmq:zmq_connect[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Sending & receiving messages::
|
|
|
|
linkzmq:zmq_send[3]
|
|
|
|
linkzmq:zmq_flush[3]
|
|
|
|
linkzmq:zmq_recv[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
MULTIPLEXING
|
|
|
|
------------
|
2009-12-04 10:06:46 +01:00
|
|
|
0MQ allows you to handle multiple sockets (0MQ as well as standard POSIX)
|
|
|
|
in an asynchronous manner.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Poll for I/O events::
|
|
|
|
linkzmq:zmq_poll[3]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
|
|
|
|
ERROR HANDLING
|
|
|
|
--------------
|
2010-01-18 13:16:14 +01:00
|
|
|
0MQ defines couple of non-POSIX error codes. Use following functions to handle
|
2009-12-04 10:06:46 +01:00
|
|
|
them neatly.
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Convert error code into human readable string::
|
|
|
|
linkzmq:zmq_strerror[3]
|
|
|
|
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
TRANSPORTS
|
|
|
|
----------
|
2009-12-04 10:06:46 +01:00
|
|
|
0MQ allows for using different underlying transport mechanisms (even multiple
|
|
|
|
at once). Each transport mechanism has its own advantages and drawbacks. For
|
|
|
|
detailed description of individual mechanisms check following manual pages:
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
TCP/IP transport::
|
|
|
|
linkzmq:zmq_tcp[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
UDP reliable multicast transport::
|
|
|
|
linkzmq:zmq_udp[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
PGM reliable multicast transport::
|
|
|
|
linkzmq:zmq_pgm[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Inter-process transport::
|
|
|
|
linkzmq:zmq_ipc[7]
|
2010-01-15 14:11:39 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
In-process (inter-thread) transport::
|
|
|
|
linkzmq:zmq_inproc[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
|
|
|
|
DEVICES
|
|
|
|
-------
|
2009-12-04 10:06:46 +01:00
|
|
|
Aside of the messaging library (a.k.a. messaging kernel) 0MQ provides pre-built
|
|
|
|
executables - devices - to serve as middle nodes in complex messaging
|
|
|
|
topologies. For detailed description of individual devices check following
|
|
|
|
manual pages:
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Forwarder device for PUB/SUB messaging::
|
|
|
|
linkzmq:zmq_forwarder[1]
|
|
|
|
|
|
|
|
Streamer device for UPSTREAM/DOWNSTREAM messaging::
|
|
|
|
linkzmq:zmq_streamer[1]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Forwarder device for REQ/REP messaging::
|
|
|
|
linkzmq:zmq_queue[1]
|
|
|
|
|
|
|
|
|
|
|
|
LANGUAGES
|
|
|
|
---------
|
2009-12-04 10:06:46 +01:00
|
|
|
0MQ manual pages provide info on C API. To find out how the your
|
|
|
|
favourite language API maps to C API and thus how to find relevant manual pages,
|
|
|
|
see following articles:
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
$$C++$$::
|
|
|
|
linkzmq:zmq_cpp[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Java::
|
|
|
|
linkzmq:zmq_java[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
Python::
|
|
|
|
linkzmq:zmq_python[7]
|
2009-12-04 10:06:46 +01:00
|
|
|
|
|
|
|
|
2010-02-10 16:18:46 +01:00
|
|
|
AUTHOR
|
|
|
|
------
|
2009-12-04 10:06:46 +01:00
|
|
|
Martin Sustrik <sustrik at 250bpm dot com>
|