openstack-ansible/deploy-guide/source/configure.rst
Jean-Philippe Evrard 58b4f6deb7 Use root folder group_vars
Make sure the group_vars can be overriden by the deployer in
userspace.

This uses the vars_plugin to load all group_vars, to allow
key-based alphabetic merging of deployer overrides
from /etc/openstack_deploy.

Change-Id: I58aea2d2d3a1c872ae31ffe463a1ef4b553d9e17
2017-05-27 19:50:14 +00:00

5.1 KiB

Configure the deployment

Ansible references some files that contain mandatory and optional configuration directives. Before you can run the Ansible playbooks, modify these files to define the target environment. Configuration tasks include:

  • Target host networking to define bridge interfaces and networks.
  • A list of target hosts on which to install the software.
  • Virtual and physical network relationships for OpenStack Networking (neutron).
  • Passwords for all services.

Initial environment configuration

OpenStack-Ansible (OSA) depends on various files that are used to build an inventory for Ansible. Perform the following configuration on the deployment host.

  1. Copy the contents of the /opt/openstack-ansible/etc/openstack_deploy directory to the /etc/openstack_deploy directory.

  2. Change to the /etc/openstack_deploy directory.

  3. Copy the openstack_user_config.yml.example file to /etc/openstack_deploy/openstack_user_config.yml.

  4. Review the openstack_user_config.yml file and make changes to the deployment of your OpenStack environment.

    Note

    The file is heavily commented with details about the various options. See openstack-user-config-reference for more details.

The configuration in the openstack_user_config.yml file defines which hosts run the containers and services deployed by OpenStack-Ansible. For example, hosts listed in the shared-infra_hosts section run containers for many of the shared services that your OpenStack environment requires. Some of these services include databases, Memcached, and RabbitMQ. Several other host types contain other types of containers, and all of these are listed in the openstack_user_config.yml file.

For examples, please see test-environment-config and production-environment-config.

For details about how the inventory is generated from the environment configuration, see developer-inventory.

For details about how variable precedence works, and how to override group vars, see developer-inventory-and-vars.

Installing additional services

To install additional services, the files in /etc/openstack_deploy/conf.d provide examples showing the correct host groups to use. To add another service, add the host group, allocate hosts to it, and then execute the playbooks.

Advanced service configuration

OpenStack-Ansible has many options that you can use for the advanced configuration of services. Each role's documentation provides information about the available options.

Infrastructure service roles

  • :role_docs:galera_server
  • :role_docs:haproxy_server
  • :role_docs:memcached_server
  • :role_docs:rabbitmq_server
  • :role_docs:repo_build
  • :role_docs:repo_server
  • :role_docs:rsyslog_server

OpenStack service roles

  • :role_docs:os_aodh
  • :role_docs:os_barbican
  • :role_docs:os_ceilometer
  • :role_docs:os_cinder
  • :role_docs:os_designate
  • :role_docs:os_glance
  • :role_docs:os_gnocchi
  • :role_docs:os_heat
  • :role_docs:os_horizon
  • :role_docs:os_ironic
  • :role_docs:os_keystone
  • :role_docs:os_magnum
  • :role_docs:os_neutron
  • :role_docs:os_nova
  • :role_docs:os_rally
  • :role_docs:os_sahara
  • :role_docs:os_swift
  • :role_docs:os_tempest
  • :role_docs:os_trove

Other roles

  • :role_docs:apt_package_pinning
  • :role_docs:ceph_client
  • :role_docs:galera_client
  • :role_docs:lxc_container_create
  • :role_docs:lxc_hosts
  • :role_docs:pip_install
  • :role_docs:plugins
  • :role_docs:openstack_hosts
  • :role_docs:openstack_openrc
  • :role_docs:rsyslog_client

Configuring service credentials

Configure credentials for each service in the /etc/openstack_deploy/*_secrets.yml files. Consider using the Ansible Vault feature to increase security by encrypting any files that contain credentials.

Adjust permissions on these files to restrict access by nonprivileged users.

The keystone_auth_admin_password option configures the admin tenant password for both the OpenStack API and Dashboard access.

We recommend that you use the pw-token-gen.py script to generate random values for the variables in each file that contains service credentials:

# cd /opt/openstack-ansible/scripts
# python pw-token-gen.py --file /etc/openstack_deploy/user_secrets.yml

To regenerate existing passwords, add the --regen flag.

Warning

The playbooks do not currently manage changing passwords in an existing environment. Changing passwords and rerunning the playbooks will fail and might break your OpenStack environment.