Execution
Date 08 Dec 2025 13:50:33 +0000
Duration 00:06:27.80
Controller aio1.openstack.local
User root
Versions
Ansible 2.18.6
ara 1.7.4 / 1.7.4
Python 3.12.11
Summary
7 Hosts
589 Tasks
576 Results
37 Plays
222 Files
0 Records

File: /etc/ansible/ansible_collections/openstack/osa/playbooks/haproxy.yml

---
# Copyright 2014, Rackspace US, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

- name: Gather haproxy facts
  hosts: haproxy
  gather_facts: "{{ osa_gather_facts | default(true) }}"
  module_defaults:
    ansible.builtin.setup:
      gather_subset: "{{ osa_gather_subset | default(lookup('ansible.builtin.env', 'ANSIBLE_GATHER_SUBSET', default='!all,min')) }}"
  tasks:
    - name: Gather additional facts
      ansible.builtin.include_role:
        name: openstack.osa.gather_extra_facts
      when: osa_gather_facts | default(true)
  tags:
    - always

- name: HAProxy base config
  hosts: haproxy
  gather_facts: false
  serial: "{{ haproxy_serial | default('50%') }}"
  user: root
  pre_tasks:
    - name: Including container-setup tasks
      ansible.builtin.include_role:
        name: "openstack.osa.{{ container_tech | default('lxc') }}_container_setup"
      when: not is_metal
    - name: Including unbound-clients tasks
      ansible.builtin.include_role:
        name: openstack.osa.unbound_clients
      when:
        - hostvars['localhost']['resolvconf_enabled'] | bool
    - name: Remove legacy haproxy configuration files
      ansible.builtin.file:
        dest: "/etc/haproxy/conf.d/{{ item.name }}"
        state: "absent"
      with_items:
        - name: "keystone_internal"
          when: "internal_lb_vip_address == external_lb_vip_address"
        - name: "heat_api_cloudwatch"
          when: "yes"
      when:
        - "item.when | bool"
      tags:
        - haproxy-config  # this tag is present because the task is ONLY a config task

  roles:
    - role: "keepalived"
      when: haproxy_use_keepalived | bool
      tags:
        - keepalived

    - role: "haproxy_server"
      haproxy_service_configs: "{{ haproxy_default_services + haproxy_extra_services | default([]) }}"

  environment: "{{ deployment_environment_variables | default({}) }}"
  tags:
    - haproxy-config
    - haproxy