The disclosure relates to computing networks and particularly relates to network routing protocols.
Network computing is a means for multiple computers or nodes to work together and communicate with one another over a network. There exist wide area networks (WAN) and local area networks (LAN). Both wide and local area networks allow for interconnectivity between computers. Local area networks are commonly used for smaller, more localized networks that may be used in a home, business, school, and so forth. Wide area networks cover larger areas such as cities and can even allow computers in different nations to connect. Local area networks are typically faster and more secure than wide area networks, but wide area networks enable widespread connectivity. Local area networks are typically owned, controlled, and managed in-house by the organization where they are deployed, while wide area networks typically require two or more constituent local area networks to be connection over the public Internet or by way of a private connection established by a telecommunications provider.
Local and wide area networks enable computers to be connected to one another and transfer data and other information. For both local and wide area networks, there must be a means to determine a path by which data is passed from one compute instance to another compute instance. This is referred to as routing. Routing is the process of selecting a path for traffic in a network or between or across multiple networks. The routing process usually directs forwarding on the basis of routing tables which maintain a record of the routes to various network destinations. Routing tables may be specified by an administrator, learned by observing network traffic, or built with the assistance of routing protocols.
One network architecture is a multi-tenant datacenter. The multi-tenant datacenter defines an end-end system suitable for service deployment in a public or private cloud-based model. The multi-tenant datacenter may include a wide area network, multiple provider datacenters, and tenant resources. The multi-tenant datacenter may include a multi-layer hierarchical network model. The multi-layer hierarchy may include a core layer, an aggregation layer, and an access layer. The multiple layers may include a layer-2 overlay and a layer-3 overlay with an L2/L3 boundary.
One datacenter overlay routing architecture is the centralized gateway architecture. Another datacenter overlay routing architecture is the distributed anycast gateway architecture. These architectures have numerous drawbacks as will be discussed further herein. In light of the foregoing, disclosed herein are systems, methods, and devices for improved routing architectures.
Non-limiting and non-exhaustive implementations of the disclosure are described with reference to the following figures, wherein like reference numerals refer to like parts throughout the various views unless otherwise specified. Advantages of the disclosure will become better understood with regard to the following description and accompanying drawings where:
Disclosed herein are systems, methods, and devices for a routed overlay solution for Internet Protocol (IP) subnet stretch using localized integrated routing and bridging (IRB) on host machines. The systems, methods, and devices disclosed herein provide a virtual first hop gateway on a virtual customer edge (CE) router on a bare metal server. The virtual CE router provides localized East-West integrated routing and bridging (IRB) service for local hosts. In an embodiment, a default routed equal-cost multipath (ECMP) uplinks from the virtual CE router to leaf nodes for North-South and East-West connectivity.
The systems, methods, and devices disclosed herein enable numerous networking benefits. The system does not require address resolution protocol (ARP)-based learning of routes and enables deterministic host learning. The improved systems discussed herein eliminate age-outs, probes, and syncs, and do not require media access control (MAC) entries on leaf node. The improved systems additionally eliminate complex multi-chassis link aggregation (MLAG) bridging functions at the leaf node. Additionally, the virtual CE router as discussed herein stores local Internet protocol (IP) and media access control (MAC) addresses along with the default ECMP route to the leaf nodes. Further, the improved systems discussed herein provide host routing at the leaf node for stretched subnets and enable host mobility.
In an Ethernet virtual private network (EVPN)-enabled multiple tenant data center overlay, an architecture with distributed anycast layer-3 (L3) gateway on the leaf nodes provides first hop gateway function for workloads. This pushes a service layer L2-L3 boundary (layer-2 to layer-3 boundary) down to the leaf node. In other words, all inter-subnet virtual private network (VPN) traffic from workload host virtual machines is routed on the leaf nodes. Virtual machine mobility and flexible workload placement is achieved by stretching the layer-2 overlay across the routed network fabric. Intra-subnet traffic across the stretched layer-2 domain is overlay bridged on the leaf node. The leaf node provides an EVPN-IRB service for directly connected host virtual machines. This routes all overlay inter-subnet VPN traffic and bridges all overlay intra-subnet VPN traffic across a routed fabric underlay.
The embodiments discussed herein eliminate the need for overlay bridging functions to be supported on the leaf nodes. Additionally, the embodiments discussed herein eliminate the need for layer-2 MLAG connectivity and related complex procedures between the leaf nodes and hosts. Further, the embodiments discussed herein eliminate the need for data plane and ARP-based host learning on the leaf nodes. These benefits are enabled by the embodiments disclosed herein while providing IP unicast inter-subnet and intra-subnet VPN connectivity, virtual machine mobility, and flexible workload placement across stretched IP subnets.
The embodiments of the disclosure separate local layer-2 switching and IRB functions from the leaf node and localize them into a small virtual CE router on the bare metal server. This is achieved by running a small virtual router VM on the bare metal server that now acts as the first hop gateway for host virtual machines and provides local IRB switching across virtual machines local to the bare metal server. This virtual router acts as a traditional CE router that may be multi-homed to multiple leaf nodes via a layer-3 routed interface on the leaf node. leaf nodes in the fabric function as pure layer-3 VPN PE routers that are free of any layer-2 bridging or IRB function. To allow for flexible placement and mobility of layer-3 endpoints across the DC overlay, while providing optimal routing, traffic can be host routed on the leaf nodes versus being subnet routed. This is also the case with EVPN-IRB.
The improved routing architectures discussed herein (see
Multi-chassis link aggregation (MLAG) and ethernet virtual private network link aggregation (EVPN-LAG) based multi-homing result in a need for complex layer-2 functions to be supported on the leaf nodes. Host MACs must still be learnt in data-plane on either of the leaf nodes and synced across all redundant leaf nodes. Host ARP bindings must still be learnt via ARP flooding on either of the leaf nodes and synced across all redundant leaf nodes. Further, a physical loop resulting from MLAG topology must be prevented for broadcast, unknown-unicast (BUM) traffic via split horizon filtering mechanism across redundant leaf nodes. Further, a designated forwarder election mechanism must be supported on the leaf nodes to prevent duplicate BUM packets being forwarded to multi-homed hosts. While EVPN procedures have been specified for each of the above, overall implementation and operational complexity of an EVPN-IRB based solution may not be desirable for all use cases.
For purposes of furthering understanding of the disclosure, some explanation will be provided for numerous networking computing devices and protocols.
In a computer network environment, a networking device such as a switch or router may be used to transmit information from one destination to a final destination. In an embodiment, a data package and a message may be generated at a first location such as computer within a person's home. The data package and the message could be generated from the person interacting with a web browser and requesting information from or providing information to a remote server accessible over the Internet. In an example, the data package and the message could be information the person input into a form accessible on a webpage connected to the Internet. The data package and the message may need to be transmitted to the remote server that may be geographically located very far from the person's computer. It is very likely that there is no direct communication between the router at the person's home and the remote server. Therefore, the data package and the message must travel by “hopping” to different networking devices until reaching the final destination at the remote server. The router at the person's home must determine a route for transmitting the data package and the message thru multiple different devices connected to the Internet until the data package and the message reach the final destination at the remote server.
A switch (may alternatively be referred to as a switching hub, bridging hub, or MAC bridge) creates a network. Most internal networks use switches to connect computers, printers, phones, camera, lights, and servers in a building or campus. A switch serves as a controller that enables networked devices to talk to each other efficiently. Switches connect devices on a computer network by using packet switching to receive, process, and forward data to the destination device. A network switch is a multiport network bridge that uses hardware addresses to process and forward data at a data link layer (layer 2) of the Open Systems Interconnection (OSI) model. Some switches can also process data at the network layer (layer 3) by additionally incorporating routing functionality. Such switches are commonly known as layer-3 switches or multilayer switches.
A router connects networks. Switches and routers perform similar functions, but each has its own distinct function to perform on a network. A router is a networking device that forwards data packets between computer networks. Routers perform the traffic directing functions on the Internet. Data sent through the Internet, such as a web page, email, or other form of information, is sent in the form of a data packet. A packet is typically forwarded from one router to another router through the networks that constitute an internetwork (e.g., the Internet) until the packet reaches its destination node. Routers are connected to two or more data lines from different networks. When a data packet comes in on one of the lines, the router reads the network address information in the packet to determine the ultimate destination. Then, using information in the router's routing table or routing policy, the router directs the packet to the next network on its journey. A BGP speaker is a router enabled with the Border Gateway Protocol (BGP).
A customer edge router (CE router) is a router located on the customer premises that provides an interface between the customer's LAN and the provider's core network. CE routers, provider routers, and provider edge routers are components in a multiprotocol label switching architecture. Provider routers are located in the core of the provider's or carrier's network. Provider edge routers sit at the edge of the network. Customer edge routers connect to provider edge routers and provider edge routers connect to other provider edge routers over provider routers.
A routing table or routing information base (RIB) is a data table stored in a router or a networked computer that lists the routes to particular network destinations. In some cases, a routing table includes metrics for the routes such as distance, weight, and so forth. The routing table includes information about the topology of the network immediately around the router on which it is stored. The construction of routing tables is the primary goal of routing protocols. Static routes are entries made in a routing table by non-automatic means and which are fixed rather than being the result of some network topology discovery procedure. A routing table may include at least three information fields, including a field for network ID, metric, and next hop. The network ID is the destination subnet. The metric is the routing metric of the path through which the packet is to be sent. The route will go in the direction of the gateway with the lowest metric. The next hop is the address of the next station to which the packet is to be sent on the way to its final destination. The routing table may further include quality of service associate with the route, links to filtering criteria lists associated with the route, interface for an Ethernet card, and so forth.
For hop-by-hop routing, each routing table lists, for all reachable destinations, the address of the next device along the path to that destination, i.e. the next hop. Assuming the routing tables are consistent, the algorithm of relaying packets to their destination's next hop thus suffices to deliver data anywhere in a network. Hop-by-hop is a characteristic of an IP Internetwork Layer and the Open Systems Interconnection (OSI) model.
Some network communication systems are large, enterprise-level networks with thousands of processing nodes. The thousands of processing nodes share bandwidth from multiple Internet Service Providers (ISPs) and can process significant Internet traffic. Such systems can be extremely complex and must be properly configured to result in acceptable Internet performance. If the systems are not properly configured for optimal data transmission, the speed of Internet access can decrease, and the system can experience high bandwidth consumption and traffic. To counteract this problem, a set of services may be implemented to remove or reduce these concerns. This set of services may be referred to as routing control.
An embodiment of a routing control mechanism is composed of hardware and software. The routing control mechanism monitors all outgoing traffic through its connection with an Internet Service Provider (ISP). The routing control mechanism aids in selecting the best path for efficient transmission of data. The routing control mechanism may calculate the performance and efficiency of all ISPs and select only those ISPs that have performed optimally in applicable areas. Route control devices can be configured according to defined parameters pertaining to cost, performance, and bandwidth.
Equal cost multipath (ECMP) routing is a routing strategy where next-hop packet forwarding to a single destination can occur over multiple “best paths.” The multiple best paths are equivalent based on routing metric calculations. Multiple path routing can be used in conjunction with many routing protocols because routing is a per-hop decision limited to a single router. Multiple path routing can substantially increase bandwidth by load-balancing traffic over multiple paths. However, there are numerous issues known with ECMP routing when the strategy is deployed in practice. Disclosed herein are systems, methods, and devices for improved ECMP routing.
For the purposes of promoting an understanding of the principles in accordance with the disclosure, reference will now be made to the embodiments illustrated in the drawings and specific language will be used to describe the same. It will nevertheless be understood that no limitation of the scope of the disclosure is thereby intended. Any alterations and further modifications of the inventive features illustrated herein, and any additional applications of the principles of the disclosure as illustrated herein, which would normally occur to one skilled in the relevant art and having possession of this disclosure, are to be considered within the scope of the disclosure claimed.
Before the structure, systems and methods for tracking the life cycle of objects in a network computing environment are disclosed and described, it is to be understood that this disclosure is not limited to the particular structures, configurations, process steps, and materials disclosed herein as such structures, configurations, process steps, and materials may vary somewhat. It is also to be understood that the terminology employed herein is used for the purpose of describing particular embodiments only and is not intended to be limiting since the scope of the disclosure will be limited only by the appended claims and equivalents thereof.
In describing and claiming the subject matter of the disclosure, the following terminology will be used in accordance with the definitions set out below.
It must be noted that, as used in this specification and the appended claims, the singular forms “a,” “an,” and “the” include plural referents unless the context clearly dictates otherwise.
As used herein, the terms “comprising,” “including,” “containing,” “characterized by,” and grammatical equivalents thereof are inclusive or open-ended terms that do not exclude additional, unrecited elements or method steps.
As used herein, the phrase “consisting of” and grammatical equivalents thereof exclude any element or step not specified in the claim.
As used herein, the phrase “consisting essentially of” and grammatical equivalents thereof limit the scope of a claim to the specified materials or steps and those that do not materially affect the basic and novel characteristic or characteristics of the claimed disclosure.
Referring now to the figures,
The switch 106 connects devices in the local area network 160 by using packet switching to receive, process, and forward data to a destination device. The switch 106 can be configured to, for example, receive data from a computer that is destined for a printer. The switch 106 can receive the data, process the data, and send the data to the printer. The switch 106 may be a layer-1 switch, a layer-2 switch, a layer-3 switch, a layer-4 switch, a layer-7 switch, and so forth. A layer-1 network device transfers data but does not manage any of the traffic coming through it. An example of a layer-1 network device is an Ethernet hub. A layer-2 network device is a multiport device that uses hardware addresses to process and forward data at the data link layer (layer 2). A layer-3 switch can perform some or all of the functions normally performed by a router. However, some network switches are limited to supporting a single type of physical network, typically Ethernet, whereas a router may support different kinds of physical networks on different ports.
The router 162 is a networking device that forwards data packets between computer networks. In the example system 100 shown in
The internet service provider (ISP) 102 is an organization that provides services for accessing, using, or participating in the Internet. The ISP 102 may be organized in various forms, such as commercial, community-owned, non-profit, or privately owned. Internet services typically provided by ISPs 102 include Internet access, Internet transit, domain name registration, web hosting, Usenet service, and colocation. The ISPs 102 shown in
The network service provider (NSP) 104 is an organization that provides bandwidth or network access by providing direct Internet backbone access to Internet service providers. Network service providers may provide access to network access points (NAPS). Network service providers 104 are sometimes referred to as backbone providers or Internet providers. Network service providers 104 may include telecommunication companies, data carriers, wireless communication providers, Internet service providers, and cable television operators offering high-speed Internet access. Network service providers 104 can also include information technology companies.
It should be appreciated that the system 100 illustrated in
There are numerous drawbacks with the centralized gateway architecture 200. There may be an L3-L3 boundary on the spine layer that causes a scale bottleneck. This further causes a single point of failure in the architecture 200. Further, there are numerous operational complexities at the leaf node in the centralized gateway architecture 200. One complexity is that the architecture 200 must deal with the unpredictable nature of MAC and ARP age-outs, probes, silent hosts, and moves. Further, the architecture 200 must be configured to flood overlay ARP and populate both IP and MAC forwarding entries for all hosts across the overlay bridge. Additionally, the architecture 200 must be configured to sync MAC addresses and ARP for MLAG and perform filtering and election for MLAG.
The architecture 300 further illustrates an exemplary architecture for providing a completely routed network fabric. However, certain drawbacks exist with the architecture 300 shown in
MLAG or EVPN-LAG based multi-homing in particular results in a need for complex layer-2 functions to be supported on the distributed anycast routers. For example, host MACs must still be learnt in data-plane on either of the leaf nodes and synced across all redundant distributed anycast routers. Similarly, host ARP bindings must still be learnt via ARP flooding on either of the distributed anycast routers and synced across all redundant distributed anycast routers. A physical loop resulting from MLAG topology must be prevented for BUM traffic via split horizon filtering mechanism across redundant distributed anycast routers. Further, a designated forwarder election mechanism must be supported on the distributed anycast routers to prevent duplicate BUM packets being forwarded to multi-homed hosts.
While EVPN procedures have been specified for each of the above, overall implementation and operational complexity of an EVPN-IRB based solution may not be desirable for all use cases. Accordingly, an alternate solution is provided and discussed herein. For example, the need for overlay bridging functions to be supported on the distributed anycast routers is eliminated. Similarly, this architecture eliminates the need for layer 2 MLAG connectivity and related complex procedures between the distributed anycast routers and hosts and also eliminates the need for data-plane and ARP based host learning on the distributed anycast routers while providing IP unicast inter-subnet and intra-subnet VPN connectivity, VM mobility, and flexible workload placement across stretched IP subnets.
In the example illustrated in
The architecture illustrated in
The architecture 400 includes spine nodes S1 and S2 in communication with leaf nodes L1, L2, L3, and L4. The address for leaf node L1 is 15.1.1.1, the address for leaf node L2 is 14.1.1.1, the address for leaf node L3 is 15.1.1.1, and the address for leaf node L4 is 14.1.1.1. The nodes L1 and L2 are in communication with a virtual customer edge (CE) router. The virtual CE router is located on a bare metal server along with the virtual machines. The nodes L3 and L4 are in communication with a virtual customer edge (CE) router. The L2-L3 boundary exists at the virtual CE router level. The virtual CE routers are in communication with multiple virtual machines, including VM-a, VM-b, VM-c, VM-d, VM-e, VM-f, VM-g, and VM-h as illustrated.
Host virtual machine IP-MAC bindings are traditionally learnt on the first hop gateway via ARP. However, in a stretched subnet scenario, ARP-based learning results in a need to flood ARP requests across the overlay to bootstrap host learning at the local virtual CE router. This requires a layer-2 overlay flood domain. To avoid a layer-2 overlay across the leaf nodes and reliance on ARP-based host learning, the host virtual machine IP and MAC binding configured on the virtual machine external interface and must be passively learnt by L3DL on the server via them being exposed to the hypervisor. This ensures that directly connected host virtual machine bindings are always known upfront. This further avoids any need for glean processing and flooding. Local VM IP host routes (overlay host routes) are relayed from hypervisor to the leaf nodes by way of L3DL.
The architecture 400 introduces a small virtual CE router on the server that terminates layer-2 from the host. The virtual CE router provides IRB service for local host virtual machines. The virtual CE router routes all traffic to external host virtual machines via ECMP layer-3 links to leaf nodes via the default route. The virtual CE routers learn host virtual machine interface IP addresses and MAC addresses at host boot-up. Local VM IP host routes (overlay host routes) are relayed from the hypervisor to the leaf nodes by way of L3DL. The leaf nodes advertise local host routes to remote leaf nodes via Border Gateway Protocol (BGP).
In an embodiment, subnet stretch is enabled via host routing of both intra-subnet and inter-subnet flows at the leaf node. The virtual CE router is configured as a proxy ARP to host route intra-subnet flows via leaf node. The virtual CE router may be configured with the same anycast gateway IP addresses and MAC addresses everywhere. The architecture 400 provides EVPN host mobility procedures applied at the leaf nodes. The architecture 400 enables flexible workload placement and virtual machine mobility across the stretched subnet.
In the architecture 400, end to end host routing is setup at boot-up. Both inter-subnet and intra-subnet traffic flows across stretched subnets enabled via end-to-end host routing. There is no reliance on indeterministic data plane and ARP-based learning.
The architecture 400 provides local host learning via L3DL to the virtual customer edge (virtual CE router) router. The EVPN host routing is performed across the overlay. The EVPN has layer-3 host mobility and layer-3 mass withdraw. The architecture 400 provides private subnet that is never redistributed into Border Gateway Protocol (BGP). In the architecture 400, first hop anycast gateway provides a local IRB service.
The virtual CE routers may be configured as an ARP proxy for all directly connected host virtual machines to that inter-subnet and intra-subnet traffic flows can be routed. The virtual CE routers may be configured with default route pointing to a set of upstream leaf nodes to which the virtual CE router is multi-homed to. The virtual CE routers may be configured with the same anycast gateway MAC on all bare metal servers to enable host virtual machine mobility across the DC fabric. The virtual CE routers may not redistribute server-facing connected subnets into DC side routing protocol to avoid IP addressing overhead on server links. The virtual CE routers may reside in the hypervisor that is provisioned as the default gateway for the host virtual machines in a VLAN. The virtual CE routers may be separate router virtual machines such that the router virtual machine is provisioned as the default gateway for the host virtual machines in a VLAN.
In an embodiment, the leaf nodes must advertise host routes learnt from locally connected virtual CE routers as EVPN RT-5 across the EVPN overlay. The EVPN mobility procedure may be extended to EVPN RT-5 to achieve host virtual machine mobility. The EVPN mass withdraw procedures may be extended to EVPN RT-5 for faster convergence.
The embodiments discussed herein eliminate the need for overlay bridging functions to be supported on the leaf nodes. Additionally, the embodiments discussed herein eliminate the need for layer-2 MLAG connectivity and related complex procedures between the leaf nodes and hosts. Further, the embodiments discussed herein eliminate the need for data plane and ARP-based host learning on the leaf nodes. These benefits are enabled by the embodiments disclosed herein while providing IP unicast inter-subnet and intra-subnet VPN connectivity, virtual machine mobility, and flexible workload placement across stretched IP subnets.
The embodiments of the disclosure separate local layer-2 switching and IRB functions from the leaf node and localize them into a small virtual CE router on the bar metal server. This is achieved by running a small virtual router VM on the bare metal server that now acts as the first hop gateway for host virtual machines and provides local IRB switching across virtual machines local to the bare metal server. This virtual router acts as a traditional CE router that may be multi-homed to multiple leaf nodes via a layer-3 routed interface on the leaf node. leaf nodes in the fabric function as pure layer-3 VPN PE routers that are free of any layer-2 bridging or IRB function. To allow for flexible placement and mobility of layer-3 endpoints across the DC overlay, while providing optimal routing, traffic can be host routed on the leaf nodes versus being subnet routed. This is the case with EVPN-IRB.
In an embodiment, subnet extension across the overlay is enabled via routing intra-subnet traffic at the virtual CE router and then at the leaf node. In order to terminate layer-2 at the virtual CE router, the virtual CE router must be configured as an ARP proxy for host virtual machine subnets such that both intra-subnet and inter-subnet traffic can be routed at the virtual CE router and then at the leaf node.
In an embodiment, the IP subnet used for layer-3 links to the server must be locally scoped to avoid IP addressing overhead. In other words, server facing connected subnets should not be redistributed into northbound routing protocol.
In an embodiment, to achieve multiple tenancy, overlay layer-3 VLAN/IRB interface on the virtual CE router first hop gateway must be attached to a tenant VRF. Further, routed VXLAN/VNI encapsulation is used between the virtual CE router and the leaf node to segregate multiple tenant traffic. In addition, for L3DL overlay host routes sent to the leaf node to be installed in the correct VPN/VRF table on the leaf node, the L3DL overlay hosts must also include the layer-3 VNI ID. This VNI ID is then used at the leaf node to identify and install the route in the correct VRF.
In the protocol illustrated in
In the inter-subnet flow protocol illustrated in
In the protocol illustrated in
A protocol, shown in
Another protocol, illustrated in
In the protocol illustrated in
The protocols illustrated in
All outbound inter-subnet and intra-subnet traffic from host virtual machines is now routed by this virtual CE router across layer-3 ECMP links to upstream leaf nodes instead of being hashed across a layer-2 LAG. leaf nodes act as pure layer-3 routers that are completely free of any layer-2 bridging or IRB function. East-West flows across servers connected to the same leaf node are routed locally by the leaf node to destination virtual CE router next hop.
East-West flows (both inter-subnet and intra-subnet) across servers connected to different leaf nodes are routed from virtual CE routers to the local leaf nodes via default route, and then routed at the leaf node across the routed overlay to the destination. The next hop leaf node is based on host routes learnt via EVPN RT-5. The leaf node to leaf node routing may be based on a summarized or subnet route instead of host routes only if the subnet is not stretched across the overlay.
North-South flows to destinations external to the DC may be routed via a per-VRF default route on the leaf nodes toward the border leaf.
Another protocol provides a simplicity and scaling embodiment. In this embodiment, in response to a first-hop GW localized on the virtual CE, leaf nodes no longer install any host MAC routes, saving forwarding resources on the distributed anycast router. Further, with default routing on the leaf nodes, virtual CEs only maintain adjacencies to host VMs local to each bare metal server. All bridging and MLAG functions are completely removed from the leaf nodes, resulting in operational simplicity and greater reliability. Using deterministic protocol-based host route learning between the virtual CE and distributed anycast router, EVPN aliasing procedures are no longer required on the distributed anycast router and with deterministic protocol-based host route learning between the virtual CE and leaf node, ARP flooding is never required across the overlay. Further, using a deterministic protocol-based host route learning between the virtual CE and distributed anycast router, unknown unicast flooding is never required. Finally, with layer-3 ECMP links between the virtual CE and leaf nodes, EVPN DF election, and split horizon filtering procedures are no longer required.
Referring now to
Computing device 1100 includes one or more processor(s) 1102, one or more memory device(s) 1104, one or more interface(s) 1106, one or more mass storage device(s) 1108, one or more Input/output (I/O) device(s) 1102, and a display device 1130 all of which are coupled to a bus 1112. Processor(s) 1102 include one or more processors or controllers that execute instructions stored in memory device(s) 1104 and/or mass storage device(s) 1108. Processor(s) 1102 may also include various types of computer-readable media, such as cache memory.
Memory device(s) 1104 include various computer-readable media, such as volatile memory (e.g., random access memory (RAM) 1114) and/or nonvolatile memory (e.g., read-only memory (ROM) 1116). Memory device(s) 1104 may also include rewritable ROM, such as Flash memory.
Mass storage device(s) 1108 include various computer readable media, such as magnetic tapes, magnetic disks, optical disks, solid-state memory (e.g., Flash memory), and so forth. As shown in
Input/output (I/O) device(s) 1102 include various devices that allow data and/or other information to be input to or retrieved from computing device 1100. Example I/O device(s) 1102 include cursor control devices, keyboards, keypads, microphones, monitors or other display devices, speakers, printers, network interface cards, modems, and the like.
Display device 1130 includes any type of device capable of displaying information to one or more users of computing device 1100. Examples of display device 1130 include a monitor, display terminal, video projection device, and the like.
Interface(s) 1106 include various interfaces that allow computing device 1100 to interact with other systems, devices, or computing environments. Example interface(s) 1106 may include any number of different network interfaces 1120, such as interfaces to local area networks (LANs), wide area networks (WANs), wireless networks, and the Internet. Other interface(s) include user interface 1118 and peripheral device interface 1122. The interface(s) 1106 may also include one or more user interface elements 1118. The interface(s) 1106 may also include one or more peripheral interfaces such as interfaces for printers, pointing devices (mice, track pad, or any suitable user interface now known to those of ordinary skill in the field, or later discovered), keyboards, and the like.
Bus 1112 allows processor(s) 1102, memory device(s) 1104, interface(s) 1106, mass storage device(s) 1108, and I/O device(s) 1102 to communicate with one another, as well as other devices or components coupled to bus 1112. Bus 1112 represents one or more of several types of bus structures, such as a system bus, PCI bus, IEEE bus, USB bus, and so forth.
For purposes of illustration, programs and other executable program components are shown herein as discrete blocks, although it is understood that such programs and components may reside at various times in different storage components of computing device 1100 and are executed by processor(s) 1102. Alternatively, the systems and procedures described herein can be implemented in hardware, or a combination of hardware, software, and/or firmware. For example, one or more application specific integrated circuits (ASICs) can be programmed to carry out one or more of the systems and procedures described herein.
The foregoing description has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. Further, it should be noted that any or all of the aforementioned alternate implementations may be used in any combination desired to form additional hybrid implementations of the disclosure.
Further, although specific implementations of the disclosure have been described and illustrated, the disclosure is not to be limited to the specific forms or arrangements of parts so described and illustrated. The scope of the disclosure is to be defined by the claims appended hereto, if any, any future claims submitted here and in different applications, and their equivalents.
The following examples pertain to further embodiments.
Example 1 is a system. The system includes a virtual customer edge router one a server and a host routed overlay comprising a plurality of host virtual machines. The system includes a routed uplink from the virtual customer edge router to one or more of a plurality of leaf nodes. The system is such that the virtual customer edge router is configured to provide localized integrated routing and bridging (IRB) service for the plurality of host virtual machines of the host routed overlay.
Example 2 is a system as in Example 1, wherein the host routed overlay is an Ethernet virtual private network (EVPN) host.
Example 3 is a system as in any of Examples 1-2, wherein the host routed overlay comprises EVPN layer-3 mobility.
Example 4 is a system as in any of Examples 1-3, wherein the virtual customer edge router is a first hop anycast gateway for one or more of the plurality of leaf nodes.
Example 5 is a system as in any of Examples 1-4, wherein the virtual customer edge router routes traffic to external leaf nodes via equal-cost multipath (ECMP) routing links to leaf nodes.
Example 6 is a system as in any of Examples 1-5, wherein the virtual customer edge router is configured as a proxy address resolution protocol (ARP) to host route intra-subnet flows in the host routed overlay.
Example 7 is a system as in any of Examples 1-6, wherein the routed uplink from the virtual customer edge router to one or more of the plurality of leaf nodes is a layer-3 interface.
Example 8 is a system as in any of Examples 1-7, wherein the virtual customer edge router stores addresses locally and does not redistribute the addresses in Border Gateway Protocol (BGP) routing.
Example 9 is a system as in any of Examples 1-8, wherein the virtual customer edge router comprises memory storing one or more of: local Internet Protocol (IP) entries for the host routed overlay, media access control (MAC) entries for the host routed overlay, or a default ECMP route to the host routed overlay.
Example 10 is a system as in any of Examples 1-9, wherein the host routed overlay is configured to perform host routed for stretched subnets.
Example 11 is a system as in any of Examples 1-10, wherein the virtual customer edge router is located on a single tenant physical server.
Example 12 is a system as in any of Examples 1-11, wherein the virtual customer edge router is a virtual router virtual machine running on a single tenant physical server and is configured to act as a first hop gateway for one or more of the plurality of leaf nodes.
Example 13 is a system as in any of Examples 1-12, wherein the plurality of host virtual machines are located on the single tenant physical server.
Example 14 is a system as in any of Examples 1-13, wherein the virtual customer edge router is multi-homed to multiple distributed anycast routers via a layer-3 routed interface on a distributed anycast router.
Example 15 is a system as in any of Examples 1-14, wherein the virtual customer edge router is configured to learn local host virtual machine routes without dependency on glean processing and ARP-based learning.
Example 16 is a system as in any of Examples 1-15, wherein the virtual customer edge router is further configured to advertise local host virtual machine routes to a directly connected distributed anycast router.
Example 17 is a system as in any of Examples 1-16, wherein the virtual customer edge router is configured to learn IP bindings and MAC bindings for one or more of the plurality of host virtual machines via link state over ethernet (LSoE).
Example 18 is a system as in any of Examples 1-17, wherein the virtual customer edge router comprises memory and is configured to store in the memory adjacencies for one or more of the host virtual machines that are local to a same bare metal server on which the virtual customer edge router is located.
Example 19 is a system as in any of Examples 1-18, further comprising a distributed anycast router, and wherein the virtual customer edge router is configured to enact deterministic protocol-based host route learning between the virtual customer edge router and the distributed anycast router.
Example 20 is a system as in any of Examples 1-19, wherein the routed uplink from the virtual customer edge router to the one or more of the plurality of host machines is a layer-3 equal-cost multipath (ECMP) routing link.
Example 21 is a system as in any of Examples 1-20, wherein one or more of the plurality of leaf nodes comprises a virtual private network-virtual routing and forwarding (VPI-VRF) table.
Example 22 is a system as in any of Examples 1-21, wherein the one or more of the plurality of leaf nodes further comprises a layer-3 virtual network identifier (VNI) used at the one or more of the plurality of leaf nodes to install a route in a correct virtual routing and forwarding table.
It is to be understood that any features of the above-described arrangements, examples, and embodiments may be combined in a single embodiment comprising a combination of features taken from any of the disclosed arrangements, examples, and embodiments.
It will be appreciated that various features disclosed herein provide significant advantages and advancements in the art. The following claims are exemplary of some of those features.
In the foregoing Detailed Description of the Disclosure, various features of the disclosure are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed disclosure requires more features than are expressly recited in each claim. Rather, inventive aspects lie in less than all features of a single foregoing disclosed embodiment.
It is to be understood that the above-described arrangements are only illustrative of the application of the principles of the disclosure. Numerous modifications and alternative arrangements may be devised by those skilled in the art without departing from the spirit and scope of the disclosure and the appended claims are intended to cover such modifications and arrangements.
Thus, while the disclosure has been shown in the drawings and described above with particularity and detail, it will be apparent to those of ordinary skill in the art that numerous modifications, including, but not limited to, variations in size, materials, shape, form, function and manner of operation, assembly and use may be made without departing from the principles and concepts set forth herein.
Further, where appropriate, functions described herein can be performed in one or more of: hardware, software, firmware, digital components, or analog components. For example, one or more application specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs) can be programmed to carry out one or more of the systems and procedures described herein. Certain terms are used throughout the following description and claims to refer to particular system components. As one skilled in the art will appreciate, components may be referred to by different names. This document does not intend to distinguish between components that differ in name, but not function.
The foregoing description has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. Further, it should be noted that any or all the aforementioned alternate implementations may be used in any combination desired to form additional hybrid implementations of the disclosure.
Further, although specific implementations of the disclosure have been described and illustrated, the disclosure is not to be limited to the specific forms or arrangements of parts so described and illustrated. The scope of the disclosure is to be defined by the claims appended hereto, any future claims submitted here and in different applications, and their equivalents.
This application is a continuation of U.S. patent application Ser. No. 17/527,890 filed Nov. 16, 2021 titled “Host Routed Overlay With Deterministic Host Learning And Localized Integrated Routing And Bridging,” now issued as Patent (U.S. Pat. No. 11,675,637 B2), which is a continuation of U.S. patent application Ser. No. 16/549,731 filed Aug. 23, 2019 titled “Host Routed Overlay With Deterministic Host Learning And Localized Integrated Routing And Bridging,” now issued as Patent (U.S. Pat. No. 11,206,208 B2), which claims priority to U.S. Provisional Patent Application Ser. No. 62/722,003 filed Aug. 23, 2018 titled “Database Systems Methods And Devices,” all of which are incorporated herein by reference in their entirety, including but not limited to those portions that specifically appear hereinafter, the incorporation by reference being made with the following exception: In the event that any portion of the above-referenced applications is inconsistent with this application, this application supersedes the above-referenced applications.
Number | Name | Date | Kind |
---|---|---|---|
5873076 | Barr | Feb 1999 | A |
6879594 | Lee | Apr 2005 | B1 |
6970561 | Obana | Nov 2005 | B1 |
7274869 | Pan | Sep 2007 | B1 |
7593320 | Cohen et al. | Sep 2009 | B1 |
7945813 | Watson | May 2011 | B1 |
7970918 | Thompson et al. | Jun 2011 | B2 |
8060533 | Wheeler | Nov 2011 | B1 |
8756656 | Hartmann | Jun 2014 | B1 |
8849955 | Prahlad | Sep 2014 | B2 |
9288101 | Dalal | Mar 2016 | B1 |
9330154 | Di Vincenzo | May 2016 | B2 |
9331940 | Balus | May 2016 | B2 |
9544185 | Yadav | Jan 2017 | B1 |
9652483 | Cao | May 2017 | B1 |
10200274 | Anantharamu | Feb 2019 | B1 |
10530873 | Arya | Jan 2020 | B1 |
10931530 | Rzehak | Feb 2021 | B1 |
11074300 | Falco | Jul 2021 | B1 |
20030012133 | Jappinen | Jan 2003 | A1 |
20030012193 | Novaes | Jan 2003 | A1 |
20040003064 | Astley | Jan 2004 | A1 |
20040264460 | Yoshimoto | Dec 2004 | A1 |
20050021622 | Cullen | Jan 2005 | A1 |
20060136256 | Roots | Jun 2006 | A1 |
20060233322 | Allman | Oct 2006 | A1 |
20070074150 | Jolfaei et al. | Mar 2007 | A1 |
20070086429 | Lawrence | Apr 2007 | A1 |
20070104192 | Yoon | May 2007 | A1 |
20070291773 | Khan | Dec 2007 | A1 |
20090043911 | Flammer | Feb 2009 | A1 |
20090296579 | Dharwadkar | Dec 2009 | A1 |
20100046531 | Louati | Feb 2010 | A1 |
20100061366 | DelRegno | Mar 2010 | A1 |
20100189115 | Kitada | Jul 2010 | A1 |
20100189117 | Gowda | Jul 2010 | A1 |
20100211781 | Auradkar et al. | Aug 2010 | A1 |
20100250867 | Bettger | Sep 2010 | A1 |
20100293235 | Cadoret | Nov 2010 | A1 |
20110004913 | Nagarajan | Jan 2011 | A1 |
20120201124 | Marques | Aug 2012 | A1 |
20120281700 | Koganti | Nov 2012 | A1 |
20120300782 | Farinacci | Nov 2012 | A1 |
20130028073 | Tatipamula | Jan 2013 | A1 |
20130188521 | Jain | Jul 2013 | A1 |
20130286846 | Atlas et al. | Oct 2013 | A1 |
20130329584 | Ghose | Dec 2013 | A1 |
20130336164 | Yang et al. | Dec 2013 | A1 |
20140044126 | Sabhanatarajan et al. | Feb 2014 | A1 |
20140092901 | Kapadia et al. | Apr 2014 | A1 |
20140112122 | Kapadia | Apr 2014 | A1 |
20140207991 | Kaushik | Jul 2014 | A1 |
20140233399 | Mann | Aug 2014 | A1 |
20140258485 | Yang | Sep 2014 | A1 |
20140317616 | Chu | Oct 2014 | A1 |
20140366037 | Berretta | Dec 2014 | A1 |
20140372748 | Dixon | Dec 2014 | A1 |
20150010002 | Duda | Jan 2015 | A1 |
20150124590 | Chu | May 2015 | A1 |
20150172172 | DeCusatis et al. | Jun 2015 | A1 |
20150188753 | Anumala et al. | Jul 2015 | A1 |
20150188808 | Ghanwani | Jul 2015 | A1 |
20150195136 | Mermoud | Jul 2015 | A1 |
20150199415 | Bourbonnais | Jul 2015 | A1 |
20150263899 | Tubaltsev | Sep 2015 | A1 |
20150304206 | Filsfils et al. | Oct 2015 | A1 |
20150312134 | Kapadia | Oct 2015 | A1 |
20150355946 | Kang | Dec 2015 | A1 |
20160014025 | Wang | Jan 2016 | A1 |
20160028613 | Haramaty | Jan 2016 | A1 |
20160065498 | Harper | Mar 2016 | A1 |
20160112821 | Raleigh | Apr 2016 | A1 |
20160142313 | Devireddy et al. | May 2016 | A1 |
20160196320 | Borowiec | Jul 2016 | A1 |
20160277210 | Lin et al. | Sep 2016 | A1 |
20160294608 | Biswal | Oct 2016 | A1 |
20160337231 | Dixon | Nov 2016 | A1 |
20160352619 | Gattani | Dec 2016 | A1 |
20160357778 | MacKenzie | Dec 2016 | A1 |
20170032011 | Song | Feb 2017 | A1 |
20170041239 | Goldenberg | Feb 2017 | A1 |
20170109369 | Feng | Apr 2017 | A1 |
20170126486 | Prieto | May 2017 | A1 |
20170155542 | Fang | Jun 2017 | A1 |
20170171057 | Dong et al. | Jun 2017 | A1 |
20170310548 | Jailani | Oct 2017 | A1 |
20170331669 | Ganesh | Nov 2017 | A1 |
20180034665 | Nguyen | Feb 2018 | A1 |
20180048591 | Sellappa et al. | Feb 2018 | A1 |
20180062914 | Boutros | Mar 2018 | A1 |
20180062993 | Wu | Mar 2018 | A1 |
20180121433 | Nevrekar | May 2018 | A1 |
20180167475 | Agarwal | Jun 2018 | A1 |
20180167476 | Hoffner | Jun 2018 | A1 |
20180183706 | Przygienda et al. | Jun 2018 | A1 |
20180219953 | Arra et al. | Aug 2018 | A1 |
20180220283 | Condeixa | Aug 2018 | A1 |
20180351857 | Vairavakkalai | Dec 2018 | A1 |
20190073419 | Dong | Mar 2019 | A1 |
20190089575 | Pundir | Mar 2019 | A1 |
20190104438 | Mittal | Apr 2019 | A1 |
20190124013 | Murugesan | Apr 2019 | A1 |
20190141112 | Kalathur | May 2019 | A1 |
20190149361 | Sarwar | May 2019 | A1 |
20190149896 | Gramm | May 2019 | A1 |
20190155741 | Linke | May 2019 | A1 |
20190207844 | Kodavanty | Jul 2019 | A1 |
20190260670 | Kulkarni | Aug 2019 | A1 |
20190327166 | Thubert | Oct 2019 | A1 |
20190342389 | Bono | Nov 2019 | A1 |
20190349426 | Smith | Nov 2019 | A1 |
20190349733 | Nolan | Nov 2019 | A1 |
20190363975 | Djernaes | Nov 2019 | A1 |
20200036787 | Gupta | Jan 2020 | A1 |
20200044963 | Kwok | Feb 2020 | A1 |
20200084103 | Miller | Mar 2020 | A1 |
20210075630 | Immidi | Mar 2021 | A1 |
Number | Date | Country |
---|---|---|
104486124 | Apr 2015 | CN |
105991432 | Oct 2016 | CN |
106878065 | Jun 2017 | CN |
107547402 | Jan 2018 | CN |
3070877 | Sep 2016 | EP |
2003204332 | Jul 2003 | JP |
2015070236 | May 2015 | WO |
Entry |
---|
Samman et al. “Multicast parallel pipeline router architecture for network-on-chip.” In: Proceedings of the conference on Design, automation and test in Europe. Mar. 2008 (Mar. 2008) Retrieved on Oct. 18, 2019 (Oct. 18, 2019) from <https://www.researchgate.net/profile/Manfred_Glesner/publication/221340626_Multicast_Parall el_Pipeline_Router_Architecture_for_Network-on-Chip/links/02bfe50de0dc34c390000000/Multic ast-Parallel-Pipeline-Router-Architecture-for-Network-on-Chip.pdf> entire document. |
Saurav Haloi: “Introduction to Apache ZooKeeper”, Internet Citation, Feb. 5, 2015 (Feb. 5, 2015), XP002806551, Retrieved from the Internet: URL:https://hub.packtpub.com/introductionapache-zookeeper/ [retrieved on May 18, 2022] * chapter “The ZooKeeper Watches” *. |
Husseman. “A Beginner's Guide to Understanding the Leaf-Spine Network Topology.” In: West Monroe Partners. Mar. 23, 2015 (Mar. 23, 2015) Retrieved on Oct. 13, 2019 (Oct. 13, 2019) from <https://blog.westmonroepartners.com/a-beginners-guide-to-understanding-the-leaf-spine-netw ork-topology/> entire document. |
Sajassi et al., BGP MP LS-Based Ethernet VPN, Feb. 2015 (Year: 2015). |
Juniper, Understanding EVPN Pure Route Type-5 on QFX Series Switches, Jul. 2017 (Year: 2017). |
Internet Engineering Task Force (IETF) Request for Comments: 7432 Category: Standards Track ISSN: 2070-1721, BGP MPLS-Based Ethernet VPN, A. Sajassi, Ed. |
Wu et al. “A new multi-channel MAC protocol with on-demand channel assignment for multi-hop mobile ad hoc networks.” In: Proceedings International Symposium on Parallel Architectures, Algorithms and Networks. Dec. 9, 2000 {Dec. 9, 2000) Retrieved on Oct. 13, 2019 (Oct. 13, 2019) from <http:/fciteseerx.ist.psu.edu/viewdoc/download? doi= 1O.1.1.457 .5412&rep=rep 1 &type=pdf> entire document. |
Number | Date | Country | |
---|---|---|---|
20230236908 A1 | Jul 2023 | US |
Number | Date | Country | |
---|---|---|---|
62722003 | Aug 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17527890 | Nov 2021 | US |
Child | 18296149 | US | |
Parent | 16549731 | Aug 2019 | US |
Child | 17527890 | US |