Changing the default port-binding configuration

networking-odl no longer supports the network-topology port
binding controller and instead now relies on a pseudo-agent binding
controller.  This means that each OVS node must be configured with
host configuration in OVSDB about which VIF types, network types,
functions, etc that this OVS node supports.  The end result is this
affects where nova and neutron will schedule instances.

Changes Include:
 - Modifying default port binding controller to use pseudo agent
 - Adds necessary per role parameters to be able to configure host
   config on a per role basis to allow for heterogenous compute node
   configurations.

Change-Id: I50458abf6a8a6bf724ad97accb6444d9c497d287
Closes-Bug: 1674995
Signed-off-by: Tim Rozet <trozet@redhat.com>
This commit is contained in:
Itzik Brown 2017-07-20 14:36:26 +03:00 committed by Tim Rozet
parent a34955d451
commit 52e8df6614
3 changed files with 55 additions and 2 deletions

View File

@ -33,7 +33,7 @@ parameters:
OpenDaylightPortBindingController: OpenDaylightPortBindingController:
description: OpenDaylight port binding controller description: OpenDaylight port binding controller
type: string type: string
default: 'network-topology' default: 'pseudo-agentdb-binding'
resources: resources:

View File

@ -33,6 +33,28 @@ parameters:
Required for VLAN deployments. For example physnet1 -> eth1. Required for VLAN deployments. For example physnet1 -> eth1.
type: comma_delimited_list type: comma_delimited_list
default: "datacentre:br-ex" default: "datacentre:br-ex"
HostAllowedNetworkTypes:
description: Allowed tenant network types for this OVS host. Note this can
vary per host or role to constrain which hosts nova instances
and networks are scheduled to.
type: comma_delimited_list
default: ['local', 'vlan', 'vxlan', 'gre']
OvsEnableDpdk:
description: Whether or not to configure enable DPDK in OVS
default: false
type: boolean
OvsVhostuserMode:
description: Specify the mode for OVS with vhostuser port creation. In
client mode, the hypervisor will be responsible for creating
vhostuser sockets. In server mode, OVS will create them.
type: string
default: "client"
constraints:
- allowed_values: [ 'client', 'server' ]
VhostuserSocketDir:
description: Specify the directory to use for vhostuser sockets
type: string
default: "/var/run/openvswitch"
EndpointMap: EndpointMap:
default: {} default: {}
description: Mapping of service endpoint -> protocol. Typically set description: Mapping of service endpoint -> protocol. Typically set
@ -71,6 +93,28 @@ resources:
RoleName: {get_param: RoleName} RoleName: {get_param: RoleName}
RoleParameters: {get_param: RoleParameters} RoleParameters: {get_param: RoleParameters}
# Merging role-specific parameters (RoleParameters) with the default parameters.
# RoleParameters will have the precedence over the default parameters.
RoleParametersValue:
type: OS::Heat::Value
properties:
type: json
value:
map_replace:
- map_replace:
- neutron::plugins::ovs::opendaylight::allowed_network_types: HostAllowedNetworkTypes
neutron::plugins::ovs::opendaylight::enable_dpdk: OvsEnableDpdk
neutron::plugins::ovs::opendaylight::vhostuser_socket_dir: VhostuserSocketDir
neutron::plugins::ovs::opendaylight::vhostuser_mode: OvsVhostuserMode
neutron::plugins::ovs::opendaylight::provider_mappings: OpenDaylightProviderMappings
- values: {get_param: [RoleParameters]}
- values:
HostAllowedNetworkTypes: {get_param: HostAllowedNetworkTypes}
OvsEnableDpdk: {get_param: OvsEnableDpdk}
VhostuserSocketDir: {get_param: VhostuserSocketDir}
OvsVhostuserMode: {get_param: OvsVhostuserMode}
OpenDaylightProviderMappings: {get_param: OpenDaylightProviderMappings}
outputs: outputs:
role_data: role_data:
description: Role data for the OpenDaylight service. description: Role data for the OpenDaylight service.
@ -86,7 +130,6 @@ outputs:
opendaylight_check_url: {get_param: OpenDaylightCheckURL} opendaylight_check_url: {get_param: OpenDaylightCheckURL}
opendaylight::nb_connection_protocol: {get_param: OpenDaylightConnectionProtocol} opendaylight::nb_connection_protocol: {get_param: OpenDaylightConnectionProtocol}
neutron::agents::ml2::ovs::local_ip: {get_param: [ServiceNetMap, NeutronTenantNetwork]} neutron::agents::ml2::ovs::local_ip: {get_param: [ServiceNetMap, NeutronTenantNetwork]}
neutron::plugins::ovs::opendaylight::provider_mappings: {get_param: OpenDaylightProviderMappings}
tripleo.opendaylight_ovs.firewall_rules: tripleo.opendaylight_ovs.firewall_rules:
'118 neutron vxlan networks': '118 neutron vxlan networks':
proto: 'udp' proto: 'udp'
@ -94,6 +137,7 @@ outputs:
'136 neutron gre networks': '136 neutron gre networks':
proto: 'gre' proto: 'gre'
- get_attr: [Ovs, role_data, config_settings] - get_attr: [Ovs, role_data, config_settings]
- get_attr: [RoleParametersValue, value]
step_config: | step_config: |
include tripleo::profile::base::neutron::plugins::ovs::opendaylight include tripleo::profile::base::neutron::plugins::ovs::opendaylight
upgrade_tasks: upgrade_tasks:

View File

@ -0,0 +1,9 @@
---
fixes:
- Setting the port-binding to be pseudo-agentdb-binding.
Networking-odl no longer supports network-topology
features:
- Enables per role configuration of per host
configuration which allows an operator to dedicate
different compute roles to different network or
port types in OpenDaylight deployments.