<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
</head>
<body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; font-family: Calibri, sans-serif; font-size: 14px; color: rgb(0, 0, 0);">
<div><br>
</div>
<div><br>
</div>
<div>On 6/1/15, 5:03 PM, "Davanum Srinivas" <<a href="mailto:davanum@gmail.com">davanum@gmail.com</a>> wrote:</div>
<div><br>
</div>
<blockquote id="MAC_OUTLOOK_ATTRIBUTION_BLOCKQUOTE" style="BORDER-LEFT: #b5c4df 5 solid; PADDING:0 0 0 5; MARGIN:0 0 0 5;">
<div>fyi, the spec for zeromq driver in oslo.messaging is here:</div>
<div><a href="https://review.openstack.org/#/c/187338/1/specs/liberty/zmq-patterns-usage">https://review.openstack.org/#/c/187338/1/specs/liberty/zmq-patterns-usage</a></div>
<div>.rst,unified</div>
<div><br>
</div>
</blockquote>
<div><br>
</div>
<div>The above spec suggests using the zmq pub/sub/xpub/xsub proxy pattern for implementing the oslo messaging fanout API.</div>
<div>This is described in the zmq guide (<a href="http://zguide.zeromq.org/">http://zguide.zeromq.org/</a>, search for "Figure 13 - Pub-Sub Network with a Proxy").</div>
<div><br>
</div>
<div>When applied to openstack, this pattern will result in a number of publishers connecting to a</div>
<div>potentially large number of proxies (the proposal calls for 1 proxy per node in the cloud), and each proxy connected to a relatively small number of local services (typically</div>
<div>agents).</div>
<div> </div>
<div>All connections in this pattern are based on TCP (for inter-node) and could be based on IPC (Unix domain socket) for intra-node.</div>
<div>ZMQ provides the option of having either side initiate the connection, in our case, it is logical and simple to have the agents connect to their</div>
<div>local proxy (just use any well known unix domain socket name). However the connectivity on the other end (publisher to proxy) is not as simple without some form of name service/service discovery (in the present version of ZMQ driver, this is handled by
 matchmaker/redis).</div>
<div><br>
</div>
<div>GROUP MANAGEMENT</div>
<div>The ZMQ guide mentions rightly so that this pattern is great for decoupling publishers and subscribers as they can independently connect to the proxy without having to know each other.</div>
<div>So publishers would basically simply connect to *the* proxy and not have to deal with other publishers or any subscriber.</div>
<div>However when the number of proxies can be very large (thousands), the difficulty resides in keeping track of nodes as they can get added or removed during regular operations. When a node is added, we would need a way to</div>
<div>have each publisher connect to that new node.  Same can be said about node deletion.</div>
<div>If we go that route we will need a good solution on how to do that efficiently and at scale.</div>
<div><br>
</div>
<div>And this is one of my main reserve for the spec currently proposed in gerrit.</div>
<div><br>
</div>
<div>To handle group management, we could reuse the existing matchmaker code (based on redis) or decide to use a more streamlined solution based on a name service. I would like to hear about any feedback on the use of matchmaker at scale if there is any experience
 (because I do have lots of questions on how matchmaker is designed and how it fares regarding scale and HA).</div>
<div><br>
</div>
<div>I'll try to start another email thread regarding scale numbers (number of connections, current usage of fanout in the code, emulated vs. true multicast)</div>
<div><br>
</div>
<div>  Alec</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
</body>
</html>