0
0
mirror of https://github.com/zeromq/libzmq.git synced 2024-12-27 23:51:04 +08:00
libzmq/doc/zmq_ipc.txt

95 lines
2.8 KiB
Plaintext
Raw Normal View History

2010-02-10 16:18:46 +01:00
zmq_ipc(7)
==========
2010-01-15 14:11:39 +01:00
2010-02-10 16:18:46 +01:00
NAME
----
2010-03-09 18:47:31 +01:00
zmq_ipc - 0MQ local inter-process communication transport
2010-02-10 16:18:46 +01:00
SYNOPSIS
--------
2010-03-09 18:47:31 +01:00
The inter-process transport passes messages between local processes using a
system-dependent IPC mechanism.
2010-01-15 14:11:39 +01:00
2010-03-09 18:47:31 +01:00
NOTE: The inter-process transport is currently only implemented on operating
systems that provide UNIX domain sockets.
2010-01-15 14:11:39 +01:00
2010-03-09 18:47:31 +01:00
ADDRESSING
----------
2012-10-27 09:43:19 +09:00
A 0MQ endpoint is a string consisting of a 'transport'`://` followed by an
'address'. The 'transport' specifies the underlying protocol to use. The
'address' specifies the transport-specific address to connect to.
2010-03-09 18:47:31 +01:00
2012-10-27 09:43:19 +09:00
For the inter-process transport, the transport is `ipc`, and the meaning of
the 'address' part is defined below.
2010-03-09 18:47:31 +01:00
2012-10-27 09:43:19 +09:00
Binding a socket
~~~~~~~~~~~~~~~~
When binding a 'socket' to a local address using _zmq_bind()_ with the 'ipc'
2010-03-09 18:47:31 +01:00
transport, the 'endpoint' shall be interpreted as an arbitrary string
identifying the 'pathname' to create. The 'pathname' must be unique within the
operating system namespace used by the 'ipc' implementation, and must fulfill
any restrictions placed by the operating system on the format and length of a
'pathname'.
2012-10-27 09:43:19 +09:00
When the address is `*`, _zmq_bind()_ shall generate a unique temporary
pathname. The caller should retrieve this pathname using the ZMQ_LAST_ENDPOINT
socket option. See linkzmq:zmq_getsockopt[3] for details.
2013-01-14 17:49:19 +01:00
NOTE: any existing binding to the same endpoint shall be overridden. That is,
if a second process binds to an endpoint already bound by a process, this
will succeed and the first process will lose its binding. In this behavior,
the 'ipc' transport is not consistent with the 'tcp' or 'inproc' transports.
NOTE: the endpoint pathname must be writable by the process. When the endpoint
starts with '/', e.g., `ipc:///pathname`, this will be an _absolute_ pathname.
If the endpoint specifies a directory that does not exist, the bind shall fail.
2012-10-27 09:43:19 +09:00
2010-03-09 18:47:31 +01:00
Connecting a socket
~~~~~~~~~~~~~~~~~~~
When connecting a 'socket' to a peer address using _zmq_connect()_ with the
'ipc' transport, the 'endpoint' shall be interpreted as an arbitrary string
identifying the 'pathname' to connect to. The 'pathname' must have been
previously created within the operating system namespace by assigning it to a
'socket' with _zmq_bind()_.
2010-01-15 14:11:39 +01:00
2010-03-09 18:47:31 +01:00
EXAMPLES
--------
.Assigning a local address to a socket
----
2012-10-27 09:43:19 +09:00
// Assign the pathname "/tmp/feeds/0"
2010-03-09 18:47:31 +01:00
rc = zmq_bind(socket, "ipc:///tmp/feeds/0");
assert (rc == 0);
----
.Connecting a socket
----
2012-10-27 09:43:19 +09:00
// Connect to the pathname "/tmp/feeds/0"
2010-03-09 18:47:31 +01:00
rc = zmq_connect(socket, "ipc:///tmp/feeds/0");
assert (rc == 0);
----
2010-01-15 14:11:39 +01:00
2010-02-10 16:18:46 +01:00
SEE ALSO
--------
2010-03-09 18:47:31 +01:00
linkzmq:zmq_bind[3]
linkzmq:zmq_connect[3]
2010-02-10 16:18:46 +01:00
linkzmq:zmq_inproc[7]
linkzmq:zmq_tcp[7]
linkzmq:zmq_pgm[7]
2012-10-27 09:43:19 +09:00
linkzmq:zmq_getsockopt[3]
2010-03-09 18:47:31 +01:00
linkzmq:zmq[7]
2010-01-15 14:11:39 +01:00
AUTHORS
-------
2012-10-27 09:43:19 +09:00
This 0MQ manual page was written by Pieter Hintjens <ph@imatix.com>,
Martin Sustrik <sustrik@250bpm.com> and Martin Lucina <mato@kotelna.sk>.
2013-01-14 17:49:19 +01:00