Add default types info in admin docs

This patch adds information about default volume types i.e. project
default and deployment default (set via default_volume_type in cinder.conf)
and also regarding __DEFAULT__ type.

Change-Id: I47151b621003aea04082d38bd1d5cc911afab0f4
This commit is contained in:
whoami-rajat 2021-11-19 05:08:06 -05:00
parent ba28f29254
commit 104e3e049d
3 changed files with 75 additions and 2 deletions

View File

@ -419,8 +419,9 @@ operator, in a `Create a volume`_ request. If you wish to create a volume of
*Note to operators:* The ``__DEFAULT__`` volume type was introduced in *Note to operators:* The ``__DEFAULT__`` volume type was introduced in
the Train release as a placeholder to prevent the creation of untyped the Train release as a placeholder to prevent the creation of untyped
volumes. Under the proper conditions, it may be removed from your volumes. Under the proper conditions, it may be removed from your
deployment. Consult the `Train series release notes deployment. Consult the Default Volume Types section in
<https://docs.openstack.org/releasenotes/cinder/train.html#other-notes>`_ `Cinder Administration Guide
<https://docs.openstack.org/cinder/latest/admin/index.html>`_
for details. for details.
Response codes Response codes

View File

@ -0,0 +1,71 @@
====================
Default Volume Types
====================
Beginning with the Train release, untyped volumes (that is, volumes with no
volume-type) have been disallowed. To facilitate this, a ``__DEFAULT__``
volume-type was included as part of the Train database migration.
Since the Train release, handling of the default volume-type has been
improved:
- The default_volume_type configuration option is required to have a value.
The default value is ``__DEFAULT__``.
- A request to delete the currently configured default_volume_type will fail.
(You can delete that volume-type, but you cannot do it while it is the value
of the configuration option.)
- There must always be at least one volume-type defined in a Cinder
installation. This is enforced by the type-delete call.
- If the default_volume_type is misconfigured (that is, if the value refers to
a non-existent volume-type), requests that rely on the default volume-type
(for example, a volume-create request that does not specify a volume-type)
will result in a HTTP 500 response.
Default types per project
-------------------------
We have overriden the existing Cinder default Volume Type on a per project
basis to make it easier to manage complex deployments.
With the introduction of this new default volume type support, well now
have 2 different default volume types. From more specific to more generic these
are:
- Per project
- Defined in cinder.conf (defaults to ``__DEFAULT__`` type)
So when a user creates a new volume that has no defined volume type
(explicit or in the source), Cinder will look for the appropriate default
first by checking if theres one defined in the DB for the specific project
and use it, if there isnt one, it will continue like it does today,
using the default type from cinder.conf.
Administrators and users must still be careful with the normal Cinder behavior
when creating volumes, as Cinder will still only resort to using the default
volume type if the user doesnt select one on the request or if theres no
volume type in the source, which means that Cinder will not use any of those
defaults if we:
- Create a volume providing a volume type
- Create a volume from a snapshot
- Clone a volume
- Create a volume from an image that has cinder_img_volume_type defined in its
metadata.
There is a new set of commands in the python-cinderclient to match the new
REST API endpoints:
- Set default: ``cinder default-type-set <project-id> <type-name>``
- Unset default: ``cinder default-type-unset <project-id>``
- List defaults: ``cinder default-type-list [--project <project-id>]``
By default the policy restricting access to set, unset, get or list all
project default volume type is set to admins only.

View File

@ -52,6 +52,7 @@ Amazon EC2 Elastic Block Storage (EBS) offering.
blockstorage-volume-migration.rst blockstorage-volume-migration.rst
blockstorage-volume-multiattach.rst blockstorage-volume-multiattach.rst
blockstorage-volume-number-weigher.rst blockstorage-volume-number-weigher.rst
blockstorage-default-volume-types.rst
.. _`Storage Decisions`: https://docs.openstack.org/arch-design/design-storage/design-storage-arch.html .. _`Storage Decisions`: https://docs.openstack.org/arch-design/design-storage/design-storage-arch.html
.. _`OpenStack Operations Guide`: https://wiki.openstack.org/wiki/OpsGuide .. _`OpenStack Operations Guide`: https://wiki.openstack.org/wiki/OpsGuide