/nova-docker

Docker driver for OpenStack Nova

Primary LanguagePythonApache License 2.0Apache-2.0

nova-docker

Docker driver for OpenStack Nova.

Free software: Apache license

Installation & Configuration

1. Install the python modules.

For example:

$ python setup.py install

Note: There are better and cleaner ways of managing Python modules, such as using distribution packages or 'pip'. The setup.py file and Debian's stdeb, for instance, may be used to create Debian/Ubuntu packages.

2. Enable the driver in Nova's configuration

In nova.conf:

compute_driver=novadocker.virt.docker.DockerDriver

3. Optionally tune site-specific settings.

In nova.conf:

[docker]
# Commented out. Uncomment these if you'd like to customize:
## vif_driver=novadocker.virt.docker.vifs.DockerGenericVIFDriver
## snapshots_directory=/var/tmp/my-snapshot-tempdir

Uploading Images to Glance

1. Enable the driver in Glance's configuration

In glance-api.conf:

container_formats=ami,ari,aki,bare,ovf,ova,docker

2. Save docker images to Glance

Images may now be saved directly to Glance:

$ docker pull busybox
$ docker save busybox | openstack image create busybox --public --container-format docker --disk-format raw

Note: At present, only administrators should be allowed to manage images. With devstack you can make yourself administrator by sourcing openrc as:

source openrc admin

Once done you can go back to a user:

source openrc demo

The name of the image in Glance should be explicitly set to the same name as the image as it is known to Docker. In the example above, an image has been tagged in Docker as 'busybox'. Matching this is the '--name busybox' argument to glance image-create. If these names do not align, the image will not be bootable.

Note: There should be a long lived process running in the docker image, otherwise the instance will not be able to spawn successfully. This can be done by using CMD or ENTRYPOINT in DockerFile:

https://docs.docker.com/reference/builder/

or specifing the command through glance image property 'os_command_line' for test:

glance image-update --property os_command_line='/usr/sbin/sshd -D' $IMAGE_ID

3. Generate a keypair

You can optionally create a keypair to use in your docker images:

nova keypair-add mykey > mykey.pem

4. Start a container

Start a new container. This uses the key created above:

nova boot --flavor m1.small --image busybox --key-name mykey test1

5. ssh into container

You can check the IP address of the container by using:

nova list

And then ssh into it:

ssh -i ../devstack/mykey.pem cirros@<IP ADDRESS>

Notes

  • Earlier releases of this driver required the deployment of a private docker registry. This is no longer required. Images are now saved and loaded from Glance.
  • Images loaded from Glance may do bad things. Only allow administrators to add images. Users may create snapshots of their containers, generating images in Glance -- these images are managed and thus safe.

Contact Us

Join us in #nova-docker on Freenode IRC

Features

  • TODO