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:
parent
a34955d451
commit
52e8df6614
@ -33,7 +33,7 @@ parameters:
|
||||
OpenDaylightPortBindingController:
|
||||
description: OpenDaylight port binding controller
|
||||
type: string
|
||||
default: 'network-topology'
|
||||
default: 'pseudo-agentdb-binding'
|
||||
|
||||
resources:
|
||||
|
||||
|
@ -33,6 +33,28 @@ parameters:
|
||||
Required for VLAN deployments. For example physnet1 -> eth1.
|
||||
type: comma_delimited_list
|
||||
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:
|
||||
default: {}
|
||||
description: Mapping of service endpoint -> protocol. Typically set
|
||||
@ -71,6 +93,28 @@ resources:
|
||||
RoleName: {get_param: RoleName}
|
||||
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:
|
||||
role_data:
|
||||
description: Role data for the OpenDaylight service.
|
||||
@ -86,7 +130,6 @@ outputs:
|
||||
opendaylight_check_url: {get_param: OpenDaylightCheckURL}
|
||||
opendaylight::nb_connection_protocol: {get_param: OpenDaylightConnectionProtocol}
|
||||
neutron::agents::ml2::ovs::local_ip: {get_param: [ServiceNetMap, NeutronTenantNetwork]}
|
||||
neutron::plugins::ovs::opendaylight::provider_mappings: {get_param: OpenDaylightProviderMappings}
|
||||
tripleo.opendaylight_ovs.firewall_rules:
|
||||
'118 neutron vxlan networks':
|
||||
proto: 'udp'
|
||||
@ -94,6 +137,7 @@ outputs:
|
||||
'136 neutron gre networks':
|
||||
proto: 'gre'
|
||||
- get_attr: [Ovs, role_data, config_settings]
|
||||
- get_attr: [RoleParametersValue, value]
|
||||
step_config: |
|
||||
include tripleo::profile::base::neutron::plugins::ovs::opendaylight
|
||||
upgrade_tasks:
|
||||
|
@ -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.
|
Loading…
Reference in New Issue
Block a user