On Wed, Oct 30, 2024 at 2:31 AM Qin, Qiaofeng via discuss <ovs-discuss@openvswitch.org> wrote: > > Hi Numan, > > Thank you for the reply. Yes, The given command (ovn-appctl -t ovn-northd > inc-engine/recompute) can fix the issue without restarting. Besides, we also > found that creating a logical switch (ovn-nbctl ls-add test3) can make the > missing ACL appear in SB.
One work around before this issue is fixed is to create a separate ACLs for each port group rather than sharing across pgs. Thanks Numan > > > Thanks, > Qiaofeng > ________________________________ > From: Numan Siddique <num...@ovn.org> > Sent: Tuesday, October 29, 2024 7:41 PM > To: Qin, Qiaofeng <qiaofeng....@intel.com> > Cc: b...@openvswitch.org <b...@openvswitch.org> > Subject: Re: [ovs-discuss] [OVN] ACLs not translated to SB when added to > multiple port groups > > On Tue, Oct 29, 2024 at 8:47 PM Qin, Qiaofeng via discuss > <ovs-discuss@openvswitch.org> wrote: > > > > Hi, > > > > Recently, we encountered an issue when assigning some ACLs to two port > > groups. When configuring the first ACL, everything looks correct. However, > > after creating the second ACL and assigning it to the second port group, > > the ACL does not appear in the Logical_Flow table, until we continue to > > perform some other operations in the northbound or restart ovn-northd. I > > wonder if this is a bug or a known limitation. > > > > We installed ovn-central 24.09.0 through apt in a Debian Sid host. The > > following logs are the steps to reproduce the issue: > > > > > > # Setup: 2 switches, 2 ports and 2 port groups > > root@38469380e572:/# ovn-nbctl ls-add test1 > > root@38469380e572:/# ovn-nbctl ls-add test2 > > root@38469380e572:/# ovn-nbctl lsp-add test1 p1 > > root@38469380e572:/# ovn-nbctl lsp-add test2 p2 > > root@38469380e572:/# ovn-nbctl pg-add g1 > > root@38469380e572:/# ovn-nbctl pg-add g2 p1 p2 > > > > # Assign acl1 first to g1, then to g2 > > root@334a6440dc45:/# ovn-nbctl --name=rule1 acl-add g1 from-lport 100 > > "foo1" drop > > root@334a6440dc45:/# ovn-nbctl list acl rule1 | grep uuid > > _uuid : fa7caa68-d4fa-4e69-8274-c5e5b57490aa > > root@334a6440dc45:/# ovn-nbctl add port_group g2 acls > > fa7caa68-d4fa-4e69-8274-c5e5b57490aa > > > > # Northbound results: Correct > > root@334a6440dc45:/# ovn-nbctl acl-list g1 > > from-lport 100 (foo1) drop log(name=rule1) > > root@334a6440dc45:/# ovn-nbctl acl-list g2 > > from-lport 100 (foo1) drop log(name=rule1) > > > > # Southbound results: Correct > > root@334a6440dc45:/# ovn-sbctl dump-flows | grep foo > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > > > # Assign acl2 first to g1, then to g2 > > root@334a6440dc45:/# ovn-nbctl --name=rule2 acl-add g1 from-lport 100 > > "foo2" drop > > root@334a6440dc45:/# ovn-nbctl list acl rule2 | grep uuid > > _uuid : 6b6080e5-1ecf-4d1d-bb86-8eb487c622c0 > > root@334a6440dc45:/# ovn-nbctl add port_group g2 acls > > 6b6080e5-1ecf-4d1d-bb86-8eb487c622c0 > > > > # Northbound results: Correct > > root@334a6440dc45:/# ovn-nbctl acl-list g1 > > from-lport 100 (foo1) drop log(name=rule1) > > from-lport 100 (foo2) drop log(name=rule2) > > root@334a6440dc45:/# ovn-nbctl acl-list g2 > > from-lport 100 (foo1) drop log(name=rule1) > > from-lport 100 (foo2) drop log(name=rule2) > > > > # Southbound results: Incorrect - Second ACL does not show > > root@334a6440dc45:/# ovn-sbctl dump-flows | grep foo > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > > > # Remove acl1 from g2 > > root@334a6440dc45:/# ovn-nbctl acl-del g2 from-lport 100 "foo1" > > > > # Northbound results: Correct > > root@334a6440dc45:/# ovn-nbctl acl-list g1 > > from-lport 100 (foo1) drop log(name=rule1) > > from-lport 100 (foo2) drop log(name=rule2) > > root@334a6440dc45:/# ovn-nbctl acl-list g2 > > from-lport 100 (foo2) drop log(name=rule2) > > > > # Southbound results: Incorrect - first ACL not removed > > root@334a6440dc45:/# ovn-sbctl dump-flows | grep foo > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo1)), > > action=(log(name="rule1", severity=info, verdict=drop); reg8[17] = 1; next;) > > > > # Restart OVN can fix the inconsistency: acl1 removed, acl2 appears > > root@334a6440dc45:/# ovn-ctl restart_northd > > root@334a6440dc45:/# ovn-sbctl dump-flows | grep foo > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo2)), > > action=(log(name="rule2", severity=info, verdict=drop); reg8[17] = 1; next;) > > table=8 (ls_in_acl_eval ), priority=1100 , match=((foo2)), > > action=(log(name="rule2", severity=info, verdict=drop); reg8[17] = 1; next;) > > > > > > When we assigned each ACL to only one port group, we did not observe the > > same issue. When we assigned ACLs to (either one or more) logical switches > > instead of port groups, this issue also did not happen. > > Thanks for reporting the issue. Looks like a bug to me in ovn-northd. > > Can you please run the below command instead of restarting and see if > it fixes the issue ? If so, it seems like an incremental processing > bug in ovn-northd. > > ovn-appctl -t ovn-northd inc-engine/recompute > > Thanks > Numan > > > > > > Thanks, > > Qiaofeng > > _______________________________________________ > > discuss mailing list > > disc...@openvswitch.org > > https://mail.openvswitch.org/mailman/listinfo/ovs-discuss > _______________________________________________ > discuss mailing list > disc...@openvswitch.org > https://mail.openvswitch.org/mailman/listinfo/ovs-discuss _______________________________________________ discuss mailing list disc...@openvswitch.org https://mail.openvswitch.org/mailman/listinfo/ovs-discuss