NSX|V: enable binding floating ip's per AZ

Enable admin to enable this config variable per AZ.

Change-Id: I19ee2b4adf49e9bcd3e6004dc76d61761bb81b92
This commit is contained in:
Gary Kotton 2018-01-14 00:58:30 -08:00
parent c4a462d131
commit b448aba9b8
6 changed files with 34 additions and 4 deletions

View File

@ -0,0 +1,10 @@
---
prelude: >
Enable 'bind_floatingip_to_all_interfaces' to be configured per
availability zone.
features:
- |
Enable 'bind_floatingip_to_all_interfaces' to be configured per
availability zone. This will enable an admin to ensure that an AZ
can have flotaing IP's configured on all edge vNICS. This enables VM's
on the same subnet to communicate via floating IP's.

View File

@ -777,6 +777,12 @@ nsxv_az_opts = [
cfg.BoolOpt('exclusive_dhcp_edge', cfg.BoolOpt('exclusive_dhcp_edge',
default=False, default=False,
help=_("(Optional) Have exclusive DHCP edge per network.")), help=_("(Optional) Have exclusive DHCP edge per network.")),
cfg.BoolOpt('bind_floatingip_to_all_interfaces', default=False,
help=_("If set to False, router will associate floating ip "
"with external interface of only, thus denying "
"connectivity between hosts on same network via "
"their floating ips. If True, floating ip will "
"be associated with all router interfaces.")),
] ]
# define the configuration of each NSX-V3 availability zone. # define the configuration of each NSX-V3 availability zone.

View File

@ -67,6 +67,8 @@ class NsxVAvailabilityZone(common_az.ConfiguredAvailabilityZone):
self.dvs_id = cfg.CONF.nsxv.dvs_id self.dvs_id = cfg.CONF.nsxv.dvs_id
self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups
self.exclusive_dhcp_edge = cfg.CONF.nsxv.exclusive_dhcp_edge self.exclusive_dhcp_edge = cfg.CONF.nsxv.exclusive_dhcp_edge
self.bind_floatingip_to_all_interfaces = (
cfg.CONF.nsxv.bind_floatingip_to_all_interfaces)
# No support for metadata per az # No support for metadata per az
self.az_metadata_support = False self.az_metadata_support = False
@ -135,6 +137,8 @@ class NsxVAvailabilityZone(common_az.ConfiguredAvailabilityZone):
self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups
self.exclusive_dhcp_edge = az_info.get('exclusive_dhcp_edge', False) self.exclusive_dhcp_edge = az_info.get('exclusive_dhcp_edge', False)
self.bind_floatingip_to_all_interfaces = az_info.get(
'bind_floatingip_to_all_interfaces', False)
# Support for metadata per az only if configured, and different # Support for metadata per az only if configured, and different
# from the global one # from the global one
@ -195,6 +199,8 @@ class NsxVAvailabilityZone(common_az.ConfiguredAvailabilityZone):
self.dvs_id = cfg.CONF.nsxv.dvs_id self.dvs_id = cfg.CONF.nsxv.dvs_id
self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups self.edge_host_groups = cfg.CONF.nsxv.edge_host_groups
self.exclusive_dhcp_edge = cfg.CONF.nsxv.exclusive_dhcp_edge self.exclusive_dhcp_edge = cfg.CONF.nsxv.exclusive_dhcp_edge
self.bind_floatingip_to_all_interfaces = (
cfg.CONF.nsxv.bind_floatingip_to_all_interfaces)
def supports_metadata(self): def supports_metadata(self):
# Return True if this az has it's own metadata configuration # Return True if this az has it's own metadata configuration

View File

@ -24,6 +24,7 @@ from neutron_lib.callbacks import registry
from vmware_nsx._i18n import _ from vmware_nsx._i18n import _
from vmware_nsx.common import exceptions as nsxv_exc from vmware_nsx.common import exceptions as nsxv_exc
from vmware_nsx.common import nsxv_constants from vmware_nsx.common import nsxv_constants
from vmware_nsx.plugins.nsx_v import availability_zones as nsx_az
from vmware_nsx.plugins.nsx_v.vshield import edge_utils from vmware_nsx.plugins.nsx_v.vshield import edge_utils
@ -76,6 +77,7 @@ class RouterBaseDriver(RouterAbstractDriver):
self.nsx_v = plugin.nsx_v self.nsx_v = plugin.nsx_v
self.edge_manager = plugin.edge_manager self.edge_manager = plugin.edge_manager
self.vcns = self.nsx_v.vcns self.vcns = self.nsx_v.vcns
self._availability_zones = nsx_az.NsxVAvailabilityZones()
def _notify_after_router_edge_association(self, context, router): def _notify_after_router_edge_association(self, context, router):
registry.notify(nsxv_constants.SERVICE_EDGE, events.AFTER_CREATE, registry.notify(nsxv_constants.SERVICE_EDGE, events.AFTER_CREATE,

View File

@ -211,6 +211,9 @@ class RouterSharedDriver(router_driver.RouterBaseDriver):
def _update_nat_rules_on_routers(self, context, def _update_nat_rules_on_routers(self, context,
target_router_id, router_ids): target_router_id, router_ids):
edge_id, az_name = self.plugin._get_edge_id_and_az_by_rtr_id(
context, target_router_id)
az = self._availability_zones.get_availability_zone(az_name)
snats = [] snats = []
dnats = [] dnats = []
vnics_by_router = self._get_all_routers_vnic_indices( vnics_by_router = self._get_all_routers_vnic_indices(
@ -222,7 +225,7 @@ class RouterSharedDriver(router_driver.RouterBaseDriver):
snat, dnat = self.plugin._get_nat_rules(context, router) snat, dnat = self.plugin._get_nat_rules(context, router)
snats.extend(snat) snats.extend(snat)
dnats.extend(dnat) dnats.extend(dnat)
if (not cfg.CONF.nsxv.bind_floatingip_to_all_interfaces and if (not az.bind_floatingip_to_all_interfaces and
len(dnat) > 0): len(dnat) > 0):
# Copy each DNAT rule to all vnics of the other routers, # Copy each DNAT rule to all vnics of the other routers,
# to allow NAT-ed traffic between routers # to allow NAT-ed traffic between routers
@ -241,7 +244,7 @@ class RouterSharedDriver(router_driver.RouterBaseDriver):
dnats.extend([new_rule]) dnats.extend([new_rule])
edge_utils.update_nat_rules( edge_utils.update_nat_rules(
self.nsx_v, context, target_router_id, snats, dnats) self.nsx_v, context, target_router_id, snats, dnats, az=az)
def _update_external_interface_on_routers(self, context, def _update_external_interface_on_routers(self, context,
target_router_id, router_ids): target_router_id, router_ids):

View File

@ -2393,10 +2393,13 @@ def delete_interface(nsxv_manager, context, router_id, network_id, dist=False):
context.session, edge_id, network_id) context.session, edge_id, network_id)
def update_nat_rules(nsxv_manager, context, router_id, snat, dnat): def update_nat_rules(nsxv_manager, context, router_id, snat, dnat, az=None):
binding = nsxv_db.get_nsxv_router_binding(context.session, router_id) binding = nsxv_db.get_nsxv_router_binding(context.session, router_id)
if binding: if binding:
bind_to_all = cfg.CONF.nsxv.bind_floatingip_to_all_interfaces if not az:
azs = nsx_az.NsxVAvailabilityZones()
az = azs.get_availability_zone(binding['availability_zone'])
bind_to_all = az.bind_floatingip_to_all_interfaces
indices = None indices = None
if bind_to_all: if bind_to_all: