-
Michal Nasiadka authored
Change-Id: I8bf5453c6943fd2ad8912e5d80af179296ada894
Michal Nasiadka authoredChange-Id: I8bf5453c6943fd2ad8912e5d80af179296ada894
SRIOV
Neutron SRIOV
Preparation and deployment
SRIOV requires specific NIC and BIOS configuration and is not supported on all platforms. Consult NIC and platform specific documentation for instructions on enablement.
Modify the /etc/kolla/globals.yml
file as the following example
shows which automatically appends sriovnicswitch
to the
mechanism_drivers
inside ml2_conf.ini
.
enable_neutron_sriov: "yes"
It is also a requirement to define physnet:interface mappings for all
SRIOV devices as shown in the following example where sriovtenant1
is the
physnet mapped to ens785f0
interface:
neutron_sriov_physnet_mappings:
sriovtenant1: ens785f0
However, the provider networks using SRIOV should be configured. Both flat and VLAN are configured with the same physical network name in this example:
[ml2_type_vlan]
network_vlan_ranges = sriovtenant1:1000:1009
[ml2_type_flat]
flat_networks = sriovtenant1
Modify the nova.conf
file and add PciPassthroughFilter
to
enabled_filters
. This filter is required by the Nova Scheduler
service on the controller node.
[filter_scheduler]
enabled_filters = <existing filters>, PciPassthroughFilter
available_filters = nova.scheduler.filters.all_filters
PCI devices listed under neutron_sriov_physnet_mappings
will be
whitelisted on the Compute hosts inside nova.conf
.
Physical network to interface mappings in neutron_sriov_physnet_mappings
will be automatically added to sriov_agent.ini
. Specific VFs can be
excluded via excluded_devices
. However, leaving blank (default) leaves all
VFs enabled:
[sriov_nic]
exclude_devices =
To use OpenvSwitch hardware offloading modify /etc/kolla/globals.yml`:
openvswitch_hw_offload: "yes"
Run deployment.
Verification
Check that VFs were created on the compute node(s). VFs will appear in the
output of both lspci
and ip link show
. For example:
# lspci | grep net
05:10.0 Ethernet controller: Intel Corporation 82599 Ethernet Controller Virtual Function (rev 01)
# ip -d link show ens785f0
4: ens785f0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq master ovs-system state UP mode DEFAULT qlen 1000
link/ether 90:e2:ba:ba:fb:20 brd ff:ff:ff:ff:ff:ff promiscuity 1
openvswitch_slave addrgenmode eui64
vf 0 MAC 52:54:00:36:57:e0, spoof checking on, link-state auto, trust off
vf 1 MAC 52:54:00:00:62:db, spoof checking on, link-state auto, trust off
vf 2 MAC fa:16:3e:92:cf:12, spoof checking on, link-state auto, trust off
vf 3 MAC fa:16:3e:00:a3:01, vlan 1000, spoof checking on, link-state auto, trust off
Verify the SRIOV Agent container is running on the compute node(s):
# docker ps --filter name=neutron_sriov_agent
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
b03a8f4c0b80 10.10.10.10:4000/registry/centos-source-neutron-sriov-agent:17.04.0 "kolla_start" 18 minutes ago Up 18 minutes neutron_sriov_agent
Verify the SRIOV Agent service is present and UP:
# openstack network agent list
+--------------------------------------+--------------------+-------------+-------------------+-------+-------+---------------------------+
| ID | Agent Type | Host | Availability Zone | Alive | State | Binary |
+--------------------------------------+--------------------+-------------+-------------------+-------+-------+---------------------------+
| 7c06bda9-7b87-487e-a645-cc6c289d9082 | NIC Switch agent | av09-18-wcp | None | :-) | UP | neutron-sriov-nic-agent |
+--------------------------------------+--------------------+-------------+-------------------+-------+-------+---------------------------+
Create a new provider network. Set provider-physical-network
to the
physical network name that was configured in /etc/kolla/config/nova.conf
.
Set provider-network-type
to the desired type. If using VLAN, ensure
provider-segment
is set to the correct VLAN ID. This example uses VLAN
network type:
# openstack network create --project=admin \
--provider-network-type=vlan \
--provider-physical-network=sriovtenant1 \
--provider-segment=1000 \
sriovnet1