5. Creating, Uploading & Sharing virtual machine images
CSC provides a set of standard images that are well suited for cloud use. In most cases you can use these images instead of creating your own. These images are created automatically using a tool called diskimage-builder. If you are interested in the details about how these images are created, see this GitHub page. These images are updated at regular intervals so that they contain the latest security updates at the time virtual machines are launched.
It is possible that for some use cases the automatically created images are not suitable. In this case it is possible to create your own images and use them instead. However, there are some caveats that you need to consider when creating your own images that you would not need to consider when using the default images. This page documents some of these caveats and gives instructions on how to upload your own virtual machine images to Pouta clouds (cPouta/ePouta).
There are two different options for creating new virtual machine images: creating the image from scratch or launching a virtual machine based on an existing image, making modifications on the running machine and saving the changes as a new image by creating a snapshot.
5.1.1 Creating an image based on an existing image
Launch a virtual machine using one of the available images either through the Horizon web interface or through the command line interface. Here is the command for launching an instance from the command line:
openstack server create --flavor <flavor> \ --image <image uuid> \ --key-name <key name> \ --nic net-id=<name of network> \ --security-group default \ --security-group <additional security group> <name of server>
Login and make any necessary changes. To ensure consistent snapshots, snapshots should only be created from instances which are powered off. First power off your instance.
openstack server stop <name of vm>
Then create a snapshot of the machine's current state:
openstack server image create --name <name of snapshot to create> <name of vm>
It will take a little time to create the snapshot. Once it's finished, it will appear as a new image. If you need the original instance you can power it on after the snapshot has been created.
openstack server start <name of vm>
In the web UI under Compute | Instances, the instance specific Create Snapshot -menu items work for the same effect as the above CLI command. The snapshots created will appear in the Compute | Images section.
5.1.2 Creating an image from scratch
There are a number of tools for creating images from scratch. These tools can be categorized into tools that involve running an operating system install in a virtual machine for setting up the image and tools that take a base image and make modifications to it without running a virtual machine. We will call these "Installation based tools" and "Base image tools".
|Installation based tools||Base image tools|
|Pros|| || |
|Cons|| || |
|Examples||virt-install, virt-manager, VirtualBox||diskimage-builder, virt-builder|
The generic workflow when using installation based tools is as follows:
- Obtain an installation media or a network installation link
- Start a virtual machine and point it to the installation media or network installation link
- Go through the installer
- This step can optionally be automated using e.g. Kickstart
- After the installation is finished, shut down VM and use additional tools to prepare the image for cloud use
The generic workflow when using base image tools is as follows:
- Optionally customize configuration files that are used to generate the final image
- Determine suitable customization parameters
- Run a command to generate the final image
You can get more information about creating images in the very thorough "OpenStack virtual machine image guide". In particular, see chapters on creating images manually and tool support for creating images.
188.8.131.52 Caveats to keep in mind when creating images from scratch
These caveats usually only need to be considered when using installation based methods of image creation. The tools that use base images are usually specifically designed to create images for clouds, so they take care of these caveats for you. If you decide to use an installation based method of image creation, you should look into the excellent virt-sysprep tool that will take care of most modifications necessary for cloud use with a single command line command. This chapter lists some of the caveats that need to be handled before an image is ready for clouds.
There is a tool called cloud-init that must be installed on any images that are to be used in Pouta clouds. It is used for certain tasks that need to be run when a virtual machine first boots up like generating SSH host keys and adding user SSH public keys.
User accounts (can be done with virt-sysprep)
Cloud images should only have a minimal set of user accounts. Most likely they should only have one regular generic user account (e.g. "cloud-user" on the default images provided by CSC) and the root user account.
SSH host keys (can be done with virt-sysprep)
Images used in the cloud must not contain any SSH host keys, as having them in the image would mean that every server launched using the image would have the same identity from the point of view of SSH. It is also a security risk, as anyone with access to the image file would be able to personate any server launched using that image file. Fresh SSH host keys need to be generated by cloud-init (see above) when a virtual machine first boots up.
Network interface ordering (can be done with virt-sysprep)
The udev device manager in the Linux kernel has a function that it pins a specific network interface name to a specific MAC address. This is not good if several virtual machines are to be created from an image, as all the virtual machines will have different MAC addresses. It is also not good if you create a snapshot out of a virtual machine and try to use that snapshot to launch a virtual machine, as it will remember the MAC address of the old virtual machine that was used to create the snapshot. The best way to do this is to use virt-sysprep.
When partitioning a Linux image, you should make sure the root partition is the first and only partition. During the virtual machine bootup process, OpenStack will insert SSH keys on the first partition under the /root/.ssh directory, which means this partition must be the root partition and not e.g. /boot. Logging in will not be possible without the root password unless the keys are correctly inserted.
The ACPI daemon is used to receive commands to manage the power state of a virtual machine. You should install an ACPI daemon on the machine images to allow proper power down/reboot from the cloud interface.
To be able to use volumes, you need to have ACPI hotplug enabled. This is on by default in CentOS 6 and newer, but for Ubuntu you need to add a line "acpiphp" to /etc/modules. For other distros, please check how to load acpiphp on boot from the distro documentation.
You can upload images either using the web interface or by using the "openstack" command line tool.
Before uploading, you will need to know what format the image you are uploading is. The most likely options are "qcow2" and "raw". You can find out the type of the image using the "file" command. This is what a qcow2 image looks like when you examine it with file:
$ file images/Ubuntu-15.10-Phoronix.qcow2 images/Ubuntu-15.10-Phoronix.qcow2: Qemu Image, Format: Qcow (v3), 10737418240 bytes
And this is what a raw image looks like:
$ file images/Ubuntu-14.04-old.raw images/Ubuntu-14.04-old.raw: x86 boot sector; partition 1: ID=0x83, active, starthead 0, startsector 16065, 20948760 sectors, code offset 0x63
To upload using the command line, you would use this command:
openstack image create --disk-format <disk format> --private --file <image file to upload> <name of image to create>
This should upload the image. It will take a while before the image is usable.
If you prefer to use the web interface instead, you can upload images from the Compute | Images section by clicking the Create Image button:
You will be presented with this dialog:
In this dialog, for example we are creating an image called "Alpine-linux". You can optionally add some Image Description for the image, if you need it for your reference. Due to security concerns, we support image uploads only via your local machine and image upload via public URLs is disabled. In this example, we have thus selected an image we want to upload from our local machine via Browse button. In this example, our image is an ISO image so we have selected the same from Format drop-down menu. All remaining fields other than Image Sharing | Visibility could be left their default values. In Image Sharing | Visibility checkbox please make sure that you have selected visibility of the image as "Private". It is not possible for normal users to create public images due to security reasons. In case you attempt to upload an image and set its visibility as "Public", you will get an error message. Setting your Image visibility to "Private" will make your uploaded image private to your particular OpenStack project and only project members of your project would have access to that.
You can share images between different Pouta projects using "glance" command line tool. Image share between projects is currently not supported using Pouta web interface. Once shared, image will be visible in both of the projects i.e. between donor & acceptor projects.
Please note image sharing works within same cloud environment i.e. you can share images from one cPouta project to another but not between a cPouta project and ePouta project or vice versa.
To begin with, you need to add acceptor project as the member of image to be shared by executing following glance command in the donor project:
glance member-create <your-image-UUID> <acceptor-project-ID>
Then acceptor project needs to accept this membership. To do so you/your colleague needs to execute following glance command in the acceptor project.
glance member-update <your-image-UUID> <acceptor-project-ID> accepted
|Previous chapter||One level up||Next chapter|