Enabling in Devstack¶
Download DevStack
Copy the sample local.conf over:
cp devstack/local.conf.example local.conf
Optionally, to manually configure this:
Add this repo as an external repository:
> cat local.conf [[local|localrc]] enable_plugin networking-odl http://opendev.org/openstack/networking-odl
Optionally, to enable support for OpenDaylight L3 router functionality, add the below:
> cat local.conf [[local|localrc]] ODL_L3=True
Note
This is only relevant when using old netvirt (ovsdb based, default).
If you need to route the traffic out of the box (e.g. br-ex), set ODL_PROVIDER_MAPPINGS to map the physical provider network to device mapping, as shown below:
> cat local.conf [[local|localrc]] ODL_L3=True ODL_PROVIDER_MAPPINGS=${ODL_PROVIDER_MAPPINGS:-br-ex:eth2} # for old netvirt (ovsdb based) ODL_PROVIDER_MAPPINGS=${ODL_PROVIDER_MAPPINGS:-physnet1:eth2} # for new netvirt (vpnservice based)
run
stack.sh
Note: In a multi-node devstack environment, for each compute node you will want to add this to the local.conf file:
> cat local.conf [[local|localrc]] enable_plugin networking-odl http://opendev.org/openstack/networking-odl ODL_MODE=compute
Note: In a node using a release of Open vSwitch provided from another source than your Linux distribution you have to enable in your local.conf skipping of OVS installation step by setting SKIP_OVS_INSTALL=True. For example when stacking together with networking-ovs-dpdk Neutron plug-in to avoid conflicts between openvswitch and ovs-dpdk you have to add this to the local.conf file:
> cat local.conf [[local|localrc]] enable_plugin networking-ovs-dpdk http://opendev.org/openstack/networking-ovs-dpdk enable_plugin networking-odl http://opendev.org/openstack/networking-odl SKIP_OVS_INSTALL=True
Note: Optionally, to use the new netvirt implementation (netvirt-vpnservice-openstack), add the following to the local.conf file (only allinone topology is currently supported by devstack, since tunnel endpoints are not automatically configured). For tunnel configurations after loading devstack, please refer to this guide https://wiki.opendaylight.org/view/Netvirt:_L2Gateway_HowTo#Configuring_Tunnels:
> cat local.conf [[local|localrc]] ODL_NETVIRT_KARAF_FEATURE=odl-restconf-all,odl-aaa-authn,odl-dlux-core,odl-mdsal-apidocs,odl-netvirt-vpnservice-openstack ODL_BOOT_WAIT_URL=restconf/operational/network-topology:network-topology/ # Workaround since netvirt:1 no longer exists in DS!
Note: To enable Quality Of Service (QoS) with OpenDaylight Backend, add the following lines in neutron.conf:
> in /etc/neutron/neutron.conf service_plugins = qos, odl-router
enable qos extension driver in ml2 conf:
> in /etc/neutron/plugins/ml2/ml2_conf.ini extensions_drivers = qos, port_security
restart neutron service neutron-api
Note: legacy netvirt specific options
OVS conntrack support
- variable
ODL_LEGACY_NETVIRT_CONNTRACK By default it’s False for compatibility and version requirements.
version requirement
- ODL version
Boron release or later. (ODL legacy netvirt support is from Beryllium. But networking-odl devstack supports Boron+)
- OVS version
2.5 or later
enable OVS conntrack support:
> cat local.conf [[local|localrc]] ODL_LEGACY_NETVIRT_CONNTRACK=True
Note: To enable Vlan Aware VMs (Trunk) with OpenDaylight Backend, make the following entries in local.conf:
> cat local.conf [[local|localrc]] Q_SERVICE_PLUGIN_CLASSES=trunk
Enabling L2Gateway Backend for OpenDaylight
The package networking-l2gw must be installed as a pre-requisite.
So include in your localrc (or local.conf) the following:
enable_plugin networking-l2gw http://opendev.org/x/networking-l2gw enable_service l2gw-plugin NETWORKING_L2GW_SERVICE_DRIVER=L2GW:OpenDaylight:networking_odl.l2gateway.driver_v2.OpenDaylightL2gwDriver:default
Now stack up Devstack and after stacking completes, we are all set to use l2gateway-as-a-service with OpenDaylight.
Note: To enable Service Function Chaining support driven by networking-sfc, the following steps have to be taken:
local.conf should contain the following lines:
# enable our plugin: enable_plugin networking-odl https://github.com/openstack/networking-odl.git # enable the networking-sfc plugin: enable_plugin networking-sfc https://github.com/openstack/networking-sfc.git # enable the odl-netvirt-sfc Karaf feature in OpenDaylight ODL_NETVIRT_KARAF_FEATURE+=,odl-netvirt-sfc # enable the networking-sfc OpenDaylight driver pair [[post-config|$NEUTRON_CONF]] [sfc] drivers = odl_v2 [flowclassifier] drivers = odl_v2
A special commit of Open vSwitch should be compiled and installed (containing compatible NSH OpenFlow support). This isn’t done automatically by networking-odl or DevStack, so the user has to manually install. Please follow the instructions in: https://wiki.opendaylight.org/view/Service_Function_Chaining:Main#Building_Open_vSwitch_with_VxLAN-GPE_and_NSH_support
Fluorine is the recommended and latest version of OpenDaylight to use, you can specify it by adding the following to local.conf:
ODL_RELEASE=fluorine-snapshot-0.9.0
To clarify, OpenDaylight doesn’t have to be running/installed before stacking with networking-odl (and it shouldn’t). The networking-odl DevStack plugin will download and start OpenDaylight automatically. However, it will not fetch the correct Open vSwitch version, so the instructions above and the usage of
SKIP_OVS_INSTALL
are important.
To enable BGPVPN driver to use with OpenDaylight controller Include the following lines in your localrc (or local.conf):
enable_plugin networking-bgpvpn https://opendev.org/openstack/networking-bgpvpn.git [[post-config|$NETWORKING_BGPVPN_CONF]] [service_providers] service_provider=BGPVPN:OpenDaylight:networking_odl.bgpvpn.odl_v2.OpenDaylightBgpvpnDriver:default
and then stack up your devstack.
To enable DHCP Service in OpenDaylight deployments with Openstack, please use:
[[local|localrc]] ODL_DHCP_SERVICE=True
To enable ODL with OVS hardware Offload support please use:
[[local|localrc]] ODL_OVS_HOSTCONFIGS_OPTIONS="--noovs_dpdk --debug --ovs_sriov_offload"
- Note: OVS offload support minimal version requirements -
Linux kernel from version 4.12 OVS from version 2.8.0 ODL from version Nitrogen (please note that Nitrogen is no longer maintained)
For development environment, if opendaylight installation is not required for stack.sh then a parameter ODL_INSTALL should be set to False. By default it is set to True therefore it is backward compatible with gate and already existing scripts:
[[local|localrc]] ODL_INSTALL=False
To Enable L3 Flavors with ODL, service providers should be added to neutron.conf:
[service_providers] service_provider = L3_ROUTER_NAT:ODL:networking_odl.l3.l3_flavor.ODLL3ServiceProvider:default
Note: Service Plugin ‘router’ should be used in neutron.conf for enabling L3 flavors completely