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
51750a7d
Commit
51750a7d
authored
May 23, 2013
by
shripchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactored ZMQ_ROUTER_ANNOUNCE_SELF code. renamed it to ZMQ_PROBE_NEW_PEERS.
implement it for DEALER tocket. +documentation
parent
910b4692
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
86 additions
and
19 deletions
+86
-19
zmq_setsockopt.txt
doc/zmq_setsockopt.txt
+15
-0
zmq.h
include/zmq.h
+1
-1
dealer.cpp
src/dealer.cpp
+40
-1
dealer.hpp
src/dealer.hpp
+4
-0
router.cpp
src/router.cpp
+22
-13
router.hpp
src/router.hpp
+4
-4
No files found.
doc/zmq_setsockopt.txt
View file @
51750a7d
...
@@ -421,6 +421,21 @@ Default value:: 0
...
@@ -421,6 +421,21 @@ Default value:: 0
Applicable socket types:: ZMQ_ROUTER
Applicable socket types:: ZMQ_ROUTER
ZMQ_PROBE_NEW_PEERS: automatically send empty packet to every established connection
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Sets the 'ROUTER' & 'DEALER' sockets behavior to automatically send an empty packet
to any new connection made (or accepted) by socket. It could help sockets to
auto discovery themself. It especially important in 'ROUTER' <-> 'ROUTER' connections
where it solves 'who will write first' problems.
[horizontal]
Option value type:: int
Option value unit:: 0, 1
Default value:: 0
Applicable socket types:: ZMQ_ROUTER, ZMQ_DEALER
ZMQ_XPUB_VERBOSE: provide all subscription messages on XPUB sockets
ZMQ_XPUB_VERBOSE: provide all subscription messages on XPUB sockets
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
...
...
include/zmq.h
View file @
51750a7d
...
@@ -274,7 +274,7 @@ ZMQ_EXPORT int zmq_msg_set (zmq_msg_t *msg, int option, int optval);
...
@@ -274,7 +274,7 @@ ZMQ_EXPORT int zmq_msg_set (zmq_msg_t *msg, int option, int optval);
#define ZMQ_CURVE_SERVER 47
#define ZMQ_CURVE_SERVER 47
#define ZMQ_CURVE_PUBLICKEY 48
#define ZMQ_CURVE_PUBLICKEY 48
#define ZMQ_CURVE_SERVERKEY 49
#define ZMQ_CURVE_SERVERKEY 49
#define ZMQ_
ROUTER_ANNOUNCE_SELF
50
#define ZMQ_
PROBE_NEW_PEERS
50
/* Message options */
/* Message options */
#define ZMQ_MORE 1
#define ZMQ_MORE 1
...
...
src/dealer.cpp
View file @
51750a7d
...
@@ -22,7 +22,8 @@
...
@@ -22,7 +22,8 @@
#include "msg.hpp"
#include "msg.hpp"
zmq
::
dealer_t
::
dealer_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
zmq
::
dealer_t
::
dealer_t
(
class
ctx_t
*
parent_
,
uint32_t
tid_
,
int
sid_
)
:
socket_base_t
(
parent_
,
tid_
,
sid_
)
socket_base_t
(
parent_
,
tid_
,
sid_
),
probe_new_peers
(
false
)
{
{
options
.
type
=
ZMQ_DEALER
;
options
.
type
=
ZMQ_DEALER
;
}
}
...
@@ -37,10 +38,48 @@ void zmq::dealer_t::xattach_pipe (pipe_t *pipe_, bool icanhasall_)
...
@@ -37,10 +38,48 @@ void zmq::dealer_t::xattach_pipe (pipe_t *pipe_, bool icanhasall_)
(
void
)
icanhasall_
;
(
void
)
icanhasall_
;
zmq_assert
(
pipe_
);
zmq_assert
(
pipe_
);
if
(
probe_new_peers
)
{
int
rc
,
ok
;
msg_t
probe_msg_
;
rc
=
probe_msg_
.
init
();
errno_assert
(
rc
==
0
);
ok
=
pipe_
->
write
(
&
probe_msg_
);
zmq_assert
(
ok
);
pipe_
->
flush
();
rc
=
probe_msg_
.
close
();
errno_assert
(
rc
==
0
);
}
fq
.
attach
(
pipe_
);
fq
.
attach
(
pipe_
);
lb
.
attach
(
pipe_
);
lb
.
attach
(
pipe_
);
}
}
int
zmq
::
dealer_t
::
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
size_t
optvallen_
)
{
bool
is_int
=
(
optvallen_
==
sizeof
(
int
));
int
value
=
is_int
?
*
((
int
*
)
optval_
)
:
0
;
switch
(
option_
)
{
case
ZMQ_PROBE_NEW_PEERS
:
if
(
is_int
&&
value
>=
0
)
{
probe_new_peers
=
value
;
return
0
;
}
break
;
default
:
break
;
}
errno
=
EINVAL
;
return
-
1
;
}
int
zmq
::
dealer_t
::
xsend
(
msg_t
*
msg_
)
int
zmq
::
dealer_t
::
xsend
(
msg_t
*
msg_
)
{
{
return
lb
.
send
(
msg_
);
return
lb
.
send
(
msg_
);
...
...
src/dealer.hpp
View file @
51750a7d
...
@@ -46,6 +46,7 @@ namespace zmq
...
@@ -46,6 +46,7 @@ namespace zmq
// Overloads of functions from socket_base_t.
// Overloads of functions from socket_base_t.
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
int
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
size_t
optvallen_
);
int
xsend
(
zmq
::
msg_t
*
msg_
);
int
xsend
(
zmq
::
msg_t
*
msg_
);
int
xrecv
(
zmq
::
msg_t
*
msg_
);
int
xrecv
(
zmq
::
msg_t
*
msg_
);
bool
xhas_in
();
bool
xhas_in
();
...
@@ -61,6 +62,9 @@ namespace zmq
...
@@ -61,6 +62,9 @@ namespace zmq
fq_t
fq
;
fq_t
fq
;
lb_t
lb
;
lb_t
lb
;
// if true, send an empty message to every connected peer
bool
probe_new_peers
;
dealer_t
(
const
dealer_t
&
);
dealer_t
(
const
dealer_t
&
);
const
dealer_t
&
operator
=
(
const
dealer_t
&
);
const
dealer_t
&
operator
=
(
const
dealer_t
&
);
};
};
...
...
src/router.cpp
View file @
51750a7d
...
@@ -34,7 +34,7 @@ zmq::router_t::router_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
...
@@ -34,7 +34,7 @@ zmq::router_t::router_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
next_peer_id
(
generate_random
()),
next_peer_id
(
generate_random
()),
mandatory
(
false
),
mandatory
(
false
),
raw_sock
(
false
),
raw_sock
(
false
),
announce_self
(
false
)
probe_new_peers
(
false
)
{
{
options
.
type
=
ZMQ_ROUTER
;
options
.
type
=
ZMQ_ROUTER
;
options
.
recv_identity
=
true
;
options
.
recv_identity
=
true
;
...
@@ -85,7 +85,7 @@ int zmq::router_t::xsetsockopt (int option_, const void *optval_,
...
@@ -85,7 +85,7 @@ int zmq::router_t::xsetsockopt (int option_, const void *optval_,
// DEBUGGING PROBLEM WITH TRAVIS CI
// DEBUGGING PROBLEM WITH TRAVIS CI
printf
(
"E: invalid option value (int=%d value=%d)
\n
"
,
is_int
,
value
);
printf
(
"E: invalid option value (int=%d value=%d)
\n
"
,
is_int
,
value
);
break
;
break
;
case
ZMQ_ROUTER_MANDATORY
:
case
ZMQ_ROUTER_MANDATORY
:
if
(
is_int
&&
value
>=
0
)
{
if
(
is_int
&&
value
>=
0
)
{
mandatory
=
value
;
mandatory
=
value
;
...
@@ -94,14 +94,14 @@ int zmq::router_t::xsetsockopt (int option_, const void *optval_,
...
@@ -94,14 +94,14 @@ int zmq::router_t::xsetsockopt (int option_, const void *optval_,
// DEBUGGING PROBLEM WITH TRAVIS CI
// DEBUGGING PROBLEM WITH TRAVIS CI
printf
(
"E: invalid option value (int=%d value=%d)
\n
"
,
is_int
,
value
);
printf
(
"E: invalid option value (int=%d value=%d)
\n
"
,
is_int
,
value
);
break
;
break
;
case
ZMQ_
ROUTER_ANNOUNCE_SELF
:
case
ZMQ_
PROBE_NEW_PEERS
:
if
(
is_int
&&
value
>=
0
)
{
if
(
is_int
&&
value
>=
0
)
{
announce_self
=
value
;
probe_new_peers
=
value
;
return
0
;
return
0
;
}
}
break
;
break
;
default
:
default
:
break
;
break
;
}
}
...
@@ -397,14 +397,23 @@ bool zmq::router_t::identify_peer (pipe_t *pipe_)
...
@@ -397,14 +397,23 @@ bool zmq::router_t::identify_peer (pipe_t *pipe_)
ok
=
outpipes
.
insert
(
outpipes_t
::
value_type
(
identity
,
outpipe
)).
second
;
ok
=
outpipes
.
insert
(
outpipes_t
::
value_type
(
identity
,
outpipe
)).
second
;
zmq_assert
(
ok
);
zmq_assert
(
ok
);
if
(
announce_self
)
{
if
(
probe_new_peers
)
{
msg_t
tmp_
;
int
rc
;
tmp_
.
init
();
msg_t
probe_msg_
;
ok
=
pipe_
->
write
(
&
tmp_
);
zmq_assert
(
ok
);
rc
=
probe_msg_
.
init
();
errno_assert
(
rc
==
0
);
ok
=
pipe_
->
write
(
&
probe_msg_
);
pipe_
->
flush
();
pipe_
->
flush
();
tmp_
.
close
();
};
rc
=
probe_msg_
.
close
();
errno_assert
(
rc
==
0
);
// Ignore not probed peers
if
(
!
ok
)
return
false
;
}
return
true
;
return
true
;
}
}
...
...
src/router.hpp
View file @
51750a7d
...
@@ -47,8 +47,8 @@ namespace zmq
...
@@ -47,8 +47,8 @@ namespace zmq
// Overloads of functions from socket_base_t.
// Overloads of functions from socket_base_t.
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
void
xattach_pipe
(
zmq
::
pipe_t
*
pipe_
,
bool
icanhasall_
);
int
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
size_t
optvallen_
);
int
xsetsockopt
(
int
option_
,
const
void
*
optval_
,
size_t
optvallen_
);
int
xsend
(
msg_t
*
msg_
);
int
xsend
(
zmq
::
msg_t
*
msg_
);
int
xrecv
(
msg_t
*
msg_
);
int
xrecv
(
zmq
::
msg_t
*
msg_
);
bool
xhas_in
();
bool
xhas_in
();
bool
xhas_out
();
bool
xhas_out
();
void
xread_activated
(
zmq
::
pipe_t
*
pipe_
);
void
xread_activated
(
zmq
::
pipe_t
*
pipe_
);
...
@@ -112,8 +112,8 @@ namespace zmq
...
@@ -112,8 +112,8 @@ namespace zmq
bool
mandatory
;
bool
mandatory
;
bool
raw_sock
;
bool
raw_sock
;
// if true, send an empty message to every connected peer to solve 'who will write first
' race condition
// if true, send an empty message to every connected peer to solve 'who will write first
?' auto discovery problem
bool
announce_self
;
bool
probe_new_peers
;
router_t
(
const
router_t
&
);
router_t
(
const
router_t
&
);
const
router_t
&
operator
=
(
const
router_t
&
);
const
router_t
&
operator
=
(
const
router_t
&
);
...
...
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