Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
06105d16
Commit
06105d16
authored
Jan 13, 2010
by
Martin Sustrik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
transports man pages updated
parent
30a107e0
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
145 additions
and
3 deletions
+145
-3
zmq_inproc.7
man/man7/zmq_inproc.7
+33
-1
zmq_pgm.7
man/man7/zmq_pgm.7
+76
-1
zmq_tcp.7
man/man7/zmq_tcp.7
+5
-0
zmq_udp.7
man/man7/zmq_udp.7
+31
-1
No files found.
man/man7/zmq_inproc.7
View file @
06105d16
...
@@ -2,8 +2,40 @@
...
@@ -2,8 +2,40 @@
.SH NAME
.SH NAME
In-process (inter-thread) tranport for 0MQ
In-process (inter-thread) tranport for 0MQ
.SH SYNOPSIS
.SH SYNOPSIS
.SH DESCRIPTION
In-process transport is optimised for passing messages betweem threads in the
same process.
Messages are passed directly from one application thread to
another application thread. There are no intervening I/O threads involved.
Thus, if you are using 0MQ for in-process messaging only, you can initialise
the library (
.IR zmq_init
) with zero I/O worker threads.
.SH CONNECTION STRING
Connection string for inproc transport is "inproc://" followed by an arbitrary
string. There are no restrictions on the string format:
.nf
inproc://my_endpoint
inproc://feeds/opra/cboe
inproc://feeds.opra.nasdaq
inproc://!&W#($)_@_123*((^^^
.fi
.SH WIRE FORMAT
In-process transport transfers messages via memory thus there is no need for a
wire format specification.
.SH "SEE ALSO"
.SH "SEE ALSO"
.BR zmq_tcp (7)
.BR zmq_udp (7)
.BR zmq_pgm (7)
.SH AUTHOR
.SH AUTHOR
Martin Sustrik <sustrik at 250bpm dot com>
Martin Sustrik <sustrik at 250bpm dot com>
man/man7/zmq_pgm.7
View file @
06105d16
...
@@ -2,8 +2,83 @@
...
@@ -2,8 +2,83 @@
.SH NAME
.SH NAME
PGM-based tranport for 0MQ
PGM-based tranport for 0MQ
.SH SYNOPSIS
.SH SYNOPSIS
.SH DESCRIPTION
PGM is a protocol for reliable multicast (RFC3208). 0MQ's PGM transport allows
you to deliver messages to multiple destinations sending the data over
the network once only. It makes sense to use PGM transport if the data,
delivered to each destination separately, would seriously load or even overload
the network.
PGM sending is rate limited rather than controlled by receivers. Thus, to get
optimal performance you should set ZMQ_RATE and ZMQ_RECOVERY_IVL socket options
prior to using PGM transport. Also note that passing multicast packets via
loopback interface has negative effect on the overall performance of the system.
Thus, if not needed, you should turn multicast loopback off using ZMQ_MCAST_LOOP
socket option.
PGM transport can be used only with ZMQ_PUB and ZMQ_SUB sockets.
.SH CONNECTION STRING
Connection string for PGM transport is "pgm://" followed by an IP adress
of the NIC to use, semicolon, IP adress of the multicast group, colon and
port numbrt. IP address of the NIC can be either its numeric representation
or the name of the NIC as reported by operating system. IP address of the
mutlicast group should be specified in the numeric representation. For example:
.nf
pgm://eth0:224.0.0.1:5555
pgm://lo:230.0.0.0:6666
pgm://192.168.0.111:224.0.0.1:5555
.fi
.SH WIRE FORMAT
Consecutive PGM packets are interpreted as a single continuous stream of data.
The data is then split into messages using the wire format described in
.IR zmq_tcp(7) .
Thus, messages are not aligned with packet boundaries and each message can start
at an arbitrary position within the packet and span several packets.
Given this wire format, it would be impossible for late joining consumers to
identify message boundaries. To solve this problem, each PGM packet payload
starts with 16-bit unsigned integer in network byte order which specifies the
offset of the first message in the packet. If there's no beginning of a message
in the packet (it's a packet transferring inner part of a larger message)
the value of the initial integer is 0xFFFF.
Each packet thus looks like this:
.nf
+-----------+------------+------------------+--------
| IP header | PGM header | offset (16 bits) | data .....
+-----------+------------+------------------+--------
.fi
Following example shows how messages are arranged in subsequent packets:
.nf
+---------------+--------+-----------+-----------------------------+
| PGM/IPheaders | 0x0000 | message 1 | message 2 (part 1) |
+---------------+--------+-----------+-----------------------------+
+---------------+--------+-----------------------------------------+
| PGM/IPheaders | 0xFFFF | message 2 (part 2) |
+---------------+--------+-----------------------------------------+
+---------------+--------+--------------------------+-----------+
| PGM/IPheaders | 0x0008 | message 2 (last 8 bytes) | message 3 |
+---------------+--------+--------------------------+-----------+
.fi
.SH "SEE ALSO"
.SH "SEE ALSO"
.BR zmq_udp (7)
.BR zmq_tcp (7)
.BR zmq_inproc (7)
.BR zmq_setsockopt (3)
.SH AUTHOR
.SH AUTHOR
Martin Sustrik <sustrik at 250bpm dot com>
Martin Sustrik <sustrik at 250bpm dot com>
man/man7/zmq_tcp.7
View file @
06105d16
...
@@ -64,6 +64,11 @@ Binary layout of a larger message:
...
@@ -64,6 +64,11 @@ Binary layout of a larger message:
.fi
.fi
.SH "SEE ALSO"
.SH "SEE ALSO"
.BR zmq_udp (7)
.BR zmq_pgm (7)
.BR zmq_inproc (7)
.SH AUTHOR
.SH AUTHOR
Martin Sustrik <sustrik at 250bpm dot com>
Martin Sustrik <sustrik at 250bpm dot com>
man/man7/zmq_udp.7
View file @
06105d16
...
@@ -2,8 +2,38 @@
...
@@ -2,8 +2,38 @@
.SH NAME
.SH NAME
UDP-based tranport for 0MQ
UDP-based tranport for 0MQ
.SH SYNOPSIS
.SH SYNOPSIS
.SH DESCRIPTION
UDP transport is exactly the same as PGM transport except that PGM packets
are encapsulated in UDP packets. Rationale for this transport is that user-space
implementation of PGM requires right to create raw sockets (PGM is located
directly on top of IP layer in the netwroking stack), which is often not
available. UDP encapsulation solves this problem, however, it adds some overhead
related to creating and transferring UDP packet headers.
.SH CONNECTION STRING
Connection string for UDP transport is "udp://" followed by an IP adress
of the NIC to use, semicolon, IP adress of the multicast group, colon and
port numbrt. IP address of the NIC can be either its numeric representation
or the name of the NIC as reported by operating system. IP address of the
mutlicast group should be specified in the numeric representation. For example:
.nf
udp://eth0:224.0.0.1:5555
udp://lo:230.0.0.0:6666
udp://192.168.0.111:224.0.0.1:5555
.fi
.SH WIRE FORMAT
Same as with PGM transport except for UDP packet headers.
.SH "SEE ALSO"
.SH "SEE ALSO"
.BR zmq_pgm (7)
.BR zmq_tcp (7)
.BR zmq_inproc (7)
.SH AUTHOR
.SH AUTHOR
Martin Sustrik <sustrik at 250bpm dot com>
Martin Sustrik <sustrik at 250bpm dot com>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment