openstack-ansible/doc/source/install-guide-revised-draft/overview-network-arch.rst
Jesse Pretorius 24e63abeb2 Fix 'D001 Line too long' documentation lint failures
Change-Id: I4522fe318541dac7f4ff4e45d72d4cd8869420ba
2016-07-13 21:32:31 +00:00

11 KiB

Home OpenStack-Ansible Installation Guide

Network architecture

For a production environment, some components are mandatory, such as bridges described below. We recommend other components such as a bonded network interface.

Important

Follow the reference design as closely as possible.

Although Ansible automates most deployment operations, networking on target hosts requires manual configuration as it varies dramatically per environment. For demonstration purposes, these instructions use a reference architecture with example network interface names, networks, and IP addresses. Modify these values as needed for your particular environment.

Bonded network interfaces

The reference architecture for a production environment includes bonded network interfaces, which use multiple physical network interfaces for better redundancy and throughput. Avoid using two ports on the same multi-port network card for the same bonded interface since a network card failure affects both physical network interfaces used by the bond.

The bond0 interface carries traffic from the containers running your OpenStack infrastructure. Configure a static IP address on the bond0 interface from your management network.

The bond1 interface carries traffic from your virtual machines. Do not configure a static IP on this interface, since neutron uses this bond to handle VLAN and VXLAN networks for virtual machines.

Additional bridge networks are required for OpenStack-Ansible. These bridges connect the two bonded network interfaces.

Adding bridges

The combination of containers and flexible deployment options require implementation of advanced Linux networking features, such as bridges and namespaces.

Bridges provide layer 2 connectivity (similar to switches) among physical, logical, and virtual network interfaces within a host. After creating a bridge, the network interfaces are virtually plugged in to it.

OpenStack-Ansible uses bridges to connect physical and logical network interfaces on the host to virtual network interfaces within containers.

Namespaces provide logically separate layer 3 environments (similar to routers) within a host. Namespaces use virtual interfaces to connect with other namespaces, including the host namespace. These interfaces, often called veth pairs, are virtually plugged in between namespaces similar to patch cables connecting physical devices such as switches and routers.

Each container has a namespace that connects to the host namespace with one or more veth pairs. Unless specified, the system generates random names for veth pairs.

The following image demonstrates how the container network interfaces are connected to the host's bridges and to the host's physical network interfaces:

image

Target hosts contain the following network bridges:

  • LXC internal lxcbr0:
    • This bridge is required, but LXC configures it automatically.
    • Provides external (typically internet) connectivity to containers.
    • This bridge does not directly attach to any physical or logical interfaces on the host because iptables handles connectivity. It attaches to eth0 in each container, but the container network interface is configurable in openstack_user_config.yml in the provider_networks dictionary.
  • Container management br-mgmt:
    • This bridge is required.
    • Provides management of and communication among infrastructure and OpenStack services.
    • Manually creates and attaches to a physical or logical interface, typically a bond0 VLAN subinterface. Also attaches to eth1 in each container. The container network interface is configurable in openstack_user_config.yml.
  • Storage br-storage:
    • This bridge is optional, but recommended.
    • Provides segregated access to Block Storage devices between Compute and Block Storage hosts.
    • Manually creates and attaches to a physical or logical interface, typically a bond0 VLAN subinterface. Also attaches to eth2 in each associated container. The container network interface is configurable in openstack_user_config.yml.
  • OpenStack Networking tunnel br-vxlan:
    • This bridge is required.
    • Provides infrastructure for VXLAN tunnel networks.
    • Manually creates and attaches to a physical or logical interface, typically a bond1 VLAN subinterface. Also attaches to eth10 in each associated container. The container network interface is configurable in openstack_user_config.yml.
  • OpenStack Networking provider br-vlan:
    • This bridge is required.
    • Provides infrastructure for VLAN networks.
    • Manually creates and attaches to a physical or logical interface, typically bond1. Attaches to eth11 for vlan type networks in each associated container. It does not contain an IP address because it only handles layer 2 connectivity. The container network interface is configurable in openstack_user_config.yml.
    • This interface supports flat networks with additional bridge configuration. More details are available here: network_configuration.

Network diagrams

The following image shows how all of the interfaces and bridges interconnect to provide network connectivity to the OpenStack deployment:

image

OpenStack-Ansible deploys the compute service on the physical host rather than in a container. The following image shows how to use bridges for network connectivity:

image

The following image shows how the neutron agents work with the bridges br-vlan and br-vxlan. OpenStack Networking (neutron) is configured to use a DHCP agent, L3 agent, and Linux Bridge agent within a networking-agents container. The image shows how DHCP agents provide information (IP addresses and DNS servers) to the instances, and how routing works on the image:

image

The following image shows how virtual machines connect to the br-vlan and br-vxlan bridges and send traffic to the network outside the host:

image

Network ranges

In this guide, the following IP addresses and hostnames are used when installing OpenStack-Ansible.

Network IP Range
Management Network 172.29.236.0/22
Tunnel (VXLAN) Network 172.29.240.0/22
Storage Network 172.29.244.0/22

IP assignments

Host name Management IP Tunnel (VxLAN) IP Storage IP
infra1 172.29.236.101 172.29.240.101 172.29.244.101
infra2 172.29.236.102 172.29.240.102 172.29.244.102
infra3 172.29.236.103 172.29.240.103 172.29.244.103
net1 172.29.236.111 172.29.240.111
net2 172.29.236.112 172.29.240.112
net3 172.29.236.113 172.29.240.113
compute1 172.29.236.121 172.29.240.121 172.29.244.121
compute2 172.29.236.122 172.29.240.122 172.29.244.122
compute3 172.29.236.123 172.29.240.123 172.29.244.123
lvm-storage1 172.29.236.131 172.29.244.131
nfs-storage1 172.29.236.141 172.29.244.141
ceph-mon1 172.29.236.151 172.29.244.151
ceph-mon2 172.29.236.152 172.29.244.152
ceph-mon3 172.29.236.153 172.29.244.153
swift1 172.29.236.161 172.29.244.161
swift2 172.29.236.162 172.29.244.162
swift3 172.29.236.163 172.29.244.163
log1 172.29.236.171