1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
{% set control_dict = {} %}
{% set compute_dict = {} %}
{% for host in groups['ostack'] %}
{% if hostvars[host].node_type is defined and hostvars[host].node_type == 'controller' %}
{% set control_dict = control_dict.update({hostvars[host].ansible_host: hostvars[host].ansible_default_ipv4.interface}) %}
{% endif %}
{% endfor %}
{% for host in groups['ostack'] %}
{% if hostvars[host].node_type is defined and hostvars[host].node_type == 'compute' %}
{% for iface in hostvars[host].ansible_interfaces %}
{%- if ((hostvars[host]['ansible_' + iface.replace('-', '_')].ipv4 is defined) and
(hostvars[host]['ansible_' + iface.replace('-', '_')].ipv4.address is defined) and
(hostvars[host]['ansible_' + iface.replace('-', '_')].ipv4.address == hostvars[host].secondary_ip)) -%}
{% set compute_dict = compute_dict.update({hostvars[host].ansible_host: iface}) %}
{% endif %}
{% endfor %}
{% endif %}
{% endfor %}
{% macro print_node(in_dict, iface_str='', cnt=1) %}
{%- for host, iface in in_dict | dictsort -%}
{% if loop.index <= cnt %}
{% if iface_str %}
{{ host }} ansible_ssh_user={{ hostvars[host].ansible_user }} ansible_private_key_file=/root/.ssh/id_rsa ansible_become=True {{ iface_str }}={{ iface }}
{% else %}
{{ host }} ansible_ssh_user={{ hostvars[host].ansible_user }} ansible_private_key_file=/root/.ssh/id_rsa ansible_become=True
{% endif %}
{% endif %}
{% endfor %}
{% endmacro %}
[control]
{{ print_node(control_dict, iface_str='network_interface', cnt=control_dict | length) }}
[compute]
{{ print_node(compute_dict, iface_str='network_interface', cnt=compute_dict | length) }}
[network]
{{ print_node(control_dict, iface_str='', cnt=control_dict | length) }}
[monitoring]
{{ print_node(control_dict) }}
[storage]
{{ print_node(control_dict, iface_str='', cnt=control_dict | length) }}
|