<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">2015-06-05 19:35 GMT+08:00 Sean Dague <span dir="ltr"><<a href="mailto:sean@dague.net" target="_blank">sean@dague.net</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On 06/05/2015 01:28 AM, Adrian Otto wrote:<br>
><br>
>> On Jun 4, 2015, at 11:03 AM, Devananda van der Veen<br>
</span><span class="">>> <<a href="mailto:devananda.vdv@gmail.com">devananda.vdv@gmail.com</a> <mailto:<a href="mailto:devananda.vdv@gmail.com">devananda.vdv@gmail.com</a>>> wrote:<br>
>><br>
>><br>
>> On Jun 4, 2015 12:00 AM, "Xu, Hejie" <<a href="mailto:hejie.xu@intel.com">hejie.xu@intel.com</a><br>
</span><div><div class="h5">>> <mailto:<a href="mailto:hejie.xu@intel.com">hejie.xu@intel.com</a>>> wrote:<br>
>> ><br>
>> > Hi, guys,<br>
>> ><br>
>> > I’m working on adding Microversion into the API-WG’s guideline which<br>
>> make sure we have consistent Microversion behavior in the API for user.<br>
>> > The Nova and Ironic already have Microversion implementation, and as<br>
>> I know Magnum <a href="https://review.openstack.org/#/c/184975/" target="_blank">https://review.openstack.org/#/c/184975/</a> is going to<br>
>> implement Microversion also.<br>
>> ><br>
>> > Hope all the projects which support( or plan to) Microversion can<br>
>> join the review of guideline.<br>
>> ><br>
>> > The Mircoversion specification(this almost copy from nova-specs):<br>
>> <a href="https://review.openstack.org/#/c/187112" target="_blank">https://review.openstack.org/#/c/187112</a><br>
>> > And another guideline for when we should bump Mircoversion<br>
>> <a href="https://review.openstack.org/#/c/187896/" target="_blank">https://review.openstack.org/#/c/187896/</a><br>
>> ><br>
>> > As I know, there already have a little different between Nova and<br>
>> Ironic’s implementation. Ironic return min/max version when the requested<br>
>> > version doesn’t support in server by http-headers. There isn’t such<br>
>> thing in nova. But that is something for version negotiation we need<br>
>> for nova also.<br>
>> > Sean have pointed out we should use response body instead of http<br>
>> headers, the body can includes error message. Really hope ironic team<br>
>> can take a<br>
>> > look at if you guys have compelling reason for using http headers.<br>
>> ><br>
>> > And if we think return body instead of http headers, we probably<br>
>> need think about back-compatible also. Because Microversion itself<br>
>> isn’t versioned.<br>
>> > So I think we should keep those header for a while, does make sense?<br>
>> ><br>
>> > Hope we have good guideline for Microversion, because we only can<br>
>> change Mircoversion itself by back-compatible way.<br>
>><br>
>> Ironic returns the min/max/current API version in the http headers for<br>
>> every request.<br>
>><br>
>> Why would it return this information in a header on success and in the<br>
>> body on failure? (How would this inconsistency benefit users?)<br>
>><br>
>> To be clear, I'm not opposed to *also* having a useful error message<br>
>> in the body, but while writing the client side of api versioning,<br>
>> parsing the range consistently from the response header is, IMO,<br>
>> better than requiring a conditional.<br>
>><br>
> +1. I fully agree with Devananda on this point. Use the headers<br>
> consistently, and add helpful errors into the body only as an addition<br>
> to that behavior, not a substitute.<br>
<br>
</div></div>I think the difference between Nova and Ironic here is that Nova doesn't<br>
send all the headers all the time in the final implementation (that part<br>
of the spec evolved out I think). Part of that was pressure about Header<br>
bloat that people were concerned about, as that impacts caching layers.<br></blockquote><div><br></div><div>Can I ask more detail about this concern? Header bloat may have performance problem for extra data transfer between server and client. For the caching, we use Vary header. What impact you refer to?</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
I would a agree that if Ironic is sending all the headers all the time,<br>
that's fine. However, for consistency it would be great to also put a<br>
real body that explains the issue as well, as headers are not the first<br>
place people look when things go wrong, and are often not logged by<br>
client side tools on errors (where the body would be).<br>
<span class="HOEnZb"><font color="#888888"><br></font></span></blockquote><div><br></div><div>Thanks all the replied, let me update the guideline.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="HOEnZb"><font color="#888888">
-Sean<br>
<br>
--<br>
Sean Dague<br>
<a href="http://dague.net" target="_blank">http://dague.net</a><br>
</font></span><div class="HOEnZb"><div class="h5"><br>
__________________________________________________________________________<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>