Add the Docker container format

A Docker image is a tar archive typically containing a container
filesystem. In order to use the nova-docker compute driver nova and boot
docker instances glance support of the docker container format is
required.

This patch adds the Docker container format to the Glance configuration.

DocImpact: Docs will need to be updated to indicate that the docker
container_format is now one of the default container formats supported
by Glance.

UpgradeImpact: Adds 'docker' to the default list of container_formats.
Operators will no longer need to configure specifically to use docker
containers.

Closes-Bug: #1519402
Change-Id: Ifa206686086232a5599e7bc27a852bc5f3186ebc
This commit is contained in:
Dave McNally 2015-11-24 15:48:20 +00:00
parent e3b8753d27
commit f666e5f5e6
7 changed files with 12 additions and 6 deletions

View File

@ -106,3 +106,8 @@ You can set your image's container format to one of the following:
* **ova** * **ova**
This indicates what is stored in Glance is an OVA tar archive file This indicates what is stored in Glance is an OVA tar archive file
* **docker**
This indicates what is stored in Glance is a Docker tar archive of
the container filesystem

View File

@ -427,7 +427,7 @@ The list of metadata headers that Glance accepts are listed below.
* ``x-image-meta-container_format`` * ``x-image-meta-container_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``, ``bare``, or ``ovf``. ``aki``, ``ari``, ``ami``, ``bare``, ``ovf``, or ``docker``.
For more information, see :doc:`About Disk and Container Formats <formats>`. For more information, see :doc:`About Disk and Container Formats <formats>`.

View File

@ -963,7 +963,7 @@
# Supported values for the 'container_format' image attribute (list # Supported values for the 'container_format' image attribute (list
# value) # value)
# Deprecated group/name - [DEFAULT]/container_formats # Deprecated group/name - [DEFAULT]/container_formats
#container_formats = ami,ari,aki,bare,ovf,ova #container_formats = ami,ari,aki,bare,ovf,ova,docker
# 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

View File

@ -45,7 +45,7 @@ paste_deploy_opts = [
] ]
image_format_opts = [ image_format_opts = [
cfg.ListOpt('container_formats', cfg.ListOpt('container_formats',
default=['ami', 'ari', 'aki', 'bare', 'ovf', 'ova'], default=['ami', 'ari', 'aki', 'bare', 'ovf', 'ova', 'docker'],
help=_("Supported values for the 'container_format' " help=_("Supported values for the 'container_format' "
"image attribute"), "image attribute"),
deprecated_opts=[cfg.DeprecatedOpt('container_formats', deprecated_opts=[cfg.DeprecatedOpt('container_formats',

View File

@ -27,7 +27,8 @@ class ImageAsAnArtifact(definitions.ArtifactType):
mutable=False) mutable=False)
container_format = definitions.String(allowed_values=['ami', 'ari', container_format = definitions.String(allowed_values=['ami', 'ari',
'aki', 'bare', 'aki', 'bare',
'ovf', 'ova'], 'ovf', 'ova',
'docker'],
required=True, required=True,
mutable=False) mutable=False)
min_disk = definitions.Integer(min_value=0, default=0) min_disk = definitions.Integer(min_value=0, default=0)

View File

@ -3755,7 +3755,7 @@ class TestImageSchemaFormatConfiguration(test_utils.BaseTestCase):
def test_default_container_formats(self): def test_default_container_formats(self):
schema = glance.api.v2.images.get_schema() schema = glance.api.v2.images.get_schema()
expected = [None, 'ami', 'ari', 'aki', 'bare', 'ovf', 'ova'] expected = [None, 'ami', 'ari', 'aki', 'bare', 'ovf', 'ova', 'docker']
actual = schema.properties['container_format']['enum'] actual = schema.properties['container_format']['enum']
self.assertEqual(expected, actual) self.assertEqual(expected, actual)

View File

@ -39,7 +39,7 @@ class GlancePlugin(scenario.OpenStackScenario):
:param image_name: String used to name the image :param image_name: String used to name the image
:param container_format: Container format of image. :param container_format: Container format of image.
Acceptable formats: ami, ari, aki, bare, and ovf. 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, vmdk, raw, qcow2, vdi, and iso.