237013afef
We decided during the ODS documentation session that several documents need retitling. This patch retitles the documents but doesn't actually adjust the content. There is a separate patch under work which refactors the content from three documents into one document. Change-Id: If5a4718b0ab50c405d42a2e20b7b054b93f3227a
216 lines
7.1 KiB
ReStructuredText
216 lines
7.1 KiB
ReStructuredText
Bare Metal Deployment of Kolla
|
|
==============================
|
|
|
|
Evaluation and Developer Environments
|
|
-------------------------------------
|
|
|
|
Two virtualized evaluation and development environment options are
|
|
available. These options permit the evaluation of Kolla without
|
|
disrupting the host operating system.
|
|
|
|
If developing or evaluating Kolla on an OpenStack cloud environment that
|
|
supports Heat, follow the :doc:`Heat evaluation and developer environment guide <devenv-heat>`.
|
|
|
|
If developing or evaluating Kolla on a system that provides VirtualBox,
|
|
Vagrant may be used and is documented in the :doc:`Vagrant evaluation and developer environment guide <devenv-vagrant>`.
|
|
|
|
If evaluating or deploying OpenStack on bare-metal with Kolla, follow the
|
|
instructions in this document to get started.
|
|
|
|
Installing Dependencies
|
|
-----------------------
|
|
|
|
Kolla is tested on Fedora/Ubuntu/CentOS. It should work with other OS
|
|
distributions, but some need further testing. If other OS distributions can
|
|
be verified, update this doc accordingly. For Fedora/Ubuntu, follow below
|
|
recommendations:
|
|
|
|
Fedora: Kolla will not run on Fedora 22 or later currently. Fedora 22
|
|
compresses kernel modules with the .xz compressed format. The guestfs system
|
|
in the CentOS family of containers cannot read these images because a dependent
|
|
package supermin in CentOS needs to be updated to add .xz compressed format
|
|
support.
|
|
|
|
Ubuntu: For Ubuntu based systems where Docker is used, do not use AUFS when
|
|
starting Docker daemon unless you are running the Ubuntu with 3.19 kernel or
|
|
above. AUFS requires CONFIG\_AUFS\_XATTR=y set when building the kernel. On
|
|
Ubuntu, versions prior to 3.19 did not set this flag to be compatible with
|
|
Docker. If unable to upgrade the kernel, the Kolla community recommends using
|
|
a different storage backend such as btrfs when running Docker daemon.
|
|
|
|
On the deployment host Ansible>=1.8.4 must be installed and is the only
|
|
requirement for deploying OpenStack. To build the Docker container images
|
|
locally the dependencies docker>=1.7.0 and the Python libraries
|
|
docker-py>=1.2.0 and Jinja2>=2.6 must be installed.
|
|
|
|
The deployment target nodes require the installation of docker>=1.7.0 and
|
|
docker-py>=1.2.0.
|
|
|
|
To install Kolla Python dependencies use:
|
|
|
|
::
|
|
|
|
git clone https://git.openstack.org/openstack/kolla
|
|
cd kolla
|
|
sudo pip install -r requirements.txt
|
|
|
|
Since Docker is required to build images as well as be present on all deployed
|
|
targets, the Kolla community recommends installing the Docker Inc. packaged
|
|
version of Docker for maximum stability and compatibility with the following
|
|
command:
|
|
|
|
::
|
|
|
|
curl -sSL https://get.docker.io | bash
|
|
|
|
On the system where the OpenStack CLI/Python code is run, the Kolla community
|
|
recommends installing the OpenStack python clients if they are not installed.
|
|
This could be a completely different machine then the deployment host or
|
|
deployment targets. Before installing the OpenStack python client, there are
|
|
the following requirements needed by your system:
|
|
|
|
::
|
|
|
|
# Ubuntu
|
|
apt-get install -y python-dev python-pip libffi-dev libssl-dev
|
|
|
|
# Fedora
|
|
yum install -y python-devel python-pip libffi-devel openssl-devel
|
|
|
|
# Centos
|
|
easy_install pip
|
|
yum install -y python-devel libffi-devel openssl-devel
|
|
|
|
To install these clients use:
|
|
|
|
::
|
|
|
|
pip install -U python-openstackclient
|
|
|
|
OpenStack uses healthcheck timers which run off wall-clock time rather then
|
|
starting a timer and expring the timer, encoding the expiration in the message
|
|
contents. In some cases, this timer interval can be on the order of 60
|
|
seconds. For OpenStack to Operate correctly with these tight health-check
|
|
timer intervals, the Kolla community highly recommends running the ntpd
|
|
service on all deployment targets. To install, start, and enable ntp on
|
|
CentOS execute the following:
|
|
|
|
::
|
|
|
|
yum -y install ntp
|
|
chkconfig ntpd enable
|
|
service ntpd start
|
|
|
|
Libvirt is started by default on many operating systems. Please disable libvirt
|
|
on any machines that will be deployment targets. Only one copy of libvirt may
|
|
be running at a time.
|
|
|
|
::
|
|
|
|
service libvirtd disable
|
|
service libvirtd stop
|
|
|
|
Kolla deploys OpenStack using
|
|
`Ansible <http://www.ansible.com>`__. Install Ansible from distribution
|
|
packaging if the distro packaging has 1.8.4 or greater available. Currently
|
|
Ubuntu's version of Ansible is too old to use from packaging. On RPM
|
|
based systems install from packaging using:
|
|
|
|
::
|
|
|
|
yum -y install ansible
|
|
|
|
On DEB based systems this can be done using:
|
|
|
|
::
|
|
|
|
apt-get install ansible
|
|
|
|
If the distro packaged version of Ansible is too old, install Ansible using
|
|
pip:
|
|
|
|
::
|
|
|
|
pip install -U ansible
|
|
|
|
Building Container Images
|
|
--------------------------
|
|
|
|
The Kolla community does not currently generate new images for each commit
|
|
to the repository. The push time for a full image build to the docker registry
|
|
is about 5 hours on 100mbit Internet, so there are technical limitations to
|
|
using the Docker Hub registry with our current OpenStack CI/CD systems.
|
|
|
|
The Kolla community builds and pushes tested images for each tagged release of
|
|
Kolla, but if running from master, it is recommended to build images locally.
|
|
All Docker images can be built as follows.
|
|
|
|
Before running the below instructions, ensure the docker daemon is running
|
|
or the build process would fail:
|
|
|
|
::
|
|
|
|
tools/build.py
|
|
|
|
A docker build of all containers on Xeon hardware with SSDs and 100mbit network
|
|
takes roughly 30 minutes. The CentOS mirrors are flakey and the RDO delorean
|
|
repository is not mirrored at all. As a result occasionally some containers
|
|
fail to build. To rectify this, the build tool will automatically attempt three
|
|
retries of a build operation if the first one fails.
|
|
|
|
It is also possible to build individual containers. If for some reason the glance
|
|
containers failed to build, all glance related containers can be rebuilt as follows:
|
|
|
|
::
|
|
|
|
tools/build.py glance
|
|
|
|
Starting Kolla
|
|
--------------
|
|
|
|
Configure Ansible by reading the
|
|
:doc:`Kolla Ansible configuration Guide <ansible-deployment>` documentation.
|
|
|
|
Finally, run the deploy operation:
|
|
|
|
::
|
|
|
|
./tools/kolla-ansible deploy
|
|
|
|
A bare metal system takes three minutes to deploy AIO. A virtual machine
|
|
deployment takes five minutes to deploy AIO. These are estimates; different
|
|
hardware may be faster or slower but should be near these results.
|
|
|
|
Debugging Kolla
|
|
---------------
|
|
|
|
The container's status can be determined on the deployment targets by
|
|
executing:
|
|
|
|
::
|
|
|
|
docker ps -a
|
|
|
|
If any of the containers exited, this indicates a bug in the container. Please
|
|
seek help by filing a bug or contacting the developers via IRC.
|
|
|
|
the logs can be examined by executing:
|
|
|
|
::
|
|
|
|
docker logs <container-name>
|
|
|
|
Note some of the containers don't log to stdout at present so the above
|
|
command will provide no information. Instead they log to files
|
|
in /var/log/<service_> inside the container. The Kolla community is
|
|
working to improve auditing and make things more consistent. The Kolla
|
|
community expects this work to complete by Liberty rc1. An example of
|
|
reading the logs for nova-api:
|
|
|
|
::
|
|
|
|
docker exec -t nova_api more /var/log/nova/nova-api.log
|
|
|
|
Note reading the logs via an exec operation can only be done if the
|
|
container is running.
|