Merge "Rename role haproxy to loadbalancer"

This commit is contained in:
Zuul 2021-09-02 16:18:58 +00:00 committed by Gerrit Code Review
commit 0e9a6fe773
27 changed files with 65 additions and 46 deletions

View File

@ -577,6 +577,7 @@ enable_openstack_core: "yes"
enable_glance: "{{ enable_openstack_core | bool }}" enable_glance: "{{ enable_openstack_core | bool }}"
enable_haproxy: "yes" enable_haproxy: "yes"
enable_keepalived: "{{ enable_haproxy | bool }}" enable_keepalived: "{{ enable_haproxy | bool }}"
enable_loadbalancer: "{{ enable_haproxy | bool or enable_keepalived | bool }}"
enable_keystone: "{{ enable_openstack_core | bool }}" enable_keystone: "{{ enable_openstack_core | bool }}"
enable_keystone_federation: "{{ (keystone_identity_providers | length > 0) and (keystone_identity_mappings | length > 0) }}" enable_keystone_federation: "{{ (keystone_identity_providers | length > 0) and (keystone_identity_mappings | length > 0) }}"
enable_mariadb: "yes" enable_mariadb: "yes"

View File

@ -75,9 +75,15 @@ control
[hacluster-remote:children] [hacluster-remote:children]
compute compute
[haproxy:children] [loadbalancer:children]
network network
[keepalived:children]
loadbalancer
[haproxy:children]
loadbalancer
[mariadb:children] [mariadb:children]
control control

View File

@ -99,9 +99,15 @@ control
[hacluster-remote:children] [hacluster-remote:children]
compute compute
[haproxy:children] [loadbalancer:children]
network network
[keepalived:children]
loadbalancer
[haproxy:children]
loadbalancer
[mariadb:children] [mariadb:children]
control control

View File

@ -1,3 +0,0 @@
---
- include_tasks: "{{ kolla_action }}.yml"
when: inventory_hostname in groups['haproxy']

View File

@ -1,7 +1,7 @@
--- ---
project_name: "haproxy" project_name: "loadbalancer"
haproxy_services: loadbalancer_services:
haproxy: haproxy:
container_name: haproxy container_name: haproxy
group: haproxy group: haproxy
@ -13,7 +13,7 @@ haproxy_services:
healthcheck: "{{ haproxy_healthcheck }}" healthcheck: "{{ haproxy_healthcheck }}"
keepalived: keepalived:
container_name: keepalived container_name: keepalived
group: haproxy group: keepalived
enabled: "{{ enable_keepalived | bool }}" enabled: "{{ enable_keepalived | bool }}"
image: "{{ keepalived_image_full }}" image: "{{ keepalived_image_full }}"
privileged: True privileged: True

View File

@ -49,7 +49,7 @@
- name: Restart backup haproxy container - name: Restart backup haproxy container
vars: vars:
service_name: "haproxy" service_name: "haproxy"
service: "{{ haproxy_services[service_name] }}" service: "{{ loadbalancer_services[service_name] }}"
become: true become: true
kolla_docker: kolla_docker:
action: "recreate_or_restart_container" action: "recreate_or_restart_container"
@ -78,7 +78,7 @@
- name: Start backup keepalived container - name: Start backup keepalived container
vars: vars:
service_name: "keepalived" service_name: "keepalived"
service: "{{ haproxy_services[service_name] }}" service: "{{ loadbalancer_services[service_name] }}"
become: true become: true
kolla_docker: kolla_docker:
action: "recreate_or_restart_container" action: "recreate_or_restart_container"
@ -128,7 +128,7 @@
- name: Start master haproxy container - name: Start master haproxy container
vars: vars:
service_name: "haproxy" service_name: "haproxy"
service: "{{ haproxy_services[service_name] }}" service: "{{ loadbalancer_services[service_name] }}"
become: true become: true
kolla_docker: kolla_docker:
action: "recreate_or_restart_container" action: "recreate_or_restart_container"
@ -157,7 +157,7 @@
- name: Start master keepalived container - name: Start master keepalived container
vars: vars:
service_name: "keepalived" service_name: "keepalived"
service: "{{ haproxy_services[service_name] }}" service: "{{ loadbalancer_services[service_name] }}"
become: true become: true
kolla_docker: kolla_docker:
action: "recreate_or_restart_container" action: "recreate_or_restart_container"

View File

@ -1,5 +1,5 @@
--- ---
- name: Check haproxy containers - name: Check loadbalancer containers
become: true become: true
kolla_docker: kolla_docker:
action: "compare_container" action: "compare_container"
@ -13,6 +13,6 @@
when: when:
- inventory_hostname in groups[item.value.group] - inventory_hostname in groups[item.value.group]
- item.value.enabled | bool - item.value.enabled | bool
with_dict: "{{ haproxy_services }}" with_dict: "{{ loadbalancer_services }}"
notify: notify:
- "Restart {{ item.key }} container" - "Restart {{ item.key }} container"

View File

@ -10,11 +10,11 @@
when: when:
- inventory_hostname in groups[item.value.group] - inventory_hostname in groups[item.value.group]
- item.value.enabled | bool - item.value.enabled | bool
with_dict: "{{ haproxy_services }}" with_dict: "{{ loadbalancer_services }}"
- name: Ensuring service config subdir exists - name: Ensuring haproxy service config subdir exists
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
file: file:
path: "{{ node_config_directory }}/haproxy/services.d" path: "{{ node_config_directory }}/haproxy/services.d"
state: "directory" state: "directory"
@ -28,20 +28,20 @@
- name: Copying over config.json files for services - name: Copying over config.json files for services
template: template:
src: "{{ item.key }}.json.j2" src: "{{ item.key }}/{{ item.key }}.json.j2"
dest: "{{ node_config_directory }}/{{ item.key }}/config.json" dest: "{{ node_config_directory }}/{{ item.key }}/config.json"
mode: "0660" mode: "0660"
become: true become: true
when: when:
- inventory_hostname in groups[item.value.group] - inventory_hostname in groups[item.value.group]
- item.value.enabled | bool - item.value.enabled | bool
with_dict: "{{ haproxy_services }}" with_dict: "{{ loadbalancer_services }}"
notify: notify:
- "Restart {{ item.key }} container" - "Restart {{ item.key }} container"
- name: Copying over haproxy.cfg - name: Copying over haproxy.cfg
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
template: template:
src: "{{ item }}" src: "{{ item }}"
dest: "{{ node_config_directory }}/haproxy/haproxy.cfg" dest: "{{ node_config_directory }}/haproxy/haproxy.cfg"
@ -53,13 +53,13 @@
with_first_found: with_first_found:
- "{{ node_custom_config }}/haproxy/{{ inventory_hostname }}/haproxy_main.cfg" - "{{ node_custom_config }}/haproxy/{{ inventory_hostname }}/haproxy_main.cfg"
- "{{ node_custom_config }}/haproxy/haproxy_main.cfg" - "{{ node_custom_config }}/haproxy/haproxy_main.cfg"
- "haproxy_main.cfg.j2" - "haproxy/haproxy_main.cfg.j2"
notify: notify:
- Restart haproxy container - Restart haproxy container
- name: Copying over custom haproxy services configuration - name: Copying over custom haproxy services configuration
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
template: template:
src: "{{ item }}" src: "{{ item }}"
dest: "{{ node_config_directory }}/haproxy/services.d/" dest: "{{ node_config_directory }}/haproxy/services.d/"
@ -75,7 +75,7 @@
- name: Copying over keepalived.conf - name: Copying over keepalived.conf
vars: vars:
service: "{{ haproxy_services['keepalived'] }}" service: "{{ loadbalancer_services['keepalived'] }}"
template: template:
src: "{{ item }}" src: "{{ item }}"
dest: "{{ node_config_directory }}/keepalived/keepalived.conf" dest: "{{ node_config_directory }}/keepalived/keepalived.conf"
@ -87,13 +87,13 @@
with_first_found: with_first_found:
- "{{ node_custom_config }}/keepalived/{{ inventory_hostname }}/keepalived.conf" - "{{ node_custom_config }}/keepalived/{{ inventory_hostname }}/keepalived.conf"
- "{{ node_custom_config }}/keepalived/keepalived.conf" - "{{ node_custom_config }}/keepalived/keepalived.conf"
- "keepalived.conf.j2" - "keepalived/keepalived.conf.j2"
notify: notify:
- Restart keepalived container - Restart keepalived container
- name: Copying over haproxy.pem - name: Copying over haproxy.pem
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
copy: copy:
src: "{{ kolla_external_fqdn_cert }}" src: "{{ kolla_external_fqdn_cert }}"
dest: "{{ node_config_directory }}/haproxy/{{ item }}" dest: "{{ node_config_directory }}/haproxy/{{ item }}"
@ -111,7 +111,7 @@
- name: Copying over haproxy-internal.pem - name: Copying over haproxy-internal.pem
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
copy: copy:
src: "{{ kolla_internal_fqdn_cert }}" src: "{{ kolla_internal_fqdn_cert }}"
dest: "{{ node_config_directory }}/haproxy/{{ item }}" dest: "{{ node_config_directory }}/haproxy/{{ item }}"
@ -133,7 +133,7 @@
- name: Copying over haproxy start script - name: Copying over haproxy start script
vars: vars:
service: "{{ haproxy_services['haproxy'] }}" service: "{{ loadbalancer_services['haproxy'] }}"
template: template:
src: "{{ item }}" src: "{{ item }}"
dest: "{{ node_config_directory }}/haproxy/haproxy_run.sh" dest: "{{ node_config_directory }}/haproxy/haproxy_run.sh"
@ -145,6 +145,6 @@
with_first_found: with_first_found:
- "{{ node_custom_config }}/haproxy/{{ inventory_hostname }}/haproxy_run.sh" - "{{ node_custom_config }}/haproxy/{{ inventory_hostname }}/haproxy_run.sh"
- "{{ node_custom_config }}/haproxy/haproxy_run.sh" - "{{ node_custom_config }}/haproxy/haproxy_run.sh"
- "haproxy_run.sh.j2" - "haproxy/haproxy_run.sh.j2"
notify: notify:
- Restart haproxy container - Restart haproxy container

View File

@ -3,4 +3,4 @@
import_role: import_role:
role: service-cert-copy role: service-cert-copy
vars: vars:
project_services: "{{ haproxy_services }}" project_services: "{{ loadbalancer_services }}"

View File

@ -0,0 +1,3 @@
---
- include_tasks: "{{ kolla_action }}.yml"
when: inventory_hostname in groups['loadbalancer']

View File

@ -2,7 +2,7 @@
- import_role: - import_role:
name: service-precheck name: service-precheck
vars: vars:
service_precheck_services: "{{ haproxy_services }}" service_precheck_services: "{{ loadbalancer_services }}"
service_name: "{{ project_name }}" service_name: "{{ project_name }}"
- name: Get container facts - name: Get container facts
@ -19,7 +19,7 @@
changed_when: false changed_when: false
when: when:
- enable_keepalived | bool - enable_keepalived | bool
- inventory_hostname in groups['haproxy'] - inventory_hostname in groups['keepalived']
- name: Group hosts by whether they are running HAProxy - name: Group hosts by whether they are running HAProxy
group_by: group_by:
@ -34,7 +34,7 @@
# NOTE(mgoddard): We can only reliably run this precheck if all hosts in # NOTE(mgoddard): We can only reliably run this precheck if all hosts in
# the haproxy group are included in the batch. This may not be the case if # the haproxy group are included in the batch. This may not be the case if
# using --limit or --serial. # using --limit or --serial.
all_hosts_in_batch: "{{ groups['haproxy'] | difference(ansible_play_batch) | list | length == 0 }}" all_hosts_in_batch: "{{ groups['loadbalancer'] | difference(ansible_play_batch) | list | length == 0 }}"
set_fact: set_fact:
keepalived_vip_prechecks: "{{ all_hosts_in_batch and groups['keepalived_running_True'] is not defined }}" keepalived_vip_prechecks: "{{ all_hosts_in_batch and groups['keepalived_running_True'] is not defined }}"
haproxy_vip_prechecks: "{{ all_hosts_in_batch and groups['haproxy_running_True'] is not defined }}" haproxy_vip_prechecks: "{{ all_hosts_in_batch and groups['haproxy_running_True'] is not defined }}"
@ -156,7 +156,7 @@
- enable_haproxy | bool - enable_haproxy | bool
- enable_keepalived | bool - enable_keepalived | bool
- container_facts['keepalived'] is not defined - container_facts['keepalived'] is not defined
- inventory_hostname in groups['haproxy'] - inventory_hostname in groups['loadbalancer']
- name: Getting haproxy stat - name: Getting haproxy stat
shell: echo "show stat" | docker exec -i haproxy socat unix-connect:/var/lib/kolla/haproxy/haproxy.sock stdio # noqa 306 shell: echo "show stat" | docker exec -i haproxy socat unix-connect:/var/lib/kolla/haproxy/haproxy.sock stdio # noqa 306

View File

@ -2,5 +2,5 @@
- import_role: - import_role:
name: service-stop name: service-stop
vars: vars:
project_services: "{{ haproxy_services }}" project_services: "{{ loadbalancer_services }}"
service_name: "{{ project_name }}" service_name: "{{ project_name }}"

View File

@ -10,13 +10,13 @@ vrrp_instance kolla_internal_vip_{{ keepalived_virtual_router_id }} {
nopreempt nopreempt
interface {{ api_interface }} interface {{ api_interface }}
virtual_router_id {{ keepalived_virtual_router_id }} virtual_router_id {{ keepalived_virtual_router_id }}
priority {{ groups['haproxy'].index(inventory_hostname) + 1 }} priority {{ groups['loadbalancer'].index(inventory_hostname) + 1 }}
advert_int 1 advert_int 1
{% if keepalived_traffic_mode == 'unicast' %} {% if keepalived_traffic_mode == 'unicast' %}
unicast_src_ip {{ api_interface_address }} unicast_src_ip {{ api_interface_address }}
{% if groups['haproxy'] | length > 1 %} {% if groups['loadbalancer'] | length > 1 %}
unicast_peer { unicast_peer {
{% for host in groups['haproxy'] %} {% for host in groups['loadbalancer'] %}
{% set ip_addr = 'api' | kolla_address(host) %} {% set ip_addr = 'api' | kolla_address(host) %}
{% if ip_addr != api_interface_address %} {% if ip_addr != api_interface_address %}
{{ ip_addr }} {{ ip_addr }}

View File

@ -8,7 +8,7 @@
when: when:
- not enable_mariadb | bool - not enable_mariadb | bool
- enable_external_mariadb_load_balancer | bool - enable_external_mariadb_load_balancer | bool
- inventory_hostname in groups['haproxy'] - inventory_hostname in groups['loadbalancer']
- name: "Check if external database address is reachable from all hosts" - name: "Check if external database address is reachable from all hosts"
wait_for: wait_for:

View File

@ -34,7 +34,6 @@
- enable_glance_{{ enable_glance | bool }} - enable_glance_{{ enable_glance | bool }}
- enable_gnocchi_{{ enable_gnocchi | bool }} - enable_gnocchi_{{ enable_gnocchi | bool }}
- enable_grafana_{{ enable_grafana | bool }} - enable_grafana_{{ enable_grafana | bool }}
- enable_haproxy_{{ enable_haproxy | bool }}
- enable_hacluster_{{ enable_hacluster | bool }} - enable_hacluster_{{ enable_hacluster | bool }}
- enable_heat_{{ enable_heat | bool }} - enable_heat_{{ enable_heat | bool }}
- enable_horizon_{{ enable_horizon | bool }} - enable_horizon_{{ enable_horizon | bool }}
@ -45,6 +44,7 @@
- enable_keystone_{{ enable_keystone | bool }} - enable_keystone_{{ enable_keystone | bool }}
- enable_kibana_{{ enable_kibana | bool }} - enable_kibana_{{ enable_kibana | bool }}
- enable_kuryr_{{ enable_kuryr | bool }} - enable_kuryr_{{ enable_kuryr | bool }}
- enable_loadbalancer_{{ enable_loadbalancer | bool }}
- enable_magnum_{{ enable_magnum | bool }} - enable_magnum_{{ enable_magnum | bool }}
- enable_manila_{{ enable_manila | bool }} - enable_manila_{{ enable_manila | bool }}
- enable_mariadb_{{ enable_mariadb | bool }} - enable_mariadb_{{ enable_mariadb | bool }}
@ -113,17 +113,17 @@
tags: chrony, tags: chrony,
when: enable_chrony | bool } when: enable_chrony | bool }
- name: Apply role haproxy - name: Apply role loadbalancer
gather_facts: false gather_facts: false
hosts: hosts:
- haproxy - loadbalancer
- '&enable_haproxy_True' - '&enable_loadbalancer_True'
serial: '{{ kolla_serial|default("0") }}' serial: '{{ kolla_serial|default("0") }}'
tags: tags:
- haproxy - loadbalancer
roles: roles:
- { role: haproxy, - { role: loadbalancer,
when: enable_haproxy | bool } when: enable_loadbalancer | bool }
tasks: tasks:
- block: - block:
- include_role: - include_role:

View File

@ -155,9 +155,15 @@ control
[hacluster-remote:children] [hacluster-remote:children]
compute compute
[haproxy:children] [loadbalancer:children]
network network
[keepalived:children]
loadbalancer
[haproxy:children]
loadbalancer
[mariadb:children] [mariadb:children]
control control