From 493b2a12951862def9127558a8269c4513eeb0e4 Mon Sep 17 00:00:00 2001 From: Mark Goddard Date: Wed, 8 Nov 2017 10:42:57 +0000 Subject: [PATCH] Add documentation on custom kolla-ansible configuration --- doc/source/configuration/kolla-ansible.rst | 138 +++++++++++++++++++++ 1 file changed, 138 insertions(+) diff --git a/doc/source/configuration/kolla-ansible.rst b/doc/source/configuration/kolla-ansible.rst index 2f3cf0c32..261b6b17a 100644 --- a/doc/source/configuration/kolla-ansible.rst +++ b/doc/source/configuration/kolla-ansible.rst @@ -20,8 +20,146 @@ kolla-ansible is installed and executed. ====================== ================================================== ============================ ``$KOLLA_CONFIG_PATH`` Path on the ansible control host in which ``/etc/kolla`` the kolla-ansible configuration will be generated. + These files should not be manually edited. ``$KOLLA_SOURCE_PATH`` Path on the ansible control host in which ``$PWD/src/kolla-ansible`` the kolla-ansible source code will be cloned. ``$KOLLA_VENV_PATH`` Path on the ansible control host in which ``$PWD/venvs/kolla-ansible`` the kolla-ansible virtualenv will be created. ====================== ================================================== ============================ + +Control Plane Services +====================== + +Kolla-ansible provides a flexible mechanism for configuring the services that +it deploys. Kayobe adds some commonly required configuration options to the +defaults provided by kolla-ansible, but also allows for the free-form +configuration supported by kolla-ansible. The `kolla-ansible documentation +`_ should be used as a +reference. + +Global Variables +---------------- + +Kolla-ansible uses a single file for global variables, ``globals.yml``. Kayobe +provides configuration variables for all required variables and many of the +most commonly used the variables in this file. Some of these are in +``$KAYOBE_CONFIG_PATH/kolla.yml``, and others are determined from other sources +such as the networking configuration in ``$KAYOBE_CONFIG_PATH/networks.yml``. + +Configuring Custom Global Variables +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +Additional global configuration may be provided by creating +``$KAYOBE_CONFIG_PATH/kolla/globals.yml``. Variables in this file will be +templated using Jinja2, and merged with the Kayobe ``globals.yml`` +configuration. + +.. code-block:: yaml + :caption: ``$KAYOBE_CONFIG_PATH/kolla/globals.yml`` + + --- + # Use a custom tag for the nova-api container image. + nova_api_tag: v1.2.3 + +Passwords +--------- + +Kolla-ansible auto-generates passwords to a file, ``passwords.yml``. Kayobe +handles the orchestration of this, as well as encryption of the file using an +ansible vault password specified in the ``KAYOBE_VAULT_PASSWORD`` environment +variable, if present. The file is generated to +``$KAYOBE_CONFIG_PATH/kolla/passwords.yml``, and should be stored along with +other kayobe configuration files. This file should not be manually modified. + +Configuring Custom Passwords +^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +In order to write additional passwords to ``passwords.yml``, set the kayobe +variable ``kolla_ansible_custom_passwords`` in +``$KAYOBE_CONFIG_PATH/kolla.yml``. + +.. code-block:: yaml + :caption: ``$KAYOBE_CONFIG_PATH/kolla.yml`` + + --- + # Dictionary containing custom passwords to add or override in the Kolla + # passwords file. + kolla_ansible_custom_passwords: > + {{ kolla_ansible_default_custom_passwords | + combine({'my_custom_password': 'correcthorsebatterystaple'}) }} + +Service Configuration +--------------------- + +Kolla-ansible's flexible configuration is described in the `kolla-ansible +service configuration documentation +`_. +We won't duplicate that here, but essentially it involves creating files under +a directory which for users of kayobe will be ``$KOLLA_CONFIG_PATH/config``. In +kayobe, files in this directory are auto-generated and managed by kayobe. +Instead, users should create files under ``$KAYOBE_CONFIG_PATH/kolla/config`` +with the same directory structure. These files will be templated using Jinja2, +merged with kayobe's own configuration, and written out to +``$KOLLA_CONFIG_PATH/config``. + +The following files, if present, will be templated and provided to +kolla-ansible. All paths are relative to ``$KAYOBE_CONFIG_PATH/kolla/config``. +Note that typically kolla-ansible does not use the same wildcard patterns, and +has a more restricted set of files that it will process. In some cases, it may +be necessary to inspect the kolla-ansible configuration tasks to determine +which files are supported. + +.. table: Kolla-ansible configuration files + + =============================== ======================================================= + File Purpose + =============================== ======================================================= + ``ceph/*`` Ceph configuration. + ``glance.conf`` Glance configuration. + ``glance/*`` Extended glance configuration. + ``fluentd/filter`` Fluentd filter configuration. + ``fluentd/output`` Fluentd output configuration. + ``heat.conf`` Heat configuration. + ``heat/*`` Extended heat configuration. + ``horizon/*`` Extended horizon configuration. + ``ironic-inspector.conf`` Ironic inspector configuration. + ``ironic.conf`` Ironic configuration. + ``ironic/*`` Extended ironic configuration. + ``keystone/*`` Extended keystone configuration. + ``magnum.conf`` Magnum configuration. + ``magnum/*`` Extended magnum configuration. + ``manila/*`` Extended manila configuration. + ``murano.conf`` Murano configuration. + ``murano/*`` Extended murano configuration. + ``neutron.conf`` Neutron configuration. + ``neutron/*`` Extended neutron configuration. + ``nova.conf`` Nova configuration. + ``nova/*`` Extended nova configuration. + ``sahara.conf`` Sahara configuration. + ``sahara/*`` Extended sahara configuration. + ``swift/*`` Extended swift configuration. + =============================== ======================================================= + +Configuring an OpenStack Component +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +To provide custom configuration to be applied to all glance services, create +``$KAYOBE_CONFIG_PATH/kolla/config/glance.conf``. For example: + +.. code-block:: yaml + :caption: ``$KAYOBE_CONFIG_PATH/kolla/config/glance.conf`` + + [DEFAULT] + api_limit_max = 500 + +Configuring an OpenStack Service +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +To provide custom configuration for the glance API service, create +``$KAYOBE_CONFIG_PATH/kolla/config/glance/glance-api.conf``. For example: + +.. code-block:: yaml + :caption: ``$KAYOBE_CONFIG_PATH/kolla/config/glance/glance-api.conf`` + + [DEFAULT] + api_limit_max = 500