summaryrefslogtreecommitdiffstats
path: root/mcp/reclass/classes/cluster/baremetal-mcp-ocata-common/openstack_compute_init.yml.j2
blob: cad407f57fe5ca927982bea8e54d5223977f685a (plain)
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
##############################################################################
# Copyright (c) 2017 Mirantis Inc., Enea AB and others.
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
{# NOTE: br-{mgmt,ctl} are cross-referenced, careful when changing names #}
{%- if conf.net_config is defined and conf.idf is defined -%}
    {#- NOTE: Currently, we assume all cluster nodes use the same mapping -#}

    {#- Determine interface index for each network (plumbing vars) -#}
    {%- set idx_admin = conf['net_config']['admin']['interface'] -%}
    {%- set idx_mgmt = conf['net_config']['mgmt']['interface'] -%}
    {%- set idx_private = conf['net_config']['private']['interface'] -%}
    {%- set idx_public = conf['net_config']['public']['interface'] -%}

    {#- Physical interface OS name for each network (e.g. em1, enp1s0f1) -#}
    {%- set iface_names = conf['idf']['fuel']['network']['node'][0]['interfaces'] -%}
    {%- set nic_admin = iface_names[idx_admin] -%}
    {%- set nic_mgmt = iface_names[idx_mgmt] -%}
    {%- set nic_private = iface_names[idx_private] -%}
    {%- set nic_public = iface_names[idx_public] -%}

    {#- VLAN for each network (only untagged 'admin' is supported by MaaS config!) -#}
    {%- set vlan_admin = conf['net_config']['admin']['vlan'] -%}
    {%- set vlan_mgmt = conf['net_config']['mgmt']['vlan'] -%}
    {%- set vlan_private = conf['net_config']['private']['vlan'] -%}
    {%- set vlan_public = conf['net_config']['public']['vlan'] -%}

    {%- set gateway_public = conf['net_config']['public']['gateway'] -%}
{%- else -%}
    {%- set nic_admin = 'enp6s0' -%}
    {%- set nic_mgmt = 'enp6s0' -%}
    {%- set nic_private = None -%}
    {%- set nic_public = None -%}
    {%- set vlan_admin = 'native' -%}
    {%- set vlan_mgmt = '300' -%}
    {%- set vlan_private = '1000' -%}
{%- endif -%}

{#- Filter-out NIC duplicates by constructing a dict (used NICs only) -#}
{%- set nics = { nic_admin: True, nic_mgmt: True, nic_public: True} -%}

{%- set vlans = { vlan_admin: nic_admin, vlan_mgmt: nic_mgmt, vlan_public: nic_public} -%}
---
parameters:
  linux:
    network:
      bridge: openvswitch
      interface:
{%- for nic in nics %}
    {%- if nic == nic_admin %}
        {{ nic }}:
          enabled: true
          type: eth
          proto: dhcp
          name: {{ nic }}
    {%- else %}
        {{ nic }}:
          enabled: true
          type: eth
          proto: manual
          address: 0.0.0.0
          netmask: 255.255.255.0
          mtu: ${_param:interface_mtu}
          name: {{ nic }}
    {%- endif %}
{%- endfor %}

{%- for vlan in vlans %}
    {%- if vlan and vlan != 'native' %}
        {{ vlans[vlan] }}.{{ vlan }}:
          enabled: true
          proto: manual
          type: vlan
          name: {{ vlans[vlan] }}.{{ vlan }}
          use_interfaces:
            - {{ vlans[vlan] }}
    {%- endif %}
{%- endfor %}

        br-ctl:
          enabled: true
          type: bridge
          proto: static
          address: ${_param:single_address}
          netmask: 255.255.255.0
          use_interfaces:
            - {{ nic_mgmt }}{% if vlan_mgmt and vlan_mgmt != 'native' %}.{{ vlan_mgmt }}{% endif %}
        br-floating:
          enabled: true
          type: ovs_bridge
          mtu: ${_param:interface_mtu}
        br-ex:
          enabled: true
          type: ovs_bridge
          mtu: ${_param:interface_mtu}
          address: ${_param:external_address}
          netmask: 255.255.255.0
          proto: static
          gateway: {{ gateway_public }}
        floating-to-ex:
          enabled: true
          type: ovs_port
          port_type: patch
          bridge: br-floating
          peer: ex-to-floating
        ex-to-floating:
          enabled: true
          type: ovs_port
          port_type: patch
          bridge: br-ex
          peer: floating-to-ex
        public_ovs_interface:
          enabled: true
          name: {{ nic_public }}{% if vlan_public and vlan_public != 'native' %}.{{ vlan_public }}{% endif %}
          proto: manual
          ovs_port_type: OVSPort
          type: ovs_port
          ovs_bridge: br-ex
          bridge: br-ex