project-config/nodepool/elements
2015-03-06 01:19:24 +00:00
..
cache-devstack Use GIT_BASE environment variable 2015-03-04 17:28:25 -08:00
node-devstack Move to using package-installs.yaml 2014-12-11 13:48:13 -08:00
nodepool-base zuul-swift-upload support recursive globs 2015-03-04 09:33:17 +11:00
openstack-repos Rename config => system-config for nodepool 2014-10-17 21:28:44 +00:00
puppet Respect NODEPOOL_SSH_KEY in prepare-node for dib 2015-02-19 10:43:39 -08:00
slave-db Reorganizes project-config 2014-09-25 11:41:04 -04:00
README.rst Always use sudo -H when pip installing 2014-12-26 10:41:58 +01:00

Using diskimage-builder to build devstack-gate nodes

In addition to being able to just download and consume images that are the same as what run devstack-gate, it's easy to make your own for local dev or testing - or just for fun.

Install diskimage-builder

Install the dependencies:

sudo apt-get install kpartx qemu-utils curl python-yaml

Install diskimage-builder:

sudo -H pip install diskimage-builder

Build an image

Building an image is simple, we have a script!

DISTRO="ubuntu" bash tools/build-image.sh

See the script for environment variables to set distribution, etc. You should be left with a .qcow2 image file of your selected distribution.

It is a good idea to set TMP_DIR to somewhere with plenty of space to avoid the disappointment of a full-disk mid-way through the script run.

Mounting the image

If you would like to examine the contents of the image, you can mount it on a loopback device using qemu-nbd.

sudo apt-get install qemu-utils
sudo modprobe nbd max_part=16
sudo mkdir -p /tmp/newimage
sudo qemu-nbd -c /dev/nbd1 devstack-gate-precise.qcow2
sudo mount /dev/nbd1 /tmp/newimage

Other things

It's a qcow2 image, so you can do tons of things with it. You can upload it to glance, you can boot it using kvm, and you can even copy it to a cloud server, replace the contents of the server with it and kexec the new kernel.