<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Mar 21, 2014 at 6:29 AM, Derek Higgins <span dir="ltr"><<a href="mailto:derekh@redhat.com" target="_blank">derekh@redhat.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Hi All,<br>
I'm trying to get a handle on what needs to happen before getting<br>
tripleo-ci(toci) into the gate, I realize this may take some time but<br>
I'm trying to map out how to get to the end goal of putting multi node<br>
tripleo based deployments in the gate which should cover a lot of uses<br>
cases that devstact-gate doesn't. Here are some of the stages I think we<br>
need to achieve before being in the gate along with some questions where<br>
people may be able to fill in the blanks.<br>
<br>
Stage 1: check - tripleo projects<br>
This is what we currently have running, 5 separate jobs running non<br>
voting checks against tripleo projects<br>
<br>
Stage 2 (a). reliability<br>
Obviously keeping the reliability of both the results and the ci<br>
system is a must and we should always aim towards 0% false test results,<br>
but is there an acceptable number of false negatives for example that<br>
would be acceptable to infa, what are the numbers on the gate at the<br>
moment? should we aim to match those at the very least (Maybe we already<br>
have). And for how long do we need to maintain those levels before<br>
considering the system proven?<br></blockquote><div><br></div><div>I cannot come up with a specific number for this, perhaps someone else can. I see the results and CI system reliability as two very different things, for the CI system it should ideally never go down for very long (although this is less critical while tripleo is non-voting check only, like all other 3rd party systems). As for false negatives in the results, they should be on par with devstack-gate jobs especially once you start running tempest.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
Stage 2 (b). speedup<br>
How long can the longest jobs take? We have plans in place to speed<br>
up our current jobs but what should the target be?<br>
<br></blockquote><div><br></div><div>Gate jobs currently take up to a little over an hour [0][1]</div><div><br></div><div>[0] <a href="https://jenkins01.openstack.org/job/check-tempest-dsvm-postgres-full/buildTimeTrend">https://jenkins01.openstack.org/job/check-tempest-dsvm-postgres-full/buildTimeTrend</a></div>
<div>[1] <a href="https://jenkins02.openstack.org/job/check-tempest-dsvm-postgres-full/buildTimeTrend">https://jenkins02.openstack.org/job/check-tempest-dsvm-postgres-full/buildTimeTrend</a></div><div><br></div><div> </div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
3. More Capacity<br></blockquote><div><br></div><div>If you wanted to run tripleo-check everwhere a ''check-tempest-dsvm-full' job is run that is over 600 jobs in a 24 hour period.</div><div><br></div><div>[3] <a href="http://graphite.openstack.org/render/?from=00%3A00_20140203&fgcolor=000000&title=Check%20Hit%20Count&_t=0.2247244759928435&height=308&bgcolor=ffffff&width=586&hideGrid=false&until=23%3A59_20140324&showTarget=color(alias(hitcount(sum(stats.zuul.pipeline.gate.job.gate-tempest-dsvm-neutron-heat-slow.%7BSUCCESS%2CFAILURE%7D)%2C%275hours%27)%2C%20%27gate-tempest-dsvm-neutron-heat-slow%27)%2C%27green%27)&_salt=1395701365.817&lineMode=staircase&target=color(alias(hitcount(sum(stats.zuul.pipeline.check.job.check-tempest-dsvm-full.%7BSUCCESS%2CFAILURE%7D)%2C%2724hours%27)%2C%20%27check-tempest-dsvm-full%20hits%20over%2024%20hours%27)%2C%27orange%27)">graphite</a> color(alias(hitcount(sum(stats.zuul.pipeline.check.job.check-tempest-dsvm-full.{SUCCESS,FAILURE}),'24hours'), 'check-tempest-dsvm-full hits over 24 hours'),'orange')<br>
</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
I'm going to talk about RAM here as its probably the resource where<br>
we will hit our infrastructure limits first.<br>
Each time a suite of toci jobs is kicked off we currently kick off 5<br>
jobs (which will double once Fedora is added[1])<br>
In total these jobs spawn 15 vm's consuming 80G of RAM (its actually<br>
120G to workaround a bug we will should soon have fixed[2]), we also<br>
have plans that will reduce this 80G further but lets stick with it for<br>
the moment.<br>
Some of these jobs complete after about 30 minutes but lets say our<br>
target is an overall average of 45 minutes.<br>
<br>
With Fedora that means each run will tie up 160G for 45 minutes. Or<br>
160G can provide us with 32 runs (each including 10 jobs) per day<br>
<br>
So to kick off 500 (I made this number up) runs per day, we would need<br>
(500 / 32.0) * 160G = 2500G of RAM<br>
<br>
We then need to double this number to allow for redundancy, so thats<br>
5000G of RAM<br>
<br>
We probably have about 3/4 of this available to us at the moment but<br>
its not evenly balanced between the 2 clouds so we're not covered from a<br>
redundancy point of view.<br>
<br>
So we need more hardware (either by expanding the clouds we have or<br>
added new clouds), I'd like for us to start a separate effort to map out<br>
exactly what our medium term goals should be, including<br>
o jobs we want to run<br>
o how long we expect each of them to take<br>
o how much ram each one would take<br>
so that we can roughly put together an idea of what our HW<br>
requirements will be.<br>
<br>
4. check - all openstack projects<br>
Once we're happy we have the required capacity I think we can then<br>
move to check on all openstack projects<br>
<br>
5. voting check - all projects<br>
Once we're happy that everybody is happy with reliability I think we<br>
can move to voting check<br>
<br>
6. gate on all openstack projects<br>
And then finally when everything else lines up I think we can be<br>
added to the gate<br>
<br>
A) Gating with Ironic<br>
I bring this up because there was some confusion about ironic's status<br>
in the Gate at a recent tripleo meeting[3], when can tripleo's ironic<br>
jobs be part of the gate?<br>
<br>
Any thoughts? Am I way off with any of my assumptions? Is my maths correct?<br>
<br>
thanks,<br>
Derek.<br>
<br>
[1] <a href="https://review.openstack.org/#/q/status:open+topic:add-f20-jobs,n,z" target="_blank">https://review.openstack.org/#/q/status:open+topic:add-f20-jobs,n,z</a><br>
[2] <a href="https://bugs.launchpad.net/diskimage-builder/+bug/1289582" target="_blank">https://bugs.launchpad.net/diskimage-builder/+bug/1289582</a><br>
[3]<br>
<a href="http://eavesdrop.openstack.org/meetings/tripleo/2014/tripleo.2014-03-11-19.01.log.html" target="_blank">http://eavesdrop.openstack.org/meetings/tripleo/2014/tripleo.2014-03-11-19.01.log.html</a><br>
<br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</blockquote></div><br></div></div>