From 0e4a002884efdb3504bae6c6477e579cc49ae67e Mon Sep 17 00:00:00 2001 From: Eduardo Olivares Date: Fri, 25 Oct 2024 13:14:20 +0200 Subject: [PATCH] [BGP] Add AZs to schedule Octavia mgmt network on OCP nodes Octavia needs to schedule its management network on the OCP nodes/workers. With BGP, OCP nodes/workers should not be used to schedule OVN router ports. In order to resolve this conflict, this patch uses Availability Zones. --- examples/dt/bgp/bgp_dt01/README.md | 23 ++++++++++++------- .../control-plane/service-values.yaml | 9 ++++++-- .../bgp/bgp_dt01/edpm/networkers/values.yaml | 2 ++ 3 files changed, 24 insertions(+), 10 deletions(-) diff --git a/examples/dt/bgp/bgp_dt01/README.md b/examples/dt/bgp/bgp_dt01/README.md index 70aa8683a..4f5eb4a08 100644 --- a/examples/dt/bgp/bgp_dt01/README.md +++ b/examples/dt/bgp/bgp_dt01/README.md @@ -37,6 +37,13 @@ This DT configures both compute and networker EDPM nodes. So far, networker nodes are needed when BGP is used on RHOSO, in order to expose routes to SNAT traffic (OVN Gateway IPs). In other words, when RHOSO is used with BGP, the OCP workers cannot be configured as OVN Gateways. +On the other hand, Octavia needs to use OCP workers as OVN Gateways for +its management network. +To resolve this conflict, BGP DT01 uses Availability Zones: +* zone-1 is only used for the Octavia management network, which is scheduled on + the OCP workers +* zone-2 is used for the provider networks, whose routers ports will be + scheduled on the networker nodes. The OCP and EDPM nodes deployed with this DT are distributed into three different racks. Each rack is connected to two leaves. @@ -74,14 +81,14 @@ network). ## Services, enabled features and configurations -| Service | configuration | Lock-in coverage? | -| ---------------- | ---------------- | ------------------ | -| Glance | Swift | Must have | -| Swift | (default) | Must have | -| Octavia | (default) | Must have | -| Heat | (default) | Must have | -| frr | dataplane | Must have | -| ovn-bgp-agent | dataplane | Must have | +| Service | configuration | Lock-in coverage? | +| ---------------- | ----------------- | ------------------ | +| Glance | Swift | Must have | +| Swift | (default) | Must have | +| Octavia | (default) | Must have | +| Heat | (default) | Must have | +| frr | dataplane | Must have | +| ovn-bgp-agent | dataplane | Must have | ## Considerations/Constraints diff --git a/examples/dt/bgp/bgp_dt01/control-plane/service-values.yaml b/examples/dt/bgp/bgp_dt01/control-plane/service-values.yaml index 6be14fea6..2d87689c6 100644 --- a/examples/dt/bgp/bgp_dt01/control-plane/service-values.yaml +++ b/examples/dt/bgp/bgp_dt01/control-plane/service-values.yaml @@ -30,6 +30,8 @@ data: enabled: true amphoraImageContainerImage: quay.io/gthiemonge/octavia-amphora-image apacheContainerImage: registry.redhat.io/ubi9/httpd-24:latest + availabilityZones: + - zone-1 octaviaAPI: networkAttachments: - internalapi @@ -60,12 +62,15 @@ data: nicMappings: datacentre: ocpbr octavia: octbr - external-ids: - enable-chassis-as-gateway: false + availability-zones: + - zone-1 neutron: customServiceConfig: | [DEFAULT] vlan_transparent = true debug = true + default_availability_zones = zone-1,zone-2 [ovs] igmp_snooping_enable = true + [ovn] + ovn_emit_need_to_frag = true diff --git a/examples/dt/bgp/bgp_dt01/edpm/networkers/values.yaml b/examples/dt/bgp/bgp_dt01/edpm/networkers/values.yaml index 0d7eae44c..788897633 100644 --- a/examples/dt/bgp/bgp_dt01/edpm/networkers/values.yaml +++ b/examples/dt/bgp/bgp_dt01/edpm/networkers/values.yaml @@ -21,6 +21,8 @@ data: ansiblePort: 22 ansibleVars: edpm_ovn_encap_ip: "{{ lookup('vars', 'bgpmainnet_ip') }}" + edpm_ovn_availability_zones: + - zone-2 edpm_ovn_bgp_agent_expose_tenant_networks: false edpm_frr_bgp_ipv4_src_network: bgpmainnet edpm_frr_bgp_ipv6_src_network: bgpmainnetv6