project-config/nodepool/elements
Colleen Murphy e94c80b91e Manage NTP on zuul workers in DIB
Currently, NTP is configured on zuul workers via puppet[1]. As part of
reducing the nodepool image builds' dependency on puppet, this patch
adds the necessary package dependencies and service configuration to
have NTP running on nodes without needing puppet to install and start
it.

[1] http://git.openstack.org/cgit/openstack-infra/system-config/tree/modules/openstack_project/manifests/template.pp?id=1b0e016093a71ad4eb1b4dde55ac9398b2505f24#n243

Change-Id: Iee6babc183dd12cc82ce76ddfde04f2d98ddc4d6
2017-04-04 09:31:49 +02:00
..
cache-bindep Remove 50-cache-pkgs from cache-bindep 2016-11-29 15:41:37 -05:00
cache-devstack Stop caching devstack packages 2016-12-14 09:44:13 -05:00
infra-package-needs Manage NTP on zuul workers in DIB 2017-04-04 09:31:49 +02:00
initialize-urandom Fix typos in initialize-urandom.py & gerrit-git-prep.sh 2016-11-08 03:57:55 +00:00
nodepool-base Make journald log collection persistent 2017-01-03 09:39:06 -08:00
openstack-repos Merge "Skip pre-caching /deb- repositories in nodepool images" 2017-04-03 08:06:04 +00:00
prepare-node Move prepare-node to it's own element 2016-05-19 21:38:11 -05:00
puppet Update nodepool elements for openSUSE Leap 42.2 2017-02-28 10:54:53 +01:00
stackviz Update nodepool elements for openSUSE Leap 42.2 2017-02-28 10:54:53 +01:00
zuul-worker Update nodepool elements for openSUSE Leap 42.2 2017-02-28 10:54:53 +01:00
README.rst Update doc to have 'debootstrap' dep and describe minimal 2016-10-12 19:27:05 -07:00

README.rst

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 debootstrap

Install diskimage-builder:

sudo -H pip install diskimage-builder

Build an image

Building an image is simple, we have a script!

bash tools/build-image.sh

See the script for environment variables to set distribution, etc. By default it builds an ubuntu-minimal based image. You should be left with a .qcow2 image file of your selected distribution.

Infra uses the -minimal build type for building Ubuntu/CentOS/Fedora. For example: ubuntu-minimal.

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.

While testing, consider exporting DIB_OFFLINE=true, to skip updating the cache.

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 /path/to/devstack-gate-precise.qcow2
sudo mount /dev/nbd1p1 /tmp/newimage

or use the scripts

sudo apt-get install qemu-utils
sudo modprobe nbd max_part=16
sudo tools/mount-image.sh devstack-gate-precise.qcow2
sudo tools/umount-image.sh

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.