<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Mon, May 4, 2015 at 6:33 PM, Jastrzebski, Michal <span dir="ltr"><<a href="mailto:michal.jastrzebski@intel.com" target="_blank">michal.jastrzebski@intel.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">W dniu 5/4/2015 o 8:21 AM, Angus Salkeld pisze:> On Thu, Apr 30, 2015 at 9:25 PM, Jastrzebski, Michal<br>
<div><div class="h5">> <<a href="mailto:michal.jastrzebski@intel.com">michal.jastrzebski@intel.com</a> <mailto:<a href="mailto:michal.jastrzebski@intel.com">michal.jastrzebski@intel.com</a>>> wrote:<br>
><br>
>     Hello,<br>
><br>
>     After discussions, we've spotted possible gap in versioned objects:<br>
>     backporting of too-new versions in RPC.<br>
>     Nova does that by conductor, but not every service has something<br>
>     like that. I want to propose another approach:<br>
><br>
>     1. Milestone pinning - we need to make single reference to versions<br>
>     of various objects - for example heat in version 15.1 will mean<br>
>     stack in version 1.1 and resource in version 1.5.<br>
>     2. Compatibility mode - this will add flag to service<br>
>     --compatibility=15.1, that will mean that every outgoing RPC<br>
>     communication will be backported before sending to object versions<br>
>     bound to this milestone.<br>
><br>
>     With this 2 things landed we'll achieve rolling upgrade like that:<br>
>     1. We have N nodes in version V<br>
>     2. We take down 1 node and upgrade code to version V+1<br>
>     3. Run code in ver V+1 with --compatibility=V<br>
>     4. Repeat 2 and 3 until every node will have version V+1<br>
>     5. Restart each service without compatibility flag<br>
><br>
>     This approach has one big disadvantage - 2 restarts required, but<br>
>     should solve problem of backporting of too-new versions.<br>
>     Any ideas? Alternatives?<br>
><br>
><br>
> AFAIK if nova gets a message that is too new, it just forwards it on<br>
> (and a newer server will handle it).<br>
><br>
> With that this *should* work, shouldn't it?<br>
> 1. rolling upgrade of heat-engine<br>
<br>
</div></div>That will be hard part. When we'll have only one engine from given version, we lose HA. Also, since we never know where given task lands, we might end up with one task bouncing from old version to old version, making call indefinitely long. Ofc with each upgraded engine we'll lessen change for that to happen, but I think we should aim for lowest possible downtime. That being said, that might be good idea to solve this problem not-too-clean, but quickly.<br></blockquote><div><br></div><div>I don't think losing HA in the time it takes some heat-engines to stop, install new software and restart the heat-engines is a big deal (IMHO).</div><div><br></div><div>-Angus</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<span class="im HOEnZb"><br>
> 2. db sync<br>
> 3. rolling upgrade of heat-api<br>
><br>
> -Angus<br>
><br>
><br>
>     Regards,<br>
</span><div class="HOEnZb"><div class="h5">__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</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>
</div></div></blockquote></div><br></div></div>