72b63dfee7
Per comments on [1]. [1] https://review.opendev.org/c/openstack/kolla-ansible/+/843727 Change-Id: I60162b54bc06e158534d29311d4474b34750c64d
157 lines
5.3 KiB
ReStructuredText
157 lines
5.3 KiB
ReStructuredText
.. _multi-regions:
|
|
|
|
======================================
|
|
Multiple Regions Deployment with Kolla
|
|
======================================
|
|
|
|
This section describes how to perform a basic multiple region deployment
|
|
with Kolla. A basic multiple region deployment consists of separate
|
|
OpenStack installations in two or more regions (RegionOne, RegionTwo, ...)
|
|
with a shared Keystone and Horizon. The rest of this documentation assumes
|
|
Keystone and Horizon are deployed in RegionOne, and other regions have
|
|
access to the internal endpoint (for example, ``kolla_internal_fqdn``) of
|
|
RegionOne.
|
|
It also assumes that the operator knows the name of all OpenStack regions
|
|
in advance, and considers as many Kolla deployments as there are regions.
|
|
|
|
There is specifications of multiple regions deployment at
|
|
`Multi Region Support for Heat
|
|
<https://wiki.openstack.org/wiki/Heat/Blueprints/Multi_Region_Support_for_Heat>`__.
|
|
|
|
Deployment of the first region with Keystone and Horizon
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Deployment of the first region results in a typical Kolla deployment
|
|
whether it is an *all-in-one* or *multinode* deployment (see
|
|
:doc:`quickstart`). It only requires slight modifications in the
|
|
``/etc/kolla/globals.yml`` configuration file. First of all, ensure that
|
|
Keystone and Horizon are enabled:
|
|
|
|
.. code-block:: console
|
|
|
|
enable_keystone: "yes"
|
|
enable_horizon: "yes"
|
|
|
|
Then, change the value of ``multiple_regions_names`` to add names of other
|
|
regions. In this example, we consider two regions. The current one,
|
|
formerly known as RegionOne, that is hidden behind
|
|
``openstack_region_name`` variable, and the RegionTwo:
|
|
|
|
.. code-block:: yaml
|
|
|
|
openstack_region_name: "RegionOne"
|
|
multiple_regions_names:
|
|
- "{{ openstack_region_name }}"
|
|
- "RegionTwo"
|
|
|
|
.. note::
|
|
|
|
Kolla uses these variables to create necessary endpoints into
|
|
Keystone so that services of other regions can access it. Kolla
|
|
also updates the Horizon ``local_settings`` to support multiple
|
|
regions.
|
|
|
|
Finally, note the value of ``kolla_internal_fqdn`` and run
|
|
``kolla-ansible``. The ``kolla_internal_fqdn`` value will be used by other
|
|
regions to contact Keystone. For the sake of this example, we assume the
|
|
value of ``kolla_internal_fqdn`` is ``10.10.10.254``.
|
|
|
|
Deployment of other regions
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Deployment of other regions follows an usual Kolla deployment except that
|
|
OpenStack services connect to the RegionOne's Keystone. This implies to
|
|
update the ``/etc/kolla/globals.yml`` configuration file to tell Kolla how
|
|
to reach Keystone. In the following, ``kolla_internal_fqdn_r1`` refers to
|
|
the value of ``kolla_internal_fqdn`` in RegionOne:
|
|
|
|
.. code-block:: yaml
|
|
|
|
kolla_internal_fqdn_r1: 10.10.10.254
|
|
|
|
keystone_internal_url: "{{ internal_protocol }}://{{ kolla_internal_fqdn_r1 }}:{{ keystone_public_port }}"
|
|
|
|
openstack_auth:
|
|
auth_url: "{{ keystone_internal_url }}"
|
|
username: "{{ keystone_admin_user }}"
|
|
password: "{{ keystone_admin_password }}"
|
|
user_domain_name: "{{ default_user_domain_name }}"
|
|
system_scope: "all"
|
|
|
|
.. note::
|
|
|
|
If the ``kolla_internal_vip_address`` and/or the
|
|
``kolla_external_vip_address`` reside on the same subnet as
|
|
``kolla_internal_fqdn_r1``, you should set the
|
|
``keepalived_virtual_router_id`` value in the ``/etc/kolla/globals.yml``
|
|
to a unique number.
|
|
|
|
Configuration files of cinder,nova,neutron,glance... have to be updated to
|
|
contact RegionOne's Keystone. Fortunately, Kolla allows you to override all
|
|
configuration files at the same time thanks to the
|
|
``node_custom_config`` variable (see :ref:`service-config`). To do so,
|
|
create a ``global.conf`` file with the following content:
|
|
|
|
.. code-block:: ini
|
|
|
|
[keystone_authtoken]
|
|
www_authenticate_uri = {{ keystone_internal_url }}
|
|
auth_url = {{ keystone_internal_url }}
|
|
|
|
The Placement API section inside the nova configuration file also has
|
|
to be updated to contact RegionOne's Keystone. So create, in the same
|
|
directory, a ``nova.conf`` file with below content:
|
|
|
|
.. code-block:: ini
|
|
|
|
[placement]
|
|
auth_url = {{ keystone_internal_url }}
|
|
|
|
The Heat section inside the configuration file also
|
|
has to be updated to contact RegionOne's Keystone. So create, in the same
|
|
directory, a ``heat.conf`` file with below content:
|
|
|
|
.. code-block:: ini
|
|
|
|
[trustee]
|
|
www_authenticate_uri = {{ keystone_internal_url }}
|
|
auth_url = {{ keystone_internal_url }}
|
|
|
|
[ec2authtoken]
|
|
www_authenticate_uri = {{ keystone_internal_url }}
|
|
|
|
[clients_keystone]
|
|
www_authenticate_uri = {{ keystone_internal_url }}
|
|
|
|
The Ceilometer section inside the configuration file also
|
|
has to be updated to contact RegionOne's Keystone. So create, in the same
|
|
directory, a ``ceilometer.conf`` file with below content:
|
|
|
|
.. code-block:: ini
|
|
|
|
[service_credentials]
|
|
auth_url = {{ keystone_internal_url }}
|
|
|
|
And link the directory that contains these files into the
|
|
``/etc/kolla/globals.yml``:
|
|
|
|
.. code-block:: yaml
|
|
|
|
node_custom_config: path/to/the/directory/of/global&nova_conf/
|
|
|
|
Also, change the name of the current region. For instance, RegionTwo:
|
|
|
|
.. code-block:: yaml
|
|
|
|
openstack_region_name: "RegionTwo"
|
|
|
|
Finally, disable the deployment of Keystone and Horizon that are
|
|
unnecessary in this region and run ``kolla-ansible``:
|
|
|
|
.. code-block:: yaml
|
|
|
|
enable_keystone: "no"
|
|
enable_horizon: "no"
|
|
|
|
The configuration is the same for any other region.
|