[OVN] Fix inconsistent IGMP configuration
Prior to this patch the IGMP configuration for ML2/OVN was inconsistent with the configuration option description and also the ML2/OVS driver because it was flooding traffic to unregistered VMs [0]. The "igmp_snooping_enable" configuration option says: "Setting this option to True will also enable Open vSwitch mcast-snooping-disable-flood-unregistered flag. This option will disable flooding of unregistered multicast packets to all ports." But, in ML2/OVN that behavior was inconsistent prior to this patch because it allowed traffic to flood to unregistered VMs. This patch fixes it. [0] https://opendev.org/openstack/neutron/src/branch/master/neutron/conf/agent/ovs_conf.py#L36-L47 Change-Id: I5cbe09e26120905b29351d61bbadb30b5dd14938 Closes-Bug: #1904399 Signed-off-by: Lucas Alvares Gomes <lucasagomes@gmail.com>
This commit is contained in:
parent
f6e2c45bcd
commit
9dc8bca740
@ -35,15 +35,15 @@ OVN Database information
|
|||||||
~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
The ``igmp_snooping_enable`` configuration from Neutron is translated
|
The ``igmp_snooping_enable`` configuration from Neutron is translated
|
||||||
into the ``mcast_snoop`` and ``mcast_flood_unregistered`` options set
|
into the ``mcast_snoop`` option set in the ``other_config`` column
|
||||||
in the ``other_config`` column from the ``Logical_Switch`` table in the
|
from the ``Logical_Switch`` table in the OVN Northbound Database
|
||||||
OVN Northbound Database:
|
(``mcast_flood_unregistered`` is always "false"):
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
$ ovn-nbctl list Logical_Switch
|
$ ovn-nbctl list Logical_Switch
|
||||||
_uuid : d6a2fbcd-aaa4-4b9e-8274-184238d66a15
|
_uuid : d6a2fbcd-aaa4-4b9e-8274-184238d66a15
|
||||||
other_config : {mcast_flood_unregistered="true", mcast_snoop="true"}
|
other_config : {mcast_flood_unregistered="false", mcast_snoop="true"}
|
||||||
...
|
...
|
||||||
|
|
||||||
.. end
|
.. end
|
||||||
|
@ -566,7 +566,7 @@ class DBInconsistenciesPeriodics(SchemaAwarePeriodicsBase):
|
|||||||
'Logical_Switch', ls.name,
|
'Logical_Switch', ls.name,
|
||||||
('other_config', {
|
('other_config', {
|
||||||
ovn_const.MCAST_SNOOP: value,
|
ovn_const.MCAST_SNOOP: value,
|
||||||
ovn_const.MCAST_FLOOD_UNREGISTERED: value})))
|
ovn_const.MCAST_FLOOD_UNREGISTERED: 'false'})))
|
||||||
|
|
||||||
raise periodics.NeverAgain()
|
raise periodics.NeverAgain()
|
||||||
|
|
||||||
|
@ -1577,7 +1577,7 @@ class OVNClient(object):
|
|||||||
vlan_transparent = (
|
vlan_transparent = (
|
||||||
'true' if network.get('vlan_transparent') else 'false')
|
'true' if network.get('vlan_transparent') else 'false')
|
||||||
params['other_config'] = {ovn_const.MCAST_SNOOP: value,
|
params['other_config'] = {ovn_const.MCAST_SNOOP: value,
|
||||||
ovn_const.MCAST_FLOOD_UNREGISTERED: value,
|
ovn_const.MCAST_FLOOD_UNREGISTERED: 'false',
|
||||||
ovn_const.VLAN_PASSTHRU: vlan_transparent}
|
ovn_const.VLAN_PASSTHRU: vlan_transparent}
|
||||||
return params
|
return params
|
||||||
|
|
||||||
|
@ -846,7 +846,7 @@ class TestMaintenance(_TestMaintenanceHelper):
|
|||||||
|
|
||||||
self.assertEqual('true', ls['other_config'][ovn_const.MCAST_SNOOP])
|
self.assertEqual('true', ls['other_config'][ovn_const.MCAST_SNOOP])
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
'true', ls['other_config'][ovn_const.MCAST_FLOOD_UNREGISTERED])
|
'false', ls['other_config'][ovn_const.MCAST_FLOOD_UNREGISTERED])
|
||||||
|
|
||||||
def test_floating_ip(self):
|
def test_floating_ip(self):
|
||||||
ext_net = self._create_network('ext_networktest', external=True)
|
ext_net = self._create_network('ext_networktest', external=True)
|
||||||
|
@ -319,7 +319,7 @@ class TestDBInconsistenciesPeriodics(testlib_api.SqlTestCaseLight,
|
|||||||
attrs={'name': 'ls2',
|
attrs={'name': 'ls2',
|
||||||
'other_config': {
|
'other_config': {
|
||||||
constants.MCAST_SNOOP: 'true',
|
constants.MCAST_SNOOP: 'true',
|
||||||
constants.MCAST_FLOOD_UNREGISTERED: 'true'}})
|
constants.MCAST_FLOOD_UNREGISTERED: 'false'}})
|
||||||
|
|
||||||
nb_idl.ls_list.return_value.execute.return_value = [ls0, ls1, ls2]
|
nb_idl.ls_list.return_value.execute.return_value = [ls0, ls1, ls2]
|
||||||
|
|
||||||
@ -332,11 +332,11 @@ class TestDBInconsistenciesPeriodics(testlib_api.SqlTestCaseLight,
|
|||||||
mock.call('Logical_Switch', 'ls0',
|
mock.call('Logical_Switch', 'ls0',
|
||||||
('other_config', {
|
('other_config', {
|
||||||
constants.MCAST_SNOOP: 'true',
|
constants.MCAST_SNOOP: 'true',
|
||||||
constants.MCAST_FLOOD_UNREGISTERED: 'true'})),
|
constants.MCAST_FLOOD_UNREGISTERED: 'false'})),
|
||||||
mock.call('Logical_Switch', 'ls1',
|
mock.call('Logical_Switch', 'ls1',
|
||||||
('other_config', {
|
('other_config', {
|
||||||
constants.MCAST_SNOOP: 'true',
|
constants.MCAST_SNOOP: 'true',
|
||||||
constants.MCAST_FLOOD_UNREGISTERED: 'true'})),
|
constants.MCAST_FLOOD_UNREGISTERED: 'false'})),
|
||||||
]
|
]
|
||||||
nb_idl.db_set.assert_has_calls(expected_calls)
|
nb_idl.db_set.assert_has_calls(expected_calls)
|
||||||
|
|
||||||
|
@ -718,7 +718,7 @@ class TestOVNMechanismDriver(test_plugin.Ml2PluginV2TestCase):
|
|||||||
ovn_utils.ovn_name(net['id']), external_ids=mock.ANY,
|
ovn_utils.ovn_name(net['id']), external_ids=mock.ANY,
|
||||||
may_exist=True,
|
may_exist=True,
|
||||||
other_config={ovn_const.MCAST_SNOOP: value,
|
other_config={ovn_const.MCAST_SNOOP: value,
|
||||||
ovn_const.MCAST_FLOOD_UNREGISTERED: value,
|
ovn_const.MCAST_FLOOD_UNREGISTERED: 'false',
|
||||||
ovn_const.VLAN_PASSTHRU: 'false'})
|
ovn_const.VLAN_PASSTHRU: 'false'})
|
||||||
|
|
||||||
def test_create_network_igmp_snoop_enabled(self):
|
def test_create_network_igmp_snoop_enabled(self):
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
issues:
|
||||||
|
- |
|
||||||
|
Even with the "igmp_snooping_enable" configuration option stating that
|
||||||
|
traffic would not be flooded to unregistered VMs when this option was
|
||||||
|
enabled, the ML2/OVN driver didn't follow that behavior. This
|
||||||
|
has now been fixed and ML2/OVN will no longer flood traffic to
|
||||||
|
unregistered VMs when this configuration option is set to True.
|
Loading…
Reference in New Issue
Block a user