-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Overlay ECMP with BFD support #861
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 1 commit
Commits
Show all changes
6 commits
Select commit
Hold shift + click to select a range
9f58c56
Overlay ECMP with BFD support HLD
prsunny b9f1e94
Update Overlay ECMP with BFD.md
prsunny 1230d23
Update Overlay ECMP with BFD.md
prsunny 8ca1ac9
Update Overlay ECMP with BFD.md
prsunny a2c68f2
Updated for IPv6 test cases
prsunny 48f4cd0
Added testcases and scaling requirements
prsunny File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,216 @@ | ||
| # Overlay ECMP with BFD monitoring | ||
| ## High Level Design Document | ||
| ### Rev 1.0 | ||
|
|
||
| # Table of Contents | ||
|
|
||
| * [Revision](#revision) | ||
|
|
||
| * [About this Manual](#about-this-manual) | ||
|
|
||
| * [Scope](#scope) | ||
|
|
||
| * [Definitions/Abbreviation](#definitionsabbreviation) | ||
|
|
||
| * [1 Requirements Overview](#1-requirements-overview) | ||
| * [1.1 Usecase](#11-Usecase) | ||
| * [1.2 Functional requirements](#12-functional-requirements) | ||
| * [1.3 CLI requirements](#13-cli-requirements) | ||
| * [1.4 Warm Restart requirements ](#14-warm-restart-requirements) | ||
| * [2 Modules Design](#2-modules-design) | ||
| * [2.1 Config DB](#21-config-db) | ||
| * [2.2 App DB](#22-app-db) | ||
| * [2.3 Orchestration Agent](#23-orchestration-agent) | ||
| * [2.4 CLI](#24-cli) | ||
|
|
||
| ###### Revision | ||
| | Rev | Date | Author | Change Description | | ||
| |:---:|:-----------:|:------------------:|-----------------------------------| | ||
| | 0.1 | 09/09/2021 | Prince Sunny | Initial version | | ||
|
|
||
| # About this Manual | ||
| This document provides general information about the Vxlan Overlay ECMP feature implementation in SONiC with BFD support. This is an extension to the existing VNET Vxlan support as defined in the [Vxlan HLD](https://github.com/Azure/SONiC/blob/master/doc/vxlan/Vxlan_hld.md) | ||
| # Scope | ||
| This document describes the high level design of the Overlay ECMP feature and associated BFD support. General BFD support and configurations are beyond the scope of this document. | ||
|
|
||
| # Definitions/Abbreviation | ||
| ###### Table 1: Abbreviations | ||
| | | | | ||
| |--------------------------|--------------------------------| | ||
| | BFD | Bidirectional Forwarding | | ||
| | VNI | Vxlan Network Identifier | | ||
| | VTEP | Vxlan Tunnel End Point | | ||
| | VNet | Virtual Network | | ||
|
|
||
| # 1 Requirements Overview | ||
|
|
||
| ## 1.1 Usecase | ||
|
|
||
|  | ||
|
|
||
| ## 1.1 Functional requirements | ||
|
|
||
| At a high level the following should be supported: | ||
|
|
||
| - Configure ECMP with Tunnel Nexthops (IPv4 and IPv6) | ||
| - Tunnel Endpoint monitoring via BFD | ||
| - Add/Withdraw Nexthop based on Tunnel or Endpoint health | ||
|
|
||
| ## 1.2 CLI requirements | ||
| - User should be able to show the BFD session | ||
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| - User should be able to show the Vnet routes | ||
|
|
||
| ## 1.3 Warm Restart requirements | ||
| No special handling for Warm restart support. | ||
|
|
||
| # 2 Modules Design | ||
|
|
||
| The following are the schema changes. | ||
|
|
||
| ## 2.1 Config DB | ||
|
|
||
| Existing Vxlan and Vnet tables. | ||
|
|
||
| ### 2.1.1 VXLAN Table | ||
| ``` | ||
| VXLAN_TUNNEL|{{tunnel_name}} | ||
| "src_ip": {{ip_address}} | ||
| "dst_ip": {{ip_address}} (OPTIONAL) | ||
| ``` | ||
| ### 2.1.2 VNET/Interface Table | ||
| ``` | ||
| VNET|{{vnet_name}} | ||
| "vxlan_tunnel": {{tunnel_name}} | ||
| "vni": {{vni}} | ||
| "scope": {{"default"}} (OPTIONAL) | ||
| "peer_list": {{vnet_name_list}} (OPTIONAL) | ||
| ``` | ||
|
|
||
| ## 2.2 APP DB | ||
|
|
||
| ### VNET | ||
|
|
||
| The following are the changes for Vnet Route table | ||
|
|
||
| Existing: | ||
|
|
||
| ``` | ||
| VNET_ROUTE_TUNNEL_TABLE:{{vnet_name}}:{{prefix}} | ||
| "endpoint": {{ip_address}} | ||
| "mac_address":{{mac_address}} (OPTIONAL) | ||
| "vni": {{vni}}(OPTIONAL) | ||
| ``` | ||
|
|
||
| Proposed: | ||
| ``` | ||
| VNET_ROUTE_TUNNEL_TABLE:{{vnet_name}}:{{prefix}} | ||
| "endpoint": {{ip_address1},{ip_address2},...} | ||
| "endpoint_monitor": {{ip_address1},{ip_address2},...} (OPTIONAL) | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| "mac_address":{{mac_address1},{mac_address2},...} (OPTIONAL) | ||
| "vni": {{vni1},{vni2},...} (OPTIONAL) | ||
| "weight": {{w1},{w2},...} (OPTIONAL) | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| “profile”: {{profile_name}} (OPTIONAL) | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| ``` | ||
|
|
||
| ``` | ||
| key = VNET_ROUTE_TUNNEL_TABLE:vnet_name:prefix ; Vnet route tunnel table with prefix | ||
| ; field = value | ||
| ENDPOINT = list of ipv4 addresses ; comma separated list of endpoints | ||
| ENDPOINT_MONITOR = list of ipv4 addresses ; comma separated list of endpoints | ||
| MAC_ADDRESS = 12HEXDIG ; Inner dst mac in encapsulated packet | ||
| VNI = DIGITS ; VNI value in encapsulated packet | ||
| WEIGHT = DIGITS ; Weights for the nexthops, comma separated (Optional) | ||
| PROFILE = STRING ; profile name to be applied for this route, for community | ||
| string etc (Optional) | ||
| ``` | ||
|
|
||
| ### BFD | ||
|
|
||
| ``` | ||
| BFD_SESSION:{{ifname}}:{{prefix}} | ||
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| "tx_interval": {{interval}} (OPTIONAL) | ||
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
| "rx_interval": {{interval}} (OPTIONAL) | ||
| "multiplier": {{detection multiplier}} (OPTIONAL) | ||
| "shutdown": {{false}} | ||
| "multihop": {{false}} | ||
| "local_addr": {{ipv4/v6}} (OPTIONAL) | ||
| "type": {{string}} (active/passive..) | ||
| ; Defines APP DB schema to initiate BFD session. | ||
| ``` | ||
|
|
||
| ## 2.3 Module Interaction | ||
|
|
||
| Overlay routes can be programmed via RestAPI or gNMI/gRPC interface which is not described in this document. A highlevel module interaction is shown below | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
|
||
|  | ||
|
|
||
| ## 2.3 Orchestration Agent | ||
| Following orchagents shall be modified. | ||
|
|
||
| ### VnetOrch | ||
|
|
||
| #### Requirements | ||
|
|
||
| - Vnetorch to add support to handle multiple endpoints for APP_VNET_RT_TUNNEL_TABLE_NAME based route task. | ||
| - Reuse Nexthop tunnel based on the endpoint configuration. | ||
| - If there is already the same endpoint exists, use that as member for Nexthop group. | ||
| - Similar to above, reuse nexthop group, if multiple routes are programmed with the same set of nexthops. | ||
| - Provide support for endpoint modification for a route prefix. Require SAI support for SET operation of routes. | ||
| - Provide support for endpoint deletion for a route prefix. Orchagent shall check the existing entries and delete any tunnel/nexthop based on the new route update | ||
| - Ensure backward compatibility with single endpoint routes | ||
| - Use SAI_NEXT_HOP_GROUP_MEMBER_ATTR_WEIGHT for specifying weights to nexthop member | ||
| - Desirable to have per tunnel stats via sai_tunnel_stat_t | ||
|
|
||
| #### Detailed flow | ||
|
|
||
| VnetOrch is one of the critical module for supporting overlay ecmp. VnetOrch subscribes to VNET and ROUTE updates from APP_DB. | ||
|
|
||
| When a new route update is processed by the add operation, | ||
|
|
||
| 1. VnetOrch checks the nexthop group and if it exists, reuse the group | ||
| 2. For a new nexthop group member, add the ECMP member and identify the corresponding monitoring IP address. Create a mapping between the monitoring IP and nexthop tunnel endpoint. | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| 3. Initiate a BFD session for the monitoring IP if it does not exist | ||
| 4. Based on the BFD implementation (BfdOrch vs Control plane BFD), subscribe to BFD state change, either directly as subject observer (similar to port oper state notifications in orchagent) or via STATEDB update. | ||
prsunny marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| 5. Based on the VNET global configuration to advertise prefixes, indicate to STATEDB if the prefix must be advertised by BGP/FRR only if there is atleast one active nexthop. Remove this entry if there are no active nexthops indicated by BFD session down so that the network pfx is no longer advertised. | ||
|
|
||
| #### Monitoring Endpoint Mapping | ||
|
|
||
| VNET_ROUTE_TUNNEL_TABLE can provide monitoring endpoint IPs which can be different from the tunnel termination endpoints. VnetOrch creates a mapping for such endpoints and based on the monitoring endpoint (MonEP1) health, proceed with adding/removing nexthop tunnel endpoint (EP1) from the ECMP group for the respective prefix. It is assumed that for one tunnel termination endpoint (EP1), there shall be only one corresponding monitoring endpoint (MonEP1). | ||
|
|
||
| #### Pros of SWSS to handle route update based on tunnel nexthop health: | ||
|
|
||
| - No significant changes, if BFD session management is HW offload via SAI notifications or Control Plane assisted. | ||
| - Similar to NHFLAGS handling for existing route ECMP group | ||
| - Better performance in re-programming routes in ASIC instead of separate process to monitor and modify each route prefix by updating DB entries | ||
|
|
||
| ### BfdOrch | ||
| Sonic may offload the BFD session handling to hardware that has BFD capabilities. A new module, BfdOrch shall be introduced to handle BFD session to monitoring endpoints and check the health of remote endpoints. BfdOrch shall offload the session initiation/sustenance to hardware via SAI APIs and gets the notifications of session state from SAI. The session state shall be updated in STATE_DB and to any other observer orchestration agents. | ||
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
|  | ||
|
|
||
| For offloading, the following shall be the SAI attributes programmed by BfdOrch. | ||
|
|
||
| | Attribute Type | Value | | ||
| |--------------------------|--------------------------------| | ||
| | SAI_BFD_SESSION_ATTR_TYPE | SAI_BFD_SESSION_TYPE_ASYNC_ACTIVE | | ||
| | SAI_BFD_SESSION_ATTR_OFFLOAD_TYPE | SAI_BFD_SESSION_OFFLOAD_TYPE_FULL | | ||
| | SAI_BFD_SESSION_ATTR_BFD_ENCAPSULATION_TYPE | SAI_BFD_ENCAPSULATION_TYPE_NONE | | ||
| | SAI_BFD_SESSION_ATTR_SRC_IP_ADDRESS | Loopback0 IPv4 or v6 address | | ||
| | SAI_BFD_SESSION_ATTR_DST_IP_ADDRESS | Remote IPv4 or v6 address | | ||
| | SAI_BFD_SESSION_ATTR_MULTIHOP | True | | ||
|
|
||
| Sai shall notify via notification channel on the session state as one of sai_bfd_session_state_t. BfdOrch can listen on these notifications and update the StateDB for the session state. | ||
|
|
||
| The flow of BfdOrch is presented in the following figure. BfdOrch subscribes to the BFD_SESSION_TABLE of APPL_DB and send the corresponding request to program the BFD sessions to syncd accordingly. The BfdOrch also creates the STATE_DB entry of the BFD session which includes the BFD parameters and an initial state. Upon receiving bfd session state change notifications from syncd, BfdOrch update the STATE_DB field to update the BFD session state. | ||
prsunny marked this conversation as resolved.
Outdated
Show resolved
Hide resolved
|
||
|
|
||
|  | ||
|
|
||
| ## 2.5 CLI | ||
|
|
||
| The following commands shall be modified/added : | ||
|
|
||
| ``` | ||
| - show vnet routes all | ||
| - show vnet routes tunnel | ||
| - show bfd session <session name> | ||
| ``` | ||
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.