Improve external gateway update handling
Once gateway is set, external_gateway_added() was getting called every time a router update was received. The check for change in external gateway compared previously cached copy of gateway port (ri.ex_gw_port) with the one passed in through update router (ri.router['gw_port']). The cached copy was already being modified by code so the two values would always appear to be different. Making the change to compare correctly and remove actions not required for gateway update. Change-Id: I1a703b327e6c569dfaa8263a222e4bc797e5dbfd Closes-Bug: 1348737
This commit is contained in:
@@ -768,9 +768,12 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback, manager.Manager):
|
||||
interface_name = None
|
||||
if ex_gw_port_id:
|
||||
interface_name = self.get_external_device_name(ex_gw_port_id)
|
||||
if ex_gw_port and ex_gw_port != ri.ex_gw_port:
|
||||
if ex_gw_port:
|
||||
self._set_subnet_info(ex_gw_port)
|
||||
self.external_gateway_added(ri, ex_gw_port, interface_name)
|
||||
if not ri.ex_gw_port:
|
||||
self.external_gateway_added(ri, ex_gw_port, interface_name)
|
||||
elif ex_gw_port != ri.ex_gw_port:
|
||||
self.external_gateway_updated(ri, ex_gw_port, interface_name)
|
||||
elif not ex_gw_port and ri.ex_gw_port:
|
||||
self.external_gateway_removed(ri, ri.ex_gw_port, interface_name)
|
||||
|
||||
@@ -1117,6 +1120,19 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback, manager.Manager):
|
||||
self._external_gateway_added(ri, ex_gw_port, interface_name,
|
||||
ri.ns_name, preserve_ips)
|
||||
|
||||
def external_gateway_updated(self, ri, ex_gw_port, interface_name):
|
||||
preserve_ips = []
|
||||
if ri.router['distributed']:
|
||||
ns_name = self.get_snat_ns_name(ri.router['id'])
|
||||
else:
|
||||
ns_name = ri.ns_name
|
||||
floating_ips = self.get_floating_ips(ri)
|
||||
preserve_ips = [ip['floating_ip_address'] + FLOATING_IP_CIDR_SUFFIX
|
||||
for ip in floating_ips]
|
||||
|
||||
self._external_gateway_added(ri, ex_gw_port, interface_name,
|
||||
ns_name, preserve_ips)
|
||||
|
||||
def _external_gateway_added(self, ri, ex_gw_port, interface_name,
|
||||
ns_name, preserve_ips):
|
||||
if not ip_lib.device_exists(interface_name,
|
||||
|
||||
Reference in New Issue
Block a user