2019-06-17 21:37:25 +00:00
|
|
|
===============================
|
|
|
|
Building Octavia Amphora Images
|
|
|
|
===============================
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
Octavia is an operator-grade reference implementation for Load Balancing as a
|
|
|
|
Service (LBaaS) for OpenStack. The component of Octavia that does the load
|
|
|
|
balancing is known as amphora. Amphora may be a virtual machine, may be a
|
|
|
|
container, or may run on bare metal. Creating images for bare metal amphora
|
|
|
|
installs is outside the scope of this version but may be added in a
|
|
|
|
future release.
|
|
|
|
|
|
|
|
Prerequisites
|
|
|
|
=============
|
|
|
|
|
|
|
|
This script assumes a typical Linux environment and was developed on
|
|
|
|
Ubuntu 12.04.5 LTS.
|
|
|
|
|
2017-03-08 16:18:06 +00:00
|
|
|
Python pip should be installed as well as the python modules found in the
|
|
|
|
requirements.txt file.
|
2014-11-05 19:05:16 +00:00
|
|
|
|
2018-12-11 14:05:44 +00:00
|
|
|
To do so, you can use the following command on ubuntu:
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ # Install python pip
|
|
|
|
$ sudo apt install python-pip
|
|
|
|
$ # Eventually create a virtualenv
|
|
|
|
$ sudo apt install python-virtualenv
|
|
|
|
$ virtualenv octavia_disk_image_create
|
|
|
|
$ source octavia_disk_image_create/bin/activate
|
|
|
|
$ # Install octavia requirements
|
|
|
|
$ cd octavia/diskimage-create
|
|
|
|
$ pip install -r requirements.txt
|
|
|
|
|
|
|
|
|
2014-11-05 19:05:16 +00:00
|
|
|
Your cache directory should have at least 1GB available, the working directory
|
|
|
|
will need ~1.5GB, and your image destination will need ~500MB
|
|
|
|
|
2017-03-08 16:18:06 +00:00
|
|
|
The script will use the version of diskimage-builder installed on your system,
|
|
|
|
or it can be overridden by setting the following environment variables:
|
2014-11-05 19:05:16 +00:00
|
|
|
|
2019-06-17 21:37:25 +00:00
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
DIB_REPO_PATH = /<some directory>/diskimage-builder
|
|
|
|
DIB_ELEMENTS = /<some directory>/diskimage-builder/elements
|
2014-11-05 19:05:16 +00:00
|
|
|
|
2018-12-11 14:05:44 +00:00
|
|
|
|
2014-11-05 19:05:16 +00:00
|
|
|
The following packages are required on each platform:
|
2018-12-11 14:05:44 +00:00
|
|
|
|
|
|
|
Ubuntu
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
2019-01-24 07:42:46 +00:00
|
|
|
$ sudo apt install qemu-utils git kpartx debootstrap
|
2018-12-11 14:05:44 +00:00
|
|
|
|
|
|
|
Fedora, CentOS and Red Hat Enterprise Linux
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ sudo yum install qemu-img git e2fsprogs policycoreutils-python
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
Test Prerequisites
|
|
|
|
------------------
|
|
|
|
The tox image tests require libguestfs-tools 1.24 or newer.
|
2016-12-20 07:46:09 +00:00
|
|
|
Libguestfs allows testing the Amphora image without requiring root privileges.
|
2014-11-05 19:05:16 +00:00
|
|
|
On Ubuntu systems you also need to give read access to the kernels for the user
|
|
|
|
running the tests:
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ sudo chmod 0644 /boot/vmlinuz*
|
|
|
|
|
|
|
|
Tests were run on Ubuntu 14.04.1 LTS during development.
|
|
|
|
|
|
|
|
Usage
|
|
|
|
=====
|
|
|
|
This script and associated elements will build Amphora images. Current support
|
|
|
|
is with an Ubuntu base OS and HAProxy. The script can use Fedora
|
2018-10-29 18:52:09 +00:00
|
|
|
as a base OS but these will not initially be tested or supported.
|
2014-11-05 19:05:16 +00:00
|
|
|
As the project progresses and/or the diskimage-builder project adds support
|
|
|
|
for additional base OS options they may become available for Amphora images.
|
|
|
|
This does not mean that they are necessarily supported or tested.
|
|
|
|
|
2019-06-17 17:36:18 +00:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
If your cloud has multiple hardware architectures available to nova,
|
|
|
|
remember to set the appropriate hw_architecture property on the
|
|
|
|
image when you load it into glance. For example, when loading an
|
|
|
|
amphora image built for "amd64" you would add
|
|
|
|
"--property hw_architecture='x86_64'" to your "openstack image create"
|
|
|
|
command line.
|
|
|
|
|
2014-11-05 19:05:16 +00:00
|
|
|
The script will use environment variables to customize the build beyond the
|
|
|
|
Octavia project defaults, such as adding elements.
|
|
|
|
|
|
|
|
The supported and tested image is created by using the diskimage-create.sh
|
|
|
|
defaults (no command line parameters or environment variables set). As the
|
|
|
|
project progresses we may add additional supported configurations.
|
|
|
|
|
|
|
|
Command syntax:
|
|
|
|
|
|
|
|
|
2019-06-17 21:37:25 +00:00
|
|
|
.. code-block::
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
$ diskimage-create.sh
|
2019-04-17 16:22:28 +00:00
|
|
|
[-a i386 | **amd64** | armhf | ppc64le ]
|
2014-11-05 19:05:16 +00:00
|
|
|
[-b **haproxy** ]
|
|
|
|
[-c **~/.cache/image-create** | <cache directory> ]
|
2019-04-15 14:49:12 +00:00
|
|
|
[-d **bionic**/**7** | xenial | 8 | <other release id> ]
|
2018-10-29 18:52:09 +00:00
|
|
|
[-e]
|
2019-04-17 16:22:28 +00:00
|
|
|
[-f]
|
2014-11-05 19:05:16 +00:00
|
|
|
[-h]
|
2018-10-22 10:29:46 +00:00
|
|
|
[-i **ubuntu-minimal** | fedora | centos-minimal | rhel ]
|
2019-06-18 04:59:12 +00:00
|
|
|
[-k <kernel package name> ]
|
2018-10-23 07:50:08 +00:00
|
|
|
[-l <log file> ]
|
2017-08-10 00:42:08 +00:00
|
|
|
[-n]
|
2014-11-05 19:05:16 +00:00
|
|
|
[-o **amphora-x64-haproxy** | <filename> ]
|
2018-10-29 18:52:09 +00:00
|
|
|
[-p]
|
2014-11-05 19:05:16 +00:00
|
|
|
[-r <root password> ]
|
2016-07-05 09:31:07 +00:00
|
|
|
[-s **2** | <size in GB> ]
|
2014-11-05 19:05:16 +00:00
|
|
|
[-t **qcow2** | tar ]
|
|
|
|
[-v]
|
|
|
|
[-w <working directory> ]
|
2018-10-29 18:52:09 +00:00
|
|
|
[-x]
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
'-a' is the architecture type for the image (default: amd64)
|
|
|
|
'-b' is the backend type (default: haproxy)
|
|
|
|
'-c' is the path to the cache directory (default: ~/.cache/image-create)
|
2019-04-15 14:49:12 +00:00
|
|
|
'-d' distribution release id (default on ubuntu: bionic)
|
2018-10-29 18:52:09 +00:00
|
|
|
'-e' enable complete mandatory access control systems when available (default: permissive)
|
2019-04-17 16:22:28 +00:00
|
|
|
'-f' disable tmpfs for build
|
2014-11-05 19:05:16 +00:00
|
|
|
'-h' display help message
|
2019-06-18 04:59:12 +00:00
|
|
|
'-i' is the base OS (default: ubuntu-minimal)
|
2019-07-08 17:28:01 +00:00
|
|
|
'-k' is the kernel meta package name, currently only for ubuntu-minimal base OS (default: linux-image-virtual)
|
2018-10-23 07:50:08 +00:00
|
|
|
'-l' is output logfile (default: none)
|
2017-08-10 00:42:08 +00:00
|
|
|
'-n' disable sshd (default: enabled)
|
2014-11-05 19:05:16 +00:00
|
|
|
'-o' is the output image file name
|
2017-11-23 17:45:34 +00:00
|
|
|
'-p' install amphora-agent from distribution packages (default: disabled)"
|
2014-11-05 19:05:16 +00:00
|
|
|
'-r' enable the root account in the generated image (default: disabled)
|
2016-07-05 09:31:07 +00:00
|
|
|
'-s' is the image size to produce in gigabytes (default: 2)
|
2014-11-05 19:05:16 +00:00
|
|
|
'-t' is the image type (default: qcow2)
|
|
|
|
'-v' display the script version
|
|
|
|
'-w' working directory for image building (default: .)
|
2018-10-29 18:52:09 +00:00
|
|
|
'-x' enable tracing for diskimage-builder
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
Environment Variables
|
|
|
|
=====================
|
|
|
|
These are optional environment variables that can be set to override the script
|
|
|
|
defaults.
|
|
|
|
|
2019-08-05 21:28:03 +00:00
|
|
|
DIB_REPOLOCATION_amphora_agent
|
|
|
|
- Location of the amphora-agent code that will be installed in the image.
|
|
|
|
- Default: https://opendev.org/openstack/octavia
|
|
|
|
- Example: /tmp/octavia
|
|
|
|
|
|
|
|
DIB_REPOREF_amphora_agent
|
2019-06-17 21:37:25 +00:00
|
|
|
- The git reference to checkout for the amphora-agent code inside the
|
|
|
|
image.
|
2019-08-05 21:28:03 +00:00
|
|
|
- Default: master
|
|
|
|
- Example: stable/stein
|
|
|
|
- Example: refs/changes/40/674140/7
|
|
|
|
|
2014-11-05 19:05:16 +00:00
|
|
|
CLOUD_INIT_DATASOURCES
|
2016-02-04 13:51:29 +00:00
|
|
|
- Comma separated list of cloud-int datasources
|
2014-11-05 19:05:16 +00:00
|
|
|
- Default: ConfigDrive
|
|
|
|
- Options: NoCloud, ConfigDrive, OVF, MAAS, Ec2, <others>
|
|
|
|
- Reference: https://launchpad.net/cloud-init
|
|
|
|
|
2017-07-11 14:40:40 +00:00
|
|
|
DIB_DISTRIBUTION_MIRROR
|
2014-11-05 19:05:16 +00:00
|
|
|
- URL to a mirror for the base OS selected
|
|
|
|
- Default: None
|
|
|
|
|
|
|
|
DIB_ELEMENTS
|
|
|
|
- Override the elements used to build the image
|
|
|
|
- Default: None
|
|
|
|
|
|
|
|
DIB_LOCAL_ELEMENTS
|
|
|
|
- Elements to add to the build (requires DIB_LOCAL_ELEMENTS_PATH be
|
|
|
|
specified)
|
|
|
|
- Default: None
|
|
|
|
|
|
|
|
DIB_LOCAL_ELEMENTS_PATH
|
|
|
|
- Path to the local elements directory
|
|
|
|
- Default: None
|
|
|
|
|
|
|
|
DIB_REPO_PATH
|
|
|
|
- Directory containing diskimage-builder
|
|
|
|
- Default: <directory above OCTAVIA_HOME>/diskimage-builder
|
|
|
|
- Reference: https://github.com/openstack/diskimage-builder
|
|
|
|
|
|
|
|
OCTAVIA_REPO_PATH
|
|
|
|
- Directory containing octavia
|
2016-06-23 14:04:19 +00:00
|
|
|
- Default: <directory above the script location>
|
2015-06-13 00:16:51 +00:00
|
|
|
- Reference: https://github.com/openstack/octavia
|
2014-11-05 19:05:16 +00:00
|
|
|
|
2017-11-23 17:45:34 +00:00
|
|
|
Using distribution packages for amphora agent
|
|
|
|
---------------------------------------------
|
|
|
|
By default, amphora agent is installed from Octavia Git repository.
|
|
|
|
To use distribution packages, use the "-p" option.
|
|
|
|
|
|
|
|
Note this needs a base system image with the required repositories enabled (for
|
|
|
|
example RDO repositories for CentOS/Fedora). One of these variables must be
|
|
|
|
set:
|
|
|
|
|
|
|
|
DIB_LOCAL_IMAGE
|
|
|
|
- Path to the locally downloaded image
|
|
|
|
- Default: None
|
|
|
|
|
|
|
|
DIB_CLOUD_IMAGES
|
|
|
|
- Directory base URL to download the image from
|
|
|
|
- Default: depends on the distribution
|
|
|
|
|
|
|
|
For example to build a CentOS 7 amphora with Pike RPM packages:
|
2019-06-17 21:37:25 +00:00
|
|
|
|
2017-11-23 17:45:34 +00:00
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
# Get image
|
|
|
|
$ wget https://cloud.centos.org/centos/7/images/CentOS-7-x86_64-GenericCloud.qcow2
|
|
|
|
|
|
|
|
# Add repository
|
|
|
|
$ virt-customize -a CentOS-7-x86_64-GenericCloud.qcow2 --selinux-relabel --run-command 'yum install -y centos-release-openstack-pike'
|
|
|
|
|
|
|
|
# Point to modified image and run script
|
|
|
|
$ export DIB_LOCAL_IMAGE=/home/stack/CentOS-7-x86_64-GenericCloud.qcow2
|
2018-10-22 10:29:46 +00:00
|
|
|
$ ./diskimage-create.sh -p -i centos-minimal
|
2017-11-23 17:45:34 +00:00
|
|
|
|
2016-06-23 14:04:19 +00:00
|
|
|
RHEL specific variables
|
|
|
|
------------------------
|
|
|
|
Building a RHEL-based image requires:
|
2019-02-21 18:54:55 +00:00
|
|
|
- a Red Hat Enterprise Linux KVM Guest Image, manually download from the
|
|
|
|
Red Hat Customer Portal. Set the DIB_LOCAL_IMAGE variable to point to
|
|
|
|
the file. More details at:
|
|
|
|
<DIB_REPO_PATH>/elements/rhel
|
2016-06-23 14:04:19 +00:00
|
|
|
|
|
|
|
- a Red Hat subscription for the matching Red Hat OpenStack Platform
|
2019-02-21 18:54:55 +00:00
|
|
|
repository if you want to install the amphora agent from the official
|
|
|
|
distribution package (requires setting -p option in diskimage-create.sh).
|
|
|
|
Set the needed registration parameters depending on your configuration.
|
|
|
|
More details at:
|
2016-06-23 14:04:19 +00:00
|
|
|
<DIB_REPO_PATH>/elements/rhel-common
|
|
|
|
|
2019-02-21 18:54:55 +00:00
|
|
|
Here is an example with Customer Portal registration and OSP 13 repository:
|
2019-06-17 21:37:25 +00:00
|
|
|
|
2016-06-23 14:04:19 +00:00
|
|
|
.. code:: bash
|
|
|
|
|
2019-02-21 18:54:55 +00:00
|
|
|
$ export DIB_LOCAL_IMAGE='/tmp/rhel-server-7.6-x86_64-kvm.qcow2'
|
2016-06-23 14:04:19 +00:00
|
|
|
|
2019-02-21 18:54:55 +00:00
|
|
|
$ export REG_METHOD='portal' REG_REPOS='rhel-7-server-openstack-13-rpms'
|
2016-06-23 14:04:19 +00:00
|
|
|
|
|
|
|
$ export REG_USER='<user>' REG_PASSWORD='<password>' REG_AUTO_ATTACH=true
|
|
|
|
|
|
|
|
This example uses registration via a Satellite (the activation key must enable
|
|
|
|
an OSP repository):
|
2019-06-17 21:37:25 +00:00
|
|
|
|
2016-06-23 14:04:19 +00:00
|
|
|
.. code:: bash
|
|
|
|
|
2019-02-21 18:54:55 +00:00
|
|
|
$ export DIB_LOCAL_IMAGE='/tmp/rhel-server-7.6-x86_64-kvm.qcow2'
|
2016-06-23 14:04:19 +00:00
|
|
|
|
|
|
|
$ export REG_METHOD='satellite' REG_ACTIVATION_KEY="<activation key>"
|
|
|
|
|
|
|
|
$ export REG_SAT_URL="<satellite url>" REG_ORG="<satellite org>"
|
|
|
|
|
2019-01-24 07:42:46 +00:00
|
|
|
Building in a virtualenv with tox
|
|
|
|
---------------------------------
|
2019-06-17 21:37:25 +00:00
|
|
|
To make use of a virtualenv for Python dependencies you may run ``tox``. Note
|
|
|
|
that you may still need to install binary dependencies on the host for the
|
|
|
|
build to succeed.
|
2019-01-24 07:42:46 +00:00
|
|
|
|
|
|
|
If you wish to customize your build modify ``tox.ini`` to pass on relevant
|
2019-06-17 21:37:25 +00:00
|
|
|
environment variables or command line arguments to the ``diskimage-create.sh``
|
|
|
|
script.
|
2019-01-24 07:42:46 +00:00
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ tox -e build
|
|
|
|
|
2016-06-23 14:04:19 +00:00
|
|
|
|
2014-11-05 19:05:16 +00:00
|
|
|
Container Support
|
|
|
|
=================
|
|
|
|
The Docker command line required to import a tar file created with this script
|
|
|
|
is:
|
|
|
|
|
|
|
|
.. code:: bash
|
|
|
|
|
|
|
|
$ docker import - image:amphora-x64-haproxy < amphora-x64-haproxy.tar
|
|
|
|
|
|
|
|
|
|
|
|
References
|
|
|
|
==========
|
|
|
|
|
|
|
|
This documentation and script(s) leverage prior work by the OpenStack TripleO
|
|
|
|
and Sahara teams. Thank you to everyone that worked on them for providing a
|
|
|
|
great foundation for creating Octavia Amphora images.
|
|
|
|
|
2019-06-17 21:37:25 +00:00
|
|
|
* https://opendev.org/openstack/diskimage-builder
|
|
|
|
* https://opendev.org/openstack/tripleo-image-elements
|
|
|
|
* https://opendev.org/openstack/sahara-image-elements
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
Copyright
|
|
|
|
=========
|
|
|
|
|
|
|
|
Copyright 2014 Hewlett-Packard Development Company, L.P.
|
|
|
|
|
|
|
|
All Rights Reserved.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
not use this file except in compliance with the License. You may obtain
|
|
|
|
a copy of the License at
|
|
|
|
|
2019-06-17 21:37:25 +00:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2014-11-05 19:05:16 +00:00
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
License for the specific language governing permissions and limitations
|
|
|
|
under the License.
|