Add 'vhdx' disk format.

This patch adds the Hyper-V 'vhdx' disk format to the Glance
configuration. This allows users to upload 'vhdx' images by default.

'vhdx' disks can have much larger storage capacity than the older 'vhd'
format [1].  (Plus, anything with 'x' in the name is awesome.)

DocImpact: Docs will need to be updated to indicate that the 'vhdx'
disk_format is now one of the default disk formats supported by Glance.

UpgradeImpact: Adds 'vhdx' to the default list of disk_formats.  Operators
will no longer need to configure specifically to use 'vhdx' disks.

[1] https://technet.microsoft.com/en-us/library/hh831446(v=ws.11).aspx

Spec-Lite: https://review.openstack.org/#/c/347626
Change-Id: I4e172c78d7afeb8be5a0123238efe3d8e4b044c9
This commit is contained in:
Stuart McLaren 2016-07-26 12:29:37 +00:00 committed by Nikhil Komawar
parent 1af46fe933
commit fc0b47beb6
8 changed files with 27 additions and 10 deletions

View File

@ -41,6 +41,11 @@ You can set your image's disk format to one of the following:
This is the VHD disk format, a common disk format used by virtual machine This is the VHD disk format, a common disk format used by virtual machine
monitors from VMWare, Xen, Microsoft, VirtualBox, and others monitors from VMWare, Xen, Microsoft, VirtualBox, and others
* **vhdx**
This is the VHDX disk format, an enhanced version of the vhd format which
supports larger disk sizes among other features.
* **vmdk** * **vmdk**
Another common disk format supported by many common virtual machine monitors Another common disk format supported by many common virtual machine monitors

View File

@ -510,8 +510,8 @@ The list of metadata headers that Glance accepts are listed below.
* ``x-image-meta-disk_format`` * ``x-image-meta-disk_format``
This header is required, unless reserving an image. Valid values are one of This header is required, unless reserving an image. Valid values are one of
``aki``, ``ari``, ``ami``, ``raw``, ``iso``, ``vhd``, ``vdi``, ``qcow2``, or ``aki``, ``ari``, ``ami``, ``raw``, ``iso``, ``vhd``, ``vhdx``, ``vdi``,
``vmdk``. ``qcow2``, or ``vmdk``.
For more information, see :doc:`About Disk and Container Formats <formats>`. For more information, see :doc:`About Disk and Container Formats <formats>`.

View File

@ -1105,7 +1105,7 @@
# Supported values for the 'disk_format' image attribute (list value) # Supported values for the 'disk_format' image attribute (list value)
# Deprecated group/name - [DEFAULT]/disk_formats # Deprecated group/name - [DEFAULT]/disk_formats
#disk_formats = ami,ari,aki,vhd,vmdk,raw,qcow2,vdi,iso #disk_formats = ami,ari,aki,vhd,vhdx,vmdk,raw,qcow2,vdi,iso
[keystone_authtoken] [keystone_authtoken]

View File

@ -48,8 +48,8 @@ image_format_opts = [
deprecated_opts=[cfg.DeprecatedOpt('container_formats', deprecated_opts=[cfg.DeprecatedOpt('container_formats',
group='DEFAULT')]), group='DEFAULT')]),
cfg.ListOpt('disk_formats', cfg.ListOpt('disk_formats',
default=['ami', 'ari', 'aki', 'vhd', 'vmdk', 'raw', 'qcow2', default=['ami', 'ari', 'aki', 'vhd', 'vhdx', 'vmdk', 'raw',
'vdi', 'iso'], 'qcow2', 'vdi', 'iso'],
help=_("Supported values for the 'disk_format' " help=_("Supported values for the 'disk_format' "
"image attribute"), "image attribute"),
deprecated_opts=[cfg.DeprecatedOpt('disk_formats', deprecated_opts=[cfg.DeprecatedOpt('disk_formats',

View File

@ -21,8 +21,9 @@ class ImageAsAnArtifact(definitions.ArtifactType):
file = definitions.BinaryObject(required=True) file = definitions.BinaryObject(required=True)
disk_format = definitions.String(allowed_values=['ami', 'ari', 'aki', disk_format = definitions.String(allowed_values=['ami', 'ari', 'aki',
'vhd', 'vmdk', 'raw', 'vhd', 'vhdx', 'vmdk',
'qcow2', 'vdi', 'iso'], 'raw', 'qcow2', 'vdi',
'iso'],
required=True, required=True,
mutable=False) mutable=False)
container_format = definitions.String(allowed_values=['ami', 'ari', container_format = definitions.String(allowed_values=['ami', 'ari',

View File

@ -3726,8 +3726,8 @@ class TestImagesSerializerDirectUrl(test_utils.BaseTestCase):
class TestImageSchemaFormatConfiguration(test_utils.BaseTestCase): class TestImageSchemaFormatConfiguration(test_utils.BaseTestCase):
def test_default_disk_formats(self): def test_default_disk_formats(self):
schema = glance.api.v2.images.get_schema() schema = glance.api.v2.images.get_schema()
expected = [None, 'ami', 'ari', 'aki', 'vhd', 'vmdk', 'raw', 'qcow2', expected = [None, 'ami', 'ari', 'aki', 'vhd', 'vhdx', 'vmdk',
'vdi', 'iso'] 'raw', 'qcow2', 'vdi', 'iso']
actual = schema.properties['disk_format']['enum'] actual = schema.properties['disk_format']['enum']
self.assertEqual(expected, actual) self.assertEqual(expected, actual)

View File

@ -42,7 +42,7 @@ class GlancePlugin(scenario.OpenStackScenario):
Acceptable formats: ami, ari, aki, bare, ovf, and docker. Acceptable formats: ami, ari, aki, bare, ovf, and docker.
:param image_location: image file location used to upload :param image_location: image file location used to upload
:param disk_format: Disk format of image. Acceptable formats: :param disk_format: Disk format of image. Acceptable formats:
ami, ari, aki, vhd, vmdk, raw, qcow2, vdi, and iso. ami, ari, aki, vhd, vhdx, vmdk, raw, qcow2, vdi, and iso.
:param **kwargs: optional parameters to create image :param **kwargs: optional parameters to create image
returns: object of image returns: object of image

View File

@ -0,0 +1,11 @@
---
prelude: >
- Add VHDX to list of supported disk format.
features:
- The identifier ``vhdx`` has been added to the list of
supported disk formats in Glance. The respective
configuration option has been updated and the default
list shows ``vhdx`` as a supported format.
upgrade:
- The ``disk_format`` config option enables ``vhdx`` as
supported by default.