[ovs-dev] [PATCH v3 ovn 2/2] ovn-northd: Fix tunnel_key allocation for SB Port_Bindings.

Numan Siddique numans at ovn.org
Fri May 1 11:38:44 UTC 2020


On Fri, May 1, 2020 at 12:03 AM Dumitru Ceara <dceara at redhat.com> wrote:

> When generating Port_Binding records ovn-northd tries to reuse the
> tunnel_key value from the original SB record, if any available.
>
> However, there's no check for tunnel_keys that would conflict with
> newly allocated keys for new records. In order to avoid that, we
> don't reuse stale Port_Binding entries, i.e., their "datapath" field
> doesn't match the Datapath_Binding record associated with the
> logical switch/router they're part of.
>
> One way to reproduce the issue is:
> $ ovn-nbctl ls-add ls1
> $ ovn-nbctl ls-add ls2
> $ ovn-nbctl lsp-add ls1 lsp1
> $ ovn-nbctl lsp-add ls2 lsp2
> $ ovn-nbctl --wait=sb sync
> $ ovn-nbctl lsp-del lsp2 -- lsp-add ls1 lsp2
>
> Another option to reproduce the issue is with HA_Chassis_Group:
> $ ovn-nbctl ls-add ls1
> $ ovn-nbctl ls-add ls2
> $ ovn-nbctl lsp-add ls1 lsp1
> $ ovn-nbctl lsp-add ls2 lsp2
> $ ovn-nbctl lsp-set-type lsp2 external
> $ ovn-nbctl ha-chassis-group-add chg1
> $ ovn-nbctl ha-chassis-group-add-chassis chg1 chassis-1 30
> $ chg1_uuid=$(ovn-nbctl --bare --columns _uuid list ha_Chassis_Group .)
> $ ovn-nbctl set logical_switch_port lsp2 ha_chassis_group=${chg1_uuid}
> $ ovn-nbctl lsp-del lsp2 -- lsp-add ls1 lsp2
>
> Reported-by: Dan Williams <dcbw at redhat.com>
> Reported-at: https://bugzilla.redhat.com/1828637
> Signed-off-by: Dumitru Ceara <dceara at redhat.com>
>

Acked-by: Numan Siddique <numans at ovn.org>

Thanks
Numan


> ---
>  northd/ovn-northd.c |    6 +++--
>  tests/ovn-northd.at |   56
> +++++++++++++++++++++++++++++++++++++++++++++++++++
>  2 files changed, 59 insertions(+), 3 deletions(-)
>
> diff --git a/northd/ovn-northd.c b/northd/ovn-northd.c
> index de59452..e37b346 100644
> --- a/northd/ovn-northd.c
> +++ b/northd/ovn-northd.c
> @@ -2029,7 +2029,7 @@ join_logical_ports(struct northd_context *ctx,
>                  const struct nbrec_logical_switch_port *nbsp
>                      = od->nbs->ports[i];
>                  struct ovn_port *op = ovn_port_find(ports, nbsp->name);
> -                if (op) {
> +                if (op && op->sb->datapath == od->sb) {
>                      if (op->nbsp || op->nbrp) {
>                          static struct vlog_rate_limit rl
>                              = VLOG_RATE_LIMIT_INIT(5, 1);
> @@ -2123,7 +2123,7 @@ join_logical_ports(struct northd_context *ctx,
>                  }
>
>                  struct ovn_port *op = ovn_port_find(ports, nbrp->name);
> -                if (op) {
> +                if (op && op->sb->datapath == od->sb) {
>                      if (op->nbsp || op->nbrp) {
>                          static struct vlog_rate_limit rl
>                              = VLOG_RATE_LIMIT_INIT(5, 1);
> @@ -2175,7 +2175,7 @@ join_logical_ports(struct northd_context *ctx,
>                      char *redirect_name =
>                          ovn_chassis_redirect_name(nbrp->name);
>                      struct ovn_port *crp = ovn_port_find(ports,
> redirect_name);
> -                    if (crp) {
> +                    if (crp && crp->sb->datapath == od->sb) {
>                          crp->derived = true;
>                          ovn_port_set_nb(crp, NULL, nbrp);
>                          ovs_list_remove(&crp->list);
> diff --git a/tests/ovn-northd.at b/tests/ovn-northd.at
> index a4469c7..a0109ae 100644
> --- a/tests/ovn-northd.at
> +++ b/tests/ovn-northd.at
> @@ -1414,3 +1414,59 @@ lr_uuid=$(ovn-nbctl --columns _uuid list
> Logical_Router .)
>  AT_CHECK[test ${nb_uuid} = ${lr_uuid}]
>
>  AT_CLEANUP
> +
> +AT_SETUP([ovn -- check reconcile stale tunnel keys])
> +ovn_start
> +
> +ovn-nbctl ls-add ls1
> +ovn-nbctl ls-add ls2
> +ovn-nbctl lsp-add ls1 lsp1
> +ovn-nbctl lsp-add ls2 lsp2
> +AT_CHECK([ovn-nbctl --wait=sb sync], [0])
> +
> +# Ports are bound on different datapaths so it's expected that they both
> +# get tunnel_key == 1.
> +AT_CHECK([test 1 = $(ovn-sbctl --bare --columns tunnel_key find \
> +port_binding logical_port=lsp1)])
> +AT_CHECK([test 1 = $(ovn-sbctl --bare --columns tunnel_key find \
> +port_binding logical_port=lsp2)])
> +
> +ovn-nbctl lsp-del lsp2 -- lsp-add ls1 lsp2
> +AT_CHECK([ovn-nbctl --wait=sb sync], [0])
> +
> +AT_CHECK([test 1 = $(ovn-sbctl --bare --columns tunnel_key find \
> +port_binding logical_port=lsp1)])
> +AT_CHECK([test 2 = $(ovn-sbctl --bare --columns tunnel_key find \
> +port_binding logical_port=lsp2)])
> +
> +# ovn-northd should allocate a new tunnel_key for lsp1 or lsp2 to maintain
> +# unique DB indices.
> +AT_CHECK([test ${pb1_key} != ${pb2_key}])
> +
> +AT_CLEANUP
> +
> +AT_SETUP([ovn -- check reconcile stale Ha_Chassis_Group])
> +ovn_start
> +
> +ovn-nbctl ls-add ls1
> +ovn-nbctl ls-add ls2
> +ovn-nbctl lsp-add ls1 lsp1
> +ovn-nbctl lsp-add ls2 lsp2
> +
> +ovn-nbctl lsp-set-type lsp2 external
> +
> +ovn-nbctl ha-chassis-group-add chg1
> +ovn-nbctl ha-chassis-group-add-chassis chg1 chassis-1 30
> +
> +chg1_uuid=$(ovn-nbctl --bare --columns _uuid list Ha_Chassis_Group .)
> +ovn-nbctl set logical_switch_port lsp2 ha_chassis_group=${chg1_uuid}
> +AT_CHECK([ovn-nbctl --wait=sb sync], [0])
> +
> +# Move lsp2 from ls2 to ls1. This should also remove the SB
> HA_Chassis_Group
> +# record.
> +ovn-nbctl lsp-del lsp2 -- lsp-add ls1 lsp2
> +AT_CHECK([ovn-nbctl --wait=sb sync], [0])
> +
> +AT_CHECK([test 0 = $(ovn-sbctl list Ha_Chassis_Group | wc -l)])
> +
> +AT_CLEANUP
>
> _______________________________________________
> dev mailing list
> dev at openvswitch.org
> https://mail.openvswitch.org/mailman/listinfo/ovs-dev
>
>


More information about the dev mailing list