Merge "Get OVS port details from port ID"

This commit is contained in:
Jenkins 2012-08-20 20:21:32 +00:00 committed by Gerrit Code Review
commit 6c7582e7a7
3 changed files with 68 additions and 28 deletions

View File

@ -19,6 +19,7 @@
# @author: Dave Lapsley, Nicira Networks, Inc. # @author: Dave Lapsley, Nicira Networks, Inc.
import logging import logging
import re
import shlex import shlex
import signal import signal
import subprocess import subprocess
@ -47,6 +48,17 @@ class OVSBridge:
def __init__(self, br_name, root_helper): def __init__(self, br_name, root_helper):
self.br_name = br_name self.br_name = br_name
self.root_helper = root_helper self.root_helper = root_helper
self.re_id = self.re_compile_id()
def re_compile_id(self):
external = 'external_ids\s*'
mac = 'attached-mac="(?P<vif_mac>([a-fA-F\d]{2}:){5}([a-fA-F\d]{2}))"'
iface = 'iface-id="(?P<vif_id>[^"]+)"'
name = 'name\s*:\s"(?P<port_name>[^"]*)"'
port = 'ofport\s*:\s(?P<ofport>\d+)'
_re = ('%(external)s:\s{ ( %(mac)s,? | %(iface)s,? | . )* }'
' \s+ %(name)s \s+ %(port)s' % locals())
return re.compile(_re, re.M | re.X)
def run_vsctl(self, args): def run_vsctl(self, args):
full_args = ["ovs-vsctl", "--timeout=2"] + args full_args = ["ovs-vsctl", "--timeout=2"] + args
@ -221,8 +233,20 @@ class OVSBridge:
edge_ports.add(iface_id) edge_ports.add(iface_id)
return edge_ports return edge_ports
def get_vif_port(self, port_name): def get_vif_port_by_id(self, port_id):
external_ids = self.db_get_map("Interface", port_name, "external_ids") args = ['--', '--columns=external_ids,name,ofport',
ofport = self.db_get_val("Interface", port_name, "ofport") 'find', 'Interface',
return VifPort(port_name, ofport, external_ids["iface-id"], 'external_ids:iface-id="%s"' % port_id]
external_ids["attached-mac"], self) result = self.run_vsctl(args)
if not result:
return
match = self.re_id.search(result)
try:
vif_mac = match.group('vif_mac')
vif_id = match.group('vif_id')
port_name = match.group('port_name')
ofport = int(match.group('ofport'))
return VifPort(port_name, ofport, vif_id, vif_mac, self)
except Exception, e:
LOG.info("Unable to parse regex results. Exception: %s", e)
return

View File

@ -115,16 +115,17 @@ class OVSRpcCallbacks():
def port_update(self, context, **kwargs): def port_update(self, context, **kwargs):
LOG.debug("port_update received") LOG.debug("port_update received")
port = kwargs.get('port') port = kwargs.get('port')
port_name = 'tap%s' % port['id'][0:11] vif_port = self.int_br.get_vif_port_by_id(port['id'])
vif_port = self.int_br.get_vif_port(port_name) if vif_port:
if port['admin_state_up']: if port['admin_state_up']:
vlan_id = kwargs.get('vlan_id') vlan_id = kwargs.get('vlan_id')
# create the networking for the port # create the networking for the port
self.int_br.set_db_attribute("Port", vif_port.port_name, self.int_br.set_db_attribute("Port", vif_port.port_name,
"tag", str(vlan_id)) "tag", str(vlan_id))
self.int_br.delete_flows(in_port=vif_port.ofport) self.int_br.delete_flows(in_port=vif_port.ofport)
else: else:
self.int_br.clear_db_attribute("Port", vif_port.port_name, "tag") self.int_br.clear_db_attribute("Port", vif_port.port_name,
"tag")
def tunnel_update(self, context, **kwargs): def tunnel_update(self, context, **kwargs):
LOG.debug("tunnel_update received") LOG.debug("tunnel_update received")
@ -316,12 +317,12 @@ class OVSQuantumAgent(object):
continue continue
if 'port_id' in details: if 'port_id' in details:
LOG.info("Port %s updated. Details: %s", device, details) LOG.info("Port %s updated. Details: %s", device, details)
port_name = 'tap%s' % details['port_id'][0:11] port = self.int_br.get_vif_port_by_id(details['port_id'])
port = self.int_br.get_vif_port(port_name) if port:
if details['admin_state_up']: if details['admin_state_up']:
self.port_bound(port, details['vlan_id']) self.port_bound(port, details['vlan_id'])
else: else:
self.port_unbound(port, True) self.port_unbound(port, True)
else: else:
LOG.debug("Device %s not defined on plugin", device) LOG.debug("Device %s not defined on plugin", device)
return resync return resync
@ -734,13 +735,13 @@ class OVSQuantumTunnelAgent(object):
continue continue
if 'port_id' in details: if 'port_id' in details:
LOG.info("Port %s updated. Details: %s", device, details) LOG.info("Port %s updated. Details: %s", device, details)
port_name = 'tap%s' % details['port_id'][0:11] port = self.int_br.get_vif_port_by_id(details['port_id'])
port = self.int_br.get_vif_port(port_name) if port:
if details['admin_state_up']: if details['admin_state_up']:
self.port_bound(port, details['network_id'], self.port_bound(port, details['network_id'],
details['vlan_id']) details['vlan_id'])
else: else:
self.port_unbound(port, details['network_id']) self.port_unbound(port, details['network_id'])
else: else:
LOG.debug("Device %s not defined on plugin", device) LOG.debug("Device %s not defined on plugin", device)
return resync return resync

View File

@ -277,3 +277,18 @@ class OVS_Lib_Test(unittest.TestCase):
self.mox.ReplayAll() self.mox.ReplayAll()
self.br.clear_db_attribute("Port", pname, "tag") self.br.clear_db_attribute("Port", pname, "tag")
self.mox.VerifyAll() self.mox.VerifyAll()
def test_port_id_regex(self):
result = ('external_ids : {attached-mac="fa:16:3e:23:5b:f2",'
' iface-id="5c1321a7-c73f-4a77-95e6-9f86402e5c8f",'
' iface-status=active}\nname :'
' "dhc5c1321a7-c7"\nofport : 2\n')
match = self.br.re_id.search(result)
vif_mac = match.group('vif_mac')
vif_id = match.group('vif_id')
port_name = match.group('port_name')
ofport = int(match.group('ofport'))
self.assertEqual(vif_mac, 'fa:16:3e:23:5b:f2')
self.assertEqual(vif_id, '5c1321a7-c73f-4a77-95e6-9f86402e5c8f')
self.assertEqual(port_name, 'dhc5c1321a7-c7')
self.assertEqual(ofport, 2)