Use haproxy for metal deployments

Depends-On: https://review.opendev.org/754092
Depends-On: https://review.opendev.org/754093
Change-Id: Ib3b9ebd5a4c204d2f14c6b5d2b9d3e42669e8931
This commit is contained in:
Jonathan Rosser 2020-06-03 22:10:43 +01:00
parent e1144246d6
commit 4b8a3b05b1
5 changed files with 8 additions and 15 deletions

View File

@ -22,6 +22,7 @@ used_ips:
{% endif %} {% endif %}
- "172.29.236.1,172.29.236.50" - "172.29.236.1,172.29.236.50"
- "172.29.236.100" - "172.29.236.100"
- "172.29.236.101"
- "172.29.240.1,172.29.240.50" - "172.29.240.1,172.29.240.50"
- "172.29.240.100" - "172.29.240.100"
- "172.29.244.1,172.29.244.50" - "172.29.244.1,172.29.244.50"
@ -30,7 +31,7 @@ used_ips:
- "172.29.248.100" - "172.29.248.100"
global_overrides: global_overrides:
internal_lb_vip_address: 172.29.236.100 internal_lb_vip_address: 172.29.236.101
# The external IP is quoted simply to ensure that the .aio file can be used as input # The external IP is quoted simply to ensure that the .aio file can be used as input
# dynamic inventory testing. # dynamic inventory testing.
external_lb_vip_address: "{{ bootstrap_host_public_address | default(ansible_default_ipv4.address) }}" external_lb_vip_address: "{{ bootstrap_host_public_address | default(ansible_default_ipv4.address) }}"

View File

@ -44,8 +44,6 @@
msg: "The scenario key words 'lxc' and 'metal' are mutually exclusive." msg: "The scenario key words 'lxc' and 'metal' are mutually exclusive."
- conditional: "{{ (bootstrap_host_scenario is search('metal')) and (bootstrap_host_scenario is search('nspawn')) }}" - conditional: "{{ (bootstrap_host_scenario is search('metal')) and (bootstrap_host_scenario is search('nspawn')) }}"
msg: "The scenario key words 'metal' and 'nspawn' are mutually exclusive." msg: "The scenario key words 'metal' and 'nspawn' are mutually exclusive."
- conditional: "{{ (bootstrap_host_scenario is search('metal')) and (bootstrap_host_scenario is search('haproxy')) }}"
msg: "The scenario key words 'metal' and 'haproxy' are mutually exclusive."
- name: Identify the space available in / - name: Identify the space available in /
# NOTE(hwoarang): df does not work reliably on btrfs filesystems # NOTE(hwoarang): df does not work reliably on btrfs filesystems

View File

@ -104,8 +104,11 @@
bridge: "br-mgmt" bridge: "br-mgmt"
mtu: 9000 mtu: 9000
- interface: "br-mgmt" - interface: "br-mgmt"
address: "172.29.236.100" config_overrides:
netmask: "255.255.252.0" Network:
Address:
? "172.29.236.100/22"
? "172.29.236.101/22"
- interface: "dummy-storage" - interface: "dummy-storage"
bridge: "br-storage" bridge: "br-storage"

View File

@ -40,12 +40,6 @@ galera_wsrep_provider_options:
## Repo ## Repo
repo_nginx_threads: 2 repo_nginx_threads: 2
{% if 'metal' in bootstrap_host_scenarios %}
# NOTE(mnaser): We don't currently deploy HAproxy in metal scenarios therefore
# all URLs which be using HTTP instead of HTTPS.
openstack_service_publicuri_proto: http
{% endif %}
## Keystone ## Keystone
keystone_httpd_mpm_start_servers: 2 keystone_httpd_mpm_start_servers: 2
keystone_httpd_mpm_min_spare_threads: 1 keystone_httpd_mpm_min_spare_threads: 1

View File

@ -20,12 +20,9 @@ bootstrap_host_scenarios: "{{ (bootstrap_host_scenario.split('_') | reject('equa
bootstrap_host_scenarios_expanded: |- bootstrap_host_scenarios_expanded: |-
{# Keystone is included in every scenario #} {# Keystone is included in every scenario #}
{% set scenario_list = bootstrap_host_scenarios + ['keystone'] %} {% set scenario_list = bootstrap_host_scenarios + ['keystone'] %}
{% if 'metal' not in bootstrap_host_scenarios %}
{% set _ = scenario_list.append('haproxy') %}
{% endif %}
{% if ['aio', 'translations'] | intersect(bootstrap_host_scenarios) | length > 0 %} {% if ['aio', 'translations'] | intersect(bootstrap_host_scenarios) | length > 0 %}
{# Base services deployed with aio and translations scenarios #} {# Base services deployed with aio and translations scenarios #}
{% set _ = scenario_list.extend(['cinder', 'glance', 'neutron', 'nova', 'placement']) %} {% set _ = scenario_list.extend(['cinder', 'glance', 'neutron', 'nova', 'placement', 'haproxy']) %}
{% if 'metal' not in bootstrap_host_scenarios %} {% if 'metal' not in bootstrap_host_scenarios %}
{# Horizon is a base service in container jobs #} {# Horizon is a base service in container jobs #}
{% set _ = scenario_list.append('horizon') %} {% set _ = scenario_list.append('horizon') %}