Merge "NSX: Remove logic for creating chained logical switches"
This commit is contained in:
commit
bc4ca8d51f
@ -373,25 +373,8 @@ class NsxPluginV2(addr_pair_db.AllowedAddressPairsMixin,
|
|||||||
|
|
||||||
def _nsx_find_lswitch_for_port(self, context, port_data):
|
def _nsx_find_lswitch_for_port(self, context, port_data):
|
||||||
network = self._get_network(context, port_data['network_id'])
|
network = self._get_network(context, port_data['network_id'])
|
||||||
network_bindings = nsx_db.get_network_bindings(
|
return self._handle_lswitch_selection(
|
||||||
context.session, port_data['network_id'])
|
context, self.cluster, network)
|
||||||
max_ports = self.nsx_opts.max_lp_per_overlay_ls
|
|
||||||
allow_extra_lswitches = False
|
|
||||||
for network_binding in network_bindings:
|
|
||||||
if network_binding.binding_type in (c_utils.NetworkTypes.FLAT,
|
|
||||||
c_utils.NetworkTypes.VLAN):
|
|
||||||
max_ports = self.nsx_opts.max_lp_per_bridged_ls
|
|
||||||
allow_extra_lswitches = True
|
|
||||||
break
|
|
||||||
try:
|
|
||||||
return self._handle_lswitch_selection(
|
|
||||||
context, self.cluster, network, network_bindings,
|
|
||||||
max_ports, allow_extra_lswitches)
|
|
||||||
except api_exc.NsxApiException:
|
|
||||||
err_desc = _("An exception occurred while selecting logical "
|
|
||||||
"switch for the port")
|
|
||||||
LOG.exception(err_desc)
|
|
||||||
raise nsx_exc.NsxPluginException(err_msg=err_desc)
|
|
||||||
|
|
||||||
def _nsx_create_port_helper(self, session, ls_uuid, port_data,
|
def _nsx_create_port_helper(self, session, ls_uuid, port_data,
|
||||||
do_port_security=True):
|
do_port_security=True):
|
||||||
@ -844,53 +827,31 @@ class NsxPluginV2(addr_pair_db.AllowedAddressPairsMixin,
|
|||||||
super(NsxPluginV2, self).extend_port_dict_binding(port_res, port_db)
|
super(NsxPluginV2, self).extend_port_dict_binding(port_res, port_db)
|
||||||
port_res[pbin.VNIC_TYPE] = pbin.VNIC_NORMAL
|
port_res[pbin.VNIC_TYPE] = pbin.VNIC_NORMAL
|
||||||
|
|
||||||
def _handle_lswitch_selection(self, context, cluster, network,
|
def _handle_lswitch_selection(self, context, cluster, network):
|
||||||
network_bindings, max_ports,
|
# NOTE(salv-orlando): This method used to select a NSX logical switch
|
||||||
allow_extra_lswitches):
|
# with an available port, and create a new logical switch if
|
||||||
|
# necessary. As there is no more need to perform switch chaining in
|
||||||
|
# NSX, the logic for creating a new logical switch has been removed.
|
||||||
|
max_ports = self.nsx_opts.max_lp_per_overlay_ls
|
||||||
|
network_bindings = nsx_db.get_network_bindings(
|
||||||
|
context.session, network['id'])
|
||||||
|
for network_binding in network_bindings:
|
||||||
|
if network_binding.binding_type in (c_utils.NetworkTypes.FLAT,
|
||||||
|
c_utils.NetworkTypes.VLAN):
|
||||||
|
max_ports = self.nsx_opts.max_lp_per_bridged_ls
|
||||||
|
# This is still necessary as there could be chained switches in
|
||||||
|
# the deployment and the code needs to find the first one with
|
||||||
|
# an available slot for a port
|
||||||
lswitches = nsx_utils.fetch_nsx_switches(
|
lswitches = nsx_utils.fetch_nsx_switches(
|
||||||
context.session, cluster, network.id)
|
context.session, cluster, network['id'])
|
||||||
try:
|
try:
|
||||||
return [ls for ls in lswitches
|
return [ls for ls in lswitches
|
||||||
if (ls['_relations']['LogicalSwitchStatus']
|
if (ls['_relations']['LogicalSwitchStatus']
|
||||||
['lport_count'] < max_ports)].pop(0)
|
['lport_count'] < max_ports)].pop(0)
|
||||||
except IndexError:
|
except IndexError:
|
||||||
# Too bad, no switch available
|
# Too bad, no switch where a port can be created
|
||||||
LOG.debug("No switch has available ports (%d checked)",
|
LOG.debug("No switch has available ports (%d checked)",
|
||||||
len(lswitches))
|
len(lswitches))
|
||||||
if allow_extra_lswitches:
|
|
||||||
# The 'main' logical switch is either the only one available
|
|
||||||
# or the one where the 'multi_lswitch' tag was set
|
|
||||||
while lswitches:
|
|
||||||
main_ls = lswitches.pop(0)
|
|
||||||
tag_dict = dict((x['scope'], x['tag'])
|
|
||||||
for x in main_ls['tags'])
|
|
||||||
if 'multi_lswitch' in tag_dict:
|
|
||||||
break
|
|
||||||
else:
|
|
||||||
# by construction this statement is hit if there is only one
|
|
||||||
# logical switch and the multi_lswitch tag has not been set.
|
|
||||||
# The tag must therefore be added.
|
|
||||||
tags = main_ls['tags']
|
|
||||||
tags.append({'tag': 'True', 'scope': 'multi_lswitch'})
|
|
||||||
switchlib.update_lswitch(cluster,
|
|
||||||
main_ls['uuid'],
|
|
||||||
main_ls['display_name'],
|
|
||||||
network['tenant_id'],
|
|
||||||
tags=tags)
|
|
||||||
transport_zone_config = self._convert_to_nsx_transport_zones(
|
|
||||||
cluster, network, bindings=network_bindings)
|
|
||||||
selected_lswitch = switchlib.create_lswitch(
|
|
||||||
cluster, network.id, network.tenant_id,
|
|
||||||
"%s-ext-%s" % (network.name, len(lswitches)),
|
|
||||||
transport_zone_config)
|
|
||||||
# add a mapping between the neutron network and the newly
|
|
||||||
# created logical switch
|
|
||||||
nsx_db.add_neutron_nsx_network_mapping(
|
|
||||||
context.session, network.id, selected_lswitch['uuid'])
|
|
||||||
return selected_lswitch
|
|
||||||
else:
|
|
||||||
LOG.error(_LE("Maximum number of logical ports reached for "
|
|
||||||
"logical network %s"), network.id)
|
|
||||||
raise nsx_exc.NoMorePortsException(network=network.id)
|
raise nsx_exc.NoMorePortsException(network=network.id)
|
||||||
|
|
||||||
def _convert_to_nsx_transport_zones(self, cluster, network=None,
|
def _convert_to_nsx_transport_zones(self, cluster, network=None,
|
||||||
|
@ -131,9 +131,9 @@ class TestPortsV2(NsxPluginV2TestCase,
|
|||||||
VIF_TYPE = portbindings.VIF_TYPE_OVS
|
VIF_TYPE = portbindings.VIF_TYPE_OVS
|
||||||
HAS_PORT_FILTER = True
|
HAS_PORT_FILTER = True
|
||||||
|
|
||||||
def test_exhaust_ports_overlay_network(self):
|
def _test_exhaust_ports(self, providernet_args=None):
|
||||||
cfg.CONF.set_override('max_lp_per_overlay_ls', 1, group='NSX')
|
|
||||||
with self.network(name='testnet',
|
with self.network(name='testnet',
|
||||||
|
providernet_args=providernet_args,
|
||||||
arg_list=(pnet.NETWORK_TYPE,
|
arg_list=(pnet.NETWORK_TYPE,
|
||||||
pnet.PHYSICAL_NETWORK,
|
pnet.PHYSICAL_NETWORK,
|
||||||
pnet.SEGMENTATION_ID)) as net:
|
pnet.SEGMENTATION_ID)) as net:
|
||||||
@ -142,22 +142,15 @@ class TestPortsV2(NsxPluginV2TestCase,
|
|||||||
# creating another port should see an exception
|
# creating another port should see an exception
|
||||||
self._create_port('json', net['network']['id'], 400)
|
self._create_port('json', net['network']['id'], 400)
|
||||||
|
|
||||||
|
def test_exhaust_ports_overlay_network(self):
|
||||||
|
cfg.CONF.set_override('max_lp_per_overlay_ls', 1, group='NSX')
|
||||||
|
self._test_exhaust_ports()
|
||||||
|
|
||||||
def test_exhaust_ports_bridged_network(self):
|
def test_exhaust_ports_bridged_network(self):
|
||||||
cfg.CONF.set_override('max_lp_per_bridged_ls', 1, group="NSX")
|
cfg.CONF.set_override('max_lp_per_bridged_ls', 1, group="NSX")
|
||||||
providernet_args = {pnet.NETWORK_TYPE: 'flat',
|
providernet_args = {pnet.NETWORK_TYPE: 'flat',
|
||||||
pnet.PHYSICAL_NETWORK: 'tzuuid'}
|
pnet.PHYSICAL_NETWORK: 'tzuuid'}
|
||||||
with self.network(name='testnet',
|
self._test_exhaust_ports(providernet_args=providernet_args)
|
||||||
providernet_args=providernet_args,
|
|
||||||
arg_list=(pnet.NETWORK_TYPE,
|
|
||||||
pnet.PHYSICAL_NETWORK,
|
|
||||||
pnet.SEGMENTATION_ID)) as net:
|
|
||||||
with self.subnet(network=net) as sub:
|
|
||||||
with self.port(subnet=sub):
|
|
||||||
with self.port(subnet=sub):
|
|
||||||
plugin = manager.NeutronManager.get_plugin()
|
|
||||||
ls = nsxlib.switch.get_lswitches(plugin.cluster,
|
|
||||||
net['network']['id'])
|
|
||||||
self.assertEqual(len(ls), 2)
|
|
||||||
|
|
||||||
def test_update_port_delete_ip(self):
|
def test_update_port_delete_ip(self):
|
||||||
# This test case overrides the default because the nsx plugin
|
# This test case overrides the default because the nsx plugin
|
||||||
|
Loading…
Reference in New Issue
Block a user