<div dir="ltr">Hi Alec,<div>Thanks for your inputs. I would really like to develop this feature. I don't know if i can handle it, but I would try my best. Can you suggest some pointers on how to start and how can we discuss in detail about the tasks? </div><div><br></div><div>Thanks</div><div>Akshay</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Aug 24, 2016 at 7:37 AM, Alec Hothan (ahothan) <span dir="ltr"><<a href="mailto:ahothan@cisco.com" target="_blank">ahothan@cisco.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word;color:rgb(0,0,0);font-size:14px;font-family:Futura,sans-serif">
<div>
<div>Hi Akshay,</div>
<div><br>
</div>
<div>I suppose you're talking about LBAAS v2?</div>
<div><br>
</div>
<div>Adding support for lbaas in kloudbuster will require some amount of work which can be kept to a minimum if done properly, this addition would be a pretty good way to test lbaas at scale.</div>
<div>The tricky part is to modify the staging code without breaking the other features (multicast and storage) since this staging is specific to HTTP scale test.</div>
<div>The current staging for HTTP scale is based on the following template (I show the server side only):</div>
<div><br>
</div>
<div>[Router---------[HTTP server VM]*]*</div>
<div><br>
</div>
<div>The natural extension for supporting LBAAS is to replace each HTTP server with a LB group + N HTTP servers:</div>
<div><br>
</div>
<div>
<div>[Router----------[LB-------[<wbr>HTTP server VM]*]*]*</div>
</div>
<div><br>
</div>
<div>Implementing this would require the following modifications (just a rough description of the tasks):</div>
<ul>
<li>add an additional config option to specify the number of server VMs per LB group (defaults to none/no LB) <easy></li><li>if LB is configured, the current config server count would become a LB group count</li><li>the staging code for the HTTP servers needs to be modified to handle the case of LB: <medium difficulty - need to know the LBAAS python APIs>
<ul>
<li>instead of creating as many HTTP servers as the server count argument, create as many LB groups</li><li>for each LB group, create the requested HTTP server VMs per group and add them to the group</li></ul>
</li><li>floating IP if requested need to apply to the LB port instead of the HTTP servers <easy></li><li>naturally the teardown code will have to also support cleaning up LB resources <easy></li></ul>
<div>
<ul>
<li>HTTP clients will need to connect to the LB VIP address (instead of the HTTP server IP address) <easy></li></ul>
</div>
<div>I can help you go through these individual tasks in detail in the code if you feel you can handle that, it's just python coding.</div>
<div><br>
</div>
<div><br>
</div>
<div>The VMs running the HTTP traffic generators are currently always associated 1:1 to a server VM. With the above template extension you will end up with as many HTTP client VMs as LB groups:</div>
<div><br>
</div>
<div>
<div>(removed the router for better clarity):</div>
</div>
<div><br>
</div>
<div>
<div>[HTTP client VM-------[LB-------[HTTP server VM]*]*]*</div>
</div>
<div><br>
</div>
<div>This is not ideal because each HTTP traffic generator can only support a relatively low number of connections (in the few thousands) while an HTTP server instance can easily support many times this load especially for light HTTP traffic (i.e. replies that
 are very short).</div>
<div><br>
</div>
<div>So another improvement (which we had on our roadmap) would be to support N:1 mapping:</div>
<div><br>
</div>
<div>
<div>[[HTTP client VM]*--------LB-------[HTTP server VM]*]*]*</div>
</div>
<div><br>
</div>
<div>this could be a separate extension.</div>
<div>Let me know if you'd like to do this and we can help navigate the code.</div>
<div><br>
</div>
<div>Thanks</div>
<div><br>
</div>
<div>   Alec</div>
<div><br>
</div>
<div><br>
</div>
<div>
<div></div>
</div>
</div>
<div><br>
</div>
<span>
<div style="font-family:Calibri;font-size:12pt;text-align:left;color:black;BORDER-BOTTOM:medium none;BORDER-LEFT:medium none;PADDING-BOTTOM:0in;PADDING-LEFT:0in;PADDING-RIGHT:0in;BORDER-TOP:#b5c4df 1pt solid;BORDER-RIGHT:medium none;PADDING-TOP:3pt">
<span style="font-weight:bold">From: </span>Akshay Kumar Sanghai <<a href="mailto:akshaykumarsanghai@gmail.com" target="_blank">akshaykumarsanghai@gmail.com</a>><br>
<span style="font-weight:bold">Date: </span>Tuesday, August 23, 2016 at 2:07 PM<br>
<span style="font-weight:bold">To: </span>Alec Hothan <<a href="mailto:ahothan@cisco.com" target="_blank">ahothan@cisco.com</a>><br>
<span style="font-weight:bold">Cc: </span>"Yichen Wang (yicwang)" <<a href="mailto:yicwang@cisco.com" target="_blank">yicwang@cisco.com</a>>, "OpenStack Development Mailing List (not for usage questions)" <<a href="mailto:openstack-dev@lists.openstack.org" target="_blank">openstack-dev@lists.<wbr>openstack.org</a>><br>
<span style="font-weight:bold">Subject: </span>Re: [openstack-dev] [kloudbuster] authorization failed problem<br>
</div>
<div><br>
</div>
<span>
<blockquote style="BORDER-LEFT:#b5c4df 5 solid;PADDING:0 0 0 5;MARGIN:0 0 0 5">
<div>
<div>
<div dir="ltr">Hi Yichen, Alec,
<div><br>
</div>
<div>The kloudbuster project worked perfectly fine for me. Now I want to integrate lbaas for scale testing. Can you guys help in how do i achieve that? Please include me for any contribution.</div>
<div><br>
</div>
<div>Thanks</div>
<div>Akshay Sanghai</div>
</div>
<div class="gmail_extra"><br>
<div class="gmail_quote"><br>
</div>
</div>
</div>
</div>
</blockquote>
</span></span>
</div>
</blockquote></div><br></div>