OpenStack
OpenStack is a global collaboration of developers and cloud computing technologists producing the ubiquitous open source cloud computing platform for public and private clouds. The project aims to deliver solutions for all types of clouds by being simple to implement, massively scalable, and feature rich. The technology consists of a series of interrelated projects delivering various components for a cloud infrastructure solution
Components
- Compute (Nova) — Nova is the OpenStack project that provides a way to provision compute instances (aka virtual servers).
- Networking (Neutron) — Neutron is an OpenStack project to provide "network connectivity as a service" between interface devices (e.g., vNICs) managed by other OpenStack services (e.g., nova). It implements the OpenStack Networking API.
- Image Service (Glance) — The Image service (glance) project provides a service where users can upload and discover data assets that are meant to be used with other services.
- Block Storage (Cinder) — Cinder is the OpenStack Block Storage service for providing volumes to Nova virtual machines, Ironic bare metal hosts, containers and more.
- Identity (Keystone) — Keystone is an OpenStack service that provides API client authentication, service discovery, and distributed multi-tenant authorization by implementing OpenStack’s Identity API.
- Dashboard (Horizon) — Horizon is the canonical implementation of OpenStack’s Dashboard, which provides a web based user interface to OpenStack services including Nova, Swift, Keystone, etc.
Images
Available images
Official Openstack images are available from most popular distributions of GNU/Linux.
The official Arch cloud-image can be downloaded from: https://gitlab.archlinux.org/archlinux/arch-boxes
Creating images yourself
OpenStack images need to meet certain requirements. An image can be prepared manually or with help from a tool.
For a tool, image-bootstrap with the --openstack
parameter may be of help. As of 2015-06-24, resulting images are still in experimental stage.
For manual creation, the essential steps are:
- Partitioning a disk with a single ext3/4 partition.
- Installing a base system (e.g. using
pacstrap
of arch-install-scripts) to it - Installing a boot loader (e.g. GRUB or extlinux)
- Installing and configuring cloud-init
- Adding an unpriviliged user able to run sudo without a password
- Configuring for DHCP
- Configuring udev to name network interfaces
- Configuring systemd-networkd to use DHCP on
- Installing SSH server
- Adjusting initramfs creation and regenerating initramfs images
- Disabling the hook (since autodetection works differently from a chroot)
- Either activating hook
growfs
from or installinggrowpart
from and have cloud-init do resizing by itself
- Making services start automatically by enabling them
- Deleting generated keys (i.e. those of the SSH server and pacman); optionally generating new ones during first boot
- Delete machine IDs ( and ) so that two systems are not mistaken for the same thing