Trim the release notes to just stein/master
This removes all the releasenotes related to changes already released with nova in rocky and prior. They were carried over into placement as we weren't sure how we were going to manage release notes. In a meeting it was decided that we would start the release notes fresh with "since-extraction". Therefore this change removes all the releasenotes that are already present in nova, keeping anything new. The index.rst file is already set to say "look at nova" for older release notes. Change-Id: If9255212acf21ed69abbed0601c783ad01133f72
This commit is contained in:
parent
0e97f2b9b9
commit
fca086e654
releasenotes/notes
allocation-candidates-limit-37fe5c2ce57daf7f.yamlallocation-candidates-traits-1adf079ed0c6563c.yamlallocation_candidates_support_member_of-92f7e1440ed63fe7.yamlallow-reserved-equal-total-inventory-fe93584dd28c460d.yamlbp-granular-placement-policy-65722fc6d7cb1359.yamlbp-symmetric-allocations-6ff7b270c32dcb7d.yamlbug-1732000-log-options-6db2cc8c747145ca.yamlconsumer_generation-f576ac2594b24e2e.yamldelete-inventories-placement-api-13582910371308c4.yamlidempotent-put-resource-class-dc7a267c823b7995.yamlmulti-member-of-4f9518a96652c0c6.yamlnested-resource-providers-allocation-candidates-66c1c5b0a3e93513.yamlplacement-aggregate-generation-9dad79fb0356fcc0.yamlplacement-allocation-candidates-1114a843755b93c4.yamlplacement-allocations-link-in-get-resource-providers-0b1d26a264eceb4b.yamlplacement-api-endpoint-interface-set-29af8b9400ce7775.yamlplacement-api-member-of-d8a08d0d0c5700d7.yamlplacement-cors-c7a83e8c63787736.yamlplacement-database-2e087f379273535d.yamlplacement-error-code-fcbbf5d45560984e.yamlplacement-forbidden-traits-ace037856aa29a09.yamlplacement-generation-from-create-provider-203a0ac1ebfe64d9.yamlplacement-granular-resource-requests-944f9b73f306429f.yamlplacement-incomplete-consumer-configuration-b775dac1bcd34f9d.yamlplacement-last-modified-cf43aece4c54fc97.yamlplacement-required-traits-on-list-resource-providers-fab11cdb36cd3502.yamlplacement-rest-api-filter-providers-by-resources-0ab51c9766fe654f.yamlplacement-rest-api-nested-resource-providers-552a923a96d7adca.yamlplacement-rest-custom-resource-classes-a3f2175772983b0a.yamlplacement-return-all-resources-bfc7e3f8b5151e28.yamlplacement-traits-api-efa17d46ea1b616b.yamlpost-allocations-427581fa41671820.yaml
@ -1,11 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Add support, in new placement microversion 1.16, for a ``limit`` query
|
||||
parameter when making a ``GET /allocation_candidates`` request. The
|
||||
parameter accepts an integer value, `N`, which limits the number of
|
||||
candidates returned. A new configuration item
|
||||
``[placement]/randomize_allocation_candidates``, defaulting to `False`,
|
||||
controls how the limited results are chosen. If `True`, a random sampling
|
||||
of the entire result set is taken, otherwise the first N results are
|
||||
returned.
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Add ``required`` query parameter to the ``GET /allocation_candidates`` API
|
||||
in new placement microversion 1.17. The parameter accepts a list of traits
|
||||
separated by ``,``, which is used to further limit the list of allocation
|
||||
requests to resource providers that have the capacity to fulfill the
|
||||
requested resources AND *collectively* have all of the required traits
|
||||
associated with them. In the same microversion, the provider summary
|
||||
includes the traits associated with each provider.
|
@ -1,13 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Add support, in a new placement microversion 1.21, for the ``member_of``
|
||||
query parameter, representing one or more aggregate UUIDs. When supplied,
|
||||
it will filter the returned allocation candidates to only those
|
||||
resource_providers that are associated with ("members of") the specified
|
||||
aggregate(s). This parameter can have a value of either a single aggregate
|
||||
UUID, or a comma-separated list of aggregate UUIDs. When specifying more
|
||||
than one aggregate, a resource provider needs to be associated with at
|
||||
least one of the aggregates in order to be included; it does not have to be
|
||||
associated with all of them. Because of this, the list of UUIDs must be
|
||||
prefixed with ``in:`` to represent the logical ``OR`` of the selection.
|
@ -1,6 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Introduces new placement API version ``1.26``. Starting with this version
|
||||
it is allowed to define resource provider inventories with reserved value
|
||||
equal to total.
|
@ -1,31 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
It is now possible to configure granular policy rules for placement
|
||||
REST API operations.
|
||||
|
||||
By default, all operations continue to use the ``role:admin`` check string
|
||||
so there is no upgrade impact.
|
||||
|
||||
A new configuration option is introduced, ``[placement]/policy_file``,
|
||||
which is used to configure the location of the placement policy file.
|
||||
By default, the ``placement-policy.yaml`` file may live alongside the
|
||||
nova policy file, e.g.:
|
||||
|
||||
* /etc/nova/policy.yaml
|
||||
* /etc/nova/placement-policy.yaml
|
||||
|
||||
However, if desired, ``[placement]/policy_file`` makes it possible to
|
||||
package and deploy the placement policy file separately to make the future
|
||||
split of placement and nova packages easier, e.g.:
|
||||
|
||||
* /etc/placement/policy.yaml
|
||||
|
||||
All placement policy rules are defined in code so by default no extra
|
||||
configuration is required and the default rules will be used on start of
|
||||
the placement service.
|
||||
|
||||
For more information about placement policy including a sample file, see
|
||||
the configuration reference documentation:
|
||||
|
||||
https://docs.openstack.org/nova/latest/configuration/index.html#placement-policy
|
@ -1,11 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
The 1.12 version of the placement API changes handling of the `PUT
|
||||
/allocations/{consumer_uuid}` request to use a dict-based structure for
|
||||
the JSON request body to make it more aligned with the response body of
|
||||
`GET /allocations/{consumer_uuid}`. Because `PUT` requires `user_id`
|
||||
and `project_id` in the request body, these fields are added to the
|
||||
`GET` response. In addition, the response body for
|
||||
``GET /allocation_candidates`` is updated so the allocations in the
|
||||
``allocation_requests`` object work with the new `PUT` format.
|
@ -1,7 +0,0 @@
|
||||
---
|
||||
fixes:
|
||||
- |
|
||||
The ``[DEFAULT]/log_options`` configuration option can be used to log
|
||||
configuration options at DEBUG level when the `placement-api` and/or
|
||||
`nova-api` services are started under WSGI. The default behavior is to
|
||||
log options on startup.
|
@ -1,18 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Adds a new ``generation`` column to the consumers table. This value is
|
||||
incremented every time allocations are made for a consumer. The new
|
||||
placement microversion 1.28 requires that all ``POST /allocations`` and
|
||||
``PUT /allocations/{consumer_uuid}`` requests now include the
|
||||
``consumer_generation`` parameter to ensure that if two processes are
|
||||
allocating resources for the same consumer, the second one to complete
|
||||
doesn't overwrite the first. If there is a mismatch between the
|
||||
``consumer_generation`` in the request and the current value in the
|
||||
database, the allocation will fail, and a 409 Conflict response will be
|
||||
returned. The calling process must then get the allocations for that
|
||||
consumer by calling ``GET /allocations/{consumer}``. That response will now
|
||||
contain, in addition to the allocations, the current generation value for
|
||||
that consumer. Depending on the use case, the calling process may error; or
|
||||
it may wish to combine or replace the existing allocations with the ones it
|
||||
is trying to post, and re-submit with the current consumer_generation.
|
@ -1,18 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Supports a new method for deleting all inventory for a
|
||||
resource provider
|
||||
|
||||
* DELETE /resource-providers/{uuid}/inventories
|
||||
|
||||
Return codes
|
||||
|
||||
* 204 NoContent on success
|
||||
* 404 NotFound for missing resource provider
|
||||
* 405 MethodNotAllowed if a microversion is specified that is before
|
||||
this change (1.5)
|
||||
* 409 Conflict if inventory in use or if some other request concurrently
|
||||
updates this resource provider
|
||||
|
||||
Requires OpenStack-API-Version placement 1.5
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
The 1.7 version of the placement API changes handling of
|
||||
`PUT /resource_classes/{name}` to be a create or verification of the
|
||||
resource class with `{name}`. If the resource class is a custom resource
|
||||
class and does not already exist it will be created and a ``201`` response
|
||||
code returned. If the class already exists the response code will be
|
||||
``204``. This makes it possible to check or create a resource class in one
|
||||
request.
|
@ -1,20 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new 1.24 placement API microversion adds the ability to specify multiple
|
||||
`member_of` query parameters for the `GET /resource_providers` and `GET
|
||||
allocation_candidates` endpoints.
|
||||
When multiple `member_of` query parameters are received, the placement
|
||||
service will return resource providers that match all of the requested
|
||||
aggregate memberships. The `member_of=in:<agg uuids>` format is still
|
||||
supported and continues to indicate an IN() operation for aggregate
|
||||
membership. Some examples for using the new functionality:
|
||||
Get all providers that are associated with BOTH agg1 and agg2:
|
||||
?member_of=agg1&member_of=agg2
|
||||
Get all providers that are associated with agg1 OR agg2:
|
||||
?member_of=in:agg1,agg2
|
||||
Get all providers that are associated with agg1 and ANY OF (agg2, agg3):
|
||||
?member_of=agg1&member_of=in:agg2,agg3
|
||||
Get all providers that are associated with ANY OF (agg1, agg2) AND are also
|
||||
associated with ANY OF (agg3, agg4):
|
||||
?member_of=in:agg1,agg2&member_of=in:agg3,agg4
|
@ -1,11 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
From microversion 1.29, we support allocation candidates with nested
|
||||
resource providers. Namely, the following features are added.
|
||||
1) ``GET /allocation_candidates`` is aware of nested providers. Namely,
|
||||
when provider trees are present, ``allocation_requests`` in the response
|
||||
of ``GET /allocation_candidates`` can include allocations on combinations
|
||||
of multiple resource providers in the same tree.
|
||||
2) ``root_provider_uuid`` and ``parent_provider_uuid`` are added to
|
||||
``provider_summaries`` in the response of ``GET /allocation_candidates``.
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Placement API microversion 1.19 enhances the payloads for the
|
||||
`GET /resource_providers/{uuid}/aggregates` response and the
|
||||
`PUT /resource_providers/{uuid}/aggregates` request and response to be
|
||||
identical, and to include the ``resource_provider_generation``. As with
|
||||
other generation-aware APIs, if the ``resource_provider_generation``
|
||||
specified in the `PUT` request does not match the generation known by the
|
||||
server, a 409 Conflict error is returned.
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new 1.10 API microversion is added to the Placement REST API. This
|
||||
microversion adds support for the GET /allocation_candidates resource
|
||||
endpoint. This endpoint returns information about possible allocation
|
||||
requests that callers can make which meet a set of resource constraints
|
||||
supplied as query string parameters. Also returned is some inventory and
|
||||
capacity information for the resource providers involved in the allocation
|
||||
candidates.
|
@ -1,6 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new 1.11 API microversion is added to the Placement REST API. This adds
|
||||
the ``resource_providers/{rp_uuid}/allocations`` link to the ``links``
|
||||
section of the response from ``GET /resource_providers``.
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
other:
|
||||
- The Placement API can be set to connect to a specific
|
||||
keystone endpoint interface using the ``os_interface``
|
||||
option in the ``[placement]`` section inside ``nova.conf``.
|
||||
This value is not required but can be used if a non-default
|
||||
endpoint interface is desired for connecting to the Placement
|
||||
service. By default, keystoneauth will connect to the "public"
|
||||
endpoint.
|
@ -1,14 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new Placement API microversion 1.3 is added with support for filtering
|
||||
the list of resource providers to include only those resource providers
|
||||
which are members of any of the aggregates listed by uuid in the `member_of`
|
||||
query parameter. The parameter is used when making a
|
||||
`GET /resource_providers` request. The value of the parameter uses the
|
||||
`in:` syntax to provide a list of aggregate uuids as follows::
|
||||
|
||||
/resource_providers?member_of=in:09c931b0-c0d7-4e80-8e01-9e6511db8259,f8ab4fa2-804f-402e-b675-7918bd04b173
|
||||
|
||||
If other filtering query parameters are present, the results are a boolean
|
||||
AND of all the filters.
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
The placement API service can now be configured to support
|
||||
`CORS <http://docs.openstack.org/developer/oslo.middleware/cors.html>`_.
|
||||
If a `cors` configuration group is present in the service's configuration
|
||||
file (currently `nova.conf`), with `allowed_origin` configured, the values
|
||||
within will be used to configure the middleware. If `cors.allowed_origin`
|
||||
is not set, the middleware will not be used.
|
@ -1,24 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
An optional configuration group ``placement_database`` can be used in
|
||||
nova.conf to configure a separate database for use with the placement
|
||||
API.
|
||||
|
||||
If ``placement_database.connection`` has a value then the
|
||||
``placement_database`` configuration group will be used to configure a
|
||||
separate placement database, including using ``connection`` to identify the
|
||||
target database. That database will have a schema that is a replica of all
|
||||
the tables used in the API database. The new database schema will be
|
||||
created and synchronized when the ``nova-manage api_db sync`` command is
|
||||
run.
|
||||
|
||||
When the ``placement_database.connection`` setting is omitted the existing
|
||||
settings for the ``api_database`` will be used for hosting placement data.
|
||||
|
||||
Setting ``placement_database.connection`` and calling
|
||||
``nova-manage api_db sync`` will only create tables. No data will be
|
||||
migrated. In an existing OpenStack deployment, if there is existing
|
||||
placement data in the ``nova_api`` database this will not be copied. It is
|
||||
up to the deployment to manually replicate that data in a fashion that
|
||||
works best for the environment.
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
In microversion 1.23 of the placement service, JSON formatted error
|
||||
responses gain a new attribute, ``code``, with a value that identifies the
|
||||
type of this error. This can be used to distinguish errors that are
|
||||
different but use the same HTTP status code. Any error response which does
|
||||
not specifically define a code will have the code
|
||||
``placement.undefined_code``.
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Placement microversion '1.22' adds support for expressing traits which are
|
||||
forbidden when filtering ``GET /resource_providers`` or ``GET
|
||||
/allocation_candidates``. A forbidden trait is a properly formatted trait
|
||||
in the existing ``required`` parameter, prefixed by a ``!``. For example
|
||||
``required=!STORAGE_DISK_SSD`` asks that the results not include any
|
||||
resource providers that provide solid state disk.
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
In placement API microversion 1.20, a successful `POST /resource_providers`
|
||||
returns 200 with a payload representing the newly-created resource
|
||||
provider. The format is the same format as the result of the corresponding
|
||||
``GET /resource_providers/{uuid}`` call. This is to allow the caller to
|
||||
glean automatically-set fields, such as UUID and generation, without a
|
||||
subsequent GET.
|
@ -1,31 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
In version 1.25 of the Placement API, ``GET /allocation_candidates`` is
|
||||
enhanced to accept numbered groupings of resource, required/forbidden
|
||||
trait, and aggregate association requests. A ``resources`` query parameter
|
||||
key with a positive integer suffix (e.g. ``resources42``) will be logically
|
||||
associated with ``required`` and/or ``member_of`` query parameter keys with
|
||||
the same suffix (e.g. ``required42``, ``member_of42``). The resources,
|
||||
required/forbidden traits, and aggregate associations in that group will be
|
||||
satisfied by the same resource provider in the response. When more than one
|
||||
numbered grouping is supplied, the ``group_policy`` query parameter is
|
||||
required to indicate how the groups should interact. With
|
||||
``group_policy=none``, separate groupings - numbered or unnumbered - may or
|
||||
may not be satisfied by the same provider. With ``group_policy=isolate``,
|
||||
numbered groups are guaranteed to be satisfied by *different* providers -
|
||||
though there may still be overlap with the unnumbered group. In all cases,
|
||||
each ``allocation_request`` will be satisfied by providers in a single
|
||||
non-sharing provider tree and/or sharing providers associated via aggregate
|
||||
with any of the providers in that tree.
|
||||
|
||||
The ``required`` and ``member_of`` query parameters for a given group are
|
||||
optional. That is, you may specify ``resources42=XXX`` without a
|
||||
corresponding ``required42=YYY`` or ``member_of42=ZZZ``. However, the
|
||||
reverse (specifying ``required42=YYY`` or ``member_of42=ZZZ`` without
|
||||
``resources42=XXX``) will result in an error.
|
||||
|
||||
The semantic of the (unnumbered) ``resources``, ``required``, and
|
||||
``member_of`` query parameters is unchanged: the resources, traits, and
|
||||
aggregate associations specified thereby may be satisfied by any provider
|
||||
in the same non-sharing tree or associated via the specified aggregate(s).
|
@ -1,11 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Prior to microversion 1.8 of the placement API, one could create
|
||||
allocations and not supply a project or user ID for the consumer of the
|
||||
allocated resources. While this is no longer allowed after placement API
|
||||
1.8, older allocations exist and we now ensure that a consumer record is
|
||||
created for these older allocations. Use the two new CONF options
|
||||
``CONF.placement.incomplete_consumer_project_id`` and
|
||||
``CONF.placement.incomplete_consumer_user_id`` to control the project and
|
||||
user identifiers that are written for these incomplete consumer records.
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Throughout the Placement API, in microversion 1.15, 'last-modified' headers
|
||||
have been added to GET responses and those PUT and POST responses that have
|
||||
bodies. The value is either the actual last modified time of the most
|
||||
recently modified associated database entity or the current time if there
|
||||
is no direct mapping to the database. In addition,
|
||||
'cache-control: no-cache' headers are added where the 'last-modified'
|
||||
header has been added to prevent inadvertent caching of resources.
|
@ -1,12 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Placement API microversion 1.18 adds support for the `required` query
|
||||
parameter to the `GET /resource_providers` API. It accepts a
|
||||
comma-separated list of string trait names. When specified, the API
|
||||
results will be filtered to include only resource providers marked with
|
||||
all the specified traits. This is in addition to (logical AND) any
|
||||
filtering based on other query parameters.
|
||||
|
||||
Trait names which are empty, do not exist, or are otherwise invalid will
|
||||
result in a 400 error.
|
@ -1,19 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new Placement API microversion 1.4 is added. Users may now query the
|
||||
Placement REST API for resource providers that have the ability to meet a
|
||||
set of requested resource amounts. The `GET /resource_providers` API call
|
||||
can have a "resources" query string parameter supplied that indicates the
|
||||
requested amounts of various resources that a provider must have the
|
||||
capacity to serve. The "resources" query string parameter takes the form:
|
||||
|
||||
``?resources=$RESOURCE_CLASS_NAME:$AMOUNT,$RESOURCE_CLASS_NAME:$AMOUNT``
|
||||
|
||||
For instance, if the user wishes to see resource providers that can service
|
||||
a request for 2 vCPUs, 1024 MB of RAM and 50 GB of disk space, the user can
|
||||
issue a request of::
|
||||
|
||||
``GET /resource_providers?resources=VCPU:2,MEMORY_MB:1024,DISK_GB:50``
|
||||
|
||||
The placement API is only available to admin users.
|
@ -1,13 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- New placement REST API microversion 1.14 is added to support nested
|
||||
resource providers. Users of the placement REST API can now pass a
|
||||
``in_tree=<UUID>`` parameter to the ``GET /resource_providers`` REST API
|
||||
call. This will trigger the placement service to return all resource
|
||||
provider records within the "provider tree" of the resource provider with
|
||||
the supplied UUID value. The resource provider representation now includes
|
||||
a ``parent_provider_uuid`` value that indicates the UUID of the immediate
|
||||
parent resource provider, or ``null`` if the provider has no parent. For
|
||||
convenience, the resource provider resource also contains a
|
||||
``root_provider_uuid`` field that is populated with the UUID of the
|
||||
top-most resource provider in the provider tree.
|
@ -1,10 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
A new administrator-only resource endpoint was added to the OpenStack
|
||||
Placement REST API for managing custom resource classes. Custom resource
|
||||
classes are specific to a deployment and represent types of quantitative
|
||||
resources that are not interoperable between OpenStack clouds. See the
|
||||
`Placement REST API Version History`_ documentation for usage details.
|
||||
|
||||
.. _Placement REST API Version History: http://docs.openstack.org/developer/nova/placement.html#id2
|
@ -1,9 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
From microversion 1.27, the ``provider_summaries`` field in the
|
||||
response of the ``GET /allocation_candidates`` API includes all
|
||||
the resource class inventories, while it had only requested
|
||||
resource class inventories with older microversions.
|
||||
Now callers can use this additional inventory information in
|
||||
making further sorting or filtering decisions.
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Traits are added to the placement with Microversion 1.6.
|
||||
|
||||
* GET /traits: Returns all resource classes.
|
||||
* PUT /traits/{name}: To insert a single custom trait.
|
||||
* GET /traits/{name}: To check if a trait name exists.
|
||||
* DELETE /traits/{name}: To delete the specified trait.
|
||||
* GET /resource_providers/{uuid}/traits: a list of traits associated
|
||||
with a specific resource provider
|
||||
* PUT /resource_providers/{uuid}/traits: Set all the traits for a
|
||||
specific resource provider
|
||||
* DELETE /resource_providers/{uuid}/traits: Remove any existing trait
|
||||
associations for a specific resource provider
|
@ -1,6 +0,0 @@
|
||||
---
|
||||
features:
|
||||
- |
|
||||
Microversion 1.13 of the Placement API gives the ability to set or clear
|
||||
allocations for more than one consumer uuid with a request to
|
||||
``POST /allocations``.
|
Loading…
x
Reference in New Issue
Block a user