Skip to content
Snippets Groups Projects
advanced-configuration.rst 9.71 KiB
Newer Older
  • Learn to ignore specific revisions
  • .. _advanced-configuration:
    
    ======================
    
    Advanced Configuration
    ======================
    
    
    Endpoint Network Configuration
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    chao liu's avatar
    chao liu committed
    When an OpenStack cloud is deployed, the REST API of each service is presented
    
    caoyuan's avatar
    caoyuan committed
    as a series of endpoints. These endpoints are the admin URL, the internal
    
    URL, and the external URL.
    
    
    Kolla offers two options for assigning these endpoints to network addresses:
    
    - Combined - Where all three endpoints share the same IP address
    - Separate - Where the external URL is assigned to an IP address that is
    different than the IP address shared by the internal and admin URLs
    
    
    The configuration parameters related to these options are:
    
    - kolla_internal_vip_address
    - network_interface
    - kolla_external_vip_address
    - kolla_external_vip_interface
    
    
    For the combined option, set the two variables below, while allowing the
    
    caoyuan's avatar
    caoyuan committed
    other two to accept their default values. In this configuration all REST
    
    API requests, internal and external, will flow over the same network.
    
    .. code-block:: yaml
    
    
       kolla_internal_vip_address: "10.10.10.254"
       network_interface: "eth0"
    
    .. end
    
    caoyuan's avatar
    caoyuan committed
    For the separate option, set these four variables. In this configuration
    
    the internal and external REST API requests can flow over separate
    
    .. code-block:: yaml
    
       kolla_internal_vip_address: "10.10.10.254"
       network_interface: "eth0"
       kolla_external_vip_address: "10.10.20.254"
       kolla_external_vip_interface: "eth1"
    
    .. end
    
    
    Fully Qualified Domain Name Configuration
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    When addressing a server on the internet, it is more common to use
    
    a name, like ``www.example.net``, instead of an address like
    ``10.10.10.254``. If you prefer to use names to address the endpoints
    in your kolla deployment use the variables:
    
    - kolla_internal_fqdn
    - kolla_external_fqdn
    
    .. code-block:: yaml
    
       kolla_internal_fqdn: inside.mykolla.example.net
       kolla_external_fqdn: mykolla.example.net
    
    
    Provisions must be taken outside of kolla for these names to map to the
    
    configured IP addresses. Using a DNS server or the ``/etc/hosts`` file
    are two ways to create this mapping.
    
    RabbitMQ Hostname Resolution
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    RabbitMQ doesn't work with IP address, hence the IP address of
    ``api_interface`` should be resolvable by hostnames to make sure that
    all RabbitMQ Cluster hosts can resolve each others hostname beforehand.
    
    ~~~~~~~~~~~~~~~~~
    
    An additional endpoint configuration option is to enable or disable
    
    caoyuan's avatar
    caoyuan committed
    TLS protection for the external VIP. TLS allows a client to authenticate
    
    the OpenStack service endpoint and allows for encryption of the requests
    and responses.
    
    
    .. note::
    
       The kolla_internal_vip_address and kolla_external_vip_address must
    
       be different to enable TLS on the external network.
    
    The configuration variables that control TLS networking are:
    
    - kolla_enable_tls_external
    - kolla_external_fqdn_cert
    
    The default for TLS is disabled, to enable TLS networking:
    
    .. code-block:: yaml
    
       kolla_enable_tls_external: "yes"
       kolla_external_fqdn_cert: "{{ node_config_directory }}/certificates/mycert.pem"
    
    .. note::
    
       TLS authentication is based on certificates that have been
    
    caoyuan's avatar
    caoyuan committed
       signed by trusted Certificate Authorities. Examples of commercial
       CAs are Comodo, Symantec, GoDaddy, and GlobalSign. Letsencrypt.org
    
       is a CA that will provide trusted certificates at no charge. Many
    
       company's IT departments will provide certificates within that
    
    caoyuan's avatar
    caoyuan committed
       company's domain. If using a trusted CA is not possible for your
    
       situation, you can use `OpenSSL <https://www.openssl.org>`__
    
    chenxing's avatar
    chenxing committed
       to create your own company's domain or see the section below about
       kolla generated self-signed certificates.
    
    
    Two certificate files are required to use TLS securely with authentication.
    
    caoyuan's avatar
    caoyuan committed
    These two files will be provided by your Certificate Authority. These
    
    two files are the server certificate with private key and the CA certificate
    
    caoyuan's avatar
    caoyuan committed
    with any intermediate certificates. The server certificate needs to be
    
    installed with the kolla deployment and is configured with the
    
    caoyuan's avatar
    caoyuan committed
    ``kolla_external_fqdn_cert`` parameter. If the server certificate provided
    
    is not already trusted by the client, then the CA certificate file will
    need to be distributed to the client.
    
    When using TLS to connect to a public endpoint, an OpenStack client will
    have settings similar to this:
    
    .. code-block:: shell
    
       export OS_PROJECT_DOMAIN_ID=default
       export OS_USER_DOMAIN_ID=default
       export OS_PROJECT_NAME=demo
       export OS_USERNAME=demo
       export OS_PASSWORD=demo-password
       export OS_AUTH_URL=https://mykolla.example.net:5000
       # os_cacert is optional for trusted certificates
       export OS_CACERT=/etc/pki/mykolla-cacert.crt
       export OS_IDENTITY_API_VERSION=3
    
    Self-Signed Certificates
    
    ~~~~~~~~~~~~~~~~~~~~~~~~
    
    .. note::
    
       Self-signed certificates should never be used in production.
    
    
    It is not always practical to get a certificate signed by a well-known
    
    caoyuan's avatar
    caoyuan committed
    trust CA, for example a development or internal test kolla deployment. In
    
    these cases it can be useful to have a self-signed certificate to use.
    
    
    For convenience, the ``kolla-ansible`` command will generate the necessary
    
    certificate files based on the information in the ``globals.yml``
    configuration file:
    
    
    .. code-block:: console
    
       kolla-ansible certificates
    
    
    The files haproxy.pem and haproxy-ca.pem will be generated and stored
    
    in the ``/etc/kolla/certificates/`` directory.
    
    rcherrueau's avatar
    rcherrueau committed
    .. _service-config:
    
    
    OpenStack Service Configuration in Kolla
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    .. note::
    
       As of now kolla only supports config overrides for ini based configs.
    
    
    An operator can change the location where custom config files are read from by
    editing ``/etc/kolla/globals.yml`` and adding the following line.
    
    .. code-block:: yaml
    
    
       # The directory to merge custom config files the kolla's config files
       node_custom_config: "/etc/kolla/config"
    
    Kolla allows the operator to override configuration of services. Kolla will
    
    Xinyuan Huang's avatar
    Xinyuan Huang committed
    look for a file in ``/etc/kolla/config/<< service name >>/<< config file >>``.
    
    This can be done per-project, per-service or per-service-on-specified-host.
    
    For example to override scheduler_max_attempts in nova scheduler, the operator
    
    needs to create ``/etc/kolla/config/nova/nova-scheduler.conf`` with content:
    
    .. path /etc/kolla/config/nova/nova-scheduler.conf
    .. code-block:: ini
    
    
       [DEFAULT]
       scheduler_max_attempts = 100
    
    
    If the operator wants to configure compute node cpu and ram allocation ratio
    
    on host myhost, the operator needs to create file
    
    ``/etc/kolla/config/nova/myhost/nova.conf`` with content:
    
    .. path /etc/kolla/config/nova/myhost/nova.conf
    .. code-block:: ini
    
       cpu_allocation_ratio = 16.0
    
       ram_allocation_ratio = 5.0
    
    
    Kolla allows the operator to override configuration globally for all services.
    It will look for a file called ``/etc/kolla/config/global.conf``.
    
    For example to modify database pool size connection for all services, the
    operator needs to create ``/etc/kolla/config/global.conf`` with content:
    
    
    .. path /etc/kolla/config/global.conf
    .. code-block:: ini
    
    In case the operators want to customize ``policy.json`` file, they should
    create a full policy file for specific project in the same directory like above
    and Kolla will overwrite default policy file with it. Be aware, with some
    projects are keeping full policy file in source code, operators just need to
    copy it but with some others are defining default rules in codebase, they have
    to generate it.
    
    For example to overwrite ``policy.json`` file of Neutron project, the operator
    needs to grab ``policy.json`` from Neutron project source code, update rules
    and then put it to ``/etc/kolla/config/neutron/policy.json``.
    
    
    .. note::
    
       Currently kolla-ansible only support JSON format for policy file.
    
    The operator can make these changes after services were already deployed by
    using following command:
    
    .. code-block:: console
    
       kolla-ansible reconfigure
    
    
    IP Address Constrained Environments
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    If a development environment doesn't have a free IP address available for VIP
    configuration, the host's IP address may be used here by disabling HAProxy by
    adding:
    
    
    .. code-block:: yaml
    
       enable_haproxy: "no"
    
    .. end
    
    
    Note this method is not recommended and generally not tested by the
    Kolla community, but included since sometimes a free IP is not available
    in a testing environment.
    
    
    External Elasticsearch/Kibana environment
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    
    It is possible to use an external Elasticsearch/Kibana environment. To do this
    first disable the deployment of the central logging.
    
    
    .. code-block:: yaml
    
    
       enable_central_logging: "no"
    
    Now you can use the parameter ``elasticsearch_address`` to configure the
    address of the external Elasticsearch environment.
    
    
    Non-default <service> port
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    
    It is sometimes required to use a different than default port
    
    for service(s) in Kolla. It is possible with setting
    ``<service>_port`` in ``globals.yml`` file. For example:
    
    
    .. code-block:: yaml
    
       database_port: 3307
    
    .. end
    
    As ``<service>_port`` value is saved in different services' configuration so
    
    it's advised to make above change before deploying.
    
    
    Use an external Syslog server
    
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    
    By default, Fluentd is used as a syslog server to collect Swift and HAProxy
    logs. When Fluentd is disabled or you want to use an external syslog server,
    
    You can set syslog parameters in ``globals.yml`` file. For example:
    
    
    .. code-block:: yaml
    
    
       syslog_server: "172.29.9.145"
       syslog_udp_port: "514"
    
    .. end
    
    You can also set syslog facility names for Swift and HAProxy logs.
    By default, Swift and HAProxy use ``local0`` and ``local1``, respectively.
    
    .. code-block:: yaml
    
       syslog_swift_facility: "local0"
       syslog_haproxy_facility: "local1"