Add a route to reach the MD server when a subnet is created
When the first subnet is created, the dhcp port is created and midonet plugin correctly adds the static route to reach the MD server in create_port. When a second or following subnets are created, a new ip is added to the dhcp port. This patch takes care of adding the static route to correcly reach the MD server in update_port. This fixes the problem of VMs not being able to reach the MD if assigned to the second subnet Closes-bug: #1231914 Change-Id: Ifc95f901d4222b76a4254e21295829ac8d82493b
This commit is contained in:
parent
61dce1a606
commit
cf7aca87e1
@ -625,20 +625,30 @@ class MidonetPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
|||||||
old_port = self._get_port(context, id)
|
old_port = self._get_port(context, id)
|
||||||
net_id = old_port["network_id"]
|
net_id = old_port["network_id"]
|
||||||
mac = old_port["mac_address"]
|
mac = old_port["mac_address"]
|
||||||
old_fixed_ips = old_port.get('fixed_ips')
|
old_ips = old_port["fixed_ips"]
|
||||||
|
|
||||||
# update the port DB
|
# update the port DB
|
||||||
p = super(MidonetPluginV2, self).update_port(context, id, port)
|
p = super(MidonetPluginV2, self).update_port(context, id, port)
|
||||||
|
|
||||||
if "fixed_ips" in p:
|
new_ips = p["fixed_ips"]
|
||||||
# IPs have changed. Re-map the DHCP entries
|
if new_ips:
|
||||||
bridge = self.client.get_bridge(net_id)
|
bridge = self.client.get_bridge(net_id)
|
||||||
for cidr, ip, mac in self._dhcp_mappings(
|
# If it's a DHCP port, add a route to reach the MD server
|
||||||
context, old_fixed_ips, mac):
|
if _is_dhcp_port(p):
|
||||||
self.client.remove_dhcp_host(bridge, cidr, ip, mac)
|
for cidr, ip in self._metadata_subnets(
|
||||||
for cidr, ip, mac in self._dhcp_mappings(context,
|
context, new_ips):
|
||||||
p["fixed_ips"], mac):
|
self.client.add_dhcp_route_option(
|
||||||
self.client.add_dhcp_host(bridge, cidr, ip, mac)
|
bridge, cidr, ip, METADATA_DEFAULT_IP)
|
||||||
|
else:
|
||||||
|
# IPs have changed. Re-map the DHCP entries
|
||||||
|
for cidr, ip, mac in self._dhcp_mappings(
|
||||||
|
context, old_ips, mac):
|
||||||
|
self.client.remove_dhcp_host(
|
||||||
|
bridge, cidr, ip, mac)
|
||||||
|
|
||||||
|
for cidr, ip, mac in self._dhcp_mappings(
|
||||||
|
context, new_ips, mac):
|
||||||
|
self.client.add_dhcp_host(
|
||||||
|
bridge, cidr, ip, mac)
|
||||||
|
|
||||||
if (self._check_update_deletes_security_groups(port) or
|
if (self._check_update_deletes_security_groups(port) or
|
||||||
self._check_update_has_security_groups(port)):
|
self._check_update_has_security_groups(port)):
|
||||||
|
@ -108,6 +108,25 @@ class MidoClientTestCase(testtools.TestCase):
|
|||||||
"2A:DB:6B:8C:19:99")
|
"2A:DB:6B:8C:19:99")
|
||||||
bridge.assert_has_calls(calls, any_order=True)
|
bridge.assert_has_calls(calls, any_order=True)
|
||||||
|
|
||||||
|
def test_add_dhcp_route_option(self):
|
||||||
|
|
||||||
|
bridge = mock.Mock()
|
||||||
|
subnet = bridge.get_dhcp_subnet.return_value
|
||||||
|
subnet.get_opt121_routes.return_value = None
|
||||||
|
dhcp_subnet_call = mock.call.get_dhcp_subnet("10.0.0.0_24")
|
||||||
|
dst_ip = "10.0.0.3/24"
|
||||||
|
gw_ip = "10.0.0.1"
|
||||||
|
prefix, length = dst_ip.split("/")
|
||||||
|
routes = [{'destinationPrefix': prefix, 'destinationLength': length,
|
||||||
|
'gatewayAddr': gw_ip}]
|
||||||
|
opt121_routes_call = dhcp_subnet_call.opt121_routes(routes)
|
||||||
|
calls = [dhcp_subnet_call, opt121_routes_call,
|
||||||
|
opt121_routes_call.update()]
|
||||||
|
|
||||||
|
self.client.add_dhcp_route_option(bridge, "10.0.0.0/24",
|
||||||
|
gw_ip, dst_ip)
|
||||||
|
bridge.assert_has_calls(calls, any_order=True)
|
||||||
|
|
||||||
def test_get_router_error(self):
|
def test_get_router_error(self):
|
||||||
self.mock_api.get_router.side_effect = w_exc.HTTPInternalServerError()
|
self.mock_api.get_router.side_effect = w_exc.HTTPInternalServerError()
|
||||||
self.assertRaises(midonet_lib.MidonetApiException,
|
self.assertRaises(midonet_lib.MidonetApiException,
|
||||||
|
Loading…
Reference in New Issue
Block a user