| resource_registry: |
| "MCP2::NetworkAcc": ../fragments/NetworkAccVM.yaml |
| "MCP2::NetworkPrvFl": ../fragments/NetworkPrvFl.yaml |
| "MCP2::SrvInstances": ../fragments/SrvInstancesVM.yaml |
| |
| parameters: |
| image: bionic-server-cloudimg-amd64-20190612 |
| public_net_id: public |
| host_interface: 'ens3' |
| masters_size: 2 |
| worker_size: 3 |
| cmp_size: 2 |
| gtw_size: 2 |
| lma_size: 0 |
| osd_size: 0 |
| ucp_boot_timeout: 1200 |
| cluster_public_key: ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCp0evjOaK8c8SKYK4r2+0BN7g+8YSvQ2n8nFgOURCyvkJqOHi1qPGZmuN0CclYVdVuZiXbWw3VxRbSW3EH736VzgY1U0JmoTiSamzLHaWsXvEIW8VCi7boli539QJP0ikJiBaNAgZILyCrVPN+A6mfqtacs1KXdZ0zlMq1BPtFciR1JTCRcVs5vP2Wwz5QtY2jMIh3aiwkePjMTQPcfmh1TkOlxYu5IbQyZ3G1ahA0mNKI9a0dtF282av/F6pwB/N1R1nEZ/9VtcN2I1mf1NW/tTHEEcTzXYo1R/8K9vlqAN8QvvGLZtZduGviNVNoNWvoxaXxDt8CPv2B2NCdQFZp |
| private_floating_network_cidr: '10.11.12.0/24' |
| private_floating_interface: 'ens4' |
| worker_metadata: {"labels": {"openstack-control-plane":"enabled","openvswitch":"enabled","role":"ceph-osd-node"}} |
| cmp_metadata: {"labels": {"openstack-compute-node":"enabled","openvswitch":"enabled", "role":"ceph-osd-node"}} |
| gtw_metadata: {"labels": {"openvswitch":"enabled", "gateway": "enabled"}} |
| functions_override: | |
| function network_config { |
| PUBLIC_NODE_IP_ADDRESS=${PUBLIC_INTERFACE_IP:-$(ip addr show dev ${PUBLIC_INTERFACE} | grep -Po 'inet \K[\d.]+' | egrep -v "127.0.|172.17")} |
| PUBLIC_NODE_IP_NETMASK=${PUBLIC_INTERFACE_NETMASK:-$(ip addr show dev ${PUBLIC_INTERFACE} | grep -Po 'inet \K[\d.]+\/[\d]+' | egrep -v "127.0.|172.17" | cut -d'/' -f2)} |
| |
| local public_interface=${1:-${PUBLIC_INTERFACE}} |
| local cloud_netplan_cfg="/etc/netplan/50-cloud-init.yaml" |
| local match_ip_line |
| |
| DEBIAN_FRONTEND=noninteractive apt -y install bridge-utils atop |
| |
| cat << EOF > /etc/systemd/network/10-veth-phy-br.netdev |
| [NetDev] |
| Name=veth-phy |
| Kind=veth |
| [Peer] |
| Name=veth-br |
| EOF |
| |
| sed -i 's/.*ethernets:.*/&\n veth-phy: {}/' ${cloud_netplan_cfg} |
| sed -i 's/.*ethernets:.*/&\n veth-br: {}/' ${cloud_netplan_cfg} |
| |
| match_ip_line=$(grep -nm1 "${PUBLIC_NODE_IP_ADDRESS}/${PUBLIC_NODE_IP_NETMASK}" ${cloud_netplan_cfg} | cut -d: -f1) |
| |
| sed -i "$((${match_ip_line}-1)),$((${match_ip_line}))d" ${cloud_netplan_cfg} |
| |
| cat << EOF >> ${cloud_netplan_cfg} |
| bridges: |
| br-public: |
| dhcp4: false |
| interfaces: |
| - ${PUBLIC_INTERFACE} |
| - veth-br |
| addresses: |
| - ${PUBLIC_NODE_IP_ADDRESS}/${PUBLIC_NODE_IP_NETMASK} |
| EOF |
| netplan --debug apply |
| } |