13b6d692b0
use User and Group in octavia-interface service. this way looks more graceful this change also fix the octavia-interface does not restart when the octavia-interface.service changed. Change-Id: I9d253d7519b1774985d165a080047fdbecd321b4
100 lines
3.5 KiB
YAML
100 lines
3.5 KiB
YAML
---
|
|
- name: Create ports for Octavia health-manager nodes
|
|
become: true
|
|
kolla_toolbox:
|
|
module_name: os_port
|
|
module_args:
|
|
auth: "{{ octavia_user_auth }}"
|
|
cacert: "{{ openstack_cacert }}"
|
|
endpoint_type: "{{ openstack_interface }}"
|
|
region_name: "{{ openstack_region_name }}"
|
|
state: present
|
|
network: "{{ octavia_amp_network['name'] }}"
|
|
security_groups: "{{ octavia_amp_security_groups['health-mgr-sec-grp']['name'] }}"
|
|
device_owner: 'Octavia:health-mgr'
|
|
name: "octavia-listen-port-{{ ansible_nodename }}"
|
|
register: port_info
|
|
|
|
# ansible os_port module does not support 'host' parameter, but we need set the port's host
|
|
# value to {{ ansible_nodename }}, once os_port support this parameter, remove the task below
|
|
# https://docs.ansible.com/ansible/latest/modules/os_port_module.html#parameters
|
|
- name: Update Octavia health manager port host_id
|
|
become: True
|
|
vars:
|
|
port_id: "{{ port_info.id }}"
|
|
command: >
|
|
docker exec kolla_toolbox openstack
|
|
--os-interface {{ openstack_interface }}
|
|
--os-auth-url {{ octavia_user_auth.auth_url }}
|
|
--os-identity-api-version 3
|
|
--os-project-domain-name {{ octavia_user_auth.domain_name }}
|
|
--os-project-name {{ octavia_user_auth.project_name }}
|
|
--os-region-name {{ openstack_region_name }}
|
|
--os-username {{ octavia_user_auth.username }}
|
|
--os-password {{ octavia_user_auth.password }}
|
|
{% if openstack_cacert != '' %}--os-cacert {{ openstack_cacert }} {% endif %}
|
|
port set --host {{ ansible_nodename }} {{ port_id }}
|
|
when:
|
|
- port_info.changed
|
|
|
|
- name: Add Octavia port to openvswitch br-int
|
|
vars:
|
|
port_mac: "{{ port_info.port.mac_address }}"
|
|
port_id: "{{ port_info.id }}"
|
|
become: True
|
|
command: >
|
|
docker exec openvswitch_vswitchd ovs-vsctl --may-exist \
|
|
add-port br-int {{ octavia_network_interface }} \
|
|
-- set Interface {{ octavia_network_interface }} type=internal \
|
|
-- set Interface {{ octavia_network_interface }} external-ids:iface-status=active \
|
|
-- set Interface {{ octavia_network_interface }} external-ids:attached-mac={{ port_mac }} \
|
|
-- set Interface {{ octavia_network_interface }} external-ids:iface-id={{ port_id }} \
|
|
-- set Interface {{ octavia_network_interface }} external-ids:skip_cleanup=true
|
|
|
|
- name: Create octavia dhclient conf
|
|
become: true
|
|
copy:
|
|
content: |
|
|
request subnet-mask,broadcast-address,interface-mtu;
|
|
do-forward-updates false;
|
|
dest: /etc/dhcp/octavia-dhclient.conf
|
|
mode: 0664
|
|
|
|
- name: Create octavia-interface service
|
|
become: True
|
|
template:
|
|
src: octavia-interface.service.j2
|
|
dest: /etc/systemd/system/octavia-interface.service
|
|
register: octavia_interface
|
|
|
|
- name: Restart octavia-interface.service if required
|
|
become: True
|
|
systemd:
|
|
name: octavia-interface
|
|
daemon_reload: yes
|
|
state: restarted
|
|
when: octavia_interface.changed
|
|
|
|
- name: Enable and start octavia-interface.service
|
|
become: True
|
|
service:
|
|
name: octavia-interface
|
|
enabled: yes
|
|
state: started
|
|
|
|
- name: Wait for interface {{ octavia_network_interface }} ip appear
|
|
vars:
|
|
port_ip: "{{ port_info.port.fixed_ips[0].ip_address }}"
|
|
command: ip address show dev {{ octavia_network_interface }}
|
|
changed_when: false
|
|
register: ip_info
|
|
until: ip_info.stdout.find(port_ip) != -1
|
|
retries: 5
|
|
delay: 2
|
|
|
|
# NOTE(wuchunyang): we have gathered facts at first, but here we add a new
|
|
# network device(o-hm0) which is not collected, so we need gather facts again
|
|
- name: Gather facts
|
|
setup:
|
|
when: octavia_interface.changed
|