2015-09-22 11:59:47 +01:00
|
|
|
..
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
not use this file except in compliance with the License. You may obtain
|
|
|
|
a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
License for the specific language governing permissions and limitations
|
|
|
|
under the License.
|
|
|
|
|
2015-12-08 10:25:14 +08:00
|
|
|
=============
|
2015-09-22 11:59:47 +01:00
|
|
|
Microversions
|
2015-12-08 10:25:14 +08:00
|
|
|
=============
|
2015-09-22 11:59:47 +01:00
|
|
|
|
2016-01-04 17:16:53 +08:00
|
|
|
API v2.1 supports microversions: small, documented changes to the API. A user
|
|
|
|
can use microversions to discover the latest API microversion supported in
|
|
|
|
their cloud. A cloud that is upgraded to support newer microversions will still
|
|
|
|
support all older microversions to maintain the backward compatibility for
|
|
|
|
those users who depend on older microversions. Users can also discover new
|
|
|
|
features easily with microversions, so that they can benefit from all the
|
|
|
|
advantages and improvements of the current cloud.
|
|
|
|
|
|
|
|
There are multiple cases which you can resolve with microversions:
|
|
|
|
|
2016-01-06 14:34:42 +08:00
|
|
|
- **Older clients with new cloud**
|
2016-01-04 17:16:53 +08:00
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
Before using an old client to talk to a newer cloud, the old client can check
|
|
|
|
the minimum version of microversions to verify whether the cloud is
|
|
|
|
compatible with the old API. This prevents the old client from breaking with
|
|
|
|
backwards incompatible API changes.
|
|
|
|
|
|
|
|
Currently the minimum version of microversions is `2.1`, which is a
|
|
|
|
microversion compatible with the legacy v2 API. That means the legacy v2 API
|
|
|
|
user doesn't need to worry that their older client software will be broken
|
|
|
|
when their cloud is upgraded with new versions. And the cloud operator
|
|
|
|
doesn't need to worry that upgrading their cloud to newer versions will
|
|
|
|
break any user with older clients that don't expect these changes.
|
2016-01-04 17:16:53 +08:00
|
|
|
|
2016-01-06 14:34:42 +08:00
|
|
|
- **User discovery of available features between clouds**
|
2016-01-04 17:16:53 +08:00
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
The new features can be discovered by microversions. The user client should
|
|
|
|
check the microversions firstly, and new features are only enabled when
|
|
|
|
clouds support. In this way, the user client can work with clouds that have
|
|
|
|
deployed different microversions simultaneously.
|
2016-01-06 14:34:42 +08:00
|
|
|
|
|
|
|
Version Discovery
|
|
|
|
=================
|
|
|
|
|
|
|
|
The Version API will return the minimum and maximum microversions. These values
|
|
|
|
are used by the client to discover the API's supported microversion(s).
|
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
Requests to `/` will get version info for all endpoints. A response would look
|
2016-01-06 14:34:42 +08:00
|
|
|
as follows::
|
|
|
|
|
|
|
|
{
|
|
|
|
"versions": [
|
|
|
|
{
|
|
|
|
"id": "v2.0",
|
|
|
|
"links": [
|
|
|
|
{
|
|
|
|
"href": "http://openstack.example.com/v2/",
|
|
|
|
"rel": "self"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"status": "SUPPORTED",
|
|
|
|
"version": "",
|
|
|
|
"min_version": "",
|
|
|
|
"updated": "2011-01-21T11:33:21Z"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": "v2.1",
|
|
|
|
"links": [
|
|
|
|
{
|
|
|
|
"href": "http://openstack.example.com/v2.1/",
|
|
|
|
"rel": "self"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"status": "CURRENT",
|
|
|
|
"version": "2.14",
|
|
|
|
"min_version": "2.1",
|
|
|
|
"updated": "2013-07-23T11:33:21Z"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
``version`` is the maximum microversion, ``min_version`` is the minimum
|
2016-01-06 14:34:42 +08:00
|
|
|
microversion. If the value is the empty string, it means this endpoint doesn't
|
|
|
|
support microversions; it is a legacy v2 API endpoint -- for example, the
|
|
|
|
endpoint `http://openstack.example.com/v2/` in the above sample. The endpoint
|
|
|
|
`http://openstack.example.com/v2.1/` supports microversions; the maximum
|
2018-11-06 17:57:31 +09:00
|
|
|
microversion is `2.14`, and the minimum microversion is `2.1`. The client
|
2016-01-06 14:34:42 +08:00
|
|
|
should specify a microversion between (and including) the minimum and maximum
|
|
|
|
microversion to access the endpoint.
|
|
|
|
|
|
|
|
You can also obtain specific endpoint version information by performing a GET
|
|
|
|
on the base version URL (e.g., `http://openstack.example.com/v2.1/`). You can
|
|
|
|
get more information about the version API at :doc:`versions`.
|
2016-01-06 14:48:15 +08:00
|
|
|
|
|
|
|
Client Interaction
|
|
|
|
==================
|
|
|
|
|
|
|
|
A client specifies the microversion of the API they want by using the following
|
|
|
|
HTTP header::
|
|
|
|
|
|
|
|
X-OpenStack-Nova-API-Version: 2.4
|
|
|
|
|
2016-03-31 17:16:51 +01:00
|
|
|
Starting with microversion `2.27` it is also correct to use the
|
|
|
|
following header to specify the microversion::
|
|
|
|
|
|
|
|
OpenStack-API-Version: compute 2.27
|
|
|
|
|
|
|
|
.. note:: For more detail on this newer form see the `Microversion Specification
|
|
|
|
<http://specs.openstack.org/openstack/api-wg/guidelines/microversion_specification.html>`_.
|
|
|
|
|
2016-01-06 14:48:15 +08:00
|
|
|
This acts conceptually like the "Accept" header. Semantically this means:
|
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
* If neither ``X-OpenStack-Nova-API-Version`` nor ``OpenStack-API-Version``
|
2016-03-31 17:16:51 +01:00
|
|
|
(specifying `compute`) is provided, act as if the minimum supported
|
|
|
|
microversion was specified.
|
2016-01-06 14:48:15 +08:00
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
* If both headers are provided, ``OpenStack-API-Version`` will be preferred.
|
2016-01-06 14:48:15 +08:00
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
* If ``X-OpenStack-Nova-API-Version`` or ``OpenStack-API-Version`` is provided,
|
2016-03-31 17:16:51 +01:00
|
|
|
respond with the API at that microversion. If that's outside of the range
|
|
|
|
of microversions supported, return 406 Not Acceptable.
|
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
* If ``X-OpenStack-Nova-API-Version`` or ``OpenStack-API-Version`` has a value
|
|
|
|
of `latest` (special keyword), act as if maximum was specified.
|
2016-01-06 14:48:15 +08:00
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
.. warning:: The `latest` value is mostly meant for integration testing and
|
2016-01-06 14:48:15 +08:00
|
|
|
would be dangerous to rely on in client code since microversions are not
|
2016-02-03 12:07:53 +05:30
|
|
|
following semver and therefore backward compatibility is not guaranteed.
|
2016-01-06 14:48:15 +08:00
|
|
|
Clients should always require a specific microversion but limit what is
|
|
|
|
acceptable to the microversion range that it understands at the time.
|
|
|
|
|
|
|
|
This means that out of the box, an old client without any knowledge of
|
2016-02-22 02:39:51 +00:00
|
|
|
microversions can work with an OpenStack installation with microversions
|
2016-01-06 14:48:15 +08:00
|
|
|
support.
|
|
|
|
|
2016-03-31 17:16:51 +01:00
|
|
|
In microversions prior to `2.27` two extra headers are always returned in
|
|
|
|
the response::
|
2016-01-06 14:48:15 +08:00
|
|
|
|
2016-03-31 17:16:51 +01:00
|
|
|
X-OpenStack-Nova-API-Version: microversion_number
|
|
|
|
Vary: X-OpenStack-Nova-API-Version
|
2016-01-06 14:48:15 +08:00
|
|
|
|
|
|
|
The first header specifies the microversion number of the API which was
|
|
|
|
executed.
|
|
|
|
|
2018-11-06 17:57:31 +09:00
|
|
|
The ``Vary`` header is used as a hint to caching proxies that the response
|
2016-03-31 17:16:51 +01:00
|
|
|
is also dependent on the microversion and not just the body and query
|
|
|
|
parameters. See :rfc:`2616` section 14.44 for details.
|
|
|
|
|
|
|
|
From microversion `2.27` two additional headers are added to the
|
|
|
|
response::
|
|
|
|
|
|
|
|
OpenStack-API-Version: compute microversion_number
|
|
|
|
Vary: OpenStack-API-Version
|