Skip to content
Snippets Groups Projects
quickstart.rst 12.6 KiB
Newer Older
===========
Quick Start
===========

This guide provides step by step instructions to deploy OpenStack using Kolla
on bare metal servers or virtual machines.

Recommended reading
~~~~~~~~~~~~~~~~~~~

It's beneficial to learn basics of both `Ansible <https://docs.ansible.com>`__
and `Docker <https://docs.docker.com>`__ before running Kolla-Ansible.
Host machine requirements
~~~~~~~~~~~~~~~~~~~~~~~~~
The host machine must satisfy the following minimum requirements:
- 2 network interfaces
- 8GB main memory
- 40GB disk space
   Root access to the deployment host machine is required.

Install dependencies
~~~~~~~~~~~~~~~~~~~~
chenxing's avatar
chenxing committed
#. Install and upgrad ``pip`` to the latest before proceeding.
chenxing's avatar
chenxing committed
   For CentOS, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      yum install epel-release
      yum install python-pip
      pip install -U pip
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   For Ubuntu, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      apt-get update
      apt-get install python-pip
      pip install -U pip
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Install the following dependencies:
chenxing's avatar
chenxing committed
   For CentOS, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      yum install python-devel libffi-devel gcc openssl-devel libselinux-python
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   For Ubuntu, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      apt-get install python-dev libffi-dev gcc libssl-dev python-selinux
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Install `Ansible <http://www.ansible.com>`__ from distribution packaging:
chenxing's avatar
chenxing committed
   .. note::
chenxing's avatar
chenxing committed
      Some implemented distro versions of Ansible are too old to use distro
      packaging. Currently, CentOS and RHEL package Ansible >2.0 which is suitable
      for use with Kolla. Note that you will need to enable access to the EPEL
      repository to install via :command:`yum` to do so, take a look at `Fedora's EPEL docs
      <https://fedoraproject.org/wiki/EPEL>`__ and `FAQ
      <https://fedoraproject.org/wiki/EPEL/FAQ>`__.
chenxing's avatar
chenxing committed
   For CentOS or RHEL, this can be done using:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      yum install ansible
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   For Ubuntu, it can be installed by:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      apt-get install ansible
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Use ``pip`` to install or upgrade Ansible to latest version:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      pip install -U ansible
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   .. note::
chenxing's avatar
chenxing committed
      It is recommended to use virtualenv to install non-system packages.
chenxing's avatar
chenxing committed
#. (optional) Add the following options to ansible configuration file
   ``/etc/ansible/ansible.cfg``:
chenxing's avatar
chenxing committed
   .. path /etc/ansible/ansible.cfg
   .. code-block:: ini
chenxing's avatar
chenxing committed
      [defaults]
      host_key_checking=False
      pipelining=True
      forks=100

   .. end
Install Kolla-ansible
~~~~~~~~~~~~~~~~~~~~~
Install Kolla-ansible for deployment or evaluation
--------------------------------------------------
chenxing's avatar
chenxing committed
#. Install kolla-ansible and its dependencies using ``pip``.
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      pip install kolla-ansible
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Copy ``globals.yml`` and ``passwords.yml`` to ``/etc/kolla`` directory.
chenxing's avatar
chenxing committed
   For CentOS, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
      cp -r /usr/share/kolla-ansible/etc_examples/kolla /etc/
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   For Ubuntu, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
      cp -r /usr/local/share/kolla-ansible/etc_examples/kolla /etc/
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Copy ``all-in-one`` and ``multinode`` inventory files to
   the current directory.
chenxing's avatar
chenxing committed
   For CentOS, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      cp /usr/share/kolla-ansible/ansible/inventory/* .
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   For Ubuntu, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      cp /usr/local/share/kolla-ansible/ansible/inventory/* .
chenxing's avatar
chenxing committed
   .. end
Install Kolla for development
-----------------------------
chenxing's avatar
chenxing committed
#. Clone ``kolla`` and ``kolla-ansible`` repositories from git.
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      git clone https://github.com/openstack/kolla
      git clone https://github.com/openstack/kolla-ansible
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Install requirements of ``kolla`` and ``kolla-ansible``:
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      pip install -r kolla/requirements.txt
      pip install -r kolla-ansible/requirements.txt
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
#. Copy the configuration files to ``/etc/kolla`` directory.
   ``kolla-ansible`` holds the configuration files ( ``globals.yml`` and
   ``passwords.yml``) in ``etc/kolla``.
chenxing's avatar
chenxing committed
   .. code-block:: console
chenxing's avatar
chenxing committed
      cp -r kolla-ansible/etc/kolla /etc/kolla
chenxing's avatar
chenxing committed
   .. end

#. Copy the inventory files to the current directory. ``kolla-ansible`` holds
   inventory files ( ``all-in-one`` and ``multinode``) in the
   ``ansible/inventory`` directory.
chenxing's avatar
chenxing committed

   .. code-block:: console

      cp kolla-ansible/ansible/inventory/* .

   .. end
Prepare initial configuration
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Inventory
---------
Next step is to prepare our inventory file. Inventory is an ansible file where
we specify node roles and access credentials.
Kolla-Ansible comes with ``all-in-one`` and ``multinode`` example inventory
files. Difference between them is that the former is ready for deploying
single node OpenStack on localhost. If you need to use separate host or more
than one node, edit ``multinode`` inventory:
chenxing's avatar
chenxing committed
#. Edit the first section of ``multinode`` with connection details of your
   environment, for example:
   .. code-block:: ini
chenxing's avatar
chenxing committed
      [control]
      10.0.0.[10:12] ansible_user=ubuntu ansible_password=foobar ansible_become=true
      # Ansible supports syntax like [10:12] - that means 10, 11 and 12.
wu.chunyang's avatar
wu.chunyang committed
      # Become clause means "use sudo".
chenxing's avatar
chenxing committed
      [network:children]
      control
      # when you specify group_name:children, it will use contents of group specified.
chenxing's avatar
chenxing committed
      [compute]
      10.0.0.[13:14] ansible_user=ubuntu ansible_password=foobar ansible_become=true
chenxing's avatar
chenxing committed
      [monitoring]
      10.0.0.10
      # This group is for monitoring node.
      # Fill it with one of the controllers' IP address or some others.
chenxing's avatar
chenxing committed
      [storage:children]
      compute
chenxing's avatar
chenxing committed
      [deployment]
      localhost       ansible_connection=local become=true
      # use localhost and sudo
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   To learn more about inventory files, check
   `Ansible documentation <http://docs.ansible.com/ansible/latest/intro_inventory.html>`_.
chenxing's avatar
chenxing committed
#. Check whether the configuration of inventory is correct or not, run:
chenxing's avatar
chenxing committed
   .. code-block:: console
      ansible -i multinode all -m ping
chenxing's avatar
chenxing committed
   .. end
chenxing's avatar
chenxing committed
   .. note::
chenxing's avatar
chenxing committed
      Ubuntu might not come with python pre-installed. That will cause
      errors in ping module. To quickly install python with ansible you
      can run ``ansible -m raw -a "apt-get -y install python-dev all"``
Kolla passwords
---------------
Passwords used in our deployment are stored in ``/etc/kolla/passwords.yml``
file. All passwords are blank in this file and have to be filled either
manually or by running random password generator:
For deployment or evaluation, run:
.. code-block:: console
For development, run:
.. code-block:: console

   cd kolla-ansible/tools
   ./generate_passwords.py
Kolla globals.yml
-----------------
``globals.yml`` is the main configuration file for Kolla-Ansible.
There are a few options that are required to deploy Kolla-Ansible:
* Image options
  User has to specify images that are going to be used for our deployment.
  In this guide `DockerHub <https://hub.docker.com/u/kolla/>`__ provided
  pre-built images are going to be used. To learn more about building
  mechanism, please refer `image building documentation
  <https://docs.openstack.org/kolla/latest/admin/image-building.html>`_.
  Kolla provides choice of several Linux distributions in containers:
  - Centos
  - Ubuntu
  - Oraclelinux
  - Debian
  - RHEL
  For newcomers, we recommend to use CentOS 7 or Ubuntu 16.04.
  .. code-block:: console
     kolla_base_distro: "centos"

  .. end
  Next "type" of installation needs to be configured.
  Choices are:
  binary
   using repositories like apt or yum
  source
   using raw source archives, git repositories or local source directory
  .. note::
     This only affects OpenStack services. Infrastructure services like Ceph are
     always "binary".
  .. note::
     Source builds are proven to be slightly more reliable than binary.
  .. code-block:: console

     kolla_install_type: "source"
  To use DockerHub images, the default image tag has to be overridden. Images are
  tagged with release names. For example to use stable Pike images set
  .. code-block:: console

     openstack_release: "pike"
  It's important to use same version of images as kolla-ansible. That
  means if pip was used to install kolla-ansible, that means it's latest stable
  version so ``openstack release`` should be set to queens. If git was used with
  master branch, DockerHub also provides daily builds of master branch (which is
  tagged as ``master``):
  .. code-block:: console
     openstack_release: "master"

  .. end
* Networking
  Kolla-Ansible requires a few networking options to be set.
  We need to set network interfaces used by OpenStack.
  First interface to set is "network_interface". This is the default interface
  for multiple management-type networks.
  .. code-block:: console

     network_interface: "eth0"
caoyuan's avatar
caoyuan committed
  Second interface required is dedicated for Neutron external (or public)
  networks, can be vlan or flat, depends on how the networks are created.
  This interface should be active without IP address. If not, instances
  won't be able to access to the external networks.
  .. code-block:: console
     neutron_external_interface: "eth1"

  .. end
  To learn more about network configuration, refer `Network overview
  <https://docs.openstack.org/kolla-ansible/latest/admin/production-architecture-guide.html#network-configuration>`_.
  Next we need to provide floating IP for management traffic. This IP will be
  managed by keepalived to provide high availability, and should be set to be
  *not used* address in management network that is connected to our
  ``network_interface``.
  .. code-block:: console

     kolla_internal_vip_address: "10.1.0.250"
* Enable additional services
  By default Kolla-Ansible provides a bare compute kit, however it does provide
  support for a vast selection of additional services. To enable them, set
  ``enable_*`` to "yes". For example, to enable Block Storage service:
  .. code-block:: console
     enable_cinder: "yes"

  .. end
  Kolla now supports many OpenStack services, there is
  `a list of available services
  <https://github.com/openstack/kolla-ansible/blob/master/README.rst#openstack-services>`_.
  For more information about service configuration, Please refer to the
  `Services Reference Guide
  <https://docs.openstack.org/kolla-ansible/latest/reference/index.html>`_.
Deployment
~~~~~~~~~~
After configuration is set, we can proceed to the deployment phase. First we
need to setup basic host-level dependencies, like docker.
Kolla-Ansible provides a playbook that will install all required services in
the correct versions.
* For deployment or evaluation, run:
  #. Bootstrap servers with kolla deploy dependencies:
     .. code-block:: console

        kolla-ansible -i ./multinode bootstrap-servers
  #. Do pre-deployment checks for hosts:
     .. code-block:: console
        kolla-ansible -i ./multinode prechecks

     .. end
  #. Finally proceed to actual OpenStack deployment:
     .. code-block:: console

        kolla-ansible -i ./multinode deploy
* For development, run:
  #. Bootstrap servers with kolla deploy dependencies:
     .. code-block:: console

        cd kolla-ansible/tools
        ./kolla-ansible -i ./multinode bootstrap-servers
  #. Do pre-deployment checks for hosts:
     .. code-block:: console
        ./kolla-ansible -i ./multinode prechecks

     .. end
  #. Finally proceed to actual OpenStack deployment:
     .. code-block:: console

        ./kolla-ansible -i ./multinode deploy
When this playbook finishes, OpenStack should be up, running and functional!
If error occurs during execution, refer to
`troubleshooting guide <https://docs.openstack.org/kolla-ansible/latest/user/troubleshooting.html>`_.
Using OpenStack
~~~~~~~~~~~~~~~

OpenStack requires an openrc file where credentials for admin user etc are set.
To generate this file run
.. code-block:: console
   kolla-ansible post-deploy
   . /etc/kolla/admin-openrc.sh

.. end
Install basic OpenStack CLI clients:
.. code-block:: console

   pip install python-openstackclient python-glanceclient python-neutronclient
Depending on how you installed Kolla-Ansible, there is script that will create
example networks, images, and so on.

For pip install and CentOS host:
.. code-block:: console
   . /usr/share/kolla-ansible/init-runonce

.. end
For pip install and Ubuntu host:
.. code-block:: console

   . /usr/local/share/kolla-ansible/init-runonce
For git pulled source:

.. code-block:: console
   . kolla-ansible/tools/init-runonce